Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/302.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 对于所有Post API调用,LocustIO始终返回内部服务器错误_Python_Load Testing_Internal Server Error_Locust - Fatal编程技术网

Python 对于所有Post API调用,LocustIO始终返回内部服务器错误

Python 对于所有Post API调用,LocustIO始终返回内部服务器错误,python,load-testing,internal-server-error,locust,Python,Load Testing,Internal Server Error,Locust,我正在使用蝗虫来运行负载测试,令我惊讶的是,我尝试从它调用的所有POST API都返回“Internal Server Error-500”,但是如果我从JMeter运行相同的API,它们运行得很好。我检查了一下,在每次通话结束时都会看到像LocustIO一样的前置词和撇号。这是一个屏幕截图 这是我的设置代码: from locust import HttpLocust, TaskSet, task class justTestApi(TaskSet): @task(1)

我正在使用蝗虫来运行负载测试,令我惊讶的是,我尝试从它调用的所有POST API都返回“Internal Server Error-500”,但是如果我从JMeter运行相同的API,它们运行得很好。我检查了一下,在每次通话结束时都会看到像LocustIO一样的前置词和撇号。这是一个屏幕截图

这是我的设置代码:

from locust import HttpLocust, TaskSet, task

class justTestApi(TaskSet):

    @task(1)
    def accountInquiry(self):
        self.client.post("/users", {
    "id": 1,
    "name": "Leanne Graham",
    "username": "Bret",
    "email": "Sincere@april.biz",
    "address": {
      "street": "Kulas Light",
      "suite": "Apt. 556",
      "city": "Gwenborough",
      "zipcode": "92998-3874",
      "geo": {
        "lat": "-37.3159",
        "lng": "81.1496"
      }
    },
    "phone": "1-770-736-8031 x56442",
    "website": "hildegard.org",
    "company": {
      "name": "Romaguera-Crona",
      "catchPhrase": "Multi-layered client-server neural-net",
      "bs": "harness real-time e-markets"
    }
  });

class WebsiteUser(HttpLocust):
    task_set = justTestApi
    min_wait = 5000
    max_wait = 9000
    host = "https://jsonplaceholder.typicode.com"
    stop_timeout = 200

使用本教程,它终于可以工作了。这就是尝试测试post restful调用时安装程序的外观。我读到一个论点,说LocustIO不能用来测试https,这个测试错误了这个说法。它也可以用来测试https

from locust import HttpLocust, TaskSet, task

json = """
[{
  userId: 1,
  id: 1,
  title: "quidem molestiae enim"
}]
"""

class MyTaskSet(TaskSet):
    @task(1)
    def send(l):
        l.client.post("/albums", json) 

class MyLocust(HttpLocust):
    task_set = MyTaskSet
    min_wait = 5000
    max_wait = 15000
    # host = "http://www.somaku.com"
    host = "https://jsonplaceholder.typicode.com"
    stop_timeout = 200

您的服务器日志显示了什么?500是从服务器返回的,不是从蝗虫返回的。蝗虫将撇号和逗号传递到端点的末尾,这就是问题所在,我不知道为什么。例如:
https://myapp.com/users“,
这是它作为端点发送的内容。
是错误字符串开头的结束撇号。。。这清楚地说明了问题中的错误……这表明您向服务发送了无效的json。因此,500人作出了回应。