如何使用zeromq和线程或异步处理对python程序的多个请求?

时间:2016-03-17 13:29:11

标签: python python-2.7 zeromq python-multithreading zerorpc

我有一个小程序,它在后台进行一些计算,当我在python 2.7中通过 zerorpc 模块调用它时。

这是我的代码:

is_busy = False

class Server(object):
   def calculateSomeStuff(self):
       global is_busy

        if (is_busy):
            return 'I am busy!'

        is_busy = True

        # calculate some stuff

        is_busy = False
        print 'Done!'
        return 

    def getIsBusy(self):
        return is_busy

s = zerorpc.Server(Server())
s.bind("tcp://0.0.0.0:66666")
s.run()

我应该更改,以便在is_busy开始执行.getIsBusy()之后调用.calculateSomeStuff()方法时,此程序返回 fa 这是工作吗?

据我所知,没有办法在python 2中使它异步。

1 个答案:

答案 0 :(得分:2)

如果你正在追求的话,你需要多线程来实现真正的并发并利用多个CPU核心。请参阅Python线程模块, GIL -lock详细信息&可能的解决方法和文献。

如果您需要合作解决方案,请继续阅读。

zerorpc 使用 gevent 进行异步输入/输出。使用gevent编写协同程序(也称为greenlet或用户空间线程),它们都在一个线程上协同运行。 gevent输入输出循环正在运行的线程。 gevent ioloop 会负责恢复等待某些I / O事件的协同程序。

这里的关键是合作这个词。将其与在单个CPU /核心机器上运行的线程进行比较。实际上没有任何并发​​,但操作系统将抢占动词: 采取行动以防止(预期事件)发生)一个正在运行的线程来执行下一个等等,以便每个线程都有可能向前发展。

这种情况发生得足够快,以至于感觉所有线程都在同一时间运行。

如果您使用gevent输入/输出循环协同编写代码,可以通过小心调用 gevent.sleep(0) 来获得相同的效果gevent ioloop运行其他协同程序。

它实际上是合作的多管齐下。我听说它在Windows 2中就像是那样。

所以,在你的例子中,在繁重的计算部分,你可能会有一些循环。确保每秒呼叫gevent.sleep(0)几次,你就会产生多线程的错觉。

我希望我的回答不会太混乱。