可修改变量thread_count指定最大的并发数量,即线程的数量。
完成之后,打印输出失败的次数,以及开始时间和结束时间,单位是毫秒。
主要是学习一下Python,仅供参考。
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
|
#!/usr/bin/python3 import sys, time, json, _thread import http.client, urllib.parse thread_count = 100 #并发数量 now_count = 0 error_count = 0 begin_time = '' lock_obj = _thread.allocate() def test_http_engine(): global now_count global error_count global thread_count global begin_time conn = None if now_count = = 0 : begin_time = int ( round (time.time() * 1000 )) try : conn = http.client.HTTPConnection( "192.168.1.1" , 80 ) conn.request( 'GET' , '/' ) response = conn.getresponse() data = response.read() print (data) if json.dumps(response.status) ! = '200' : error_count + = 1 ; print ( 'error count: ' + str (error_count)) sys.stdout.flush() now_count + = 1 if now_count = = thread_count: print ( '### error count: ' + str (error_count) + ' ###' ) print ( '### begin time : ' + str (begin_time)) print ( '### end time : ' + str ( int ( round (time.time() * 1000 )))) except Exception as e: print (e) finally : if conn: conn.close() def test_thread_func(): global now_count global lock_obj cnt = 0 lock_obj.acquire() print ('') print ( '=== Request: ' + str (now_count) + ' ===' ) cnt + = 1 test_http_engine() sys.stdout.flush() lock_obj.release() def test_main(): global thread_count for i in range (thread_count): _thread.start_new_thread(test_thread_func, ()) if __name__ = = '__main__' : test_main() while True : time.sleep( 5 ) |