亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

并發(fā)模型 - python將進(jìn)程池放在裝飾器里為什么不生效也沒報(bào)錯(cuò)

瀏覽:97日期:2022-06-27 14:55:55

問題描述

我想把進(jìn)程池封裝在裝飾器里,但是它既沒生效也沒報(bào)錯(cuò)

# coding:utf-8import multiprocessingimport tornadofrom tornado.httpclient import AsyncHTTPClientprocess_num = 20 # 進(jìn)程數(shù)url = 'https://www.baidu.com'def handle_request(response): print str(response)def run_in_process(process_num): def _run_in_process(f):def __run_in_process(*args, **kwargs): pool = multiprocessing.Pool(processes=process_num) for i in range(process_num):pool.apply_async(f, args=args, kwds=kwargs, callback=kwargs.get('callback')) pool.close() pool.join()return __run_in_process return _run_in_process@run_in_process(process_num)def main(): http_client = AsyncHTTPClient() http_client.fetch(url, callback=handle_request) global loop loop = tornado.ioloop.IOLoop.instance() if loop._running is False:loop.start()if __name__ == ’__main__’: main()

結(jié)果如下

/usr/bin/python2.7 /home/xxx/workspace/py_project/crawler/center/sample.pyProcess finished with exit code 0

但是奇怪的是,我用多進(jìn)程的方式重寫一次,發(fā)現(xiàn)是可以生效的

# coding:utf-8import multiprocessingimport tornadofrom tornado.httpclient import AsyncHTTPClientprocess_num = 20 # 進(jìn)程數(shù)url = 'https://www.baidu.com'def handle_request(response): print str(response)def run_in_process(process_num): def _run_in_process(f):def __run_in_process(*args, **kwargs): _processes = [] for i in xrange(process_num):p = multiprocessing.Process(target=f, args=args, kwargs=kwargs)p.start()_processes.append(p) for p in _processes:p.join()return __run_in_process return _run_in_process@run_in_process(process_num)def main(): http_client = AsyncHTTPClient() http_client.fetch(url, callback=handle_request) global loop loop = tornado.ioloop.IOLoop.instance() if loop._running is False:loop.start()if __name__ == ’__main__’: main()

日志如下

/usr/bin/python2.7 /home/shufeng/workspace/private_project/jobscrawler/center/sample.pyHTTPResponse(_body=None,buffer=<_io.BytesIO object at 0x7f2fdaa21ef0>,code=200,effective_url=’http://www.baidu.com’,error=None,headers=<tornado.httputil.HTTPHeaders object at 0x7f2fdaa425d0>,reason=’OK’,request=<tornado.httpclient.HTTPRequest object at 0x7f2fdaa42250>,request_time=0.014312028884887695,time_info={})HTTPResponse(_body=None,buffer=<_io.BytesIO object at 0x7f2fdaa21ef0>,code=200,effective_url=’http://www.baidu.com’,error=None,headers=<tornado.httputil.HTTPHeaders object at 0x7f2fdaa43450>,reason=’OK’,request=<tornado.httpclient.HTTPRequest object at 0x7f2fdaa430d0>,request_time=0.02327895164489746,time_info={})HTTPResponse(_body=None,buffer=<_io.BytesIO object at 0x7f2fdaa21ef0>,code=200,effective_url=’http://www.baidu.com’,error=None,headers=<tornado.httputil.HTTPHeaders object at 0x7f2fdaa43510>,reason=’OK’,request=<tornado.httpclient.HTTPRequest object at 0x7f2fdaa43190>,request_time=0.026951074600219727,time_info={})HTTPResponse(_body=None,buffer=<_io.BytesIO object at 0x7f2fdaa21ef0>,code=200,effective_url=’http://www.baidu.com’,error=None,headers=<tornado.httputil.HTTPHeaders object at 0x7f2fdaa42690>,reason=’OK’,request=<tornado.httpclient.HTTPRequest object at 0x7f2fdaa42310>,request_time=0.0552978515625,time_info={})HTTPResponse(_body=None,buffer=<_io.BytesIO object at 0x7f2fdaa24ef0>,code=200,effective_url=’http://www.baidu.com’,error=None,headers=<tornado.httputil.HTTPHeaders object at 0x7f2fdaa39e10>,reason=’OK’,request=<tornado.httpclient.HTTPRequest object at 0x7f2fdaa39a90>,request_time=0.05612993240356445,time_info={})

同樣的情況也會出現(xiàn)在線程池跟協(xié)程的使用上,有誰知道這是怎么回事嗎?

問題解答

回答1:

知乎靈劍大神已回答此問題:https://www.zhihu.com/questio...

回答2:

在linux下運(yùn)行, 會得到下面的報(bào)錯(cuò):

PicklingError: Can’t pickle <type ’function’>: attribute lookup __builtin__.function failed

而這個(gè)報(bào)錯(cuò)是因?yàn)? 傳入不可序列化的對象進(jìn)進(jìn)程池時(shí), 報(bào)錯(cuò)導(dǎo)致的, 而這個(gè)對象就是實(shí)例方法, 可以試下用py3運(yùn)行下, 因?yàn)?的實(shí)例方法已經(jīng)可以支持序列化

參考資料: https://virusdefender.net/ind...

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 亚洲免费在线观看视频 | 久久精品久久精品 | 古代的一a一片一级一片 | 国产一区二区在线免费观看 | 一级女性黄 色生活片 | 久久精品国产亚洲综合色 | 香蕉免费一级视频在线观看 | 欧美精品黄页在线观看大全 | 欧美日本一道本 | 色中文在线 | 国产精品怕怕怕视频免费 | 国产精品99一区二区三区 | 久操青青| 黄色的网站免费观看 | 久久天堂夜夜一本婷婷麻豆 | a级黄色影院 | 国产成人福利色视频 | 国产视频 一区二区 | 国产欧美日韩不卡一区二区三区 | 韩国主播vip福利视频在线播放 | 一级片在线播放 | 澳门一级特黄真人毛片 | 1024 cc香蕉在线观看看中文 | 96一级毛片| 欧美中文字幕一二三四区 | 久久要| 国产在线视频欧美亚综合 | 青青热久免费精品视频网站 | 在线观看国产 | 真实国语对白视频播放 | 欧美精品一区二区三区免费观看 | 99re最新地址获取精品 | 国产亚洲精品自在久久不卡 | 12306播播影院午夜 | 久久精品影院一区二区三区 | 一级在线观看视频 | 欧美激情级毛片 | 久久网欧美| 日韩一区二区不卡中文字幕 | 日韩一级视频免费观看 | 国产精品视频网址 |