Day25-Linux网络TCP协议及OSI七层模型原理2

TCP/IP

TCP(Transmission Control Protocol 传输控制协议)是一种面向连接的 可靠的、基于字节流的传输层通信协议

UDP是User Datagram Protocol的简称, 中文名是用户数据报协议,是一种无连接的传输层协议

TCP 传输控制协议  面向连接的协议(同步传输)  可靠传输协议   传输效率低  na

UDP用户报文协议  无连接协议    (异步传输)  不可靠传输协议 传输效率高

系统中:

异步传输数据: 类似离线传输  不需要进行确认 

    优点: 传输效率较高

缺点: 安全性不高

同步传输数据: 类似在线传输  需要进行确认

    优点: 安全性高

缺点: 传输效率较低

1.TCP协议中重要原理

1) TCP三次握手过程-- 完成网络连接建立

   TCP报文结构:

   a 源端口地址    返回数据包目标端口地址 

   b 目标端口地址  要和服务端哪个网络服务建立连接

   端口的数值范围: 1-65535 是通过报文结构获知的

   根据报文结构 源端口和目标端口各占用16个bit

   公式: 2的n次方 n占用了多少比特

   占用了1bit

   端口范围: 0 1  2种   2的1次方=2 0-1       

   占用了2bit

   端口范围: 00(0) 01(1) 10(2) 11(3) 4种   2的2次方=4 0-3

   占用了3bit

   端口范围: 000(0) 001(1) 010(2) 011(3) 100(4) 101(5) 110(6) 111(7)  8种 2的3次方=8 0-7

   占用了16bit

   端口范围: 2的16次方=65536  0-65535 --- 1-65535

   PS: 一般0号端口不被使用

   c Sequence Number(序列号)

   d Acknowledgement Number(确认号)

   特殊6bit作为报文结构中的控制位:

   syn(连接)   --- 请求建立连接控制字段

   ack(确认)   --- 表示确认控制字段

   fin(断开)   --- 请求断开连接控制字段

   说明: 控制字段数值置为1表示控制功能开启 默认为0

   三次握手详细过程:

   第一次握手: 发送TCP数据报文 客户端 -- 服务端

               a TCP数据报文中,需要将syn控制字段改为1

               b TCP数据报文中,需要将seq序列号信息发出 seq=x

   第二次握手: 发送TCP数据报文 服务端 -- 客户端

               a TCP数据报文中,需要将ack控制字段改为1

               b TCP数据报文中,同时将syn控制字段改为1

               c TCP数据报文中,同时将ack确认号信息发出 ack=x+1

               d TCP数据报文中,同时将seq序列号信息发出 seq=y

   第三次握手: 发送TCP数据报文 客户端 -- 服务端

               a TCP数据报文中,需要将ack控制字段改为1

               b TCP数据报文中,同时将ack确认号信息发出 ack=y+1

               c TCP数据报文中,同时将seq序列号信息发出 seq=x+1

2.TCP四次挥手过程 -- 完成网络连接断开

   第一次挥手: 发送TCP数据报文 客户端 -- 服务端

               a TCP数据报文中, 需要将fin控制字段改为1

               b TCP数据报文中, 同时将ack控制字段改为1

                    也包含seq和ack确认号信息

   第二次挥手: 发送TCP数据报文 服务端 -- 客户端

                 a TCP数据报文中, 需要将ack控制字段改为1

   第三次挥手: 发送TCP数据报文 服务端 -- 客户端

                   a TCP数据报文中, 需要将ack控制字段改为1  

                   b TCP数据报文中, 同时将fin控制字段改为1

   第四次挥手: 发送TCP数据报文 客户端 -- 服务端

                   a TCP数据报文中, 需要将ack控制字段改为1

扩展: 如何抓取网络数据包(抓包软件) 

windows: Wireshark

linux: tcpdump命令

3. TCP 11种状态集转换(了解 -- 架构层面)

    1) 以后可以更好排查系统网络问题

  2) 以后学习网络编程会有帮助

TCP三次握手过程: 服务端和客户端状态变化(5种状态变化)

    第一历程: 初始状态信息

客户端状态为: closed

服务端状态为: closed

第二历程: 服务端开启相应服务

服务端状态为: closed -- LISTEN

第三历程: 发送建立连接请求(客户端) == 三次握手第一次

客户端发送syn信息

客户端状态为: closed -- syn_sent

第四历程: 接收建立连接请求(服务端) == 三次握手第二次

服务端接受syn信息, 发送确认以及请求建立连接信息(ack syn)

服务端状态为: LISTEN -- syn_rcvd

    第五历程: 发送最后确认信息(客户端) == 三次握手第三次

    客户端发送ack信息

    客户端状态为: syn_sent -- established

    第六历程: 接收最后确认信息(服务端)

    服务端接收ack信息

    服务端状态为: syn_rcvd -- established

    结论: 只有服务端和客户端都统一处于established连接建立状态, 才能正常传输数据信息

TCP四次挥手过程: 服务端和客户端状态变化(5种状态变化)

第一个历程: 初始状态信息

客户端状态为: established

服务端状态为: established

第二个历程: 发送断开连接请求(客户端) == 四次挥手第一次

客户端发送fin请求断开连接字段

客户端状态为: established -- fin_wait1

第三个历程: 接收断开连接请求(服务端) == 四次挥手第二次

服务端接受fin请求断开连接字段 发出确认信息(ack=1)

服务端状态为: established -- close_wait

第四个历程: 接收确认断开信息(客户端)

客户端接受服务端发出的确认信息(ack=1)

客户端状态为: fin_wait1 -- fin_wait2

第五个历程: 发送断开连接请求(服务端) == 四次挥手第三次

服务端发送fin请求断开连接字段 同时还会再次发送确认字段

服务端状态为: close_wait -- last_ack

第六个历程: 接收断开连接请求(客户端) 发送最后确认信息 == 四次挥手第四次

客户端接收断开连接请求 同时发送最后确认信息ack=1

客户端状态为: fin_wait2  -- time_wait (等时间 60s 90s 120s???)

第七个历程: 接收最后确认信息(服务端)

服务端状态为: last_ack  -- closed

第八个历程: 等待时间结束

客户端状态为: time_wait -- closed

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

推荐阅读更多精彩内容

  • 如果对网络工程基础不牢,建议通读《细说OSI七层协议模型及OSI参考模型中的数据封装过程?》 下面就是TCP/IP...
    zhoulujun阅读 3,215评论 1 10
  • 个人认为,Goodboy1881先生的TCP /IP 协议详解学习博客系列博客是一部非常精彩的学习笔记,这虽然只是...
    贰零壹柒_fc10阅读 5,051评论 0 8
  • 运输层协议概述 从通信和信息处理的角度看,运输层向它上面的应用层提供通信服务,它属于面向通信部分的最高层,同时也是...
    srtianxia阅读 2,387评论 0 2
  • 18.1 引言 TCP是一个面向连接的协议。无论哪一方向另一方发送数据之前,都必须先在双方之间建立一条连接。本章将...
    张芳涛阅读 3,342评论 0 13
  • 兔子小姐有两个姐姐,大姐姐嫁给了老虎先生,她觉得他们不会过的幸福;二姐姐嫁给了大熊先生,大熊先生对她非常好,每...
    北方南先生阅读 377评论 0 1