背景:
验证一些由于并发问题引起的死锁问题,需要用高并发发送请求来验证。我是采用gevent 来实现高并发的。在实际的使用过程中发现脚本并没有实现高并发进行,于是进行了测试验证,验证结果如下,例子采用网上通用的例子:
monkey.patch_all()
用猴子补丁 总耗时:1.0010900497436523
不用猴子补丁 总耗时:15.034797191619873
import time
import gevent
from gevent.pool import Pool
from gevent import monkey
# 定义最大并发数
p = Pool(20)
# 导入gevent猴子补丁,没有它,协称就不会并发执行
# monkey.patch_all()
def task(i):
time.sleep(i)
print("----这里---------")
if __name__ == '__main__':
time_l = time.time()
# 使用猴子补丁 总耗时:1.0010900497436523
# threads = [p.spawn(task, 1) for i in range(15)]
# 不使用猴子补丁 总耗时:15.034797191619873
threads = [p.spawn(task, 1) for i in range(15)]
gevent.joinall(threads)
time_r = time.time()
print("总耗时:{}".format(time_r-time_l))