北京网站外包公司推荐,wordpress必备工具,网站设计推广,傻瓜式网站制作软件1. 需求
目前我们开发的TCP服务端程序只能服务于一个客户端#xff0c;如何开发一个多任务版的TCP服务端程序能够服务于多个客户端呢?
完成多任务#xff0c;可以使用线程#xff0c;比进程更加节省内存资源。
2. 具体实现步骤
编写一个TCP服务端程序#xff0c;循环等…1. 需求
目前我们开发的TCP服务端程序只能服务于一个客户端如何开发一个多任务版的TCP服务端程序能够服务于多个客户端呢?
完成多任务可以使用线程比进程更加节省内存资源。
2. 具体实现步骤
编写一个TCP服务端程序循环等待接受客户端的连接请求当客户端和服务端建立连接成功创建子线程使用子线程专门处理客户端的请求防止主线程阻塞把创建的子线程设置成为守护主线程防止主线程无法退出。
3. 多任务版TCP服务端程序的示例代码:
import socket
import threading# 处理客户端的请求操作
def handle_client_request(service_client_socket, ip_port):# 循环接收客户端发送的数据while True:# 接收客户端发送的数据recv_data service_client_socket.recv(1024)# 容器类型判断是否有数据可以直接使用if语句进行判断如果容器类型里面有数据表示条件成立否则条件失败# 容器类型: 列表、字典、元组、字符串、set、range、二进制数据if recv_data:print(recv_data.decode(gbk), ip_port)# 回复service_client_socket.send(ok问题正在处理中....encode(gbk))else:print(客户端下线了:, ip_port)break# 终止和客户端进行通信service_client_socket.close()if __name__ __main__:# 创建tcp服务端套接字tcp_server_socket socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 设置端口号复用让程序退出端口号立即释放tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)# 绑定端口号tcp_server_socket.bind((, 9090))# 设置监听, listen后的套接字是被动套接字只负责接收客户端的连接请求tcp_server_socket.listen(128)# 循环等待接收客户端的连接请求while True:# 等待接收客户端的连接请求service_client_socket, ip_port tcp_server_socket.accept()print(客户端连接成功:, ip_port)# 当客户端和服务端建立连接成功以后需要创建一个子线程不同子线程负责接收不同客户端的消息sub_thread threading.Thread(targethandle_client_request, args(service_client_socket, ip_port))# 设置守护主线程sub_thread.setDaemon(True)# 启动子线程sub_thread.start()# tcp服务端套接字可以不需要关闭因为服务端程序需要一直运行# tcp_server_socket.close()执行结果:
客户端连接成功: (172.16.47.209, 51528)
客户端连接成功: (172.16.47.209, 51714)
hello1 (172.16.47.209, 51528)
hello2 (172.16.47.209, 51714)4. 小结 编写一个TCP服务端程序循环等待接受客户端的连接请求 while True:service_client_socket, ip_port tcp_server_socket.accept()当客户端和服务端建立连接成功创建子线程使用子线程专门处理客户端的请求防止主线程阻塞 while True:service_client_socket, ip_port tcp_server_socket.accept() sub_thread threading.Thread(targethandle_client_request, args(service_client_socket, ip_port))sub_thread.start()把创建的子线程设置成为守护主线程防止主线程无法退出。 while True:service_client_socket, ip_port tcp_server_socket.accept() sub_thread threading.Thread(targethandle_client_request, args(service_client_socket, ip_port))sub_thread.setDaemon(True) sub_thread.start()