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 小时前
《Python生态事件溯源与CQRS轻量化落地指南》
大数据·python·微服务
这里是彪彪15 小时前
Java中的volatile关键字的作用
java·开发语言
王夏奇15 小时前
python在汽车电子行业中应用2—具体包的介绍和使用
网络·python·汽车
Dxy123931021615 小时前
Python的zip用法详解
开发语言·python
cnstartech15 小时前
esxi-vmware 虚拟机互相打开
linux·运维·服务器
逑之15 小时前
C语言笔记3:分支与循环
c语言·开发语言·笔记
不知疲倦的仄仄15 小时前
第四天:Netty 核心原理深度解析&EventLoop、Future/Promise 与 Pipeline
linux·服务器·网络
黎雁·泠崖15 小时前
Java入门从零起步:CMD操作+JDK环境搭建+第一个Java程序
java·开发语言
f***241115 小时前
MATLAB高效算法优化实战指南
开发语言·算法·matlab
橘颂TA15 小时前
【Linux 网络编程】网络是怎么 “跑” 起来的?从协议入门到 TCP/ IP 模型的底层逻辑
linux·运维·服务器·网络