网络编程中常见问题以及解决思路

本文记录了一个P2P项目中使用MongoDB遇到的问题及解决过程,包括TCP通信故障排查和多线程中子线程EOF错误的解决方法。

最近在帮老师做一个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()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值