前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >「Linux路由实践」之实现同网段主机间回环网口通信【主机路由篇】

「Linux路由实践」之实现同网段主机间回环网口通信【主机路由篇】

作者头像
用户1456517
发布2019-03-05 16:15:07
2.6K0
发布2019-03-05 16:15:07
举报
文章被收录于专栏:芝麻实验室芝麻实验室

环境说明:

  • VMware® Workstation 12 Pro
  • CentOS 6 * 1 (hostname: route1)
  • CentOS 7 * 1 (hostnaem:route2)

注:VMware® Workstation 12 Pro是 VMware, Inc 的商业产品,点此下载试用版

我们开始吧~

1.我们先看一下主机的网络相关情况: 首先是route1:

代码语言:javascript
复制
[root@route1 ~]# ifconfig                           
eth1      Link encap:Ethernet  HWaddr 00:0C:29:CC:99:C6
          inet addr:192.168.10.100  Bcast:0.0.0.0  Mask:255.255.255.0
          inet6 addr: fe80::20c:29ff:fecc:99c6/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:159 errors:0 dropped:0 overruns:0 frame:0
          TX packets:132 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:18586 (18.1 KiB)  TX bytes:21818 (21.3 KiB)

lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:41 errors:0 dropped:0 overruns:0 frame:0
          TX packets:41 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:3816 (3.7 KiB)  TX bytes:3816 (3.7 KiB)

然后看一下route2:

代码语言:javascript
复制
[root@route2 ~]# ifconfig
ens37: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.10.200  netmask 255.255.255.0  broadcast 0.0.0.0
        inet6 fe80::20c:29ff:fe27:2379  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:27:23:79  txqueuelen 1000  (Ethernet)
        RX packets 94  bytes 9235 (9.0 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 112  bytes 22335 (21.8 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1  (Local Loopback)
        RX packets 12  bytes 1020 (1020.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 12  bytes 1020 (1020.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

我们看到,route1和route2的主网口在192.168.10.0/24网络中,这也正是我们实现回环网口互通的重点,后面会详细描述。

2.为了更好地呈现实验效果,分别手动修改一下route1和2的回环网口IP

代码语言:javascript
复制
root@route1 ~]# ifconfig lo 8.8.8.8/32  #之所以需要指定掩码为32是为了申明该网络只有自己一个地址 下同
[root@route1 ~]# ifconfig lo
lo        Link encap:Local Loopback
          inet addr:8.8.8.8  Mask:0.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:41 errors:0 dropped:0 overruns:0 frame:0
          TX packets:41 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:3816 (3.7 KiB)  TX bytes:3816 (3.7 KiB)

接着修改route2的lo回环网口:

代码语言:javascript
复制
[root@route2 ~]# ifconfig lo 8.8.8.9/32    #原因同上
[root@route2 ~]# ifconfig lo
lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 8.8.8.9  netmask 0.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1  (Local Loopback)
        RX packets 12  bytes 1020 (1020.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 12  bytes 1020 (1020.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

3.我们看一下路由信息

代码语言:javascript
复制
[root@route1 ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Ifac
e
192.168.10.0    0.0.0.0         255.255.255.0   U     0      0        0 eth1

[root@route2 ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Ifac
e
192.168.10.0    0.0.0.0         255.255.255.0   U     0      0        0 ens3
7

4.将对方主机的IP设为本机的默认路由这一步非常重要。 我们先为route1添加路由信息:

代码语言:javascript
复制
[root@route1 ~]# route add -host 8.8.8.9 gw 192.168.10.200
[root@route1 ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
8.8.8.9         192.168.10.200  255.255.255.255 UGH   0      0        0 eth1
192.168.10.0    0.0.0.0         255.255.255.0   U     0      0        0 eth1

接着为route2添加路由信息:

代码语言:javascript
复制
[root@route2 ~]# route add -host 8.8.8.8 gw 192.168.10.100
[root@route2 ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Ifac
e
8.8.8.8         192.168.10.100  255.255.255.255 UGH   0      0        0 ens3
7
192.168.10.0    0.0.0.0         255.255.255.0   U     0      0        0 ens3
7

5.OK,现在我们来验证一下前面的配置

代码语言:javascript
复制
[root@route1 ~]# yum -y install tcpdump  #我们先在route1上安装抓包工具tcpdump 
[root@route2 ~]# ping -I 8.8.8.9 8.8.8.8            # 在route2上 通过PING测试并指定使用回环网卡 来测试和route1的连接性
PING 8.8.8.8 (8.8.8.8) from 8.8.8.9 : 56(84) bytes of data.
64 bytes from 8.8.8.8: icmp_seq=1 ttl=64 time=0.552 ms
64 bytes from 8.8.8.8: icmp_seq=2 ttl=64 time=0.421 ms
64 bytes from 8.8.8.8: icmp_seq=3 ttl=64 time=0.492 ms
64 bytes from 8.8.8.8: icmp_seq=4 ttl=64 time=0.515 ms

回到route1 我们看到

代码语言:javascript
复制
[root@route1 ~]# tcpdump -i eth1 icmp
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on eth1, link-type EN10MB (Ethernet), capture size 65535 bytes
06:07:33.284722 IP 8.8.8.9 > 8.8.8.8: ICMP echo request, id 9629, seq 161, length 64
06:07:33.284774 IP 8.8.8.8 > 8.8.8.9: ICMP echo reply, id 9629, seq 161, length 64
06:07:34.286734 IP 8.8.8.9 > 8.8.8.8: ICMP echo request, id 9629, seq 162, length 64
06:07:34.286768 IP 8.8.8.8 > 8.8.8.9: ICMP echo reply, id 9629, seq 162, length 64
06:07:35.288463 IP 8.8.8.9 > 8.8.8.8: ICMP echo request, id 9629, seq 163, length 64
06:07:35.288495 IP 8.8.8.8 > 8.8.8.9: ICMP echo reply, id 9629, seq 163, length 64
06:07:36.290517 IP 8.8.8.9 > 8.8.8.8: ICMP echo request, id 9629, seq 164, length 64
06:07:36.290549 IP 8.8.8.8 > 8.8.8.9: ICMP echo reply, id 9629, seq 164, length 64
06:07:37.293046 IP 8.8.8.9 > 8.8.8.8: ICMP echo request, id 9629, seq 165, length 64
06:07:37.293104 IP 8.8.8.8 > 8.8.8.9: ICMP echo reply, id 9629, seq 165, length 64
06:07:38.294611 IP 8.8.8.9 > 8.8.8.8: ICMP echo request, id 9629, seq 166, length 64
06:07:38.294644 IP 8.8.8.8 > 8.8.8.9: ICMP echo reply, id 9629, seq 166, length 64
06:07:39.296849 IP 8.8.8.9 > 8.8.8.8: ICMP echo request, id 9629, seq 167, length 64
06:07:39.296882 IP 8.8.8.8 > 8.8.8.9: ICMP echo reply, id 9629, seq 167, length 64
06:07:40.299690 IP 8.8.8.9 > 8.8.8.8: ICMP echo request, id 9629, seq 168, length 64
06:07:40.299727 IP 8.8.8.8 > 8.8.8.9: ICMP echo reply, id 9629, seq 168, length 64
06:07:41.300620 IP 8.8.8.9 > 8.8.8.8: ICMP echo request, id 9629, seq 169, length 64

6.通过上述测试,可以确定连接性测试成功。


本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017/08/20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档