TCP/IP协议分层详解_小白菜钟意猪肉的博客-程序员秘密

一、 TCP/IP 和 ISO/OSI

这里写图片描述

ISO/OSI模型,即开放式通信系统互联参考模型(Open System Interconnection Reference Model),是国际标准化组织(ISO)提出的一个试图使各种计算机在世界范围内互连为网络的标准框架,简称OSI。 
TCP/IP协议模型(Transmission Control Protocol/Internet Protocol),包含了一系列构成互联网基础的网络协议,是Internet的核心协议,通过20多年的发展已日渐成熟,并被广泛应用于局域网和广域网中,目前已成为事实上的国际标准。TCP/IP协议簇是一组不同层次上的多个协议的组合,通常被认为是一个四层协议系统,与OSI的七层模型相对应。

二、 TCP/IP分层模型

这里写图片描述

(1). 链路层

也称作数据链路层或网络接口层(在第一个图中为网络接口层和硬件层),通常包括操作系统中的设备驱动程序和计算机中对应的网络接口卡。它们一起处理与电缆(或其他任何传输媒介)的物理接口细节。ARP(地址解析协议)和RARP(逆地址解析协议)是某些网络接口(如以太网和令牌环网)使用的特殊协议,用来转换IP层和网络接口层使用的地址。
  • 1

(2). 网络层

也称作互联网层(在第一个图中为网际层),处理分组在网络中的活动,例如分组的选路。在TCP/IP协议族中,网络层协议包括IP协议(网际协议),ICMP协议(Internet互联网控制报文协议),以及IGMP协议(Internet组管理协议)。

IP是一种网络层协议,提供的是一种不可靠的服务,它只是尽可能快地把分组从源结点送到目的结点,但是并不提供任何可靠性保证。同时被TCP和UDP使用。TCP和UDP的每组数据都通过端系统和每个中间路由器中的IP层在互联网中进行传输。

ICMP是IP协议的附属协议。IP层用它来与其他主机或路由器交换错误报文和其他重要信息。

IGMP是Internet组管理协议。它用来把一个UDP数据报多播到多个主机。
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

(3). 传输层

主要为两台主机上的应用程序提供端到端的通信。在TCP/IP协议族中,有两个互不相同的传输协议:TCP(传输控制协议)和UDP(用户数据报协议)。

TCP为两台主机提供高可靠性的数据通信。它所做的工作包括把应用程序交给它的数据分成合适的小块交给下面的网络层,确认接收到的分组,设置发送最后确认分组的超时时钟等。由于运输层提供了高可靠性的端到端的通信,因此应用层可以忽略所有这些细节。为了提供可靠的服务,TCP采用了超时重传、发送和接收端到端的确认分组等机制。

UDP则为应用层提供一种非常简单的服务。它只是把称作数据报的分组从一台主机发送到另一台主机,但并不保证该数据报能到达另一端。一个数据报是指从发送方传输到接收方的一个信息单元(例如,发送方指定的一定字节数的信息)。UDP协议任何必需的可靠性必须由应用层来提供。
  • 1
  • 2
  • 3
  • 4
  • 5

(4). 应用层

应用层负责处理特定的应用程序细节。
  • 1

三、 数据的封装与分用

这里写图片描述

当应用程序用TCP传送数据时,数据被送入协议栈中,然后逐个通过每一层直到被当作一串比特流送入网络。其中每一层对收到的数据都要增加一些首部信息(有时还要增加尾部信息),该过程如图所示。

TCP传给IP的数据单元称作TCP报文段或简称为TCP段(TCP segment);UDP数据与TCP数据基本一致。唯一的不同是UDP传给IP的信息单元称作U D P数据报(UDP datagram),而且UDP的首部长为8字节。IP传给网络接口层的数据单元称作IP数据报(IP datagram)。通过以太网传输的比特流称作帧(Frame )。 
这里写图片描述

当目的主机收到一个以太网数据帧时,数据就开始从协议栈中由底向上升,同时去掉各层协议加上的报文首部。每层协议盒都要去检查报文首部中的协议标识,以确定接收数据的上层协议。这个过程称作分用(Demultiplexing)。协议是通过目的端口号、源I P地址和源端口号进行解包的。

四、 其他相关概念

这里写图片描述

(2). 端口号

服务器一般都是通过知名端口号来识别的。例如,对于每个TCP/IP实现来说,FTP服务器的TCP端口号都是21,每个Telnet服务器的TCP端口号都是23,每个TFTP (简单文件传送协议)服务器的UDP端口号都是69。任何TCP/IP实现所提供的服务都用知名的1~1023之间的端口号。这些知名端口号由Internet号分配机构(Internet Assigned Numbers Authority, IANA)来管理。知名端口号介于1~255之间;256~1023之间的端口号通常都是由Unix系统占用,以提供一些特定的Unix服务;1024~5000端口号用于客户端分配临时端口号;大于5000的端口号是为其他服务器预留的。

