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

相关推荐
u0109147606 小时前
CSS组件库如何快速扩展_通过Sass @extend继承基础布局
jvm·数据库·python
baidu_340998826 小时前
Golang怎么用go-noescape优化性能_Golang如何使用编译器指令控制逃逸分析行为【进阶】
jvm·数据库·python
m0_678485456 小时前
如何利用虚拟 DOM 实现无痕刷新?基于 VNode 对比的状态保持技巧
jvm·数据库·python
不吃香菜学java6 小时前
Redis的java客户端
java·开发语言·spring boot·redis·缓存
qq_342295827 小时前
CSS如何实现透明背景效果_通过RGBA色彩模式控制透明度
jvm·数据库·python
TechWayfarer7 小时前
知乎/微博的IP属地显示为什么偶尔错误?用IP归属地查询平台自检工具3步验证
网络·python·网络协议·tcp/ip·网络安全
Greyson17 小时前
CSS如何处理超长文本换行问题_结合word-wrap属性
jvm·数据库·python
justjinji7 小时前
如何批量更新SQL数据表_使用UPDATE JOIN语法提升效率
jvm·数据库·python
小江的记录本7 小时前
【网络安全】《网络安全常见攻击与防御》(附:《六大攻击核心特性横向对比表》)
java·网络·人工智能·后端·python·安全·web安全
贵沫末7 小时前
python——打包自己的库并安装
开发语言·windows·python