socket只能处理一个client连接,如果需要并发处理多个链接则需要使用socketserver,下面是代码示例以及注释
server端
import socketserver
#之前的socket只能同时处理一个客户端,当需要并发处理client发送的信息是需要使用到socketserver,下面创建一个类,继承socketserver其对应实例就有并发能力
class My_Tcp_Handler(socketserver.BaseRequestHandler):
#下面的handler是自己定义的server与client交互的过程,所有交互过程都在此方法内部实现.方法名handle是固定的
def handle(self):
while True:
try:
#下面将收到的数据打印并且大写后发回给客户端
self.data = self.request.recv(1024)
print(self.data.decode(encoding="utf-8"))
self.send_data = self.data.decode(encoding="utf-8").upper().encode(encoding="utf-8")
self.request.sendall(self.send_data)
except ConnectionResetError as e:
print("一个客户端关闭了连接")
break
#实例化socketserver
My_server = socketserver.ThreadingTCPServer(("0.0.0.0", 8888), My_Tcp_Handler) #ThreadingTCPServer是使用多线程,ForkingTCPServer是使用多进程处理并发
#启动实例
My_server.serve_forever()
下面是client端
import socket
client = socket.socket()
client.connect(("127.0.0.1", 8888))
while True:
msg = input()
if len(msg) == 0:
continue
client.send(msg.encode(encoding="utf-8")) #如果发送中文需要对其进行encode,接收也需要decode;英文前面直接加b指定类型
client_rec = client.recv(1024).decode(encoding="utf-8")
print("client_rec:", client_rec)
client.close()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持亿速云。
亿速云「云数据库 MySQL」免部署即开即用,比自行安装部署数据库高出1倍以上的性能,双节点冗余防止单节点故障,数据自动定期备份随时恢复。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。