python多线程实现TCP服务端
更新时间:2019年09月03日 11:25:39 作者:HMMHMH
这篇文章主要为大家详细介绍了python多线程实现TCP服务端,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了python多线程实现TCP服务端的具体代码,供大家参考,具体内容如下
需求
1.创建一个TCP服务器接收服务端发送的信息并给予答复
2.以多线程方式实现接收客户端信息
3.间客户端发送的信息解码输出
思路分析
1.创建一个TCP客户端套接字
2.写一个接收消息的方法,可以接收客户端消息并解码输出
3.客户端被动监听,每有一个客户端连接就创建一个子线程执行接收消息方法
代码实现
# 导入模块 import socket import threading # 接收消息 def recv(client_socket, ip_port): while True: client_text = client_socket.recv(1024) # 如果接收的消息长度不为0,则将其解码输出 if client_text: print("[客户端消息]", ip_port, ":", client_text.decode("gbk")) # 给客户端响应 client_socket.send("收到\n".encode()) # 当客户端断开连接时,会一直发送''空字符串,所以长度为0已下线 else: print("客户端", ip_port, "已下线") client_socket.close() break # 程序主入口 def main(): # 创建TCP套接字 tcp_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 设置端口复用 tcp_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True) # 绑定端口 tcp_socket.bind(("", 8080)) # 设置为被动监听状态,128表示最大连接数 tcp_socket.listen(128) while True: # 等待客户端连接 client_socket, ip_port = tcp_socket.accept() print("[新客户端]:", ip_port, "已连接") # 有客户端连接后,创建一个线程将客户端套接字,IP端口传入recv函数, t1 = threading.Thread(target=recv, args=(client_socket, ip_port)) # 设置线程守护 t1.setDaemon(True) # 启动线程 t1.start() if __name__ == '__main__': main()
执行结果
接收客户端消息
响应客户端消息
客户端下线后识别
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
- Python3 socket即时通讯脚本实现代码实例(threading多线程)
- python使用多线程+socket实现端口扫描
- 解决python ThreadPoolExecutor 线程池中的异常捕获问题
- 解决python多线程报错:AttributeError: Can''t pickle local object问题
- python实现自动化报表功能(Oracle/plsql/Excel/多线程)
- Python实现多线程/多进程的TCP服务器
- python使用多线程编写tcp客户端程序
- Python3多线程版TCP端口扫描器
- python单线程下实现多个socket并发过程详解
- 详解C语言和Python中的线程混用
相关文章
基于tensorflow __init__、build 和call的使用小结
这篇文章主要介绍了基于tensorflow __init__、build 和call的使用小结,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2021-02-02
最新评论