【Python高级353】python实现多线程版本的TCP服务器

前面学了了套接字编程、tcp服务端客户端开发、面向对象版的服务端客户端、带有端口复用的服务端。

这里使用多线程开发多任务版的服务端


多任务版本的TCP服务器

来一个客户,就为其创建一个线程

python 复制代码
import socket
import threading

class WebServer:
    # 3、定义一个__init__方法,初始化套接字对象
    def __init__(self):
        self.tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        # 设置端口复用(在上一次关闭服务器后,端口不会立即释放,需要设置端口复用)
        self.tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)  # 参数2:SOL_SOCKET表示当前套接字,参数3:SO_REUSEADDR表示端口复用,参数4:True表示开启端口复用(默认是false,要等待很长时间端口才会自动释放)
    
        self.tcp_server_socket.bind(("127.0.0.1", 8000))  # 如果是本机,可以不写ip地址
        self.tcp_server_socket.listen(128)  # 128表示最大连接数

    # 4、定义一个start方法,启动服务器,接收客户端连接
    def start(self):
        while True:
            # 等待接受客户端的连接请求
            new_socket, ip_port = self.tcp_server_socket.accept()

            # 当接收到客户端连接请求后创建一个线程(线程内调用自身的handle_request()方法,用于接收和发送消息(封装性))
            sub_thread = threading.Thread(target=self.handle_request, args=(new_socket, ip_port))
            sub_thread.start()

    # 5、定义一个handle_request方法,用于接收和发送消息
    def handle_request(self, new_socket, ip_port):
        # 接收某个客户端发送过来的消息
        recv_data = new_socket.recv(1024).decode("utf-8")  # 实际工作中一条数据大小在1~1.5k之间
        print(f"接收到的数据为:{recv_data}")

        # 发送消息给客户端
        new_socket.send("信息已收到".encode("utf-8"))

        # 关闭套接字
        new_socket.close()

# 定义一个程序的执行入口
if __name__ == "__main__":
    # 1、实例化服务器对象
    server = WebServer()

    # 2、启动服务器
    server.start()
相关推荐
aiguangyuan31 分钟前
使用LSTM进行情感分类:原理与实现剖析
人工智能·python·nlp
小小张说故事39 分钟前
BeautifulSoup:Python网页解析的优雅利器
后端·爬虫·python
luoluoal40 分钟前
基于python的医疗领域用户问答的意图识别算法研究(源码+文档)
python
Shi_haoliu1 小时前
python安装操作流程-FastAPI + PostgreSQL简单流程
python·postgresql·fastapi
ZH15455891311 小时前
Flutter for OpenHarmony Python学习助手实战:API接口开发的实现
python·学习·flutter
小宋10211 小时前
Java 项目结构 vs Python 项目结构:如何快速搭一个可跑项目
java·开发语言·python
爱吃生蚝的于勒1 小时前
【Linux】进程信号之捕捉(三)
linux·运维·服务器·c语言·数据结构·c++·学习
The森1 小时前
Linux IO 模型纵深解析 01:从 Unix 传统到 Linux 内核的 IO 第一性原理
linux·服务器·c语言·经验分享·笔记·unix
期待のcode1 小时前
Redis的主从复制与集群
运维·服务器·redis