ZeroMQ - 三种模型的python实现

ZeroMQ是一个消息队列网络库,实现网络常用技术封装。在C/S中实现了三种模式,这段时间用python简单实现了一下,感觉python虽然灵活。但是数据处理不如C++自由灵活。

1.Request-Reply模式:

客户端在请求后,服务端必须回响应

server:

 1 #!/usr/bin/python
 2 #-*-coding:utf-8-*-
 3 import time
 4 import zmq
 5 
 6 context = zmq.Context()
 7 socket = context.socket(zmq.REP)
 8 socket.bind("tcp://*:5555")
 9 
10 while True:
11     message = socket.recv()
12     print message
13     #time.sleep(1)
14     socket.send("server response!")

client:

 1 #!/usr/bin/python
 2 #-*-coding:utf-8-*-
 3 
 4 import zmq
 5 import sys
 6 
 7 context = zmq.Context()
 8 socket = context.socket(zmq.REQ)
 9 socket.connect("tcp://localhost:5555")
10 
11 while(True):
12     data = raw_input("input your data:")
13     if data == 'q':
14         sys.exit()
15 
16     socket.send(data)
17 
18     response = socket.recv();
19     print response

2.Publish-Subscribe模式:

广播所有client,没有队列缓存,断开连接数据将永远丢失。client可以进行数据过滤。

server:

 1 #!/usr/bin/python
 2 #-*-coding:utf-8-*-
 3 
 4 import zmq 
 5 context = zmq.Context()  
 6 socket = context.socket(zmq.PUB)  
 7 socket.bind("tcp://127.0.0.1:5000")  
 8 while True:  
 9     msg = raw_input('input your data:') 
10     socket.send(msg)

client:

 1 #!/usr/bin/python
 2 #-*-coding:utf-8-*-
 3 
 4 import time
 5 import zmq  
 6 context = zmq.Context()  
 7 socket = context.socket(zmq.SUB)  
 8 socket.connect("tcp://127.0.0.1:5000")  
 9 socket.setsockopt(zmq.SUBSCRIBE,'') 
10 while True:  
11     print  socket.recv() 

3.Parallel Pipeline模式:

由三部分组成,push进行数据推送,work进行数据缓存,pull进行数据竞争获取处理。区别于Publish-Subscribe存在一个数据缓存和处理负载。

当连接被断开,数据不会丢失,重连后数据继续发送到对端。

server:

 1 #!/usr/bin/python
 2 #-*-coding:utf-8-*-
 3 
 4 import zmq
 5 
 6 context = zmq.Context()
 7 
 8 socket = context.socket(zmq.PULL)
 9 socket.bind('tcp://*:5558')
10 
11 while True:
12     data = socket.recv()
13     print data

work:

 1 #!/usr/bin/python
 2 #-*-coding:utf-8-*-
 3 
 4 import zmq
 5 
 6 context = zmq.Context()
 7 
 8 recive = context.socket(zmq.PULL)
 9 recive.connect('tcp://127.0.0.1:5557')
10 
11 sender = context.socket(zmq.PUSH)
12 sender.connect('tcp://127.0.0.1:5558')
13 
14 while True:
15     data = recive.recv()
16     sender.send(data)

client:

 1 #!/usr/bin/python
 2 #-*-coding:utf-8-*-
 3 
 4 import zmq
 5 import time
 6 
 7 context = zmq.Context()
 8 socket = context.socket(zmq.PUSH)
 9 
10 socket.bind('tcp://*:5557')
11 
12 while True:
13     data = raw_input('input your data:')
14     socket.send(data)

消息结构: 在每个消息buff前均会自带一个buff长度

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏菩提树下的杨过

Oracle中使用Entity Framework 6.x Code-First方式开发

去年写过一篇EF的简单学习笔记,当时EF还不支持Oracle的Code-First开发模式,今天无意又看了下Oracle官网,发现EF6.X已经支持了,并且给出...

2555
来自专栏非著名程序员

Android 开发如何做好内存优化

Android的一个应用程序的内存泄露对别的应用程序影响不大。为了能够使得Android应用程序安全且快速的运行,Android的每个应用程序都会使用一个专有...

1927
来自专栏Android研究院

彻底理解OkHttp - OkHttp 源码解析及OkHttp的设计思想

在OKhttp 源码解析之前,我们必须先要了解http的相关基础知识,任何的网络请求都离不开http。

5452
来自专栏Phoenix的Android之旅

观察者模式--DataBinding的原理和坑

上一次我们介绍了DataBinding的应用,不过只在应用层面描述了下,没有做深入分析。 关于DataBinding的实现原理,它的根本思想是观察者模式。 这篇...

2792
来自专栏Java编程技术

Spring&Mybaits数据库配置解惑

一般我们会在datasource.xml中进行如下配置,但是其中每个配置项原理和用途是什么,并不是那么清楚,如果不清楚的话,在使用时候就很有可能会遇到坑,所以下...

1232
来自专栏向治洪

深入理解Android插件化技术

插件化技术可以说是Android高级工程师所必须具备的技能之一,从2012年插件化概念的提出(Android版本),到2016年插件化的百花争艳,可以说,插件化...

5377
来自专栏Android相关

Android7.0中的ResourceNotFoundException

随着Android N的出现,适配7.0的问题也成为了各大产品头疼的问题。而最近在我们的平台上面收到了7.0的Crash。具体的栈如下:

2515
来自专栏一个会写诗的程序员的博客

浅谈android hook技术浅谈android hook技术-- coding:utf-8 --print jscode author = 'gaohe'-- coding:utf-8 --pri

您当前的位置: 安全博客 > 技术研究 > 浅谈android hook技术 浅谈android hook技术 2017年03月17日 10:06 1...

7272
来自专栏腾讯云API

【转】腾讯云 TCCLI 实践分享

原文地址:https://cloud.tencent.com/developer/article/1158013

1743
来自专栏大内老A

WCF后续之旅(6): 通过WCF Extension实现Context信息的传递

在上一篇文章中,我们讨论了如何通过CallContextInitializer实现Localization的例子,具体的做法是将client端的culture通...

2077

扫码关注云+社区

领取腾讯云代金券