使用heartbeat时发现的问题
自己用java写了一个服务,并用heartbeat实现双机热备,将heartbeat安装、配置好以后。测试heartbeat能否满足自己的需求。
测试步骤:
1.将主从节点的heartbeat启动,主结点会自动启动自定义程序
2.将主结点的网线拔掉,按道理说主结点的heartbeat会自动杀死自定义程序,并且启动从结点的自定义程序,但是实验时发现主结点的heartbeat并不能杀死自定义程序,在log日志中输出了如下内容(部分):WARN: Shutdown delayed until current resource activity finishes.假如此时自己手动的将主结点的自定义程序关掉,从结点的heartbeat就会启动自定义程序。
注:自己并没用使用peacemaker
分析这个问题的原因:当主结点的heartbeat不能ping网关时,会自动释放自己占有的资源,但是因为自定义服务是个死循环,就不能等它自己释放资源。所以heartbeat就会一直阻塞,直到手工关闭自定义程序,然后heartbeat才能释放资源。
大家遇到过这个问题没有???如何才能解决这个问题?
heartbeat释放资源时如何能自动杀死自定义程序?heartbeat能否实现这个功能?
ps:大家使用heartbeat时,有没有发现heartbeat的什么缺点?有的吐槽一下吧。
heartbeat 高可用 Shutdown?delayed 双机热备
[解决办法]
分析这个问题的原因:当主结点的heartbeat不能ping网关时,会自动释放自己占有的资源,但是因为自定义服务是个死循环,就不能等它自己释放资源。所以heartbeat就会一直阻塞,直到手工关闭自定义程序,然后heartbeat才能释放资源。
大家遇到过这个问题没有???如何才能解决这个问题?