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 是连接请求队列的最大长度,决定了在服务器处理当前连接时,可以有多少其他连接请求被挂起等待处理。

相关推荐
再睡一夏就好15 分钟前
深入Linux线程:从轻量级进程到双TCB架构
linux·运维·服务器·c++·学习·架构·线程
wyzqhhhh17 分钟前
京东啊啊啊啊啊
开发语言·前端·javascript
JIngJaneIL17 分钟前
基于java+ vue助农电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
雷中听风20 分钟前
使用字节的源安装rust
开发语言·后端·rust
云和数据.ChenGuang27 分钟前
OpenEuler系统下RabbitMQ安装与基础配置教程
服务器·分布式·rabbitmq·ruby·数据库运维工程师·运维教程
学习者00729 分钟前
python 下载离线库方法
python
工控小楠30 分钟前
EtherNET IP转Profinet协议网关在智能仓储系统中的应用
服务器·网络·tcp/ip
声声codeGrandMaster34 分钟前
AI之模型提升
人工智能·pytorch·python·算法·ai
魔镜前的帅比1 小时前
多 Agent 架构:Coordinator + Worker 模式
python·ai
特立独行的猫a1 小时前
C++开发中的Pimpl机制与类声明机制深度解析:现代C++的编译解耦艺术
开发语言·c++·pimpl