python 进程池阻塞和非阻塞_Tornado的线程池非阻塞实现

#!/usr/bin/python

# -*- coding=utf-8 -*-

import os

import sys

# 这个并发库, python3 自带, python2 需要: pip install

futures

from concurrent.futures import

ThreadPoolExecutor

import tornado.ioloop

import tornado.web

import util.config

from urls import handlers

from util.database import engine

reload(sys)

sys.setdefaultencoding('utf-8')

def main():

port =

7777

settings =

{

'debug': True,

'login_url': '',

'cookie_secret': ''

}

application =

tornado.web.Application(handlers, **settings)

application.engine =

engine

application.executor

= ThreadPoolExecutor(200) # 并发数量

application.listen(port)

print

('>>>>> Starting development server at

http://localhost:{}/ <<<<

tornado.ioloop.IOLoop.instance().start()

if __name__ == '__main__':

main()

#

basehandler.py

#!/usr/bin/python

# -*- coding=utf-8 -*-

import json

import tornado.web

from redis import StrictRedis

from sqlalchemy.orm import sessionmaker

import util.config

from util import util_redis

class BaseHandler(tornado.web.RequestHandler):

def __init__(self,

application, request, **kwargs):

self.session =

sessionmaker(bind=application.engine)()

self.redis =

StrictRedis(util.config.get('redis', 'host'),

util.config.get('redis', 'port'))

self.executor = application.executor

super(BaseHandler, self).__init__(application,

request, **kwargs)

#

examplehandler.py

#!/usr/bin/python

# -*- coding=utf-8 -*-

import time

from tornado.concurrent import run_on_executor

from api.basehandler import BaseHandler

class ExampleHandler(BaseHandler):

__model__ =

'Example'

@run_on_executor

def

get(self):

# do something

pass

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值