(3). DNS

DNS 是计算机域名系统 (Domain Name System 或Domain Name Service) 的缩写,它是由解析器以及域名服务器组成的。域名服务器是指保存有该网络中所有主机的域名和对应IP地址,并具有将域名转换为IP地址功能的服务器。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/shen251515338/article/details/105275749

智能推荐

vue 结合饿了么element-ui_饿了么ui_archer.wu的博客-程序员秘密

vue 结合饿了么element-ui本文主要介绍如何在vue框架中结合elementUI。本文主要参考:http://element-cn.eleme.io/#/zh-CN/component/installation1、阅读本文前请先阅读http://blog.csdn.net/wild46cat/article/details/763602292、在阅

adb 命令的使用(截图+通过无线连接手机断开手机)_wifi怎么adb截图_谢小丫的博客-程序员秘密

1. 截图并保存至电脑 ---windowsadb shell screencap -p > D:\login.pngwindows下这种方法保存会报图片格式错误,使用python处理一下,即可打开。原因: 重定向后,换行的格式为\r\n,需要转换成windows识别的\ndef convert_img(): with open("./login.png", "rb") as f: bys = f.read() bys_ = bys.re.

数学概率之分布函数和概率密度函数_复合函数的概率密度函数_专注于计算机视觉的AndyJiang的博客-程序员秘密

概率密度和分布函数联合概率密度边际概率密度条件概率密度复合函数概率密度

Filter 重复读取 request 的POST请求参数_request通过filter获取请求体参数_ACGkaka_的博客-程序员秘密

需求:​ 在Filter中获取POST请求参数只能调用request.getInputStream()、request.getReader()的方式把请求体读出来,可是会抛出如下异常:java.lang.IllegalStateException: getReader() has already been called for this request原因:​ request请求体只能读取一次,多次读取会抛异常,在过滤器中读取的话,在Controller中再拿请求体的字节流的时候就会抛异常。.

cucumber+springboot UI自动化测试框架搭建_cucumber ui_chenchao628的博客-程序员秘密

Cucumber、feature、spring boot项目整合介绍整合目标1.前提要求2.cucumber和springBoot整合目录3. idea安装cucumber插件4.pom.xml导入Cucumber相关jar包5.新建cucumber工作目录6.在resources->features下新建2个feature用例文件7.针对新建的2个feature用例文件,创建对应的用例实现...

Association references unmapped class_codsoul2的博客-程序员秘密

有时候还真迷糊,哐当哐当的手写一通配置文件,重启后报错:Association references unmapped class:XXXX。仔细一想,原来是忘记加入写好的配置文件了。

随便推点

Qt QString使用0补位_chuojin5043的博客-程序员秘密

int msec = 1; int sec = 1; int min = 1; int h = 1; QString tempstr = QString("%1:%2:%3.%4") .arg(h, 2, 1...

CUDA编程入门极简教程_视觉鸟的博客-程序员秘密

一、前言2006年,NVIDIA公司发布了CUDA,CUDA是建立在NVIDIA的CPUs上的一个通用并行计算平台和编程模型,基于CUDA编程可以利用GPUs的并行计算引擎来更加高效地解决比较复杂的计算难题。近年来,GPU最成功的一个应用就是深度学习领域,基于GPU的并行计算已经成为训练深度学习模型的标配。目前,最新的CUDA版本为CUDA 9。GPU并不是一个独立运行的计算平台,而需要与CPU协同工作,可以看成是CPU的协处理器,因此当我们在说GPU并行计算时,其实是指的基于CPU+GPU的异构计

spring定时任务详解(@Scheduled注解)_scheduled注解initialdelay_Wilson Tsai的博客-程序员秘密

1.initialDelay :初次执行任务之前需要等待的时间@Scheduled(initialDelay =5000)public void doSomething() {}2.fixedDelay:每次执行任务之后间隔多久再次执行该任务。(项目启动时,会立即执行任务。可以配合initialDelay一起使用(项目启动后延时执行任务))@Scheduled(fixedDe...

mysql ALTER COLUMN MODIFY COLUMN CHANGE COLUMN 区别及用法_altercolumn的用法_弘恩的博客-程序员秘密

-- 设置或删除列的默认值。该操作会直接修改.frm文件而不涉及表数据。此操作很快-- ALTER COLUMN ALTER TABLE dsp_ad_center.XianDuan ALTER COLUMN xxx SET DEFAULT 100;-- 共 0 行受到影响-- -- 执行耗时 : 0.011 sec-- 传送时间 : 1.037 sec-- 总耗时

POJ--1458:Common Subsequence (DP求最长公共子序列)_酒酿小圆子~的博客-程序员秘密

1. 题目源地址:http://poj.org/problem?id=14582. 基本题意: 给出两个序列,求出最长子序列的长度并输出。经典的动态规划求解,DP方程如下: