cpython/Demo/sockets/throughput.py

94 lines
1.8 KiB
Python
Raw Normal View History

#! /usr/bin/env python
1991-07-01 18:32:32 +00:00
# Test network throughput.
#
# Usage:
# 1) on host_A: throughput -s [port] # start a server
# 2) on host_B: throughput -c count host_A [port] # start a client
#
# The server will service multiple clients until it is killed.
#
# The client performs one transfer of count*BUFSIZE bytes and
# measures the time it takes (roundtrip!).
import sys, time
from socket import *
MY_PORT = 50000 + 42
BUFSIZE = 1024
def main():
if len(sys.argv) < 2:
usage()
1992-05-19 13:51:20 +00:00
if sys.argv[1] == '-s':
1991-07-01 18:32:32 +00:00
server()
1992-05-19 13:51:20 +00:00
elif sys.argv[1] == '-c':
1991-07-01 18:32:32 +00:00
client()
else:
usage()
def usage():
sys.stdout = sys.stderr
print 'Usage: (on host_A) throughput -s [port]'
print 'and then: (on host_B) throughput -c count host_A [port]'
sys.exit(2)
def server():
if len(sys.argv) > 2:
port = eval(sys.argv[2])
else:
port = MY_PORT
s = socket(AF_INET, SOCK_STREAM)
s.bind(('', port))
1994-02-28 09:31:19 +00:00
s.listen(1)
1991-07-01 18:32:32 +00:00
print 'Server ready...'
while 1:
conn, (host, remoteport) = s.accept()
while 1:
data = conn.recv(BUFSIZE)
if not data:
break
del data
conn.send('OK\n')
conn.close()
print 'Done with', host, 'port', remoteport
def client():
if len(sys.argv) < 4:
usage()
count = int(eval(sys.argv[2]))
host = sys.argv[3]
if len(sys.argv) > 4:
port = eval(sys.argv[4])
else:
port = MY_PORT
testdata = 'x' * (BUFSIZE-1) + '\n'
1994-02-28 09:31:19 +00:00
t1 = time.time()
1991-07-01 18:32:32 +00:00
s = socket(AF_INET, SOCK_STREAM)
1994-02-28 09:31:19 +00:00
t2 = time.time()
s.connect((host, port))
1994-02-28 09:31:19 +00:00
t3 = time.time()
1991-07-01 18:32:32 +00:00
i = 0
while i < count:
i = i+1
s.send(testdata)
s.shutdown(1) # Send EOF
1994-02-28 09:31:19 +00:00
t4 = time.time()
1991-07-01 18:32:32 +00:00
data = s.recv(BUFSIZE)
1994-02-28 09:31:19 +00:00
t5 = time.time()
1991-07-01 18:32:32 +00:00
print data
print 'Raw timers:', t1, t2, t3, t4, t5
print 'Intervals:', t2-t1, t3-t2, t4-t3, t5-t4
print 'Total:', t5-t1
1994-02-28 09:31:19 +00:00
print 'Throughput:', round((BUFSIZE*count*0.001) / (t5-t1), 3),
1991-07-01 18:32:32 +00:00
print 'K/sec.'
main()