gpt4 book ai didi

Python + ZMQ : Operation cannot be accomplished in current state

转载 作者:太空狗 更新时间:2023-10-29 18:08:06 31 4
gpt4 key购买 nike

我试图让一个 python 程序通过 zeromq 使用请求-回复模式与另一个 python 程序通信。客户端程序应向服务器程序发送请求,服务器程序进行回复。

我有两台服务器,当一台服务器出现故障时,另一台服务器接管。当第一台服务器工作时,通信工作完美,但是,当第一台服务器发生故障并且当我向第二台服务器发出请求时,我看到错误:

zmp.error.ZMQError: Operation cannot be accomplished in current state

服务器1的代码:

# Run the server
while True:

# Define the socket using the "Context"
sock = context.socket(zmq.REP)
sock.bind("tcp://127.0.0.1:5677")
data = sock.recv().decode("utf-8")
res = "Recvd"
sock.send(res.encode('utf-8'))

服务器2的代码:

# Run the server
while True:

# Define the socket using the "Context"
sock = context.socket(zmq.REP)
sock.bind("tcp://127.0.0.1:5877")
data = sock.recv().decode("utf-8")
res = "Recvd"
sock.send(res.encode('utf-8'))

客户端代码:

# ZeroMQ Context For distributed Message amogst processes
context = zmq.Context()
sock_1 = context.socket(zmq.REQ)
sock_2 = context.socket(zmq.REQ)
sock_1.connect("tcp://127.0.0.1:5677")
sock_2.connect("tcp://127.0.0.1:5877")

try:
sock_1.send(data.encode('utf-8'), zmq.NOBLOCK)
socks_1.setsockopt(zmq.RCVTIMEO, 1000)
socks_1.setsockopt(zmq.LINGER, 0)
data = socks_1.recv().decode('utf-8') #receive data from the main node

except:
try:
#when server one fails
sock_2.send(data.encode('utf-8'), zmq.NOBLOCK)
socks_2.setsockopt(zmq.RCVTIMEO, 1000)
socks_2.setsockopt(zmq.LINGER, 0)
data = socks_2.recv().decode('utf-8')
except Exception as e:
print(str(e))

这种方法有什么问题?我该如何解决这个问题?

最佳答案

问:我该如何解决?
答:避免REQ/REP死锁的已知风险!

虽然 ZeroMQ 是一个强大的框架,但了解其内部组成对于健壮可靠分布式系统设计和原型(prototype)设计是必要的。

仔细观察后,使用通用的 REQ/REP 正式沟通模式可能会使(并且确实会导致)对方陷入相互僵局:一方期望另一方做某事这一步永远也完成不了,也没有办法摆脱僵局。

更多illustrated details and FSA-schematic diagram, see this post

接下来,故障转移系统必须能够承受其自身组件的任何冲突。因此,必须设计好分布式系统状态信号,并尽可能避免对元素 FSA 设计/步进/阻塞的依赖,否则,故障安全行为仍然只是一种幻觉。

始终小心处理资源,不要将 ZeroMQ 智能信号/消息传递的组件视为任何类型的“一次性消耗品”,在学者示例中这样做可能是可以容忍的,而不是在生产系统中环境。您仍然需要支付费用(时间、资源分配/取消分配/垃圾收集)。如评论中所述,切勿在没有适当控制的情况下创建/分配资源。 当为真时:.socket(); .绑定(bind)(); .send(); 在原则上是严重错误的,并且会恶化其余的设计。

关于Python + ZMQ : Operation cannot be accomplished in current state,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41009900/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com