环境: 运行环境win 10
安装软件:1.Locust
2.Python2.7
实现说明:以下两上.py文件模拟实现了一个接收请求的server端一个发送请求的client端,都是本机运行
TcpSocketServer.py:(Server端代码)
# !/usr/bin/env python3
# -*- coding:utf-8 -*-
import time
from socket import socket, AF_INET, SOCK_STREAM
import threading
buffsize = 2048
def tcplink(sock, addr):
# print 'Accept new connection from %s:%s...' % addr
sock.send('Welcome!')
while True:
try:
# data = sock.recv(buffsize)
data = sock.recv(buffsize).decode()
time.sleep(1)
if data == 'exit' or not data:
break
sock.send('Hello, %s!' % data)
except Exception as e:
print(str(e))
break
sock.close()
print 'Connection from %s:%s closed.' % addr
def main():
host = ''
port = 12345
ADDR = (host, port)
tctime = socket(AF_INET, SOCK_STREAM)
tctime.bind(ADDR)
tctime.listen(3)
print('Wait for connection ...')
while True:
sock, addr = tctime.accept()
print 'Accept new connection from %s:%s...' % addr
t = threading.Thread(target=tcplink, args=(sock, addr))
t.start()
if __name__ == "__main__":
main()
TcpSocketLoust.py:(Client端代码)
import time
import socket
from locust import Locust, TaskSet, events, task
class TcpSocketClient(socket.socket):
# locust tcp client
# author: Max.Bai@2017
def __init__(self, af_inet, socket_type):
super(TcpSocketClient, self).__init__(af_inet, socket_type)
def connect(self, addr):
start_time = time.time()
try:
super(TcpSocketClient, self).connect(addr)
except Exception as e:
total_time = int((time.time() - start_time) * 1000)
events.request_failure.fire(request_type="tcpsocket", name="connect", response_time=total_time, exception=e)
else:
total_time = int((time.time() - start_time) * 1000)
events.request_success.fire(request_type="tcpsocket", name="connect", response_time=total_time,
response_length=0)
def send(self, msg):
start_time = time.time()
try:
super(TcpSocketClient, self).send(msg)
except Exception as e:
total_time = int((time.time() - start_time) * 1000)
events.request_failure.fire(request_type="tcpsocket", name="send", response_time=total_time, exception=e)
else:
total_time = int((time.time() - start_time) * 1000)
events.request_success.fire(request_type="tcpsocket", name="send", response_time=total_time,
response_length=0)
def recv(self, bufsize):
recv_data = ''
start_time = time.time()
try:
recv_data = super(TcpSocketClient, self).recv(bufsize)
except Exception as e:
total_time = int((time.time() - start_time) * 1000)
events.request_failure.fire(request_type="tcpsocket", name="recv", response_time=total_time, exception=e)
else:
total_time = int((time.time() - start_time) * 1000)
events.request_success.fire(request_type="tcpsocket", name="recv", response_time=total_time,
response_length=0)
return recv_data
class TcpSocketLocust(Locust):
"""
This is the abstract Locust class which should be subclassed. It provides an TCP socket client
that can be used to make TCP socket requests that will be tracked in Locust's statistics.
author: Max.bai@2017
"""
def __init__(self, *args, **kwargs):
super(TcpSocketLocust, self).__init__(*args, **kwargs)
self.client = TcpSocketClient(socket.AF_INET, socket.SOCK_STREAM)
ADDR = (self.host, self.port)
self.client.connect(ADDR)
class TcpTestUser(TcpSocketLocust):
host = "127.0.0.1" #连接的TCP服务的IP
port = 12345 #连接的TCP服务的端口
min_wait = 100
max_wait = 1000
class task_set(TaskSet):
@task
def send_data(self):
self.client.send("test") #发送的数据
data = self.client.recv(2048).decode()
print(data)
if __name__ == "__main__":
user = TcpTestUser()
user.run()
运行方法:
1.启动一个dos窗口,进入存放TcpSocketServer.py 程序的目录下,使用命令:D:\Python2.7\python.exe TcpSocketServer.py 运行Server端程序,如以下图显示为启动成功
2.再启动一个dos窗口,进入存入程序的目录下,使用命令:locust -f D:/Python2.7/Scripts/locust_tcp/TcpSocketLocust.py --csv=test --no-web -c10 -r10 -t2,如以下图显示为请求发送成功,并生成了以test开头的测试报告