Python使用monkey.patch_all()解决协程阻塞问题

时间:2021-05-22

直接参考以下实例,采用协程访问三个网站

由于IO操作非常耗时,程序经常会处于等待状态

比如请求多个网页有时候需要等待,gevent可以自动切换协程

遇到阻塞自动切换协程,程序启动时执行monkey.patch_all()解决

# 由于IO操作非常耗时,程序经常会处于等待状态# 比如请求多个网页有时候需要等待,gevent可以自动切换协程# 遇到阻塞自动切换协程,程序启动时执行monkey.patch_all()解决# 首行添加下面的语句即可from gevent import monkey; monkey.patch_all()import geventfrom urllib import requestdef run_task(url): print("Visit --> %s" % url) try: response = request.urlopen(url) data = response.read() print("%d bytes received from %s." %(len(data), url)) except Exception: print("error")if __name__ == '__main__': urls = ['https://github.com/', 'https://blog.csdn.net/', 'https://bbs.csdn.net/'] # 定义协程方法 greenlets = [gevent.spawn(run_task, url) for url in urls] # 添加协程任务,并且启动运行 gevent.joinall(greenlets)# 查看运行结果可以发现,三个协程是同时触发的,但是结束顺序不同# 网页请求的时间不同,故结束顺序不同# 但是该程序其实只有一个线程

输出结果

Visit --> https://github.com/
Visit --> https://blog.csdn.net/
Visit --> https://bbs.csdn.net/
bytes received from https://blog.csdn.net/.
bytes received from https://bbs.csdn.net/.
bytes received from https://github.com/.

Process finished with exit code 0

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章