我编写了一个简单的服务器,它扩展了SimpleHTTPRequestHandler
如果我在不向服务器发出任何请求的情况下启动和停止它,我就可以在同一个端口上重新启动。在
启动时,netstat如下所示:
sam@hersheezy:server$ sudo netstat -na --program | grep 8001 tcp 0 0 0.0.0.0:8001 0.0.0.0:* LISTEN 23392/python
发出请求后,netstat看起来像这样(即使在请求完成之后):
^{pr2}$然后,我使用C-C终止服务器,netstat如下所示(此时我无法重新启动服务器,因为端口已在使用中):
sudo netstat -na --program | grep 8001 tcp 0 0 127.0.0.1:8001 127.0.0.1:48674 TIME_WAIT -
我显然没有正确地关闭某些东西。发送回复的代码如下所示:
"""
reply is an object that can be json encoded that is written with a response code 200
"""
def send_provider_reply(self, replyobj):
try:
str_reply = json.dumps(replyobj)
self.send_response(200)
self.send_header('Content-type', 'application/json')
self.end_headers()
#do we need to send a newline??
self.wfile.write(str_reply)
except:
traceback.print_exc()
self.send_err(500, 'failed after provider creation')
socket选项SO\u LINGER会阻止套接字进入TIME_WAIT。但是TIME_WAIT的存在是有原因的:它应该保护您不受旧连接的延迟包的影响。因此,默认的等待时间是网络往返时间的两倍。所以,在时间上找到一些老的连接是正常的。在
提供一些上下文:在服务器端,对于侦听套接字,有SO\u REUSEADDR socket选项。它允许侦听套接字在TIME-WAIT结束之前在bind成功。对于服务器进程,它总是应该监听同一个端口(想想:webserver在端口80443),这是必须的。在
服务器的典型python代码可能包含以下内容:
相关问题 更多 >
编程相关推荐