最近在帮老师做一个P2P的项目,客户端包含注册以及登陆功能,关于数据库的选择,尝鲜采用了最新的mongoDB,但是在运行简单的demo的时候依然出现了许多的问题。文章会逐渐跟新,在我有时间的前提下:
关于RST ACK
本地测试正常,部署到服务器发现TCP通信出现故障,本机操作系统win10,服务器内核版本如下图所示:
在windows powershell运行程序发现出现socket.send()方法的错误,凡是网络问题就少不了抓包分析了~,本机采用wireshark进行抓包如下所示:
这里可以看到本机发送SYN(请问你有空么?)立马收到了服务器的回绝RST(没有!)。服务器上采用TCPDUMP指令进行抓包的时候也发现了问题的所在,能收到WINDOWS发来的SYN包,但是立马进行了不暇思索的回绝。
我们常见发送RST的情况有以下几种:
1、服务器端口没有打开
2、超时
3、缓存区中有内容未读取完全
这里的问题很容易定位,因为包中并未包含时间异常信息,直接在Windows10 上telnet检测端口通不通就好,(然后发现不通。
SYN(有空吗?)——>ACK,SYN(有空啊,你呢?)——>SYN(我也有空~)
最近还有一个很坑的地方就是多线程了~多线程中1、锁与2、阻塞 都是十分重要的概念,对应于python的join()方法以及lock()锁机制。最近一个常见的EOF报错就是因为主线程线性退出,留下子线程在独自运行,获取不到读入数据。这里可以采用join()方法,将子线程加入其中:
def Send(sock):
while True:
data = raw_input('>')
sock.send(data)
if data =='exit':
print '连接结束'
break
sock.close()
def Recv(sock):
while True:
data = sock.recv(BUFFSIZE)
if data == 'exit':
break
print data
sock.close()
def main():
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.connect(ADDR)
ts=Thread(target=Recv,args=(s,))
ts.start()
tr=Thread(target=Send,args=(s,))
tr.start()
tr.join()
if __name__=```
"__main__":
main()