免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: kaede_1
打印 上一主题 下一主题

[C++] socket 如何确认对端已经close [复制链接]

论坛徽章:
11
2015年迎新春徽章
日期:2015-03-04 09:55:282017金鸡报晓
日期:2017-02-08 10:39:4215-16赛季CBA联赛之辽宁
日期:2016-12-15 10:24:1715-16赛季CBA联赛之佛山
日期:2016-11-30 09:04:2015-16赛季CBA联赛之江苏
日期:2016-04-29 15:56:1215-16赛季CBA联赛之同曦
日期:2016-04-12 13:21:182016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之山东
日期:2016-02-16 11:37:52每日论坛发贴之星
日期:2016-02-07 06:20:00程序设计版块每日发帖之星
日期:2016-02-07 06:20:0015-16赛季CBA联赛之新疆
日期:2018-01-09 16:25:37
11 [报告]
发表于 2016-09-01 08:32 |只看该作者
没有,要普遍适用的话,还是的自己发送心跳
---以前一直困惑为什么很多服务器程序都那么写,的确在windows下没有必要.其他系统下面就很有必要了
经常有这样的情况,调用send成功了,可是对端就是没有收到,甚至对方已经关机了,本端看到端口还是正常的,send一次也是正常的....大坑

论坛徽章:
0
12 [报告]
发表于 2016-09-12 23:39 |只看该作者
要注意, TCP socket是全双工的. 发送和接收是可以独立的.
对端关闭发送端并不代表它不能接收数据, 因此你单靠write是无法检测到对端关闭了发送端的。
对端关闭发送端相当于告诉你,它要发送给你的数据都发送完了,没有更多的数据需要发送了。
对端关闭它的发送端时, 你这边的读取端就会收到 EOF(即 read返回0), 你就知道对端已经没有数据给你了, 你要根据实际情况来决定是否关闭发送端。

论坛徽章:
0
13 [报告]
发表于 2016-09-15 13:20 |只看该作者
有正常断开和非正常断开
正常断开,会收到singal
非正常断开,tcp keep-live或者应用层心跳

论坛徽章:
0
14 [报告]
发表于 2016-09-15 19:39 |只看该作者
其实可以站高一点,从业务逻辑的角度来看,我们的目的是完成信息交流,一般是发送一个消息出去,然后等待一个应答,

只要超时时间内等不到应答,就认为失败,按照失败的逻辑进行处理。

至于失败的原因,是对方关闭链接,还是对方断电了,还是这边发送失败了,还是甚至connect都没有成功,其实并不是那么重要。

当然,从查找原因的角度来说,程序最好还是要记录具体的原因,但这个真的对业务逻辑处理流程不产生影响

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
15 [报告]
发表于 2017-01-16 12:05 |只看该作者
evaspring 发表于 2016-08-19 17:16
看了好几个网络库 都是通过 read() == 0 来判定连接断开的

这个不一定表示链接断开。我经常在没断开的sock中发现read()==0;

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
16 [报告]
发表于 2017-01-16 12:07 |只看该作者
本帖最后由 yulihua49 于 2017-01-16 12:25 编辑
kaede_1 发表于 2016-08-19 15:10
最近纠结于两个小问题,哪位大牛帮忙解答一下,不胜感激
1.客户端给服务端发送消息,一端时间后服务端执行 ...

你的逻辑是错误的。
1.服务器收完不需要关闭socket。何时关闭应该是事先约定的。
2.客户端无需事先知道服务器是否关闭,等通信出错后进行错误处理即可。
3.发送信息大多数不知道是否成功,你需要一个确认的流程,包含一个超时处理逻辑。
第3条,我在讲解交易中间件时的确说过发送成功与否无需确认,只要交易完成时回覆。客户端只需验证交易完成确认信息即可。超过一定时限没有回覆即认为交易失败。
即,服务器收完信息,处理完成并回覆之前是不能关闭socket的。
客户端在发送第一个消息之后,没有得到回覆之前是不能发送第二个消息的。

客户端发送信息后,就要接收回覆,网络故障是在接收时发现的。
以上是半双工的。全双工的服务器就更不应该随便关闭socket了,应该继续接收客户端请求,直到双方约定的关闭条件。

论坛徽章:
2
综合交流区版块每日发帖之星
日期:2016-07-06 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:00
17 [报告]
发表于 2017-01-16 12:07 |只看该作者
各位大牛,我指的是发送,而不是读取
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP