计算机网络 - 应用层.md 11.2 KB
Newer Older
C
CyC2018 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
<!-- GFM-TOC -->
* [域名系统](#域名系统)
* [文件传送协议](#文件传送协议)
* [动态主机配置协议](#动态主机配置协议)
* [远程登录协议](#远程登录协议)
* [电子邮件协议](#电子邮件协议)
    * [1. SMTP](#1-smtp)
    * [2. POP3](#2-pop3)
    * [3. IMAP](#3-imap)
* [常用端口](#常用端口)
* [Web 页面请求过程](#web-页面请求过程)
    * [1. DHCP 配置主机信息](#1-dhcp-配置主机信息)
    * [2. ARP 解析 MAC 地址](#2-arp-解析-mac-地址)
    * [3. DNS 解析域名](#3-dns-解析域名)
    * [4. HTTP 请求页面](#4-http-请求页面)
<!-- GFM-TOC -->


# 域名系统

DNS 是一个分布式数据库,提供了主机名和 IP 地址之间相互转换的服务。这里的分布式数据库是指,每个站点只保留它自己的那部分数据。
C
CyC2018 已提交
22 23 24

域名具有层次结构,从上到下依次为:根域名、顶级域名、二级域名。

C
CyC2018 已提交
25
<div align="center"> <img src="https://gitee.com/CyC2018/CS-Notes/raw/master/docs/pics/b54eeb16-0b0e-484c-be62-306f57c40d77.jpg"/> </div><br>
C
CyC2018 已提交
26

C
CyC2018 已提交
27
DNS 可以使用 UDP 或者 TCP 进行传输,使用的端口号都为 53。大多数情况下 DNS 使用 UDP 进行传输,这就要求域名解析器和域名服务器都必须自己处理超时和重传来保证可靠性。在两种情况下会使用 TCP 进行传输:
C
CyC2018 已提交
28

C
CyC2018 已提交
29 30
- 如果返回的响应超过的 512 字节(UDP 最大只支持 512 字节的数据)。
- 区域传送(区域传送是主域名服务器向辅助域名服务器传送变化的那部分数据)。
C
CyC2018 已提交
31

C
CyC2018 已提交
32
# 文件传送协议
C
CyC2018 已提交
33

C
CyC2018 已提交
34
FTP 使用 TCP 进行连接,它需要两个连接来传送一个文件:
C
CyC2018 已提交
35

C
CyC2018 已提交
36 37
- 控制连接:服务器打开端口号 21 等待客户端的连接,客户端主动建立连接后,使用这个连接将客户端的命令传送给服务器,并传回服务器的应答。
- 数据连接:用来传送一个文件数据。
C
CyC2018 已提交
38

C
CyC2018 已提交
39
根据数据连接是否是服务器端主动建立,FTP 有主动和被动两种模式:
C
CyC2018 已提交
40

C
CyC2018 已提交
41
- 主动模式:服务器端主动建立数据连接,其中服务器端的端口号为 20,客户端的端口号随机,但是必须大于 1024,因为 0\~1023 是熟知端口号。
C
CyC2018 已提交
42

C
CyC2018 已提交
43
<div align="center"> <img src="https://gitee.com/CyC2018/CS-Notes/raw/master/docs/pics/03f47940-3843-4b51-9e42-5dcaff44858b.jpg"/> </div><br>
C
CyC2018 已提交
44

C
CyC2018 已提交
45
- 被动模式:客户端主动建立数据连接,其中客户端的端口号由客户端自己指定,服务器端的端口号随机。
C
CyC2018 已提交
46

C
CyC2018 已提交
47
<div align="center"> <img src="https://gitee.com/CyC2018/CS-Notes/raw/master/docs/pics/be5c2c61-86d2-4dba-a289-b48ea23219de.jpg"/> </div><br>
C
CyC2018 已提交
48 49 50

主动模式要求客户端开放端口号给服务器端,需要去配置客户端的防火墙。被动模式只需要服务器端开放端口号即可,无需客户端配置防火墙。但是被动模式会导致服务器端的安全性减弱,因为开放了过多的端口号。

C
CyC2018 已提交
51
# 动态主机配置协议
C
CyC2018 已提交
52

C
CyC2018 已提交
53
DHCP (Dynamic Host Configuration Protocol) 提供了即插即用的连网方式,用户不再需要去手动配置 IP 地址等信息。
C
CyC2018 已提交
54

C
CyC2018 已提交
55
DHCP 配置的内容不仅是 IP 地址,还包括子网掩码、网关 IP 地址。
C
CyC2018 已提交
56

C
CyC2018 已提交
57
DHCP 工作过程如下:
C
CyC2018 已提交
58

C
CyC2018 已提交
59 60 61 62
1. 客户端发送 Discover 报文,该报文的目的地址为 255.255.255.255:67,源地址为 0.0.0.0:68,被放入 UDP 中,该报文被广播到同一个子网的所有主机上。如果客户端和 DHCP 服务器不在同一个子网,就需要使用中继代理。
2. DHCP 服务器收到 Discover 报文之后,发送 Offer 报文给客户端,该报文包含了客户端所需要的信息。因为客户端可能收到多个 DHCP 服务器提供的信息,因此客户端需要进行选择。
3. 如果客户端选择了某个 DHCP 服务器提供的信息,那么就发送 Request 报文给该 DHCP 服务器。
4. DHCP 服务器发送 Ack 报文,表示客户端此时可以使用提供给它的信息。
C
CyC2018 已提交
63

C
CyC2018 已提交
64
<div align="center"> <img src="https://gitee.com/CyC2018/CS-Notes/raw/master/docs/pics/bf16c541-0717-473b-b75d-4115864f4fbf.jpg"/> </div><br>
C
CyC2018 已提交
65

C
CyC2018 已提交
66
# 远程登录协议
C
CyC2018 已提交
67

C
CyC2018 已提交
68
TELNET 用于登录到远程主机上,并且远程主机上的输出也会返回。
C
CyC2018 已提交
69

C
CyC2018 已提交
70
TELNET 可以适应许多计算机和操作系统的差异,例如不同操作系统系统的换行符定义。
C
CyC2018 已提交
71

C
CyC2018 已提交
72
# 电子邮件协议
C
CyC2018 已提交
73 74 75

一个电子邮件系统由三部分组成:用户代理、邮件服务器以及邮件协议。

C
CyC2018 已提交
76 77 78 79 80 81 82 83 84
邮件协议包含发送协议和读取协议,发送协议常用 SMTP,读取协议常用 POP3 和 IMAP。

<div align="center"> <img src="https://gitee.com/CyC2018/CS-Notes/raw/master/docs/pics/7b3efa99-d306-4982-8cfb-e7153c33aab4.png" width="700"/> </div><br>

## 1. SMTP

SMTP 只能发送 ASCII 码,而互联网邮件扩充 MIME 可以发送二进制文件。MIME 并没有改动或者取代 SMTP,而是增加邮件主体的结构,定义了非 ASCII 码的编码规则。

<div align="center"> <img src="https://gitee.com/CyC2018/CS-Notes/raw/master/docs/pics/ed5522bb-3a60-481c-8654-43e7195a48fe.png" width=""/> </div><br>
C
CyC2018 已提交
85

C
CyC2018 已提交
86
## 2. POP3
C
CyC2018 已提交
87

T
Twinkle 已提交
88 89
POP3 的特点是只要用户从服务器上读取了邮件,就把该邮件删除,但是目前改进的 POP3 已经全面支持下载而不删除原邮件。
它的另一个主要特点是:无论你在客户端做了任何操作(如移动、标记),都不会反映到服务器上,也就是只能单方面地从服务器“读取”。
C
CyC2018 已提交
90

C
CyC2018 已提交
91
## 3. IMAP
C
CyC2018 已提交
92

T
Twinkle 已提交
93 94
IMAP 协议中客户端和服务器上的邮件保持同步,如果不手动删除邮件,那么服务器上的邮件也不会被自动删除。IMAP 这种做法可以让用户随时随地去访问服务器上的邮件。
同时它与 POP3 的本质区别在于,在客户端的操作(包括删除)都会反映到服务器上,是一个双向的通信。
C
CyC2018 已提交
95

C
CyC2018 已提交
96
# 常用端口
C
CyC2018 已提交
97

C
CyC2018 已提交
98 99 100 101 102 103 104 105 106 107 108
|应用| 应用层协议 | 端口号 | 传输层协议 | 备注 |
| :---: | :--: | :--: | :--: | :--: |
| 域名解析 | DNS | 53 | UDP/TCP | 长度超过 512 字节时使用 TCP |
| 动态主机配置协议 | DHCP | 67/68 | UDP | |
| 简单网络管理协议 | SNMP | 161/162 | UDP | |
| 文件传送协议 | FTP | 20/21 | TCP | 控制连接 21,数据连接 20 |
| 远程终端协议 | TELNET | 23 | TCP | |
| 超文本传送协议 | HTTP | 80 | TCP | |
| 简单邮件传送协议 | SMTP | 25 | TCP | |
| 邮件读取协议 | POP3 | 110 | TCP | |
| 网际报文存取协议 | IMAP | 143 | TCP | |
C
CyC2018 已提交
109

C
CyC2018 已提交
110
# Web 页面请求过程
C
CyC2018 已提交
111

C
CyC2018 已提交
112
## 1. DHCP 配置主机信息
C
CyC2018 已提交
113

C
CyC2018 已提交
114
- 假设主机最开始没有 IP 地址以及其它信息,那么就需要先使用 DHCP 来获取。
C
CyC2018 已提交
115

C
CyC2018 已提交
116
- 主机生成一个 DHCP 请求报文,并将这个报文放入具有目的端口 67 和源端口 68 的 UDP 报文段中。
C
CyC2018 已提交
117

C
CyC2018 已提交
118
- 该报文段则被放入在一个具有广播 IP 目的地址(255.255.255.255) 和源 IP 地址(0.0.0.0)的 IP 数据报中。
C
CyC2018 已提交
119

C
CyC2018 已提交
120
- 该数据报则被放置在 MAC 帧中,该帧具有目的地址 FF:FF:FF:FF:FF:FF,将广播到与交换机连接的所有设备。
C
CyC2018 已提交
121

C
CyC2018 已提交
122
- 连接在交换机的 DHCP 服务器收到广播帧之后,不断地向上分解得到 IP 数据报、UDP 报文段、DHCP 请求报文,之后生成 DHCP ACK 报文,该报文包含以下信息:IP 地址、DNS 服务器的 IP 地址、默认网关路由器的 IP 地址和子网掩码。该报文被放入 UDP 报文段中,UDP 报文段有被放入 IP 数据报中,最后放入 MAC 帧中。
C
CyC2018 已提交
123

C
CyC2018 已提交
124
- 该帧的目的地址是请求主机的 MAC 地址,因为交换机具有自学习能力,之前主机发送了广播帧之后就记录了 MAC 地址到其转发接口的交换表项,因此现在交换机就可以直接知道应该向哪个接口发送该帧。
C
CyC2018 已提交
125

C
CyC2018 已提交
126
- 主机收到该帧后,不断分解得到 DHCP 报文。之后就配置它的 IP 地址、子网掩码和 DNS 服务器的 IP 地址,并在其 IP 转发表中安装默认网关。
C
CyC2018 已提交
127

C
CyC2018 已提交
128
## 2. ARP 解析 MAC 地址
C
CyC2018 已提交
129

C
CyC2018 已提交
130
- 主机通过浏览器生成一个 TCP 套接字,套接字向 HTTP 服务器发送 HTTP 请求。为了生成该套接字,主机需要知道网站的域名对应的 IP 地址。
C
CyC2018 已提交
131

C
CyC2018 已提交
132
- 主机生成一个 DNS 查询报文,该报文具有 53 号端口,因为 DNS 服务器的端口号是 53。
C
CyC2018 已提交
133

C
CyC2018 已提交
134
- 该 DNS 查询报文被放入目的地址为 DNS 服务器 IP 地址的 IP 数据报中。
C
CyC2018 已提交
135

C
CyC2018 已提交
136
- 该 IP 数据报被放入一个以太网帧中,该帧将发送到网关路由器。
C
CyC2018 已提交
137

C
CyC2018 已提交
138
- DHCP 过程只知道网关路由器的 IP 地址,为了获取网关路由器的 MAC 地址,需要使用 ARP 协议。
C
CyC2018 已提交
139

C
CyC2018 已提交
140
- 主机生成一个包含目的地址为网关路由器 IP 地址的 ARP 查询报文,将该 ARP 查询报文放入一个具有广播目的地址(FF:FF:FF:FF:FF:FF)的以太网帧中,并向交换机发送该以太网帧,交换机将该帧转发给所有的连接设备,包括网关路由器。
C
CyC2018 已提交
141

C
CyC2018 已提交
142
- 网关路由器接收到该帧后,不断向上分解得到 ARP 报文,发现其中的 IP 地址与其接口的 IP 地址匹配,因此就发送一个 ARP 回答报文,包含了它的 MAC 地址,发回给主机。
C
CyC2018 已提交
143

C
CyC2018 已提交
144
## 3. DNS 解析域名
C
CyC2018 已提交
145

C
CyC2018 已提交
146
- 知道了网关路由器的 MAC 地址之后,就可以继续 DNS 的解析过程了。
C
CyC2018 已提交
147

C
CyC2018 已提交
148
- 网关路由器接收到包含 DNS 查询报文的以太网帧后,抽取出 IP 数据报,并根据转发表决定该 IP 数据报应该转发的路由器。
C
CyC2018 已提交
149

C
CyC2018 已提交
150
- 因为路由器具有内部网关协议(RIP、OSPF)和外部网关协议(BGP)这两种路由选择协议,因此路由表中已经配置了网关路由器到达 DNS 服务器的路由表项。
C
CyC2018 已提交
151

C
CyC2018 已提交
152
- 到达 DNS 服务器之后,DNS 服务器抽取出 DNS 查询报文,并在 DNS 数据库中查找待解析的域名。
C
CyC2018 已提交
153

C
CyC2018 已提交
154
- 找到 DNS 记录之后,发送 DNS 回答报文,将该回答报文放入 UDP 报文段中,然后放入 IP 数据报中,通过路由器反向转发回网关路由器,并经过以太网交换机到达主机。
C
CyC2018 已提交
155

C
CyC2018 已提交
156
## 4. HTTP 请求页面
C
CyC2018 已提交
157

C
CyC2018 已提交
158
- 有了 HTTP 服务器的 IP 地址之后,主机就能够生成 TCP 套接字,该套接字将用于向 Web 服务器发送 HTTP GET 报文。
C
CyC2018 已提交
159

C
CyC2018 已提交
160
- 在生成 TCP 套接字之前,必须先与 HTTP 服务器进行三次握手来建立连接。生成一个具有目的端口 80 的 TCP SYN 报文段,并向 HTTP 服务器发送该报文段。
C
CyC2018 已提交
161

C
CyC2018 已提交
162
- HTTP 服务器收到该报文段之后,生成 TCP SYN ACK 报文段,发回给主机。
C
CyC2018 已提交
163

C
CyC2018 已提交
164
- 连接建立之后,浏览器生成 HTTP GET 报文,并交付给 HTTP 服务器。
C
CyC2018 已提交
165

C
CyC2018 已提交
166
- HTTP 服务器从 TCP 套接字读取 HTTP GET 报文,生成一个 HTTP 响应报文,将 Web 页面内容放入报文主体中,发回给主机。
C
CyC2018 已提交
167

C
CyC2018 已提交
168
- 浏览器收到 HTTP 响应报文后,抽取出 Web 页面内容,之后进行渲染,显示 Web 页面。
C
CyC2018 已提交
169 170 171 172




C
CyC2018 已提交
173 174
</br><div align="center">⭐️欢迎关注我的公众号 CyC2018,在公众号后台回复关键字 📚 **资料** 可领取复习大纲,这份大纲是我花了一整年时间整理的面试知识点列表,不仅系统整理了面试知识点,而且标注了各个知识点的重要程度,从而帮你理清多而杂的面试知识点。可以说我基本是按照这份大纲来进行复习的,这份大纲对我拿到了 BAT 头条等 Offer 起到很大的帮助。你们完全可以和我一样根据大纲上列的知识点来进行复习,就不用看很多不重要的内容,也可以知道哪些内容很重要从而多安排一些复习时间。</div></br>
<div align="center"><img width="180px" src="https://cyc-1256109796.cos.ap-guangzhou.myqcloud.com/%E5%85%AC%E4%BC%97%E5%8F%B7.jpg"></img></div>