启动两个postgres节点(节点0、主节点和节点1)并设置pgpool之后。默认情况下,Pgpool故障切换命令将node0作为主命令。我的问题是,如果发生故障切换并将节点1设为主节点,一段时间后,如果节点1(主节点)上发生故障切换,则故障切换命令会将其作为备用节点并跳过故障切换,这会导致群集没有主节点并且无法接受写入事务。任何人可以帮助我所需的更改,使故障转移命令正常工作。
带复制插槽的pgpool v4.1和postgres v9.6。
发布于 2021-02-18 03:12:02
这就是它的正常工作方式:
通过故障切换或切换分离的PostgreSQL节点永远不会在默认设置中自动返回到以前的状态(已连接状态
摘自文档:
https://www.pgpool.net/docs/41/en/html/runtime-config-failover.html
故障转移到节点1后,您只有一个节点,不再有备用节点,节点0可能完全消失。您需要重新创建它,再次设置复制并将其重新添加到池中。如果是短暂的网络中断,这可能不算多,您也许可以利用auto_failback的功能。如果只在主服务器上运行的风险很大,并且您无法容忍它,那么您需要更多备用服务器。
我会使用链接和测试,测试来阅读上面的pgpool文档。
https://stackoverflow.com/questions/66247708
复制相似问题