[081]由TCP/IP协议想到的思想

TCP/IP协议场景

说道TCP/IP协议想起了计算机网络书中举了一个红蓝军的通讯的问题。其场景如下:

红蓝军需要联手干掉山坡下敌人,双方约定某个时间一起进攻。

红军 <-------------> 蓝军

   -----A:下午5点进攻-->
   <---A+ack:收到消息---
   -----A+ack+ack:----

由于任何一次通信都可能中断,通讯次数越多概率越大。于是在通讯可靠性和时间上做了一个折中,根据理论计算至少需要3次握手概率才达到比较满意的水平。

TCP协议本质上解决是不可靠信道上需要可靠传输信息的需求

如果信道是可靠的那么,那么不需要建立连接直接发送数据包也能够确保到达。但是实际网络中信道是不可靠的,需要通过3次握手来确定一条比较可靠的信道。

所以TCP连接建立后,都是沿同一条链路发送消息么?

连接释放为什么需要4次握手

通过4次握手的目的是确保通信双方都释放了连接,这样都不在发送数据包(防止网络上有大量的无用数据包,会增加网络的拥塞)。

TCP 序列号和确认号详解

TCP 通讯涉及到 客户端 client 和服务端 server,我们根据建立连接、发送数据、释放连接 3个阶段来描述序列号和确认号生成过程。

连接建立阶段大体上是,确认号=对方的序列号+1,序列号(除了第一次)=对方的确认号
客户端 服务端
序列号J | 确认号0 |置SYN标识 ---->
<---- 序列号k | 确认号J+1 | 置SYN和ACK标识
序列号J+1| 确认号 k+1 | 置ACK标识 ---->

数据传输阶段大体上是,确认号=对方序列号 + 数据报文长度,序列号= 对方确认号

TCP 协议的状态迁移

TCP建立连接一般是服务器启动服务进行监听,处理客户端发过来的请求。
其状态流转是:
client:close -> SYN-SEND -> ESTABLISH
server: close -> LISTEN -> SYN-RECV -> ESTABLISH

连接释放,我们以客户端主动断开连接为例。
客户端 服务端
发送报文 FIN_WAIT1 --> 此时服务器 CLOSE_WAIT(被动关闭)
FIN_WAIT2 <-- 服务器 ACK到客户端
TIME_WAIT (接收到最后确认后,客户端进入TIME——WAIT) <--- 再一次确认 LASTACK
当客户端等待2MSL后 发送ack 到服务端 --> close状态了

实际连接释放可以分为两个阶段,第一阶段:半连接 ,第二阶段:服务端也释放。
第一阶段:
客户端 发送fin报文 ---> 服务端
FIN_WAIT2 <---- ACK 报文
FIN_WAIT2 状态就是半连接的状态,表示客户端已经断开连接,服务端还有一些数据要发送。

第二阶段:
过了一段时间,服务端没有数据要发送了。
此时:
TIME_WAIT <--- 服务端发送FIN 报文 进入LAST_ACk状态 (服务端在发送了FIN后等待 MSL如果没有收到ACK则会重传FIN消息)
客户端发送 ACK ---> 服务端
客户端发出ACK后,等待ACK到达对方的超时时间MSL,等待FIN重传时间也是MSL,所以如果客户端2MSL时间段内没有收到FIN报文表示 服务端已经收到了ACK报文(已经关闭了)。

用概率来衡量不确定的东西

从“背景”那里分析,握手次数越多越好概率越高。但是实际情况下是可靠性和时效性之间的折中。而对于这些不确定的事情,我们最好的思路是以概率的方式来思考(而不是强迫症似的想100%)。

同样在微服务框架中,通过两台机器提供负载均衡。这样系统可用性为 p = 1-p1*p1,p1为系统宕机的概率。

思想的运用

TCP/IP 会有超时重传的机制,每发一段报文的时候会设置一个超时时间,如果超时会重发报文。

在我们的支付系统中,系统与系统之间的交互也是类似的思想。拿下单来举例:
网关 client .................... server 银行(比如支付宝)
ewallet 下单 ---> 发报文到银行
<--- 同步返回/或者异步通知 (ack) ,如果client timeout内没有接收到ack报文,则通过定时任务扫描网关中非success 的订单,调用查询接口(查询状态)。
---> response.write("success") (ack+ack) ,同样,如果server没有收到ack+ack 报文,则会重传 ack报文(即重新异步通知)。

参考:

http://www.cnblogs.com/chenboo/archive/2011/12/19/2293327.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,264评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,549评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,389评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,616评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,461评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,351评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,776评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,414评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,722评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,760评论 2 314
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,537评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,381评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,787评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,030评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,304评论 1 252
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,734评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,943评论 2 336

推荐阅读更多精彩内容