• 基于python的性能负载测试Locust-6-脚本编写之使用HTTP client


    使用HTTP client

    每个HttpLocust实例的client属性中都有一个HttpSession实例。HttpSession类是requests.Session的子类并且通过get,post,put,delete,head,patch和options方法发送HTTP请求,然后用作Locust的统计报告。HttpSession实例保存了coookies,可以用于登录网站并且在不同的requests之间保持session。client属性也可以被Locsut实例的TaskSet实例所引用,方便重新得到client并且在任务里发送HTTP请求。

    下面是对/about路径发送GET请求的例子(假设self是TaskSet或者HttpLocust类的实例):

    response = self.client.get("/about")
    print "Response status code:", response.status_code
    print "Response content:", response.content
    

    下面是关于POST请求的例子:

    response = self.client.post("/login", {"username":"testuser", "password":"secret"})
    

    安全模式

    HTTP client被配置成在安全模式下运行。因为连接错误,超时,或者其它类似错误引起的请求失败都不会抛出异常,而是返回一个空响应对象。这个请求将被统计为失败。返回的空响应的content属性被设置为None,并且status_code被设置为0。

    手动设置一个请求为成功或者失败

    默认HTTP响应为2xx之外的请求将被标识为失败。大部分时候这样判断都没问题,但是有时候返回404是我们期望的结果,而200不是我们期望的,那么就需要手动设置成功或者失败。

    即使响应码是正常的我们也可以通过catch_response和with语句标识这个请求为失败:

    with client.get("/", catch_response=True) as response:
        if response.content != "Success":
            response.failure("Got wrong response")
    

    同样的如果一个请求的响应为HTTP错误码,我们也可以标识它的结果为成功:

    with client.get("/does_not_exist/", catch_response=True) as response:
        if response.status_code == 404:
            response.success()
    

    通过动态参数进行URLs请求的分组

    一些网站的页面URLs包含一些动态参数,这种情况也比较普遍。一般情况下,可以传递name语句给HttpSession的不同request方法,从而实现在Locust的统计报告里将这些URLs划为一组。

    例子:

    # 这些request请求的统计结果将会被分组放在: /blog/?id=[id]
    for i in range(10):
        client.get("/blog?id=%i" % i, name="/blog?id=[id]")
  • 相关阅读:
    Nginx和PHP-FPM的启动、重启、停止脚本分享
    [Linux]Fedora19修复被Windows干掉的引导
    [Linux]RHEL/CentOS6配置tomcat使用80端口(与httpd整合)
    [Linux]SAMBA共享打印机
    [Linux]配置Logwatch使用第三方smtp发送电子邮件
    [oVirt]在双网卡网络环境下使用oVirt LiveCD
    走进Linux世界主题讲座纪录
    mysql用户及权限复制
    记一次失败的K8S安装部署
    HTTP状态码与爬虫
  • 原文地址:https://www.cnblogs.com/mu-shi-shi/p/6070001.html
Copyright © 2020-2023  润新知