多线程接口压力测试python版demo

之前在做项目时有遇到需要自测一下接口的, 整理个小demo, 用于接口的压力测试

tokens放用户对应的token值, url随便拿的csdn的一个url.
"""
接口的压力测试demo
"""
import requests
import json
import threading
from script import log_handler

logger = log_handler.Logger('pressure_by_threading.log')

# 用户token字典
tokens = {'111': '111', '222': '222', '333': '333', '444': '444'}
url = 'https://event.csdn.net/logstores/csdn-pc-tracking-page-exposure/track'


def test_api(user_id, user_token):
    headers = {
        'Authorization': 'Bearer {0}'.format(user_token)
    }
    try:
        response = requests.post(
            url=url,
            headers=headers,
            timeout=5)
        resp = json.loads(response.text)
        logger.info('接口返回信息 user_id:{0}, resp:{1}'.format(user_id, resp))
        if response.status_code == 200:
            logger.info(u'接口调用状态码为200 user_id:{0}'.format(user_id))
        else:
            logger.error(u'状态码非200 user_id:{0}, status_code:{1}'.format(user_id, response.status_code))
    except Exception as e:
        logger.error(u'调用接口失败 user_id:{0}, e:{1}'.format(user_id, e))


def run():
    threads_list = []
    # 创建线程
    for k, v in tokens.items():
        t = threading.Thread(target=test_api, args=(k, v))
        threads_list.append(t)

    # 开启线程
    for i in threads_list:
        i.start()
    for i in threads_list:
        i.join()


if __name__ == '__main__':
    run()

输入日志:

[2021-12-10 20:15:00] [INFO] 接口返回信息 user_id:222, resp:{'Error': {'Code': 'OLSInvalidMethod', 'Message': 'The script name is invalid : /logstores/csdn-pc-tracking-page-exposure/track', 'RequestId': '61B344C4145FFC8FC662E187'}}
[2021-12-10 20:15:00] [INFO] 接口返回信息 user_id:444, resp:{'Error': {'Code': 'OLSInvalidMethod', 'Message': 'The script name is invalid : /logstores/csdn-pc-tracking-page-exposure/track', 'RequestId': '61B344C4426693D697D134E3'}}
[2021-12-10 20:15:00] [ERROR] 状态码非200 user_id:222, status_code:405
[2021-12-10 20:15:00] [INFO] 接口返回信息 user_id:111, resp:{'Error': {'Code': 'OLSInvalidMethod', 'Message': 'The script name is invalid : /logstores/csdn-pc-tracking-page-exposure/track', 'RequestId': '61B344C48273DB949FE8A307'}}
[2021-12-10 20:15:00] [INFO] 接口返回信息 user_id:333, resp:{'Error': {'Code': 'OLSInvalidMethod', 'Message': 'The script name is invalid : /logstores/csdn-pc-tracking-page-exposure/track', 'RequestId': '61B344C4AC14157723C8D10F'}}
[2021-12-10 20:15:00] [ERROR] 状态码非200 user_id:333, status_code:405
[2021-12-10 20:15:00] [ERROR] 状态码非200 user_id:111, status_code:405
[2021-12-10 20:15:00] [ERROR] 状态码非200 user_id:444, status_code:405

你可能感兴趣的:(python,压力测试,python,开发语言)