简单的跨路由通信分析和理解

linux route 通信

简单的拓扑模型:
A —–1 R1 2—–3 R2 4——5 R3 6——-B

问题:

如果A 通过浏览器访问B机器上网站的页面
 firefox http://B

1、
判断A和B是否在同一网段
判断方法:
a、A先和自己的子网掩码进行与运算,算出自己的网络ID,
b、然后把B机器上的IP与自己的子网掩码进行与运算,算出B机器所在的网络ID
c、两个网络ID比较,如果一样就在同一网段,如果不一样,就不在同一网段。
如果A,B不在同网段,A就没有办法通过ARP协议把B机器的mac地址解析出来,

2、
因此A机器尝试把数据包发往R1路由器的网关

在A的机器上事先肯定配置了网关(默认网关)(gateway : R1 IP1)
A机器虽然知道R1的gateway的地址,但是不知道IP1的mac1地址
ARP IP1—> mac
A机器和R1路由器IP1在同一网段,可以使用ARP广播获取到IP1的mac1地址

A ARP cache:(IP1 MAC1)
得到 R1 IP1的mac1地址,A机器会把IP1和mac1的对应关系保存到ARP表中,下一通信直接查询ARP就可以了,不需要再次发送ARP请求了

3、
我们现在已经得到目标地址和源地址,可以填写数据包信息

数据链路层
frame:DEST MAC1, SOUCRE MACA,

internet层
IP:dest IP:IPB , source IP:IPA

传输层
TCP: dest port:80 , source port: xxx(random随机)

4、
数据包的信息填写完整后,就可以根据数据的DEST MAC1把数据包发送到R1上了

5、
R1收数据包,会根据包中的目标地址,查询自己的路由表
数据包要到达 netB网段
netB R1IP2 R2IP3
要到达netB 网络,数据包要从R1的IP2接口出去,要到达R2的IP3接口
因此R1要尝试把数据包发送到R2

ARP R2IP3 — MAC3

数据包头信息重新封装
frame:DEST MAC3, SOUCRE MAC2,
ip/TCP包头不变

6、
R2收到数据包会根据包中的目标地址,查询自己的路由表
数据包要到达 netB网段
netB R2IP4 R3IP5

ARP R2IP5 — MAC5

数据包头信息重新封装
frame:DEST MAC5, SOUCRE MAC4,
ip/TCP包头不变

7、
数据包到达R3
R3收到数据包会根据包中的目标地址,查询自己的路由表
发现R3和目标地址是直连
netB R3IP6 xxx
ARP IPB —> MACB

frame :dest macB ,source mac6
ip: dest IPB, source IPA
tcp: dest port22, source port xxxx

8、
数据包到达(一次通信完成)

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/97604

(0)
linux_testlinux_test
上一篇 2018-05-06 14:20
下一篇 2018-05-06 15:25

相关推荐

  • 文件管理基础知识

                   文件管理 目录篇 / :根目录 bin    boot    dev    etc    home    root    run     sbin    tmp    usr   var 字符界面颜色的意义: 蓝色=目录、绿色=可执行文件、红色=压缩文件、浅蓝色=链接文件 灰色=其他文件 boot:引导文件的存放目录  bin:…

    Linux笔记 2018-04-08
  • 第一周作业

    1、描述计算机的组成及其功能。
    2、按系列罗列Linux的发行版,并描述不同发行版之间的联系与区别。
    3、描述Linux的哲学思想,并按照自己的理解对其进行解释性描述。
    4、说明Linux系统上命令的使用格式;详细介绍ifconfig、echo、tty、startx、export、pwd、history、shutdown、poweroff、reboot、hwclock、date命令的使用,并配合相应的示例来阐述。
    5、如何在Linux系统上获取命令的帮助信息,请详细列出,并描述man文档的章节是如何划分的。
    6、请罗列Linux发行版的基础目录名称命名法则及功用规定。

    Linux笔记 2018-05-13
  • N31第六周作业

    本周(7.23–7.29)第六周 1、简述osi七层模型和TCP/IP五层模型 OSI 七层模型 1、应用层:OSI 参考模型中最靠近用户的一层,为计算机用户提供应用接口,也为用户直接提供各种网络服务。我们常见应用层的网络服务协议有:HTTP,HTTPS,FTP,POP3、SMTP等。 2、表示层:提供各种用于应用层数据的编码和转换功能,确保一个…

    Linux笔记 2018-08-01
  • linux命令之chown

    chown(选项)(参数)

    Linux笔记 2018-08-05
  • 新开始,新航程

           每一个夏天都是变动的季节,这个夏季我毕业了。大学最后的时光是在实验室度过的,每天都被瓶瓶罐罐所包围,鼻子里不时的飘进乙酸乙酯的香味,研究完了生物柴油的催化,是时候该为自己的未来找一条出路了。         大二的时候出于对计算机的着迷,一不小心点进了51cto,从此就走上了不归路。从计算机网络到linux,再到mysql,我在这个世界里乐此不…

    Linux笔记 2018-07-21
  • 磁盘存储和文件系统

    磁盘存储和文件系统: 磁盘设备的文件命名:/dev/dev_file虚拟磁盘:/dev/vd磁盘标识: /dev/sda,/dev/sdb……磁盘分区:/dev/sda1,/dev/sdb2…… chs 磁盘sector 扇区 512bytestrack 磁道head 磁头cylinder柱面 使用磁盘: 分区创建文件系统:格式化挂载:分配目录名 hexdu…

    Linux笔记 2018-05-20