locust对应源码HttpUser剖析(7)

16 篇文章 11 订阅 ¥19.90 ¥99.00

 老规矩,先贴代码:

class HttpUser(User):  
    abstract = True   
    client = None    
    def __init__(self, *args, **kwargs):
        super(HttpUser, self).__init__(*args, **kwargs)
        if self.host is None:
            raise LocustError("You must specify the base host. Either in the host attribute in the User class, or on the command line using the --host option.")

        session = HttpSession(
            base_url=self.host, 
            request_success=self.environment.events.request_success, 
            request_failure=self.environment.events.request_failure,
        )
        session.trust_env = False
        self.client = session

比较简单,无非就是继承了User的各个属性,这里把类变量client清空了,不再是NoClientWarningRaiser()了。

其他都是继续沿用,只是实例化的时候client变成了session。这个时候第一个关注点就是,实例化的时候一定要有host属性。

我们先来看看host属性是如何得到的:

首先是从User去取,在实际过程中ÿ

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Locust是一个基于Python的开负载测试工具,它可以模拟大量的用户并发访问应用程序,从而测试应用程序的性能和稳定性。下面是Locust码分析。 ## 1. 项目结构 Locust的代码结构如下: ``` locust/ ├── core/ │ ├── events.py │ ├── exception.py │ ├── runners.py │ ├── stats.py │ └── taskset.py ├── runners/ │ ├── __init__.py │ ├── base.py │ ├── master.py │ ├── worker.py │ └── web.py ├── stats/ │ ├── __init__.py │ ├── distributions.py │ ├── history.py │ ├── percentile.py │ └── stats.py ├── test/ │ └── __init__.py ├── ui/ │ ├── __init__.py │ ├── static/ │ ├── templates/ │ └── web.py ├── util/ │ ├── __init__.py │ ├── exceptions.py │ ├── roundrobin.py │ ├── runners.py │ └── web.py ├── __init__.py ├── contrib/ ├── runners.py └── web.py ``` 其中,`core`目录下是Locust的核心代码,`runners`目录下是Locust的运行器,`stats`目录下是Locust的统计代码,`ui`目录下是Locust的Web界面代码,`util`目录下是Locust的工具代码。 ## 2. 核心代码 Locust的核心代码位于`core`目录下,其中比较重要的文件包括: - `events.py`:定义了Locust的事件管理器,用于管理不同事件的触发和处理。 - `exception.py`:定义了Locust的自定义异常。 - `runners.py`:定义了Locust的运行器,包括单机运行器和分布式运行器。 - `stats.py`:定义了Locust的统计数据模块,包括整个测试的统计数据和单个任务的统计数据。 - `taskset.py`:定义了Locust的任务集合,即一组任务的集合。 ## 3. 运行器 Locust的运行器位于`runners`目录下,其中包括如下文件: - `base.py`:定义了运行器的基类。 - `master.py`:定义了主节点运行器,用于控制整个测试的运行。 - `worker.py`:定义了工作节点运行器,用于执行任务并向主节点报告测试结果。 - `web.py`:定义了Web界面运行器,用于提供Web界面。 从上面的文件可以看出,Locust支持分布式测试,其中主节点负责控制整个测试的运行,而工作节点负责执行任务和向主节点报告测试结果。 ## 4. 统计数据 Locust的统计数据位于`stats`目录下,其中包括如下文件: - `distributions.py`:定义了一些分布函数,用于统计数据分析。 - `history.py`:定义了历史统计数据,用于保存历史统计数据并进行比较。 - `percentile.py`:定义了百分位数,用于统计数据分析。 - `stats.py`:定义了一些统计数据的类,包括请求数、错误数、响应时间等。 可以看出,Locust的统计数据比较丰富,可以帮助我们更好地分析测试结果。 ## 5. Web界面 Locust的Web界面位于`ui`目录下,其中包括如下文件: - `web.py`:定义了Web界面运行器,用于提供Web界面。 - `templates`:定义了Web界面的HTML模板。 - `static`:定义了Web界面的静态资文件,包括CSS、JavaScript等。 通过Web界面,我们可以方便地启动测试、查看测试结果以及实时监控测试进度和统计数据。 ## 6. 工具代码 Locust的工具代码位于`util`目录下,其中包括如下文件: - `exceptions.py`:定义了一些自定义异常。 - `roundrobin.py`:定义了一个循环列表,用于轮询任务执行。 - `runners.py`:定义了运行器相关的工具函数。 - `web.py`:定义了一些Web相关的工具函数。 这些工具代码为Locust的实现提供了一些辅助函数和数据结构。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值