python 多线程 多进程 zmq_Python多线程ZeroMQ REQ-REP

我正在寻找使用多线程的Python和ZeroMQ实现REQ-REP模式.

使用Python,当新客户端连接到服务器时,我可以创建一个新线程.该线程将处理与该特定客户端的所有通信,直到关闭套接字:

# Thread that will handle client's requests

class ClientThread(threading.Thread):

# Implementation...

def __init__(self, socket):

threading.Thread.__init__(self)

self.socket = socket

def run(self):

while keep_alive:

# Thread can receive from client

data = self.socket.recv(1024)

# Processing...

# And send back a reply

self.socket.send(reply)

while True:

# The server accepts an incoming connection

conn, addr = sock.accept()

# And creates a new thread to handle the client's requests

newthread = ClientThread(conn)

# Starting the thread

newthread.start()

是否可以使用ZeroMQ进行相同[*]?我已经看到了使用ZeroMQ和Python进行多线程处理的一些示例,但是在所有这些示例中,创建的线程池在开始时都具有固定数量的线程,并且似乎更倾向于负载平衡.

[*]注意我想要的是保持客户端与其线程之间的连接处于活动状态,因为线程期望来自客户端的多个REQ消息,并且它将存储必须在消息之间保留的信息(即:递增的变量计数器)它在新的REQ消息上的值;因此每个线程都有其自己的变量,并且其他任何客户端都不能访问该线程).新客户端=新线程.

解决方法:

是的,ZeroMQ是功能强大的Can-Do工具箱

然而,主要的惊奇将是,ZeroMQ< socket> -s比您在样本中使用的普通的-sockets-结构化得多.

{aZmqContext-> aZmqSocket-> aBehavioralPrimitive}

ZeroMQ在“单个” ZMQ-Context的框架下构建了一个出色的,丰富的抽象框架,ZMQ-Context是(并且将保留)唯一用作“共享”的东西.

线程不应“共享”任何其他“派生”对象,无论它们的状态如何,因为出于简洁设计和高性能及高性能的考虑,已实现了强大的分布式责任框架体系结构.低延迟.

对于所有ZMQ-Socket-,应该宁愿想象一个更加智能的分层子结构,其中的子结构将减轻对I / O活动的担忧(在ZMQ-Context责任内部进行管理-从而保持活动,计时问题公平队列缓冲/选择轮询问题对您来说不再是可见的……),其中一种形式为正式的通信模式行为(由选定的ZMQ-Socket类型原型提供).

最后

ZeroMQ和类似的nanomsg库都是类似LEGO的项目,它们使您成为建筑师和工程师.设计师比起初通常意识到的更多.

因此,人们可以专注于分布式系统的行为,而不是将时间和精力浪费在解决另一种套接字消息[噩梦]上.

(绝对值得一看ZeroMQ的共同父亲Pieter Hintjens的两本书.在这个很棒的主题上,您会发现很多Aha!时刻.)

…以及作为蛋糕上的樱桃-无论是在inproc://上传递某些消息,还是在ipc://上传递某些消息,以及同时在ipc://上传递消息,您都可以在不依赖于传输的通用环境中获得所有这些tcp://图层.

EDIT#12014-08-19 17:00 [UTC 0000]

请检查下面的评论,并进一步审查您的-基本的和高级的-设计选项,以进行

没有大量的模拟SLOC,没有任何代码样本可以完成“一码通”.

在设计分布式消息传递系统时,这是指数有效的.

不好意思这么说.

受伤,但事实如此.

"""REQ/REP modified with QUEUE/ROUTER/DEALER add-on ---------------------------

Multithreaded Hello World server

Author: Guillaume Aubert (gaubert)

"""

import time

import threading

import zmq

print "ZeroMQ version sanity-check: ", zmq.__version__

def aWorker_asRoutine( aWorker_URL, aContext = None ):

"""Worker routine"""

#Context to get inherited or create a new one trick------------------------------

aContext = aContext or zmq.Context.instance()

# Socket to talk to dispatcher --------------------------------------------------

socket = aContext.socket( zmq.REP )

socket.connect( aWorker_URL )

while True:

string = socket.recv()

print( "Received request: [ %s ]" % ( string ) )

# do some 'work' -----------------------------------------------------------

time.sleep(1)

#send reply back to client, who asked --------------------------------------

socket.send( b"World" )

def main():

"""Server routine"""

url_worker = "inproc://workers"

url_client = "tcp://*:5555"

# Prepare our context and sockets ------------------------------------------------

aLocalhostCentralContext = zmq.Context.instance()

# Socket to talk to clients ------------------------------------------------------

clients = aLocalhostCentralContext.socket( zmq.ROUTER )

clients.bind( url_client )

# Socket to talk to workers ------------------------------------------------------

workers = aLocalhostCentralContext.socket( zmq.DEALER )

workers.bind( url_worker )

# --------------------------------------------------------------------||||||||||||--

# Launch pool of worker threads --------------< or spin-off by one in OnDemandMODE >

for i in range(5):

thread = threading.Thread( target = aWorker_asRoutine, args = ( url_worker, ) )

thread.start()

zmq.device( zmq.QUEUE, clients, workers )

# ----------------------|||||||||||||||------------------------< a fair practice >--

# We never get here but clean up anyhow

clients.close()

workers.close()

aLocalhostCentralContext.term()

if __name__ == "__main__":

main()

标签:multithreading,zeromq,python

来源: https://codeday.me/bug/20191029/1958437.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值