0

0

SQL CockroachDB survival goals ZONE vs REGION 的多地域容灾选择

冰川箭仙

冰川箭仙

发布时间:2026-02-24 20:00:12

|

355人浏览过

|

来源于php中文网

原创

region定义地理大区并决定容灾级别,zone是其内故障隔离单元;仅支持region survivability,需配locality与分区策略防跨域延迟。

sql cockroachdb survival goals zone vs region 的多地域容灾选择

REGION 和 ZONE 在 CockroachDB 里到底管什么

CockroachDB 的 REGIONZONE 不是同级概念,也不是随便打标签的逻辑分组——它们对应真实物理部署约束:REGION 定义地理大区(如 us-easteu-west),必须显式声明为 PRIMARYSECONDARYZONE 是更细粒度的故障隔离单元(比如一个 AZ 内的多个机架或 Kubernetes node),靠 constraints 规则控制副本分布。

常见错误现象:ALTER DATABASE d1 SET REGION = 'us-east' 执行成功,但后续 INSERT 还是跨洲写入慢——因为没配 survival goal,也没把表绑定到 REGION 级别策略。

  • REGION 必须在集群启动时或通过 ALTER CLUSTER SET PRIMARY REGION 初始化,之后才能用 SET REGION 绑定数据库
  • REGION 模式下,ZONE 约束只影响副本在该大区内的分散度;多 REGION 模式下,ZONE 不能跨 REGION 生效
  • survival goal 只有 REGION 级别可设(REGION survivability),ZONE 级别没有“容灾目标”这回事——它只是副本放置的执行层

怎么选 survival goal:REGION survivability vs ZONE survivability

CockroachDB 实际只支持一种容灾目标:REGION survivability。所谓 ZONE survivability 是旧文档遗留说法,0.0 版本就已移除;当前所有 SURVIVE TWO REGIONSSURVIVE THREE REGIONS 都作用于 REGION 维度。

使用场景很明确:你要扛住整个云厂商区域宕机(比如 AWS us-east-1 整个不可用),就必须用 REGION survivability;如果只防单个可用区断电,那靠 ZONE 约束 + 默认三副本就够了,不用动 survival goal

  • SURVIVE TWO REGIONS 后,系统会强制每个 Raft group 至少两个副本落在不同 REGION,且自动拒绝在只剩一个 REGION 在线时接受写入
  • 不设 survival goal 时,即使你部署了三个 REGION,副本也可能全挤在主 REGION——因为默认策略是“就近写入优先”
  • SHOW CLUSTER SETTING cluster.settings.survival_goal 能查当前值,但改它需要 ADMIN 权限,且变更后需等待所有表完成 rebalance(可能耗时数分钟到小时)

多地域写入延迟高?先检查 partitioning 和 locality

开了多 REGION 却发现 INSERT 延迟翻倍,大概率是没做 LOCALITY 分区,或者误用了 GLOBAL 表。

通义万相
通义万相

通义万相,一个不断进化的AI艺术创作大模型

下载

典型错误:CREATE TABLE orders (...) LOCALITY REGIONAL BY TABLE IN PRIMARY REGION 写对了,但关联的 customers 表漏了分区,导致 JOIN 时跨 REGION 拉数据。

  • 只有 REGIONAL BY TABLEREGIONAL BY ROW 表才受 REGION 约束;GLOBAL 表副本永远全量同步到所有 REGION,写放大严重
  • REGIONAL BY ROW 需配合 crdb_region 列和 INSERT ... SELECT 显式指定归属,否则新行默认进 PRIMARY REGION
  • EXPLAIN (VERBOSE) INSERT ... 看执行计划里有没有 remote 步骤,有就说明跨 REGION 通信已发生

region 级 failover 测试时最常踩的坑

模拟 REGION 故障不是简单 docker stop 几个节点就行——CockroachDB 的故障检测有超时机制,且依赖 heartbeatsraft leader lease,硬杀节点容易触发脑裂或长时间不可写。

正确做法是用 cockroach quit --decommission 模拟优雅下线,或直接关掉整个 REGION 的网络出口(如 iptables DROP 所有到该 REGION 的 26257 端口流量)。

  • 测试前确认 cluster.settings.kv.raft_log.synchronizetrue(默认),否则日志落盘不同步,failover 后可能丢事务
  • SELECT * FROM [SHOW RANGES WITH DETAILS] 查关键表的副本分布,确保至少两个 REGION 都有 VOTER(不是 NON_VOTER
  • failover 后立刻跑 SHOW STATUSES CLUSTER,重点看 ranges_unavailableranges_underreplicated 是否归零——不归零说明 survival goal 未满足,集群仍拒绝写入

真正麻烦的是跨 REGION 事务的语义边界:CockroachDB 不保证跨 REGION 的强一致性读,AS OF SYSTEM TIME 必须显式指定,否则可能读到旧版本。这点很容易被忽略,尤其在迁移老应用时。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1027

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

337

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

379

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1822

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

377

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1394

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

437

2024.04.29

Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

1

2026.02.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 5.5万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号