网络基础之主机通信

简介: 网络通信基础介绍:mac地址,ip地址,以及路由

最近有幸做了几场面试官,基本都会问一下候选人关于主机通信的知识,但基本都答的不好,现在写写我自己的理解。

基础

IP地址:32bit,类似于1.2.3.4
mac地址(网卡地址):48bit,类似于ff:ff:ff:ff:ff:ff

局域网通信

以太网是一种局域网通信协议,主要特点是带冲突检测的载波侦听多路访问(CSMA/CD),即有所谓的退避算法。同时,它是以mac地址用于通信的基础。

以主机A(192.168.0.100)向主机B(192.168.0.101)发送数据为例:

  1. 主机A会查询本地mac地址-ip地址的缓存表中是否有192.168.0.101的记录
  2. 若没有,则主机A会向本局域网发送广播,IP地址为192.168.0.101,mac地址为ff:ff:ff:ff:ff:ff,即向局域网内询问192.168.0.101的mac地址是多少?
  3. 局域网内的主机并不响应这个广播包,只有主机B收到广播包后,回复一个单播包192.168.0.101的mac地址为01:02:03:04:05:06
  4. 主机A收到回复包后,更新自己的本地mac地址-ip地址的缓存表,并开始向mac地址为01:02:03:04:05:06开始发送数据

以上这个简单的例子就是ARP协议

网络通信

讲到网络通信,就必须讲到路由的报文转发了。局域网内的流量只是网络的最后一公里的问题,而更广大的是广域网通信。每个局域网通过路由器连接成一个网,通过路由转发实现局域网A与局域网B的通信

报文转发

路由器将从接口A中接收的报文从接口B中转发出去,这里的关键操作是如何将协议组织好。

  1. 将数据链路层的帧头和帧尾移除,解析出IP报文。
  2. 检查IP报文的目的IP地址,在路由表中查找最佳路由。
  3. 如果路由器找到匹配下一跳,则将IP报文封装到新的数据链路帧中,并将帧转发到输出接口B中,否则路由器会将报文发给自己的默认路由

以主机A(192.168.0.10)向主机B(192.168.4.30)发送数据为例:

  1. 主机A首先判断目的地址192.168.4.30是否在自己的局域网内(子网掩码后判断网络地址是否一致),若一致,则与局域网通信一致
  2. 若不一致,则将报文转发至自己的默认路由192.168.0.1,如何转发至192.168.0.1与局域网通信一致
  3. 路由器R1收到报文后,拆开数据帧后得到目的IP为192.168.4.30,查看自己的路由表,发现其需要从另外一个出口中转发,目的地址为192.168.2.10,因此构造srcIP=192.168.0.10, srcMac=aa:02,dstIP=192.168.4.30,dstMac=bb:01,的数据帧转发至路由器R2
  4. 路由器R2收到报文后,查看路由表,发现需要从192.168.4.1的出口转发,而192.168.4.1192.168.4.30位与同一个局域网中,因此,直接局域网通信转发报文给主机B
  5. 主机B收到报文后,发现目的mac地址与自己一致,并解开目的IP地址也与自己一致,则将ip报文交由上层处理

路由转发

总结

上述只是简单将主机通信的过程描述了一遍,其中的一些细节(IP地址,网络地址,子网掩码,路由表构成)并没有深究,大家感兴趣可以自行研究。

目录
相关文章
|
24天前
|
安全 网络安全 网络虚拟化
【软件设计师备考 专题 】常用网络设备和各类通信设备(一)
【软件设计师备考 专题 】常用网络设备和各类通信设备
97 2
|
1月前
|
网络协议 网络安全 网络虚拟化
网络技术基础(10)—— VLAN间通信
【3月更文挑战第2天】网络基础笔记(加班了几天,中途耽搁了,预计推迟6天),这篇借鉴了之前师兄的笔记,边听边记笔记实在是太慢了。
|
21天前
|
存储 运维 安全
云擎技术:通信网络单元定级备案指南
简介: 通信网络单元定级备案是指相关基础电信企业、增值电信企业要对本单位管理、运行的公用通信网和互联网及其各类信息系统进行单元划分,按照《通信网络安全防护管理办法》(工业和信息化部令第11号)的规定开展定级工作,并在工业和信息化部“通信网络安全防护管理系统”报送各单元的定级信息。
26 2
|
24天前
|
安全 网络安全 网络虚拟化
【软件设计师备考 专题 】常用网络设备和各类通信设备(三)
【软件设计师备考 专题 】常用网络设备和各类通信设备
33 0
|
24天前
|
安全 算法 网络安全
【软件设计师备考 专题 】常用网络设备和各类通信设备(二)
【软件设计师备考 专题 】常用网络设备和各类通信设备
41 2
|
30天前
|
安全 Linux 网络安全
Qt SSL/TLS 安全通信类:构建安全网络应用的关键组件
Qt SSL/TLS 安全通信类:构建安全网络应用的关键组件
62 0
|
1月前
ping 测试主机之间网络连通性
ping 测试主机之间网络连通性。
41 1
|
1月前
|
网络协议 网络安全 网络虚拟化
网络技术基础(12)—— VLAN间通信
【3月更文挑战第2天】网络基础笔记(加班了几天,中途耽搁了,预计推迟6天),这篇借鉴了之前师兄的笔记,边听边记笔记实在是太慢了。
|
1月前
|
网络协议 安全 网络安全
网络基础与通信原理:构建数字世界的框架
网络基础与通信原理:构建数字世界的框架
43 1