非阻塞模式下,虽然connect出错,但是getsockopt取得的错误却是0的问题
2017-06-24 21:52
381 查看
调试项目代码时,发现了一个奇怪问题,记录如下:
非阻塞模式下,connect发起建链,返回-1(这在非阻塞模式下是很正常的现象)。然后将该socket的写事件进行监听,在写事件触发后,getsockopt函数获取错误(SO_ERROR)时,没有检测到发生错误(第四个参数返回0),最后在write操作时,发生错误。
原因:因配置文件的问题,导致得到的对端IP地址为空字符串"":
但是,在connect返回-1时,没有检测错误码是否为EINPROGRESS:
调用getsockopt时,获取的错误码为0,认为没有错误。
再接下来的write操作时,write写入一个已经关闭的连接,导致触发SIGPIPE信号。
总结:
虽然非阻塞模式下的connect,一般情况下都是返回-1,但是却忘了检测errno是否为EINPROGRESS,就像这个问题,因为地址写错了,connect返回-1,但是此时的错误却是"Network is unreachable",这种情况下就不能再监听该socket上的写事件,并在回调函数中调用getsockopt了,因为getsockopt得不到错误码,只会返回0。
非阻塞模式下,connect发起建链,返回-1(这在非阻塞模式下是很正常的现象)。然后将该socket的写事件进行监听,在写事件触发后,getsockopt函数获取错误(SO_ERROR)时,没有检测到发生错误(第四个参数返回0),最后在write操作时,发生错误。
原因:因配置文件的问题,导致得到的对端IP地址为空字符串"":
struct sockaddr_in saddr; saddr.sin_addr.s_addr = inet_addr(""); saddr.sin_family = AF_INET; /* "default" family */ saddr.sin_port = htons(22);
但是,在connect返回-1时,没有检测错误码是否为EINPROGRESS:
if(connect(m_hSocket, pAddr, nAddrLen) == 0) { return true; } else { return false; }之后直接开始监听写事件。因为connect出错时,该socket套接字上的写连接已经关闭,所以写事件立即触发。
调用getsockopt时,获取的错误码为0,认为没有错误。
再接下来的write操作时,write写入一个已经关闭的连接,导致触发SIGPIPE信号。
总结:
虽然非阻塞模式下的connect,一般情况下都是返回-1,但是却忘了检测errno是否为EINPROGRESS,就像这个问题,因为地址写错了,connect返回-1,但是此时的错误却是"Network is unreachable",这种情况下就不能再监听该socket上的写事件,并在回调函数中调用getsockopt了,因为getsockopt得不到错误码,只会返回0。
相关文章推荐
- 附加数据库出错(错误5123)的解决办法(问题虽然解决了,但原因未找到,求指教!)
- 建立工程后刚开始编译出现了“error PRJ0003 : 生成 cmd.exe 时出错”这样的错误,虽然在debug中生成了.exe文件,但是无法执行,提示找不到mfc90ud.dll。
- silverlight地图出错问题A security exception occured while trying to connect to the REST endpoint.Make sure you have a cross...
- 已安全化的ActiveX控件卸载时出现"DllUnregisterServer函数出错,错误代码:0x80070002"问题解决
- 网站用utf-8编码,但是如果页面出错,则会出现乱码,必须在当前页面右键打开源文件,才能看到错误信息
- VirtualBox的Ubuntu中文件共享问题的解决:未处理的错误消息,获取文件"/media/sf_***"信息出错,协议错误
- svn unable to connect to a repository at url 执行上下文错误 不能访问SVN服务器问题
- fedora14下gedit出错:Failed to connect to the session manager 问题解决(su和su -两个命令的区别)
- "已成功与服务器建立连接,但是在登录前的握手期间发生错误"问题解决方案
- 怎样解决Myeclipse中运行jsp乱码问题,亲测有效(虽然是个小问题但是为了大家不被网络上的一些乱七八糟的回答坑)不是改什么windows-propories-...............
- 微信支付错误两个问题的解决:curl出错,错误码:60
- android编程铁定会碰到的问题 adb 出错 Failed to install Connection resused:connect
- 关于wince 使用占用空间大的内存变量问题(编译无错误但是无法运行的问题)
- Alert Log中“Fatal NI connect error 12170”错误问题
- 现在为了让程序兼容vista,我们需要给程序加上一个manifest文件,可是有时候vc6它就会弹出Resource Compiler Error RC2170 的错误,可能是vc6一个bug,我个人对vc6还是很喜欢的,不过经常会有编译死掉或出错的问题,
- 通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败。错误:“Connection refused: connect的问题
- ubuntu gedit出错:Failed to connect to the session manager的问题
- 当引用com类dll时,在VS2005下会出现,dll虽然更换了但是引用没有更换或找不到的错误
- 已安全化的ActiveX控件卸载时出现"DllUnregisterServer函数出错,错误代码:0x80070002"问题解决
- Tomcat安装出错问题及新建Servlet错误