python代码模拟服务器实验1:阻塞IO

client.py

python 复制代码
import socket
import sys

# 创建一个TCP/IP套接字
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# 连接服务器
server_address = ('localhost', 9090)

try:
    client_socket.connect(server_address)
except ConnectionRefusedError:
    print("Connection refused")
    sys.exit()

try:
    # 发送数据
    message = 'This is a test message.'
    print(f"Sending: {message}")
    client_socket.sendall(message.encode('utf-8'))

finally:
    # 发送FIN
    client_socket.close()

server.py

python 复制代码
import socket

# 创建一个TCP/IP套接字
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# 绑定套接字到地址和端口
server_address = ('localhost', 9090)
server_socket.bind(server_address)

# 开始监听传入连接
server_socket.listen(1)

print("Server is waiting for a connection...")

# 阻塞等待客户端连接
connection, client_address = server_socket.accept()

try:
    print(f"Connection established with {client_address}")

    # 循环接收数据
    while True:
        data = connection.recv(1024)  # 阻塞等待接收数据
        if data:
            print(f"Received: {data.decode('utf-8')}")
        else:
            print("No more data from client, closing connection.")
            break

finally:
    connection.close()

在这个例子中,listen(1) 指定连接队列的最大长度为1,这意味着:

如果服务器正忙于处理当前连接,而另一个连接请求到来,那么这个新的连接请求将被放入队列中。

如果在这个时候有第三个客户端请求连接,由于队列长度已经达到 1,第三个请求可能会被拒绝,或者客户端会收到 ECONNREFUSED 错误。

实际使用建议:

在实际应用中,backlog 参数的值通常会设置得比1大,尤其是在处理多个客户端的情况下。例如,常见的值有 5、10 或者更高,这样可以确保服务器能处理更多并发的连接请求而不容易拒绝新的连接。

总结:server_socket.listen(1) 中的 1 是连接请求队列的最大长度,决定了在服务器处理当前连接时,可以有多少其他连接请求被挂起等待处理。

相关推荐
数据智能老司机4 小时前
精通 Python 设计模式——分布式系统模式
python·设计模式·架构
数据智能老司机5 小时前
精通 Python 设计模式——并发与异步模式
python·设计模式·编程语言
数据智能老司机5 小时前
精通 Python 设计模式——测试模式
python·设计模式·架构
数据智能老司机5 小时前
精通 Python 设计模式——性能模式
python·设计模式·架构
c8i6 小时前
drf初步梳理
python·django
每日AI新事件6 小时前
python的异步函数
python
这里有鱼汤7 小时前
miniQMT下载历史行情数据太慢怎么办?一招提速10倍!
前端·python
databook16 小时前
Manim实现脉冲闪烁特效
后端·python·动效
程序设计实验室16 小时前
2025年了,在 Django 之外,Python Web 框架还能怎么选?
python
倔强青铜三18 小时前
苦练Python第46天:文件写入与上下文管理器
人工智能·python·面试