locust 总结

1、问题总结(登录脚本修复改造)

主要是访问地址,从浏览器获取的地址,无法正确发起请求,从fiddler抓取的请求地址,可以正确发起请求

请求地址!=请求地址

2、技术总结(1、使用tasks进行多任务设置;2、使用tasks标签进行权重的比例分配)

第一种:tasks = {test_login:1,test_search:3}

第二种:@task(1)

3、成果物展示(1、脚本,2、测试报告)

小实验:

#获取当前系统时间
# import datetime
# te=datetime.datetime.now()
# print(str(te))

#如果测试结果文件存在的话,先删除,再创建
import os
import csv
file="test.csv"
result=os.path.exists(file)
print(result)
if result:
    os.remove(file)
file=open("test.csv","a")
file.write("test111111111")
file.close()

分布式性能压测

分布式部署实施过程1:准备工作:准备压力机,一台主控压力机,在每台压力机上安装locust,把相关的测试脚本文件放在每台压力机上,明确一台主控压力机,在同一网段联网状态

分布式部署实施过程2:命令行执行方式

        locust -f XXX.py --master        表示这是主控压力机

        locust -f XXX.py --slave --master  -host=ip地址(master)

分布式部署实施过程3:设置虚拟用户

                                        每台压力机的用户数量设置多点   万十万。。。

locust 图表参数说明1

type:请求类型

name: 请求路径

requests:当前请求的数量

fails:当前请求失败的数量

Median (ms):中间值,单位毫秒,一半服务器响应时间低于该值,而另一半高于该值

Average :所有请求的平均响应时间,毫秒

Min :请求的最小的服务器响应时间,毫秒

Max :请求的最大的服务器响应时间,毫秒

Current size :单个请求的大小,单位字节

req/sec:每秒钟请求的个数

 locust图表:每秒请求数

 locust图表:响应时间 (ms)

 locust图表:用户数

locust集合点的设置

导入相关类库文件包并进行初始化设置

locust:虚拟用户数并发方式

(数量会直接在1000起点)等到1000后同时发起请求 

下图是阶段性发起请求,逐步累计到1000个请求

 locust性能测试总结

1、性能测试环境部署

        locust:安装python、pycharm、locust

        性能测试环境部署:一台压力机进行脚本研发及调试

        生产环境部署:多台压力机对系统进行正式测试

2、脚本技术总结

        1、locust原理

                测试脚本

from locust import HttpLocust, task, TaskSet

# 定义测试类:用户行为
class UserBehavior(TaskSet):
    # 指定测试任务
    @task
    def test_login(self):
        self.client.get("/")

class WebSiteUser(HttpLocust):
    host = "https://www.baidu.com/"
    task_set = UserBehavior
    min_wait = 2000
    max_wait = 5000

                命令行:locust -f 脚本名.py

        2、性能测试基础脚本

        3、构造测试数据

                1、使用数据库构造数据

create procedure insertuser(num int)
begin 
#设值循环变量
declare i int;
#循环变量赋值
set i=1;
while i <=num do 
insert into iwebshop_user(username,password) values (concat('dabai',i),'111111');
set i = i+1;
end while;
end 

                2、使用爬虫技术

# #使用爬虫技术抓取查询关键字:商品分类页面上的内容
#
# import requests
# from lxml import etree
# import csv
# #以写的方式打开文件
# file= open("searchdata.csv","w")
#
# #         1、发送商品分类页面请求
# #http://localhost/iwebshop/index.php?controller=site&action=sitemap
# response=requests.get("http://localhost/iwebshop/index.php?controller=site&action=sitemap").text
# # print(response)
# #         2、获取相关的xpath路径
# #/html/body/div[1]/div[6]/div[2]/div[3]/table[1]/tr[2]/td/a[1]
# doc=etree.HTML(response)
# for i in range(1,6):
#     keyword=doc.xpath('/html/body/div[1]/div[6]/div[2]/div[3]/table['+str(i)+']/tbody/tr[2]/td/a/text()')
#     print(keyword)
#     for ele in keyword:
#         file.write(str(ele)+"\n")
# file.close()
#
# #         3、得到对应的标签信息
# #         4、放入csv文件中  :以w方式打开文件,写入相关信息
# #         5、使用循环进行多次提取

        4、脚本优化

                1、参数化脚本实现

