03 TCP/IP 4层模型这是目前被广泛采用的一种模型,我们可以

简介: 03 TCP/IP 4层模型这是目前被广泛采用的一种模型,我们可以将 TCP / IP 模型看作是 OSI 7层模型的精简版本,由以下4层组成:应用层传输层网络

这篇文章我会首先结合我们日常的软件系统开发介绍 「“为什么网络要分层”?

我会详细介绍目前广泛使用的 「“ TCP/IP 4层模型 ”」 包括每一层做的事情以及相关的协议介绍。

说到分层,我们先从我们平时使用框架开发一个程序来说,我们往往会按照每一层做不同的事情的原则将系统分为 三层(复杂的系统分层可能会更多):Repository(数据库操作)Service(业务操作)Cooller(前后端数据交互)「复杂的系统需要分层,因为每一层都需要专注于一类事情。

」 ,我们再来较为系统的说一说:「各层之间相互独立」:各层之间相互独立,各层之间不需要关心其他层是如何实现的,只需要知道自己如何调用下层好的功能就可以了(可以简单理解为接口调用)「。

」「提高了整体灵活性」 :每一层都可以使用最适合的技术来实现,你只需要保证你的功能以及暴露的接口的规则没有改变就行了。

」「大问题化小」 :分层可以将复杂的网络间题分解为许多比较小的、界线比较清晰简单的小问题来处理和解决。

「这个和我们平时开发的时候,一般会将系统功能分解,然后将复杂的问题分解为容易理解的更小的问题是相对应的,这些较小的问题具有更好的边界(目标和接口)定义。

」说到计算机网络分层,我想到了计算机世界非常非常有名的一句话,这里分享一下:「计算机科学领域的任何问题都可以通过增加一个间接的中间层来解决,计算机整个从上到下都是按照严格的层次结构设计的。

「为了更好地去了解网络分层,我们先来看一个虽然失败,但是却了很多不错的理论基础的OSI七层模型。

」02 OSI七层模型OSI七层模型的大体结构以及每一层的功能如下。

」OSI的专家缺乏实际经验,他们在完成OSI标准时缺乏商业驱动力OSI的协议实现起来过分复杂,而且运行效率很低OSI制定标准的周期太长,因而使得按OSI标准生产的设备无法及时进入市场(20世纪90年代初期,虽然整套的OSI国际标准都已经制定出来,但基于TCP/IP的互联网已经抢先在全球相当大的范围成功运行了)OSI的层次划分不太合理,有些功能在多个层次中重复出现。

03 TCP/IP 4层模型这是目前被广泛采用的一种模型,我们可以将 TCP / IP 模型看作是 OSI 7层模型的精简版本,由以下4层组成:应用层传输层网络层网络接口层需要注意的是,我们并不能将 TCP/IP4层模型 和OSI7层模型完全精确地匹配起来,不过可以简单将两者对应起来,如下图所示:TCP-IP-4-model04 TCP/IP 4层模型网络协议概览network-protocol-overview「应用层协议」 :HTTP 协议(超文本传输协议,网页浏览常用的协议)DHCP 协议(动态主机配置)DNS 系统原理(域名系统)FTP 协议(文件传输协议)Telnet协议(远程登陆协议)电子邮件协议等(SMTP、POP3、IMAP)......「传输层协议」 :TCP 协议报文段结构可靠数据传输流量控制拥塞控制UDP 协议报文段结构RDT(可靠数据传输协议)「网络层协议」 :IP 协议(TCP/IP 协议的基础,分为 IPv4 和 IPv6)ARP 协议(地址解析协议,用于解析 IP 地址和 MAC 地址之间的映射)ICMP 协议(控制报文协议,用于发送控制消息)NAT 协议(网络地址转换协议)RIP 协议、OSPF 协议、BGP 协议(路由选择协议)......「网络接口层」 :差错检测技术多路访问协议(信道复用技术)CSMA/CD 协议MAC 协议以太网技术......应用层(Application layer)应用层的任务是通过应用进程间的交互来完成特定网络应用,我们把应用层交互的数据单元称为报文。

「应用层协议定义的是应用进程(进程:主机中正在运行的程序,比如微信、QQ)间的通信和交互的规则。

」 在互联网中应用层协议很多,如域名系统DNS,支持Web应用的HTTP协议,支持电子邮件的SMTP协议等等。

简单总结一下当今使用的一些最常见的应用层协议:HTTP:超文本传输协议「超文本传输协议(HTTP,HyperText Transfer Protocol)主要是为 Web 浏览器与 Web 服务器之间的通信而设计的。

」当我们使用浏览器浏览网页的时候,我们网页就是通过 HTTP 请求进行加载的,整个过程如下图所示。

HTTP请求过程「HTTP 协议是基于 TCP协议的」,发送 HTTP 请求之前首先要建立 TCP 连接也就是要经历 3 次握手。

目前使用的 HTTP 协议大部分都是 1.1。

在 1.1 的协议里面,默认是开启了 Keep-Alive 的,这样的话建立的连接就可以在多次请求中被复用了。

另外, 「HTTP 协议是”无状态”的协议,它无法记录客户端用户的状态」 一般我们都是通过 Session 来记录客户端用户的状态。

