python测试程序的qps和响应时间代码_python性能测试,请求QPS测试

QPS = (1000ms/平均响应时间ms)*服务并行数量

#!/user/bin/env python

#coding=utf-8

import requests

import datetime

import time

import threading

import json

class url_request():

times = []

error = []

def req(self):

for i in range(100):

myreq=url_request()

headers = {'User-Agent' : 'Mozilla/5.0 (Linux; Android 4.2.1; en-us; Nexus 4 Build/JOP40D) AppleWebKit/535.19 (KHTML, like Gecko) Chrome/18.0.1025.166 Mobile Safari/535.19'}

payload = {'user_id':"000001",'product_id':"000001","query":"价格怎么样"}

payload = json.dumps(payload)

r = requests.post("http://192.168.28.70:6666/get_answer",data=payload)

ResponseTime=float(r.elapsed.microseconds)/1000 #获取响应时间,单位ms

myreq.times.append(ResponseTime) #将响应时间写入数组

if r.status_code !=200 :

myreq.error.append("0")

if __name__=='__main__':

myreq=url_request()

threads = []

starttime = datetime.datetime.now()

print ( "request start time %s" %starttime)

nub = 1000#设置并发线程数

ThinkTime = 0.1#设置思考时间

for i in range(1, nub+1):

t = threading.Thread(target=myreq.req)

threads.append(t)

for t in threads:

time.sleep(ThinkTime)

#print "thread %s" %t #打印线程

t.setDaemon(True)

t.start()

t.join()

endtime = datetime.datetime.now()

print ("request end time %s" %endtime)

time.sleep(3)

AverageTime = "{:.3f}".format(float(sum(myreq.times))/float(len(myreq.times))) #计算数组的平均值,保留3位小数

print ("Average Response Time %s ms" %AverageTime )#打印平均响应时间

usetime = str(endtime - starttime)

hour = usetime.split(':').pop(0)

minute = usetime.split(':').pop(1)

second = usetime.split(':').pop(2)

totaltime = float(hour)*60*60 + float(minute)*60 + float(second) #计算总的思考时间+请求时间

print ("Concurrent processing %s" %nub) #打印并发数

print ("use total time %s s" %(totaltime-float(nub*ThinkTime))) #打印总共消耗的时间

print ("fail request %s" %myreq.error.count("0")) #打印错误请求数

request start time 2020-09-09 11:24:24.234534

request end time 2020-09-09 11:24:29.448628

Average Response Time 44.337 ms

Concurrent processing 50

use total time 0.21409400000000023 s

fail request 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值