高并发,使用进程开线程开协程方式向网站发送请求,查看请求量
import gevent
from gevent import monkey
from threading import Thread
from multiprocessing import Process
import requests
monkey.patch_socket()
url = 'https://'
def task():
"""任务"""
for i in range(10):
r = requests.get(url)
def g_fun():
"""协程"""
gevent.joinall([gevent.spawn(task) for i in range(10)])
def t_fun():
"""线程"""
for t in range(10):
t = Thread(target=g_fun)
t.start()
def p_fun():
"""进程"""
for p in range(5):
p = Process(target=t_fun)
p.start()
p.join()
if __name__ == '__main__':
# 启动5个进程下面启动10个线程下面启动10个协程,每个协程执行10次发送请求任务
p_fun()
查看我的服务器上nginx的日志,使用python脚本来截取ip的访问量
运行前的ip访问量3757,刷新一次页面访问量加1,已试过
运行结束后ip访问量8710次
预计访问量为51010*10=5000次,实际4953次,速度不是很快,一秒钟一百多个请求
服务器是腾讯云的免费试用的
如果涉及到数据库的查询操作,增加多点进程线程会使服务器发生502错误,访问量大cpu承受不了
只是为了试一下高并发操作