002---tcp/ip五层详解

tcp/ip 五层模型讲解

越靠底层就越接近硬件,越靠上层越接近用户。先从底层看起,理解整个互联网通信的原理。

物理层(传输电信号)

孤立的计算机想要一起玩。就必须用硬件在计算机之间完成组网。以硬件做为介质来传输。
物理层:

  • 光缆
  • 电缆
  • 双绞线

功能:主要是发生高低电压(电信号)。高电压对应1,低电压对于0。

数据链路层(ARP协议)

物理层传来的单纯的电信号0和1没任何意义。必须规定电信号多少位一组,每组代表什么意思。
功能:定义了电信号分组方式。

规定

  • 一组电信号构成一个数据包,叫做帧。
  • 每一组数据帧,包含head 和 数据data 两部分

head(固定18个字节)

  • 发送者/原地址:6个字节
  • 接收者/目标地址:6个字节
  • 数据类型:6个字节

data(46-1500字节)

  • 数据包的具体内容

mac 地址

  • head包含的目标地址和原地址就是网卡的地址,即mac地址
  • 每块网卡出厂时都被烧制一个世界上唯一的mac地址,长度为48位二进制,通常由12位16进制数表示
  • 前6位是厂商编号、后六位是流水线编号

广播

  • 有了mac地址两台计算机就能通信了。通过ARP协议获取另外一台计算机的mac地址,以广播的方式进行通信,即靠吼。
  • 收到数据包之后拆包,在head部分发现对方发来的目标地址不是自己的就丢弃,是自己的就响应。

ARP协议

  • 功能:广播的方式发生数据包,获取目标主机的mac地址。
  • 协议工作方式:每台主机ip都是已知的

网络层(IP协议)

之前有了Ethernet、mac地址、广播的方式。世界上的计算机就能彼此通信,问题是世界范围内的互联网是由一个个小小的隔离的局域网组成,那么如果所有的通信都采用以太网的广播方式,那么一台机器发生的包全世界都会收到,这不仅仅是效率的问题,这更会是一场灾难。
所以,网络层就出现了。必须有一种方法来区分哪些计算机属于同一个域,哪些不是。如果是就采用广播的方式,如果不是,就采用路由的方式。
功能:引入一套新的地址来区分不同的广播域/子网,这套地址即网络地址。

IP协议

  • 它定义的地址叫做ip地址,广泛采用iPv4,它规定用32位二进制表示
  • 范围:0.0.0.0 - 255.255.255.255
  • 一个ip地址通常写成4段十进制数:192.168.0.1

组成

  • 网络部分:标识子网
  • 主机部分:标识主机
  • 注意:单纯的ip地址段只是标识了ip地址的种类,根据网络部分或主机部分并不能判断二者是否处于同一子网。

子网掩码

所谓”子网掩码”,就是表示子网络特征的一个参数。它在形式上等同于IP地址,也是一个32位二进制数字,它的网络部分全部为1,主机部分全部为0。比如,IP地址172.16.10.1,如果已知网络部分是前24位,主机部分是后8位,那么子网络掩码就是11111111.11111111.11111111.00000000,写成十进制就是255.255.255.0。

知道子网掩码就可以判断,任意两个ip是否处于同一子网络。将两个ip地址与子网掩码分别进行and运算(两个数位加1,运算结果都是1则为1,,否则为0),最后比较结果即可。

ip数据包

  • head
  • data
  • 直接放在以太网包的data部分。

传输层(TCP和UDP协议)

网络层的IP协议帮我们区分子网,数据链路层的ARP协议帮我们区分mac地址找到主机。然后大家用的却是应用程序,比如说腾讯QQ、爱奇艺...
怎么知道找到主机的应用程序呢,答案就是端口。

功能:建立端口与端口之间的通信

端口范围:0 - 65535 ,0 - 1023 为系统占用端口

应用层(http协议、ftp协议、https协议)

用户使用的都是应用程序,均工作与应用层,大家都可以开发自己的应用程序,数据多种多样,必须规定好数据的形式。

功能:规定应用程序的数据格式

posted @ 2019-01-31 15:27  爬呀爬Xjm  阅读(386)  评论(0编辑  收藏  举报