免费注册 查看新帖 |

Chinaunix

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

[C++] 求助: linux服务器socket read或write 出现errno=5的错误 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-04-07 19:38 |只看该作者 |倒序浏览
如题,c写的一个socket网关服务器和内网的一个逻辑服进行通讯。系统版本是centos6.5 x64
观察下来如果经常性的有客户端和网关交互(网关把客户端消息转给内网服务器,或是内网服通过网关发送消息给客户端),无论
消息量的大小,网关服和内网服的socket连接在read或是write时 经常性会出现 errno=5的错误,观察下来基本2~3天就会出现一次。请问下这个错误码表示什么意思?大概是什么原因引起的

因为观察到如果几天没有任何客户端消息的情况下网关基本不会出现这个错误的。
感觉上应该和代码逻辑有点关系。
在论坛里搜到个类似的问题,有人回答可能是因为网卡等设备引起的。

求教大神!万分感谢!

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
2 [报告]
发表于 2016-04-07 20:37 |只看该作者
回复 1# xiaowulai

打开/usr/include/sys/errno.h,看看5号是个什么错误。

论坛徽章:
0
3 [报告]
发表于 2016-04-08 10:05 |只看该作者
谢谢回复!
恩这个错误是 Input/output error.  EIO错误。
比较奇怪的是 同样的版本(代码一样)在 centos 5.8 32位系统上重编运行就没有出现过这个错误。
昨天晚上在有问题的机器上做了下echo的测试,客户端每条发200+字节数据,服务器收到后回包。
上了400个连接,基本几分钟就出现一次,感觉像是这个socket到达了某个流量阈值后被断开。
用来测试的两个机器都是阿里云的服务器,只是所属的位置和版本不一样。

有人说是 网卡设备异常,驱动异常或是硬件出错 可能会引起这个错误。
难道我要换个机器或是换个版本?

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
4 [报告]
发表于 2016-04-08 10:48 |只看该作者
回复 3# xiaowulai

阿里云有带宽限制的,估计你玩的太狠了

另外先把那个屌毛云盾干掉,要不然鬼知道会发生什么。

论坛徽章:
0
5 [报告]
发表于 2016-04-08 12:50 |只看该作者
谢谢!
这个带宽也不是很多吧。如果 一个机器上的两个进程A ,B。 A connect 127.0.0.1 到 B 然后疯狂发消息,也会算带宽限制?
现在看到的每次都是断A,B之间的连接。。
我在另一台阿里云的ubuntu14.04 x64上测试 , 出现频率更高。
我试试看你说的云盾关掉。

论坛徽章:
0
6 [报告]
发表于 2016-04-12 12:50 |只看该作者
这是我最近测试下来的结果:实际测试在centos 5.8  6.5 和 unbutn 14.04上都会出现。
上面说的在 centos5.8 没有出现是因为那个版本在 send recv  后没有调用到printf。
测试版本因为要确认消息的收发,所以特意加上了log输出。

最终测试发现
只要在 send  recv 后面加上printf ,并且程序这样启动  ./xxxx &  ,那么必然会出现 errno=5的错误;
如果不加 printf,或是 printf改为写文件,或是 程序 nohup ./xxxx & 启动,那么就不会出现errno=5的错误;

哪个大神可以帮忙分析下原因吗?

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
7 [报告]
发表于 2016-04-12 14:32 |只看该作者
回复 6# xiaowulai

你不是已经将错误原因写明了吗, & 进后台了, 自然不允许写标准输出, 出现 EIO 有什么奇怪的


   

论坛徽章:
0
8 [报告]
发表于 2016-04-13 12:58 |只看该作者
但是eio这个错误是在 两个服务器进程连接的socket上捕获的。这个也是正常的吗?

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
9 [报告]
发表于 2016-04-13 20:20 |只看该作者
本帖最后由 zylthinking 于 2016-04-13 20:21 编辑

回复 8# xiaowulai

你说加上了 printf 才出现, 必然不是在 socket 上捕获的, 何况 errno 是线程全局的, 什么叫在 socket 上捕获的, 我才不信你的话
   

论坛徽章:
0
10 [报告]
发表于 2016-04-14 09:12 |只看该作者
但是确实是在recv失败了,然后输出的errno。上面忘了说明了  ./xxx  & 启动后 , 我是exit退出的。
最下面的LOG_ERROR会输出  CIoSocketEx::_DoHandleRead client[0,8] recv error[5:Input/output error]
程序是单线程的,按理这个errno应该就是这个socket产生的。

s32 recvLen = recv( m_socket, data, len, 0 );
printf("HandleRead\n";
if( recvLen==-1 && (errno==EAGAIN || errno==EWOULDBLOCK) )
{
    // ...
}
else if( recvLen == 0 )
{
}
else if( recvLen > 0 )
{
    // do something
}
else
{
     LOG_ERROR( "CIoSocketEx::_DoHandleRead client[%d,%d] recv error[%d:%s]", GetId(), m_socket, errno, strerror(errno) );
}

我换个姿势在试试看
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP