博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
http长连接和短连接以及连接的本职
阅读量:4975 次
发布时间:2019-06-12

本文共 1448 字,大约阅读时间需要 4 分钟。

 

本文主要讲了,http长连接本质是tcp的长连接。

连接的本质

建立连接这个词,是从早期的电话系统中来的,那个时候,“建立连接”就真的是把你的电话和对方电话在电路上连起来。所以这个名词就保留至今。

当然现在的电话网络,早就不需要为某个通信建立专门的电路连接了,单个通信链路支持多路通信复用。

从TCP角度来说,“连接”是个纯粹概念性的东西。从开发角度来看,假设我们的服务器要给隔壁老王(192.168.233.233)进行联络,基本大概的步骤是:

……

……

……

这个建立连接的详细内容可以阅读《TCP/IP详解 卷一》。

从上面的描写可以看出来,所谓网络连接,并不存在物理上的动作。

PS:这里并没有完整描述整个连接建立过程,比如DNS,ARP部分,有需要再写吧。不过建议题主若想详细了解,还是翻翻《TCP/IP详解 卷一》更好,一个回答真的说不完。

 原文请百度知乎,查看。

 

第二人阐述:

网络通信建立连接的本质:告知彼此的第一个发送字节的初始序列号,建立连接后对每一个发送的字节,都需要

以初始序列号为原点,进行编号,需要对方来确认,每一个字节编号都已经成功接收,此乃建立连接的本质。

 

以大家都耳熟能详的TCP来举例,但是先强调一点,TCP 有两个状态位比较特殊,

一个是SYN,

一个是FIN,
他们各占一个字节。
A(初始序列号为0)
--------TCP 连接--------
(初始序列号为0)B

双方初始序列号是由OS动态生成的,随机的值,

一般每个TCP session都会有不一样的初始序列号,占四个字节,为了便于描述,
假定通信双方的初始序列号都为0,A先发1000字节的数据给B,发送成功之后释放连接。

Step 1: A 发送TCP SYN 给B

Step 2: B 发送TCP SYN + ACK给A

Step 3: A发送ACK给B

完成建立连接,由于SYN占用一个字节,而ACK不占用字节,其实三次握手的本质是对SYN这个编号为0,占用一个字节的数据的双向确认,

此过程完成,彼此的真正数据的交换的编号为1,1。

Step 4: A 发送1000字节给B,第一个字节的编号为1,最后一个字节编号为1000

Step 5: B发送一个包含ACK的确认号1001,意思是1001这个编号前的数据已经成功接收,如果还有数据要发送,请使用编号1001。

A主动发起释放连接

Step 6: A发送包含FIN的单向释放连接,编号1001

Step 7: B确认此释放连接请求,ACK 1002

B发起单向释放连接

Step 8: B发送包含FIN的单向释放连接,编号1

Step 9: A确认此释放连接请求,ACK 2,意思是FIN已经成功接收,连接可以释放。

另外,TCP建立连接还会有MSS,Window Size,Scaling window ,SACK,SNACK,Security Authentication option等参数的协商,

但是这些参数只是为了提高传输效率、增加TCP连接的安全性,避免没有安全保护的TCP遭到第三方的伪造TCP Reset 攻击。

 

第三人阐述:

连接的本质就是通信各方用一种共同认可的机制进行数据传输。

分层结构的出现就是为了大家协商出共同认可的机制,提供指导思想。TCP/IP就是这种指导思想的一种实现。

 

本文内容摘抄自知乎。

 

转载于:https://www.cnblogs.com/Tpf386/p/6474587.html

你可能感兴趣的文章
软件建模——第9章 毕业论文管理系统—面向对象方法
查看>>
[SDOI2008]洞穴勘测
查看>>
Difference between Linearizability and Serializability
查看>>
IDEA使用操作文档
查看>>
UIView
查看>>
添加日期选择控件
查看>>
bzoj4765: 普通计算姬 (分块 && BIT)
查看>>
看完漫画秒懂区块链
查看>>
Oracle命令类别
查看>>
stc12c5a60s2驱动TEA5767收音机模块硬件调试总结
查看>>
vue中提示$index is not defined
查看>>
css选择器
查看>>
ASP.NET上传下载文件
查看>>
Galaxy Nexus 全屏显示-隐藏Navigation Bar
查看>>
Spring中使用Velocity模板
查看>>
上周热点回顾(8.18-8.24)
查看>>
Feature toggle
查看>>
day02
查看>>
gvim 配置Pydiction
查看>>
Linux安装指定mysql版本
查看>>