locust+python高并发压测总结

locust+python全链路压测总结

1. 什么是接口?

为系统提供数据服务的叫做接口(Interface)

locust安装

pip install locust

安装完成后:locust -h查看是否安装成功

2. 如何编写locust脚本?

编写locust脚本主要分为以下几个步骤:

  1. 导入Locust类
  2. 定义用户行为
  3. 定义任务
  4. 运行脚本

2.1 导入Locust类

python 复制代码
from locust import HttpUser, task, between

2.2 定义用户行为

python 复制代码
class MyUser(HttpUser):
    wait_time = between(1, 2)

    @task
    def my_task(self):
        self.client.get("/api/users")

2.3 定义任务

python 复制代码
class MyUser(HttpUser):
    wait_time = between(1, 2)

    @task
    def my_task(self):
        self.client.get("/api/users")

2.4 运行脚本

python 复制代码
from locust import HttpUser, task, between

class MyUser(HttpUser):
    wait_time = between(1, 2)

    @task
    def my_task(self):
        self.client.get("/api/users")

# 运行脚本:locust -f my_locust_script.py --host=http://example.com

3. 如何运行locust脚本?

运行locust脚本有两种方式:

  1. 命令行运行:locust -f my_locust_script.py --host=http://example.com
  2. 代码运行:
python 复制代码
from locust import runners

def main():                 
        # 运行脚本              
        runners.locust_runner.run_locust_file("my_locust_script.py", host="http://example.com")

if __name__ == "__main__":
        main()

4. 如何分析locust脚本的性能?

locust提供了一些性能分析工具,包括:

  1. 统计信息:locust -f my_locust_script.py --host=http://example.com --stats-csv=stats.csv
  2. 分析统计信息:locust -f my_locust_script.py --host=http://example.com --csv=stats.csv --no-web --only-summary
  3. 分析统计信息:locust -f my_locust_script.py --host=http://example.com --csv=stats.csv --no-web --only-summary --show-task-ratio
  4. 分析统计信息:locust -f my_locust_script.py --host=http://example.com --csv=stats.csv --no-web --only-summary --show-task-ratio --show-percentile-stats

5. 如何优化locust脚本?

  1. 优化用户行为:
    1. 减少并发用户数:通过设置并发用户数,可以控制脚本的并发用户数,减少脚本的压力。
    2. 优化请求:优化请求,可以提升脚本的吞吐量。
    3. 优化请求参数:优化请求参数,可以提升脚本的响应速度。
    4. 优化请求方式:优化请求方式,可以提升脚本的响应速度。
    5. 优化请求头:优化请求头,可以提升脚本的响应速度。
    6. 优化断言:优化断言,可以提升脚本的响应速度。
    7. 优化代码:优化代码,可以提升脚本的响应速度。
  2. 优化脚本:
    1. 优化代码结构:优化代码结构,可以提升脚本的响应速度。
    2. 优化代码逻辑:优化代码逻辑,可以提升脚本的响应速度。
    3. 优化代码性能:优化代码性能,可以提升脚本的响应速度。
    4. 优化代码配置:优化代码配置,可以提升脚本的响应速度。
    5. 优化代码环境:优化代码环境,可以提升脚本的响应速度。
    6. 优化代码部署:优化代码部署,可以提升脚本的响应速度。
  3. 优化服务器:
    1. 优化服务器硬件:优化服务器硬件,可以提升脚本的响应速度。
    2. 优化服务器软件:优化服务器软件,可以提升脚本的响应速度。
    3. 优化服务器网络:优化服务器网络,可以提升脚本的响应速度。
    4. 优化服务器负载:优化服务器负载,可以提升脚本的响应速度。
    5. 优化服务器配置:优化服务器配置,可以提升脚本的响应速度。

下面是部分优化代码:

复制代码
@task(weight_t1)
    def test_register_login(self):
        # 注册用户(web)
        uri = "/usercenter/v1/web/register/account"
        username = "web" + random_data_time_string(rule="time_ms", return_str=True)
        req_body = {
            "user_name": username,
            "coin_code": coin_code,
            "password": default_pwd,
            "application_id": application_id,
            "use_type": 1,
            "app": "web",
            "invite_code": invite_code
        }
        with self.client.post(path=uri, headers=default_headers, json=req_body, catch_response=True) as responses:
            if responses.status_code == 200 and responses.json().get("code") == 0:
                responses.success()
            else:
                responses.failure("注册失败")
相关推荐
GuokLiu20 分钟前
250708-通过两块硬盘拷贝DeepSeek两个满血版模型的bash脚本
开发语言·chrome·bash
冬天给予的预感1 小时前
DAY 54 Inception网络及其思考
网络·python·深度学习
钢铁男儿1 小时前
PyQt5高级界而控件(容器:装载更多的控件QDockWidget)
数据库·python·qt
亿牛云爬虫专家5 小时前
Kubernetes下的分布式采集系统设计与实战:趋势监测失效引发的架构进化
分布式·python·架构·kubernetes·爬虫代理·监测·采集
iCxhust7 小时前
c# U盘映像生成工具
开发语言·单片机·c#
yangzhi_emo7 小时前
ES6笔记2
开发语言·前端·javascript
emplace_back8 小时前
C# 集合表达式和展开运算符 (..) 详解
开发语言·windows·c#
jz_ddk8 小时前
[学习] C语言数学库函数背后的故事:`double erf(double x)`
c语言·开发语言·学习
萧曵 丶9 小时前
Rust 所有权系统:深入浅出指南
开发语言·后端·rust