同時プログラミング-socket単一スレッドでのコラボレーション(geventモジュール)による同時効果のテスト


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()