title: 计算机网络
date: 2021/5/6
1. TCP三次握手和四次挥手
1.1 TCP三次握手(连接)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dZsw9Vak-1658935905944)(C:\Users\ZZR\AppData\Roaming\Typora\typora-user-images\image-20210905224024162.png)]
- 客户端–发送带有 SYN 标志的数据包–一次握手–服务端
- 服务端–发送带有 SYN/ACK 标志的数据包–二次握手–客户端
- 客户端–发送带有带有 ACK 标志的数据包–三次握手–服务端
1.2 为什么要三次握手
三次握手的目的是建立可靠的通信信道,说到通讯,简单来说就是数据的发送与接收,而三次握手最主要的目的就是双方确认自己与对方的发送与接收是正常的。
第一次握手:Client 什么都不能确认;Server 确认了对方发送正常
第二次握手:Client 确认了:自己发送、接收正常,对方发送、接收正常;Server 确认了:自己接收正常,对方发送正常
第三次握手:Client 确认了:自己发送、接收正常,对方发送、接收正常;Server 确认了:自己发送、接收正常,对方发送接收正常
所以三次握手就能确认双发收发功能都正常,缺一不可。
1.3 为什么要传回SYN
接收端传回发送端所发送的 SYN 是为了告诉发送端,我接收到的信息确实就是你所发送的信号了。
1.4 传了 SYN,为啥还要传 ACK
双方通信无误必须是两者互相发送信息都无误。传了 SYN,证明发送方到接收方的通道没有问题,但是接收方到发送方的通道还需要 ACK 信号来进行验证。
1.5 TCP四次挥手(断开)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tM83oIZV-1658935905946)(C:\Users\ZZR\AppData\Roaming\Typora\typora-user-images\image-20210905224759479.png)]
- 客户端-发送一个 FIN,用来关闭客户端到服务器的数据传送
- 服务器-收到这个 FIN,它发回一 个 ACK,确认序号为收到的序号加1 。和 SYN 一样,一个 FIN 将占用一个序号
- 服务器-关闭与客户端的连接,发送一个FIN给客户端
- 客户端-发回 ACK 报文确认,并将确认序号设置为收到序号加1
1.6 为什么要四次挥手
任何一方都可以在数据传送结束后发出连接释放的通知,待对方确认后进入半关闭状态。当另一方也没有数据再发送的时候,则发出连接释放通知,对方确认后就完全关闭了TCP连接。
2. 在浏览器中输入url地址->>显示主页的过程
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Ot7EM4DU-1658935905946)(C:\Users\ZZR\AppData\Roaming\Typora\typora-user-images\image-20210905224944390.png)]
- DNS解析
- TCP连接
- 发送HTTP请求
- 服务器处理请求并返回HTTP报文
- 浏览器解析渲染页面
- 连接结束
3. HTTP和HTTPS的区别
安全性上,HTTPS是安全超文本协议,在HTTP基础上有更强的安全性。简单来说,HTTPS是使用TLS/SSL加密的HTTP协议
申请证书上,HTTPS需要使用ca申请证书
传输协议上, HTTP是超文本传输协议,明文传输;HTTPS是具有安全性的 SSL 加密传输协议
连接方式与端口上,http的连接简单,是无状态的,端口是 80; https 在http的基础上使用了ssl协议进行加密传输,端口是 443
4. TCP、UDP协议的区别
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HGkGoIZT-1658935905947)(C:\Users\ZZR\AppData\Roaming\Typora\typora-user-images\image-20210923111022268.png)]
UDP 在传送数据之前不需要先建立连接,远地主机在收到 UDP 报文后,不需要给出任何确认。虽然 UDP 不提供可靠交付,但在某些情况下 UDP 确是一种最有效的工作方式(一般用于即时通信),比如: QQ 语音、 QQ 视频 、直播等等
TCP 提供面向连接的服务。在传送数据之前必须先建立连接,数据传送结束后要释放连接。 TCP 不提供广播或多播服务。由于 TCP 要提供可靠的,面向连接的运输服务(TCP的可靠体现在TCP在传递数据之前,会有三次握手来建立连接,而且在数据传递时,有确认、窗口、重传、拥塞控制机制,在数据传完后,还会断开连接用来节约系统资源),这一难以避免增加了许多开销,如确认,流量控制,计时器以及连接管理等。这不仅使协议数据单元的首部增大很多,还要占用许多处理机资源。TCP 一般用于文件传输、发送和接收邮件、远程登录等场景。
5. 常见的状态码。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Y5ctb143-1658935905947)(C:\Users\ZZR\AppData\Roaming\Typora\typora-user-images\image-20210905225107025.png)]
输、发送和接收邮件、远程登录等场景。
5. 常见的状态码。
[外链图片转存中…(img-Y5ctb143-1658935905947)]