免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1527 | 回复: 1
打印 上一主题 下一主题

奇怪的网络问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-11-25 21:58 |只看该作者 |倒序浏览
今天测试网络的发送超时,写的简单程序,却出现异常行为,不解中

server.py

server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_socket.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1)
server_socket.bind(("", 1234))
server_socket.listen(5)

print "begin accept"
client_socket,address = server_socket.accept()
client_socket.setsockopt(socket.SOL_SOCKET,socket.SO_RCVBUF,0)
print "accept finish"
ret = client_socket.recv(4096)
print ret
time.sleep(10000000)
print "ret",ret

client.py:

import socket
import time

client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client_socket.connect(("localhost",1234))

print client_socket

print "send data"
client_socket.setsockopt(socket.SOL_SOCKET,socket.SO_SNDBUF,1)

total = 0
while 1:
    ret = client_socket.send("hello,world")
    total += ret
    print "send %d" % total

time.sleep(100)

我先启动server,然后启动client,一切正常。然后我关闭client(ctrl + c) , 在执行client,奇怪的是client还可以连上server,并且可以继续发送数据!!!但是server只做了一次accept,这后一次是怎样连上的啊?
通过netstat观察,确实是有个新的连接
tcp        0      0 localhost.localdomain:57341 localhost.localdomain:1234  FIN_WAIT2   
tcp        0     12 localhost.localdomain:57340 localhost.localdomain:1234  FIN_WAIT1  

这后一个连接是怎样连上的啊?

论坛徽章:
0
2 [报告]
发表于 2008-11-26 10:20 |只看该作者
你加上server_socket.close()再试试
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP