URL地址栏输入地址后,发生了什么?
1.DNS域名解析;
2.建立TCP连接;
3.发送HTTP请求;
4.服务器处理请求;
5.返回响应结果;
6.关闭TCP连接;
7.浏览器解析HTML;
8.浏览器布局渲染;
三次握手
首先,他三次握手是因为什么?
我客户端要给那个服务器报告我要和你建立连接,顺便把我自己的一个发送的能力发给服务器,让服务器知道。
服务器判断我是否可以给你创建链接,把我的一个接收的一个能力返回给客户端
只有三次握手,才能够保证就是双方的发送能力和接受能力都达到了一个就是我认为就是协商好的这么一个过程
但是协议没有100%可靠的,所以次已经够了。如果四次也不能保证是100%可靠的
第一次握手:客户端发送网络包,服务端收到了。这样服务端就能得出结论:客户端的发送能力、服务端的接收能力是正常的。
第二次握手:服务端发包,客户端收到了。这样客户端就能得出结论:服务端的接收、发送能力,客户端的接收、发送能力是正常的。不过此时服务器并不能确认客户端的接收能力是否正常。
第三次握手:客户端发包,服务端收到了。这样服务端就能得出结论:客户端的接收、发送能力正常,服务器自己的发送、接收能力也正常。
第一次
第一次握手:建立连接时,客户端发送syn包(seq=j)到服务器,并进入SYN_SENT状态,等待服务器确认;SYN:同步序列编号(Synchronize Sequence Numbers)。
第二次
第二次握手:服务器收到syn包,必须确认客户端的SYN(ack=j+1),同时自己也发送一个SYN包(seq=k),即SYN+ACK包,此时服务器进入SYN_RECV状态。
第三次
第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=k+1),此包发送完毕,客户端和服务器进入ESTABLISHED(TCP连接成功)状态,完成三次握手。
四次挥手
第1次挥手
由客户端向服务端发起,服务端收到信息后就能确定客户端已经停止发送数据。(我要走了)
第2次挥手
由服务端向客户端发起,客户端收到消息后就能确定服务端已经知道客户端不会再发送数据。(我知道了你要走了 ,这时候可能还有数据,可能还有话没讲完)
第3次挥手
由服务端向客户端发起,客户端收到消息后就能确定服务端已经停止发送数据。(我没有要发送的东西了,你可以不用等了)
第4次挥手
由客户端向服务端发起,服务端收到信息后就能确定客户端已经知道服务端不会再发送数据。(好的)
为什么不是3次挥手
在客服端第1次挥手时,服务端可能还在发送数据。
所以第2次挥手和第3次挥手不能合并
由于TCP连接是全双工的,因此每个方向都必须单独进行关闭。这原则是当一方完成它的数据发送任务后就