python socket server重启后,端口被占用的解决方法

在solaris 系统下, socket  server被重启后,提示端口被占用,telnet端口又是不成功的,说明服务被关闭成功了,通过netstat可以看到端口还处于于fin_wait_2状态,solaris要4分钟才能关闭,等不及,有2种解决方案。
1. 加上s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1),如下代码

        self.host=socket.gethostbyname(socket.gethostname())
        s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
        s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
        s.bind((self.host,self.port))
        s.listen(5)
2. 修改系统fin_wait,time_wait的时间设置。这个时间改短,也利于系统系能。
修改方法


如何查看或设置: 
使用get命令来确定当前时间间隔,并使用set命令将时间间隔指定为30秒。 
例如: 
ndd -get /dev/tcp tcp_time_wait_interval     
ndd -set /dev/tcp tcp_time_wait_interval 30000  
缺省值:对于 Solaris 操作系统,缺省等待时间间隔为 240000 毫秒(即 4 分钟)。 
建议值:60000 毫秒。 


Solaris TCP_FIN_WAIT_2_FLUSH_INTERVAL 
描述: 
指定禁止处于FIN_WAIT_2状态的连接保持该状态的计时器时间间隔。当连接比率较高时,这将累积大量的TCP/IP连接,从而导致服务器性能下降。在高峰时间段,服务器会发 

生延迟。如果服务器延迟,netstat命令显示对HTTP Server打开的许多套接字处于CLOSE_WAIT或FIN_WAIT_2状态。明显的延迟可能会长达4分钟,其间服务器无法发送任何响应 

,但是CPU利用率保持很高,所有活动都在系统进程中。 

如何查看和设置: 
使用get命令来确定当前时间间隔,并使用set命令将时间间隔指定为67.5秒。 
例如: 
ndd -get /dev/tcp tcp_fin_wait_2_flush_interval 
ndd -set /dev/tcp tcp_fin_wait_2_flush_interval 67500 
缺省值:675000 毫秒 
建议值:67500 毫秒 


Solaris TCP_KEEPALIVE_INTERVAL 
描述: 
“保持活动”包确保连接保持活动和已建立状态。 

如何查看或设置: 
使用ndd命令来确定当前值或设置该值。 
例如: 
ndd -set /dev/tcp tcp_keepalive_interval 300000 
缺省值:7200000 毫秒 
建议值:15000 毫秒 
### 如何使用 Python 编写 Socket 服务端 编写一个简单的 Python 基于 Socket 的服务端涉及几个关键步骤。下面是一个基础的例子,展示了如何创建、绑定、监听以及接收来自客户端的信息。 #### 创建套接字 为了初始化通信接口,需要先创建一个新的套接字对象。这可以通过调用 `socket()` 函数完成,并指明所使用的协议族(如 AF_INET 表示 IPv4),还有数据传输方式(SOCK_STREAM 对应 TCP 流式套接字)[^2]。 ```python import socket def tcpServer(): host = '192.168.1.4' port = 6000 server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) ``` #### 绑定地址和端口号 一旦有了套接字实例,下一步就是将其与特定的 IP 地址及端口关联起来以便其他设备能够找到该服务端。这里使用了本地局域网内的私有 IP 和任意选定的一个未被占用端口作为参数传递给 bind 方法。 ```python server_socket.bind((host, port)) ``` #### 开始监听请求 设置好之后就可以让服务器处于监听模式准备接受外部连接了。listen 方法中的参数表示允许的最大排队数目;当超过这个数量时新来的连接会被拒绝直到队列中有位置腾出来为止。 ```python server_socket.listen(5) print(f'Server listening on {host}:{port}') ``` #### 接受并处理客户机连接 最后一步是从 accept 获得已建立好的连接描述符,通过循环不断读取对方发过来的数据直至遇到终止条件。对于每一个成功的连接都会开启一个新的线程或子进程去单独负责交流从而不影响主线程继续等待更多客户的接入。 ```python while True: conn, addr = server_socket.accept() with conn: print('Connected by', addr) while True: data = conn.recv(1024).decode('utf-8') if not data or data.lower() == 'quit': break print(f"Received from client: {data}") response = f"ECHO: {data}" conn.sendall(response.encode('utf-8')) if __name__ == '__main__': try: tcpServer() except Exception as e: print(e) # 如果发生异常,则关闭服务器socket 并尝试重启 server_socket.close() raise SystemExit ``` 上述代码片段展示了一个完整的 Python 实现的简单 TCP Server 模型,其中包含了必要的错误处理逻辑以确保即使出现问题也能安全退出而不至于留下僵尸进程或者泄露资源[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值