python SimpleHTTPRequestHandler服务器退出后使套接字处于TIME_WAIT状态
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python SimpleHTTPRequestHandler服务器退出后使套接字处于TIME_WAIT状态,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1871字,纯文字阅读大概需要3分钟。
内容图文
我有一个简单的服务器编写,扩展了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看起来像这样(即使请求完成后):
sam@hersheezy:server$sudo netstat -na --program | grep 8001 tcp 0 0 0.0.0.0:8001 0.0.0.0:* LISTEN 23392/python tcp 0 0 127.0.0.1:8001 127.0.0.1:48659 TIME_WAIT -
然后,我使用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')
解决方法:
套接字选项SO_LINGER确实阻止套接字进入TIME_WAIT.但TIME_WAIT有一个原因:它应该保护您免受旧连接中的延迟数据包的影响.因此,TIME_WAIT的默认持续时间是网络往返的两倍.因此,在TIME_WAIT中找到一些较旧的连接是正常的.
提供一些上下文:在服务器端,使用侦听套接字,有SO_REUSEADDR套接字选项.它允许侦听套接字在TIME_WAIT结束之前成功进行绑定.对于服务器进程,总是应该侦听同一个端口(想想:端口80,443处的webserver),这是必须的.
服务器的典型python代码可能包含以下内容:
...
listener = socket(AF_INET, SOCK_STREAM)
listener.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
listener.bind((HOST, PORT))
listener.listen(32)
...
内容总结
以上是互联网集市为您收集整理的python SimpleHTTPRequestHandler服务器退出后使套接字处于TIME_WAIT状态全部内容,希望文章能够帮你解决python SimpleHTTPRequestHandler服务器退出后使套接字处于TIME_WAIT状态所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。