Guido van Rossum | f06ee5f | 1996-11-27 19:52:01 +0000 | [diff] [blame] | 1 | #! /usr/bin/env python |
Guido van Rossum | 22825e8 | 1991-07-01 18:32:32 +0000 | [diff] [blame] | 2 | |
| 3 | # Test network throughput. |
| 4 | # |
| 5 | # Usage: |
Tim Peters | e6ddc8b | 2004-07-18 05:56:09 +0000 | [diff] [blame] | 6 | # 1) on host_A: throughput -s [port] # start a server |
| 7 | # 2) on host_B: throughput -c count host_A [port] # start a client |
Guido van Rossum | 22825e8 | 1991-07-01 18:32:32 +0000 | [diff] [blame] | 8 | # |
| 9 | # The server will service multiple clients until it is killed. |
| 10 | # |
| 11 | # The client performs one transfer of count*BUFSIZE bytes and |
| 12 | # measures the time it takes (roundtrip!). |
| 13 | |
| 14 | |
| 15 | import sys, time |
| 16 | from socket import * |
| 17 | |
| 18 | MY_PORT = 50000 + 42 |
| 19 | |
| 20 | BUFSIZE = 1024 |
| 21 | |
| 22 | |
| 23 | def main(): |
Tim Peters | e6ddc8b | 2004-07-18 05:56:09 +0000 | [diff] [blame] | 24 | if len(sys.argv) < 2: |
| 25 | usage() |
| 26 | if sys.argv[1] == '-s': |
| 27 | server() |
| 28 | elif sys.argv[1] == '-c': |
| 29 | client() |
| 30 | else: |
| 31 | usage() |
Guido van Rossum | 22825e8 | 1991-07-01 18:32:32 +0000 | [diff] [blame] | 32 | |
| 33 | |
| 34 | def usage(): |
Tim Peters | e6ddc8b | 2004-07-18 05:56:09 +0000 | [diff] [blame] | 35 | sys.stdout = sys.stderr |
Collin Winter | 6f2df4d | 2007-07-17 20:59:35 +0000 | [diff] [blame] | 36 | print('Usage: (on host_A) throughput -s [port]') |
| 37 | print('and then: (on host_B) throughput -c count host_A [port]') |
Tim Peters | e6ddc8b | 2004-07-18 05:56:09 +0000 | [diff] [blame] | 38 | sys.exit(2) |
Guido van Rossum | 22825e8 | 1991-07-01 18:32:32 +0000 | [diff] [blame] | 39 | |
| 40 | |
| 41 | def server(): |
Tim Peters | e6ddc8b | 2004-07-18 05:56:09 +0000 | [diff] [blame] | 42 | if len(sys.argv) > 2: |
| 43 | port = eval(sys.argv[2]) |
| 44 | else: |
| 45 | port = MY_PORT |
| 46 | s = socket(AF_INET, SOCK_STREAM) |
| 47 | s.bind(('', port)) |
| 48 | s.listen(1) |
Collin Winter | 6f2df4d | 2007-07-17 20:59:35 +0000 | [diff] [blame] | 49 | print('Server ready...') |
Tim Peters | e6ddc8b | 2004-07-18 05:56:09 +0000 | [diff] [blame] | 50 | while 1: |
| 51 | conn, (host, remoteport) = s.accept() |
| 52 | while 1: |
| 53 | data = conn.recv(BUFSIZE) |
| 54 | if not data: |
| 55 | break |
| 56 | del data |
| 57 | conn.send('OK\n') |
| 58 | conn.close() |
Collin Winter | 6f2df4d | 2007-07-17 20:59:35 +0000 | [diff] [blame] | 59 | print('Done with', host, 'port', remoteport) |
Guido van Rossum | 22825e8 | 1991-07-01 18:32:32 +0000 | [diff] [blame] | 60 | |
| 61 | |
| 62 | def client(): |
Tim Peters | e6ddc8b | 2004-07-18 05:56:09 +0000 | [diff] [blame] | 63 | if len(sys.argv) < 4: |
| 64 | usage() |
| 65 | count = int(eval(sys.argv[2])) |
| 66 | host = sys.argv[3] |
| 67 | if len(sys.argv) > 4: |
| 68 | port = eval(sys.argv[4]) |
| 69 | else: |
| 70 | port = MY_PORT |
| 71 | testdata = 'x' * (BUFSIZE-1) + '\n' |
| 72 | t1 = time.time() |
| 73 | s = socket(AF_INET, SOCK_STREAM) |
| 74 | t2 = time.time() |
| 75 | s.connect((host, port)) |
| 76 | t3 = time.time() |
| 77 | i = 0 |
| 78 | while i < count: |
| 79 | i = i+1 |
| 80 | s.send(testdata) |
| 81 | s.shutdown(1) # Send EOF |
| 82 | t4 = time.time() |
| 83 | data = s.recv(BUFSIZE) |
| 84 | t5 = time.time() |
Collin Winter | 6f2df4d | 2007-07-17 20:59:35 +0000 | [diff] [blame] | 85 | print(data) |
| 86 | print('Raw timers:', t1, t2, t3, t4, t5) |
| 87 | print('Intervals:', t2-t1, t3-t2, t4-t3, t5-t4) |
| 88 | print('Total:', t5-t1) |
| 89 | print('Throughput:', round((BUFSIZE*count*0.001) / (t5-t1), 3), end=' ') |
| 90 | print('K/sec.') |
Guido van Rossum | 22825e8 | 1991-07-01 18:32:32 +0000 | [diff] [blame] | 91 | |
| 92 | |
| 93 | main() |