首页 > 数据库 > SQL > 正文

postgresqlkeepalived如何实现漂移ip_postgresqlvip方案

尊渡假赌尊渡假赌尊渡假赌
发布: 2025-11-20 22:21:05
原创
714人浏览过
PostgreSQL配合Keepalived通过VIP实现高可用,主库故障时备库自动接管。基于流复制同步数据,Keepalived用VRRP管理虚拟IP,结合健康检查脚本检测数据库状态,主节点异常时优先级降低,备节点升主并绑定VIP,应用通过VIP无缝连接新主库。需配置SSH免密、规划VIP、设置监控脚本,并注意脑裂防范与网络通信。方案简单高效,适用于中小规模系统。

postgresqlkeepalived如何实现漂移ip_postgresqlvip方案

PostgreSQL 配合 Keepalived 实现漂移 IP(VIP)是一种常见高可用方案,主要用于主备架构下避免单点故障。当主库宕机时,虚拟 IP 自动漂移到备库,应用无需修改连接地址即可继续访问数据库。

基本原理

该方案依赖于以下组件协同工作:

  • PostgreSQL 流复制:主库将 WAL 日志实时传输给备库,实现数据同步。
  • Keepalived:通过 VRRP 协议管理虚拟 IP,在主节点故障时自动将其转移到备节点。
  • 脚本监控:Keepalived 调用自定义脚本检测 PostgreSQL 状态,决定是否触发 VIP 漂移。

正常情况下,VIP 绑定在主库所在主机上。一旦主库或数据库进程异常,Keepalived 检测失败,优先级降低,备库提升为 MASTER 并接管 VIP。

部署前提条件

实施前需确保以下配置已完成:

  • 两台及以上服务器部署 PostgreSQL,并配置好流复制(主从模式)。
  • 网络互通,能支持组播通信(VRRP 使用)。
  • 设置无密码 SSH 登录(便于执行切换脚本)。
  • 规划一个未被使用的虚拟 IP(如 192.168.1.100),作为对外服务地址。

Keepalived 配置示例

以两节点为例,主节点(priority 100),备节点(priority 90)。

主节点 /etc/keepalived/keepalived.conf:

幻舟AI
幻舟AI

专为短片创作者打造的AI创作平台

幻舟AI 279
查看详情 幻舟AI
vrrp_script chk_pg { script "/usr/local/bin/check_postgres.sh" interval 2 weight 2 }

vrrp_instance VI_1 { state MASTER interface eth0 virtual_router_id 51 priority 100 advert_int 1 authentication { auth_type PASS auth_pass yourpass } virtual_ipaddress { 192.168.1.100/24 } track_script { chk_pg } }

备节点配置:

vrrp_script chk_pg { script "/usr/local/bin/check_postgres.sh" interval 2 weight 2 }

vrrp_instance VI_1 { state BACKUP interface eth0 virtual_router_id 51 priority 90 advert_int 1 authentication { auth_type PASS auth_pass yourpass } virtual_ipaddress { 192.168.1.100/24 } track_script { chk_pg } }

健康检查脚本 check_postgres.sh

该脚本用于判断本地 PostgreSQL 是否正常运行,是否为主库角色。

#!/bin/bash # 检查 PostgreSQL 是否运行且为 primary

PGDATA=/data/postgresql/data LOGFILE=/var/log/keepalived/pg_check.log

if pg_ctl -D "$PGDATA" status > /dev/null 2>&1; then ROLE=$(psql -U postgres -Atc "SELECT pg_is_in_recovery();" 2>/dev/null) if [ "$ROLE" = "f" ]; then exit 0 # 是主库,健康 else exit 1 # 是备库,不参与主角色竞争 fi else exit 1 # PG 未运行 fi

赋予执行权限:
chmod +x /usr/local/bin/check_postgres.sh

注意:实际环境中建议加入更严格的判断,例如端口监听、复制延迟等。

故障切换流程

  • 主库 PostgreSQL 崩溃或服务器宕机。
  • Keepalived 执行 check_postgres.sh 脚本返回失败。
  • 主节点权重下降,VRRP 优先级低于备库。
  • 备库升级为 MASTER,绑定虚拟 IP。
  • 客户端通过 VIP 连接新主库(需配合触发器或手动 promote)。

建议在备库的 keepalived 脚本中集成自动 promote 操作,或使用 repmgr 等工具辅助。

注意事项与优化建议

  • 脑裂风险:网络分区可能导致双主,建议结合仲裁机制或使用 Corosync+Pacemaker 更复杂场景。
  • IP 漂移生效时间:一般在 3~5 秒内完成,受 interval 和 advert_int 影响。
  • DNS 缓存问题:应用应直连 VIP,避免 DNS 缓存导致连接旧地址。
  • 防火墙设置:确保允许 VRRP 协议(协议号 112)通信。
  • 日志监控:定期查看 keepalived 和 PostgreSQL 日志,及时发现异常。

基本上就这些。这套方案简单有效,适合中小规模系统快速实现 PostgreSQL 高可用。关键是脚本要写稳,检测准确,避免误切。

以上就是postgresqlkeepalived如何实现漂移ip_postgresqlvip方案的详细内容,更多请关注php中文网其它相关文章!

keep
keep

Keep是一款健身安排,无论是想减肥塑形或增肌,还是寻找健身跑步瑜伽计步等训练计划,你可以随时随地选择课程进行训练!权威教练视频教学,健身干货自由分享!有需要的小伙伴快来保存下载体验吧!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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