pythongevent协程例子

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了pythongevent协程例子相关的知识,希望对你有一定的参考价值。

说在前面:用协程还是多线程需要仔细考量。我在做实验时请求了100w个ip,分别用pool为1000的协程和64个线程来跑,结果是多线程的速度是协程的10倍以上。

 

一个简单的协程例子

#!/usr/bin/env python
#coding=utf-8

from gevent import monkey; monkey.patch_socket()
import gevent.pool
import gevent

def do_something(ip):  #在io时协程自动切换
    #request ip
    pass
    
def main():
    pool = gevent.pool.Pool(1000)
    f = open("a_lot_of_ip.json", "r")
    g = []
    for d in f.readlines():
        ip = d
        pool.add(gevent.spawn(do_something, ip))
    f.close()
    pool.join()
    
if __name__ == "__main__":
    main()

 

以上是关于pythongevent协程例子的主要内容,如果未能解决你的问题,请参考以下文章

为啥 python gevent 比串行慢?

golang goroutine例子[golang并发代码片段]

分享几个实用的代码片段(附代码例子)

分享几个实用的代码片段(附代码例子)

Kotlin协程简介

Kotlin协程简介