SMTP:简单邮件传输(发送)协议「简单邮件传输协议(SMTP,Simple Mail Transfer Protocol)的缩写,基于 TCP 协议,用来发送电子邮件。

」注意:「接受邮件的协议不是 SMTP 二是POP3协议。

」SMTP 协议这块后面不会花费太多篇幅来讲解,直接提一下两个比较重要的问题:电子邮件的发送过程如何判断邮箱是真正存在的?

」比如我的邮箱是“dabai@cszhinan.com”,我要向“xiaoma@qq.com”发送邮件,整个过程可以简单分为下面几步:通过 「SMTP」 协议,我将我写好的邮件交给163邮箱服务器(邮局)。

163邮箱服务器发现我发送的邮箱是qq邮箱,然后它使用 SMTP协议将我的邮件转发到 qq邮箱服务器。

qq邮箱服务器接收邮件之后就通知邮箱为“xiaoma@qq.com”的用户来收邮件,然后用户就通过 「POP3/IMAP」 协议将邮件取出。

」很多场景(比如邮件营销)下面我们需要判断我们要发送的邮箱地址是否真的存在,这个时候我们可以利用 SMTP 协议来检测。

推荐几个在线邮箱是否有效检测工具:https://verify-email.org/http://tool.chacuo.net/mailverifyhttps://www.emailcamel.com/POP3/IMAP:邮件接收的协议这两个协议不多做阐述,只需要了解 「POP3 和 IMAP 两者都是负责邮件接收的协议」即可。

「SMTP 协议只负责邮件的发送,真正负责接收的协议是POP3/IMAP。

」IMAP 协议相比于POP3更新一点,为用户的可选功能也更多一点,几乎所有现代电子邮件客户端和服务器都支持IMAP。

FTP:文件传输协议「文件传输协议 FTP(File Transfer Protocol),文件传输服务,基于 TCP 实现可靠的传输。

」FTP 是基于客户—服务器(C/S)模型而设计的,在客户端与 FTP 服务器之间建立两个连接。

如果我们要基于 FTP 协议开发一个文件传输的软件的话,首先需要搞清楚 FTP 的原理。

关于 FTP 的原理,很多书籍上已经描述的非常详细了:FTP 的独特的优势同时也是与其它客户服务器程序最大的不同点就在于它在两台通信的主机之间使用了两条 TCP 连接(其它客户服务器应用程序一般只有一条 TCP 连接):控制连接:用于传送控制信息(命令和响应)数据连接:用于数据传送;这种将命令和数据分开传送的思想大大提高了 FTP 的效率。

FTP工作过程DNS:域名系统「域名系统(DNS,Domain Name System)将人类可读的域名 (例如,www.baidu.com) 转换为机器可读的 IP 地址 (例如,220.181.38.148)。

」 我们可以将其理解为专为互联网设计的电话薄。

dns-overviewIP 地址是一个网卡再网络世界中的通讯地址,我们可以把它理解为我们现实世界中的家庭地址。

」 (这个会在后面的文章中详细介绍到)DNS 解析的完整流程Telnet:远程登陆协议远程登陆协议,通过一个终端登陆到其他服务器,建立在可靠的传输协议 TCP 之上。

「Telnet协议的最大缺点之一是所有数据(包括用户名和密码)均以明文形式发送,这有潜在的安全风险。

」SSH:安全的网络传输协议SSH( Secure Shell)是目前较可靠,专为远程登录会话和其他网络服务安全性的协议。

利用 SSH 协议可以有效防止远程管理过程中的信息泄露问题。

SSH 建立在可靠的传输协议 TCP 之上。

「Telnet 和 SSH 之间的主要区别在于 SSH 协议会对传输的数据进行加密保证数据安全性。

」传输层(Transport layer)「传输层的主要任务就是负责向两台主机进程之间的通信通用的数据传输服务」。

「运输层主要使用以下两种协议:」「传输控制协议TCP」(Transmisson Cool Protocol)--「面向连接」的,「可靠的」数据传输服务。

「用户数据协议UDP」(User Datagram Protocol)--「无连接」的,尽最大努力的数据传输服务(「不保证数据传输的可靠性」)。

」这里强调指出,网络层中的“网络”二字已经不是我们通常谈到的具体网络,而是指计算机网络结构模型中第三层的名称.互联网是由大量的异构(heterogeneous)网络通过路由器(router)相互连接起来的。

互联网使用的网络层协议是无连接的网际协议(Intert Prococol)和许多路由选择协议,因此互联网的网络层也叫做「网际层」或「IP层」。

数据链路层(data link layer)通常简称为链路层( 两台主机之间的数据传输,总是在一段一段的链路上传送的)。

「数据链路层的作用是将网络层交下来的 IP 数据报组装成帧,在两个相邻节点间的链路上传送帧。

」「物理层的作用是实现相邻计算机节点之间比特流的透明传送,尽可能屏蔽掉具体传输介质和物理设备的差异」最后再分享一个关于OSI 七层模型非常不错的总结图片!


以上是文章"

03 TCP/IP 4层模型这是目前被广泛采用的一种模型,我们可以

"的内容,欢迎阅读过人科技网的其它文章