Yoke:PostgreSQL 高可用集群最佳实践
2025-05-25 00:42:11作者:尤峻淳Whitney
1. 项目介绍
Yoke 是一个 PostgreSQL 高可用性和自动故障转移解决方案。它提供了一个简单易管理的 PostgreSQL 集群,包含主节点、辅助节点和监控节点,确保数据库服务在出现故障时能够自动切换,保持服务的持续可用性。
2. 项目快速启动
环境准备
- 3 个服务器节点,分别作为主节点(primary)、辅助节点(secondary)和监控节点(monitor)。
- 主节点和辅助节点之间需要能够无密码 SSH 通信。
- 主节点和辅助节点需要安装 rsync(或其他同步命令)。
- 主节点和辅助节点上需要以 postgres 用户身份安装 PostgreSQL,并且 PostgreSQL 应在系统路径中。
- PostgreSQL 应作为子进程运行,不应独立启动。
配置文件
每个节点都需要一个配置文件(config.ini),以下为配置文件的基本选项:
[config]
advertise_ip = # 本节点向其他节点广播的 IP
advertise_port = 4400 # 本节点向其他节点广播的端口
data_dir = /data # PostgreSQL 数据目录
decision_timeout = 30 # 节点决定 PostgreSQL 实例状态的延时
log_level = warn # 日志级别
primary = # 主节点 IP:port
secondary = # 辅助节点 IP:port
monitor = # 监控节点 IP:port
role = # 节点角色(primary/secondary/monitor)
pg_port = 5432 # PostgreSQL 端口
status_dir = ./status # 节点状态信息存储目录
sync_command = rsync -ae "ssh -o StrictHostKeyChecking=no" --delete {{local_dir}} {{slave_ip}}:{{slave_dir}} # 数据同步命令
[vip]
ip = # 虚拟 IP
add_command = # 添加虚拟 IP 的命令
remove_command = # 移除虚拟 IP 的命令
[role_change]
command = # 节点角色变更时调用的命令
启动项目
配置完成后,通过以下命令启动 Yoke:
./yoke ./primary.ini
其中 primary.ini 是主节点的配置文件,文件名和路径可以自定义。
3. 应用案例和最佳实践
数据同步
确保 sync_command 配置正确,以便在主节点上同步数据到辅助节点。
故障转移
在监控节点上配置正确的 role_change 命令,以便在主节点故障时自动将辅助节点提升为新的主节点。
日志管理
根据需要调整 log_level,以便在开发和生产环境中获得适当的日志信息。
监控和运维
使用 Yoke 提供的 CLI 工具 yokeadm 进行集群状态查询和节点管理。
./yokeadm list # 查看集群状态
./yokeadm demote # 将节点降级
4. 典型生态项目
- Prometheus: 用于监控和告警的开源系统,可以与 Yoke 结合使用,监控 PostgreSQL 集群状态。
- Grafana: 用于可视化监控数据的开源平台,可以与 Prometheus 配合使用,展示 PostgreSQL 集群性能。
- Kubernetes: 用于自动部署、扩展和管理容器化应用程序的开源系统,可以将 Yoke 集群部署到 Kubernetes 中,实现自动化管理。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0153- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
733
4.75 K
deepin linux kernel
C
31
16
Ascend Extension for PyTorch
Python
651
797
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.25 K
153
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.1 K
611
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.01 K
1.01 K
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
147
237
昇腾LLM分布式训练框架
Python
168
200
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
434
395
暂无简介
Dart
986
253