python tornado多线程_tornado 使用多线程

本文探讨了在Tornado中使用多线程的挑战,指出由于IOLoop的单例特性,多线程可能并非最佳选择。作者通过示例代码展示了一个错误的多线程实现,并建议使用多进程来提高并发效率。最后,预告了下一篇文章将讨论Tornado结合PyZMQ实现的多进程异步方案。
摘要由CSDN通过智能技术生成

前言

tornado 线程支持非常不好, 我们更应该使用多进程, 而不是多线程. tornado 里面ioloop是一个单例, 也就是说全局只能有一个ioloop。

传统的多线程

为了让线程能并发处理更多事情, 我们会让每个线程用有独立的ioloop, 如果我们用libevent, 我们会为每一个线程创建一个event_base。

tornado 如果我们要用多线程

我们应该在主线程里面处理异步io事件, 然后发送给各个独立线程, 最后获取处理结果.

上一段错误的代码

尝试使用多线程

import tornado

import tornado.ioloop

import tornado.web

import threading

import time

import os

import ctypes

class ThreadService:

def timeout(self):

print 'Thread ' + str(ctypes.CDLL('libc.so.6').syscall(186)) + ' TimeOut'

self.ioloop.add_timeout(time.time() + 3, self.timeout)

def run(self):

print 'Thread ' + str(ctypes.CDLL('libc.so.6').syscall(186))

tornado.ioloop.IOLoop.

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值