- 論壇徽章:
- 0
|
今天測試網(wǎng)絡的發(fā)送超時,寫的簡單程序,卻出現(xiàn)異常行為,不解中
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) , 在執(zhí)行client,奇怪的是client還可以連上server,并且可以繼續(xù)發(fā)送數(shù)據(jù)!!但是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
這后一個連接是怎樣連上的? |
|