在客戶端與服務(wù)器的交互過程中,特別是多個客戶端需要與服務(wù)器同步時,例如游戲同屏,要保證客戶端A到客戶端B的消息成功發(fā)送。但是由于網(wǎng)絡(luò)的復(fù)雜情況,可能會出現(xiàn)以下情況:
1)服務(wù)器崩潰,msg:N包未發(fā)出
2)網(wǎng)絡(luò)抖動,msg:N包被網(wǎng)絡(luò)設(shè)備丟棄
一般情況下,當A向服務(wù)器發(fā)送一個信息之后,只能說明A發(fā)送成功了,但是不能保證服務(wù)器一定接收到了數(shù)據(jù)。在某些情況下,可能會出現(xiàn)上述丟包的原因。如何保證消息不丟失呢?
可以采取以下方法:
1,消息確認當A向服務(wù)器發(fā)送一條消息后,等待服務(wù)器返回處理請求成功的確認,即Ack
2,服務(wù)器接收A發(fā)送的消息后,要發(fā)送給B。
3,B,接收到消息到給服務(wù)器發(fā)送一個確認的Ack.
但是使用這種方法也可能會有問題,比如發(fā)送端可能因為上述原因接收不到Ack的確認消息,那該如何保證消息不丟失呢?這就需要借助于超時和重傳機制了。
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動安全 [無線安全]玩轉(zhuǎn)無線電——不安全的藍牙鎖 2017-07-26
- 消息隊列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標分割】 2017-07-26
- 詞向量-LRWE模型-更好地識別反義詞同義詞 2017-07-26
- 從棧不平衡問題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來看看(二) 2017-07-26