summaryrefslogtreecommitdiffstats
path: root/Demo/sockets/throughput.py
blob: 58975bf51d5a21699d23968986d608d09508c6aa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#! /usr/bin/env python

# 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()
	if sys.argv[1] == '-s':
		server()
	elif sys.argv[1] == '-c':
		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)
	s.listen(1)
	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'
	t1 = time.time()
	s = socket(AF_INET, SOCK_STREAM)
	t2 = time.time()
	s.connect(host, port)
	t3 = time.time()
	i = 0
	while i < count:
		i = i+1
		s.send(testdata)
	s.shutdown(1) # Send EOF
	t4 = time.time()
	data = s.recv(BUFSIZE)
	t5 = time.time()
	print data
	print 'Raw timers:', t1, t2, t3, t4, t5
	print 'Intervals:', t2-t1, t3-t2, t4-t3, t5-t4
	print 'Total:', t5-t1
	print 'Throughput:', round((BUFSIZE*count*0.001) / (t5-t1), 3),
	print 'K/sec.'


main()