同時プログラミング-socket単一スレッドでのコラボレーション(geventモジュール)による同時効果のテスト
1384 ワード
Geventモジュールは、単一スレッド内でコモンを起動し、ブロックが自動的に他のコモンに切り替わることを検出し、効率テストの下でサービス側の単一スレッド内でコモンを利用して、クライアントが500スレッド接続を開く効果を向上させることができる.
from gevent import monkey, spawn # gevent ,spawn
monkey.patch_all() # socket , ,
from socket import *
def communicate(conn):
while True:
try:
data = conn.recv(1024)
conn.send(data.upper())
except ConnectionResetError:
break
conn.close()
def server(ip, port):
server = socket(AF_INET, SOCK_STREAM)
server.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
server.bind((ip, port))
server.listen(500)
while True:
conn, addr = server.accept()
spawn(communicate, conn) # , ,
server.close()
if __name__ == '__main__':
server('127.0.0.1', 8090) # if __name__ == '__main__':
from socket import *
from threading import Thread, currentThread
def client():
client = socket(AF_INET, SOCK_STREAM)
client.connect(('127.0.0.1', 8090))
while True:
client.send(('%s hello' % currentThread().getName()).encode('utf-8'))
data = client.recv(1024)
print(data.decode('utf-8'))
client.close()
if __name__ == '__main__':
for i in range(500): # 500
t = Thread(target=client)
t.start()