day27-3ソケットソケットプログラミングに基づいてsocketserver並行処理を実現

ソケットのソケットプログラミングに基づくsocketserver並行処理を実現

同時実行:サーバーと複数のクライアントが同時に接続してみましょう。socketserver接続サイクル(同時)を使用しますが、自分自身の通信サイクルを使用して

サーバー

import socketserver

print('start...')


class Myhandler(socketserver.BaseRequestHandler):
    # 通信循环
    def handle(self):
        while True:

            try:
                cmd = self.request.recv(1024)
                print('来自客户端数据:', cmd)

                self.request.send(cmd.upper())

            except ConnectionResetError:
                break


if __name__ == '__main__':
    server = socketserver.ThreadingTCPServer(('127.0.0.1', 8000), Myhandler, bind_and_activate=True)
    server.serve_forever()

クライアント1

from socket import *

client = socket(AF_INET, SOCK_STREAM)

client.connect(('127.0.0.1', 8000))

while True:

    client.send('cmd'.encode('utf8'))

    data = client.recv(1024)
    print(data.decode('gbk'))

クライアント2

from socket import *

client = socket(AF_INET, SOCK_STREAM)

client.connect(('127.0.0.1', 8000))

while True:

    client.send('hello'.encode('utf8'))

    data = client.recv(1024)
    print('来自服务端的数据:',data.decode('gbk'))

おすすめ

転載: www.cnblogs.com/863652104kai/p/11099337.html