python与zmq系列(5)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/KWSY2008/article/details/49513109

我们已经了解REQ/REP,PUB/SUB,PULL/PUSH这三种模式,也曾提到过,一个上下文可以创建多个socket套接字,那么如何管理这些套接字呢?


假设我们的一个客户端既有pull又有sub,他们两个都需要接收消息,该如何协调呢,毕竟,当一个socket要收消息的时候,函数recv是阻塞的,所以,我们第一个思路是不让它阻塞,看示例代码:


 
 
  1. #coding=utf-8
  2. '''
  3. Created on 2015-10-13
  4. 在这里,同时处理多个套接字,那么接收消息的时候,就需要设置noblock
  5. 不然会在第一个接收消息的地方堵塞
  6. @author: kwsy2015
  7. '''
  8. import zmq
  9. import time
  10. # Prepare our context and sockets
  11. context = zmq.Context()
  12. # Connect to task ventilator
  13. receiver = context.socket(zmq.PULL)
  14. receiver.connect( "tcp://localhost:5557")
  15. # Connect to weather server
  16. subscriber = context.socket(zmq.SUB)
  17. subscriber.connect( "tcp://localhost:5556")
  18. subscriber.setsockopt(zmq.SUBSCRIBE, b"10001")
  19. # Process messages from both sockets
  20. # We prioritize traffic from the task ventilator
  21. while True:
  22. # Process any waiting tasks
  23. while True:
  24. try:
  25. #用了NOBLOCK,就意味着得不到消息时不会堵塞在这里
  26. msg = receiver.recv(zmq.NOBLOCK)
  27. except zmq.ZMQError:
  28. break
  29. # process task
  30. # Process any waiting weather updates
  31. while True:
  32. try:
  33. msg = subscriber.recv(zmq.NOBLOCK)
  34. except zmq.ZMQError:
  35. break
  36. # process weather update
  37. # No activity, so sleep for 1 msec
  38. time.sleep( 0.001)

      通过设置zmq.NOBLOCK,我们可以让recv不再阻塞,但是呢,要捕捉zmq.ZMQError这个异常,这样一来,两个套接字就可以不发生冲突了

       但是明显,你可以感受得到,这种做法的丑陋,看起来不是那么的优雅,所以我们换一种做法

       


 
 
  1. #coding=utf-8
  2. '''
  3. Created on 2015-10-13
  4. 这种方式比msreader要更好一些
  5. @author: kwsy2015
  6. '''
  7. import zmq
  8. # Prepare our context and sockets
  9. context = zmq.Context()
  10. # Connect to task ventilator
  11. receiver = context.socket(zmq.PULL)
  12. receiver.connect( "tcp://localhost:5557")
  13. # Connect to weather server
  14. subscriber = context.socket(zmq.SUB)
  15. subscriber.connect( "tcp://localhost:5556")
  16. subscriber.setsockopt(zmq.SUBSCRIBE, b"10001")
  17. # Initialize poll set
  18. poller = zmq.Poller()
  19. poller.register(receiver, zmq.POLLIN)
  20. poller.register(subscriber, zmq.POLLIN)
  21. # Process messages from both sockets
  22. while True:
  23. try:
  24. socks = dict(poller.poll())
  25. except KeyboardInterrupt:
  26. break
  27. if receiver in socks:
  28. message = receiver.recv()
  29. # process task
  30. if subscriber in socks:
  31. message = subscriber.recv()
  32. # process weather update

这种做法就很想socket的select模式,大家谁也别争,谁也别抢,只要有消息达到,我就通知你们,然后你们各自检查是不是自己的消息。我们在客户端创建多个socket套接字可能是合理的,但是服务端就最好别这么做了,REQ,PUSH,PUB,道理其实也很简单,服务就是服务,多个员工可以挤在一个办公司里办公,哪有多个老板挤在一起办公的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值