如题,服务器发送消息后,如何知道客户端成功接收到了消息?有什么机制吗?
|  |      1scriptB0y      2018-02-28 11:03:57 +08:00 via iPhone websocket 是在 tcp 上面的,我觉得可以放心认为发出去的消息一定会被客户端收到吧。 我记得 wensocket 一端发给另一端发不过去会报错的 | 
|  |      2BBCCBB      2018-02-28 11:06:54 +08:00 加一个确认机制,客户端处理完成之后发送一个确认消息. | 
|  |      3yonglanyouyou      2018-02-28 11:28:23 +08:00 应用层加 ack | 
|  |      4ghiei9101      2018-02-28 12:12:55 +08:00 有种机制  叫回执 | 
|  |      5pathbox      2018-02-28 12:15:49 +08:00 via iPhone 同楼上,如果你想自己控制,在应用层知道,可以自己加 ack 机制,但这个机制不要太复杂 | 
|  |      6skadi      2018-02-28 12:19:37 +08:00 server -> msg+Hash -> client 然后 client->Hash->server 跟楼上的 ack,回执 什么的都是一个意思. | 
|  |      7ioth      2018-02-28 12:22:22 +08:00 websocket 协议,只是保证阻塞的解决,其它在上一层解决。 封包、tcp/udp | 
|  |      8reid2017 OP 多谢各位,看来只能自己去实现 ack 了 | 
|      9phy25      2018-02-28 15:08:09 +08:00 via Android https://stackoverflow.com/questions/23238319/websockets-ping-pong-why-not-tcp-keepalive 以及相关问题,结论是应用层做连接检查比较好。 学到一点:不能只依靠 TCP 的特性来判断服务器到客户端的连接。因为有经过代理的情况,而且可能得等到客户端默认的 TCP 超时时间(比较长)才能检测到连接丢失。 |