我们知道,使用TCP协议需要提前建立连接,这样就只能一对一的传输,但是这样感觉十分单一,如果实现一个服务器能同时和多个客户端同信了?
这里就需要用到多线程。
处理的不同之处就在于:每一个接进来的客户都会创建一个新的进程,这样就能够做到互不干扰
#服务端 from socket import * from multiprocessing import Process #导入模块 server = socket(AF_INET,SOCK_STREAM) server.setsockopt(SOL_SOCKET,SO_REUSEADDR,1) server.bind((‘127.0.0.1‘,8130)) server.listen(5) def func(conn,addr): while True: try: ret = conn.recv(1024) if not ret:break #liunx下防止客户端断掉之后依旧发送空值 print(ret.decode(‘utf-8‘)) conn.send(ret.upper()) except ConnectionResetError: break if __name__ == "__main__": while True: conn,addr = server.accept() #接进来一个,创建一个子进程 print("收到来自%s的访问,端口号为%s"% (addr[0],addr[1])) p = Process(target = func,args = (conn,addr)) p.start()
客户端(基本没有变化):
#客户端 from socket import * client = socket(AF_INET,SOCK_STREAM) client.connect((‘127.0.0.1‘,8130)) while True: data = input(">>>").strip() if len(data) == 0:continue client.send(data.encode(‘utf-8‘)) ret = client.recv(1024) print(ret.decode(‘utf-8‘))
结果:
收到来自127.0.0.1的访问,端口号为56225 rtyu 收到来自127.0.0.1的访问,端口号为56226 fghjk