for i in range(25,106):
    username="dabai"+str(i)
    logindata = {"login_info":username,
                 "password":"111111"}
    #发送首页请求给服务器,post
    self.client.post("/index.php?controller=simple&action=login",data=logindata)

                2、参数化通过csv实现

for i in range(25,106):
    file=open("userdata.csv","r")
    table=csv.reader(file)
    for row in table:
        username="dabai"+str(i)
        logindata = {"login_info":row[0],
                     "password":row[1]}
        #发送首页请求给服务器,post
        self.client.post("/index.php?controller=simple&action=login",data=logindata)

                3、验证码处理方法

                        1、注释验证码的校验代码(和开发沟通)

                        2、在测试代码中放入”万能验证码“(和开发沟通)

                4、检查点设置

                        脚本

response=self.client.get("/index.php?controller=site&action=search_list&word="+str(word)).text
# print(response)
loc=response.find(str(word))
te=datetime.datetime.now()
if loc>=0:
    # print(str(word)+"测试成功")
    result=str(te)+str(word)+"测试成功"
    file2.write(result+"\n")
else:
    # print(str(word)+"测试失败")
    result = str(te)+str(word) + "测试失败"
    file2.write(result + "\n")

                5、业务场景权重

第一种:

tasks = {test_login:1,test_search:3}

第二种:

@task(2)
def test_login(self):

。。。

@task(3)
def test_search(self):

。。。

                6、关联

@task
def test_mycount(self):
    head = {
        "Cookie": "Pycharm-a129a11b=4c496dcd-0787-45da-8039-e4846066ba5c; PHPSESSID=f5kgu6ju9l88f4e6dgjpvq1dv1; iweb_iweb_safecode=22a8b242d6MDAwOTA5MTgwMzQ7bGFhZGE0ZDY1N2k5N2BnNGY2NWU; iweb_Captcha=2af0bcbd0bMDAzMjAwNDcwMDU5bGFmZ2I3YDEwPmk5N2FnNGY1NWI; iweb_step=c689e7d90dMjA1NjUyMjQ5NjU4ZGhgY2I3ZDU1M2c%2BMGViMmY2MGU; iweb_head_ico=19f958cbd9MjAyMDA3NjI2OTA8Z2hoYmUzZDUxNmM5NmJsNWU2NWw; iweb_user_id=70383ae4b5MDAwODUwMDAwOG8zOTUyYzVlNDgwNTFhYTBkM2c%2FYTw2Pg; iweb_username=0cf272e078NjE2MDU1MDc0MDc4MzRmNDVjMTgyMDIxZmE0NzlkPjRlZWJhazUy; iweb_safecode=6a1ff22e5bNzA2MjA5NzkwOWY5ZD0zMmoyZWc3NzI0MjdmOWY1bTZhMDkyNjE4Z2EzZjBhPzNjODRiZGJkYTZlMzc1ZTE5NA; iweb_user_pwd=67ce304223MDMwMDA4MDg3MDk3MzsxYT87OGg4YjRgPTBoM2ZhNWtlMTZhZGAzODQ5Z2E1OWFiYmU1MGwwNjZmMjBmODgzZQ",
        #"Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8",
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.181 Safari/537.36"}
    response = self.client.get("/index.php?controller=ucenter", headers=head).text

                7、集合点的设置

from gevent._semaphore import Semaphore
all_locusts_spawned=Semaphore()
all_locusts_spawned.acquire()
from locust import HttpLocust,task,TaskSet
class UserBehavior_mycount(TaskSet):
    def on_start(self):
          all_locusts_spawned.wait()

             

        5、分布式部署

                1、命令:  locust -f XXX.py  --master    主控压力机的命令

                                locust -f XXX.py  --slave --master  -host=IP地址(master)

        6、测试数据分析

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值