配置静态路由表 – Linux

查看当前路由表

使用命令netstatroute -n查看当前路由表。

命令
$ netstat -nr
Kernel IP routing table
Destination Gateway Genmask Flags MSS Window irtt Iface
0.0.0.0 192.168.50.1 0.0.0.0 UG 0 0 0 ens37
192.168.50.0 0.0.0.0 255.255.255.0 U 0 0 0 ens37
192.168.50.0 0.0.0.0 255.255.255.0 U 0 0 0 ens37
192.168.122.0 0.0.0.0 255.255.255.0 U 0 0 0 virbr0
192.168.189.0 0.0.0.0 255.255.255.0 U 0 0 0 ens33

追加记录到路由表

追加路由表有临时、永久两种方式。可通过命令或修改配置文件实现。

临时追加

可通过命令行实现追加路由表。此处使用routeip这两种方式。

route命令

・追加路由表

命令
$ route add -net 172.20.0.0 gw 172.20.0.1 netmask 255.255.0.0 ens33

・追加特定host(的路由)

命令
$ route add -host 172.20.233.10 gw 172.20.0.1 ens33

-net变成-host后,不需要子网掩码netmask
另外,单一网卡时,可以不必要指定接口ens33 。

ip命令

・network的追加
命令
$ ip route add 172.20.0.0/16 via 172.20.0.1 dev ens33
・追加单个host
命令
$ ip route add 172.20.39.128/32 via 172.20.0.1 dev ens33

此处,host与network的区别仅在子网掩码,添加具体host时使用/32。

永久追加(以CentOS为例)

使用命令追加的话,系统一旦重启,设定即会消失。
下文将介绍使路由表永久生效的方法。

文件
$ cat /etc/sysconfig/network-scripts/route-ens33 
# Static route for metadata service
172.20.0.0/16 via 172.20.0.1 dev ens33 // 设置network路由表时
192.168.189.123/32 via 192.168.189.1 dev ens37 // 指定具体host的路由时
文件
$ systemctl restart network.service

查看路由表

设定后的结果如下所示。

命令
$ netstat -nr
Kernel IP routing table
Destination     Gateway         Genmask         Flags   MSS Window  irtt Iface
0.0.0.0         172.20.0.1      0.0.0.0         UG        0 0          0 ens33
172.20.0.0      172.20.0.1      255.255.0.0     UG        0 0          0 ens33
192.168.189.123 192.168.189.1   255.255.255.255 UGH       0 0          0 ens37

删除路由表

删除路由表也有临时与永久两种方式。同理,单行命令删除为临时;永久删除需要修改配置文件。

临时删除

临时删除与追加一样使用同一个命令,routeip

route命令

・删除网段(network)记录

命令
$ route del -net 172.20.0.0 gw 172.20.0.1 netmask 255.255.0.0 ens33

・hostの削除

命令
$ route del -host 192.168.189.128 gw 192.168.189.1 ens37

与追加的时候相同,networkhost的区别在于-net变成-host的时候,不需要子网掩码netmask。且可以不写ens33

ip命令

・删除网段的路由表

命令
$ ip route del 172.20.0.0/16

・删除具体host的路由表

命令
$ ip route del 192.168.189.128/32

同理,与追加的时候一样,更改单个host路由表时,子网掩码只用写/32

永久删除

仅需要将上文配置文件中添加的部分删除,重启服务即可。

确认

命令
$ netstat -nr
Kernel IP routing table
Destination     Gateway         Genmask         Flags   MSS Window  irtt Iface
0.0.0.0         172.20.0.1      0.0.0.0         UG        0 0          0 ens33
172.20.0.0      172.20.0.1      255.255.0.0     UG        0 0          0 ens33
192.168.189.123 192.168.189.1   255.255.255.255 UGH       0 0          0 ens37

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

(3)
上一篇 2018-06-12 15:45
下一篇 2018-06-12 15:59

相关推荐

  • Week 1 — 03 Linux哲学思想

    Linux的哲学思想包括: 一切皆文件:所有的资源在linux上都以文件的形式存在,如硬件设备、进程、socket等。 由众多目的单一的小程序组成,多个程序组合完成任务。 文本文件保存配置信息:可以使用文本编辑器修改配置文件。 尽量避免跟用户交互:程序运行后不需要用户进行操作。

    Linux笔记 2018-08-15
  • liunx 基础

    简单命令:

    Linux笔记 2018-04-01
  • grep、vim及用户和组练习

    grep
    chown
    chmod
    vim

    2018-07-23
  • 用户和组管理以及grep文本处理实例

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 who | cut -d” ” -f1 | sort -u 2、取出最后登录到当前系统的用户的相关信息。 who | tail -1 3、取出当前系统上被用户当作其默认shell的最多的那个shell。 cut -d: -f7 /etc/pas…

    Linux笔记 2018-08-14
  • dns看图来配,思路一下明了

      1.子域授权: 每个域的名称服务器,都是通过其上级名称服务在解析库中进行授权。 如:根域授权顶级域是怎么做的? 说明.com.这个域   它的ns服务器是主机名ns1.com.;2.com. .com.     IN  NS    ns1.com. .com.     IN  NS    ns2.com. ns1.com.   IN   A  …

    Linux笔记 2018-06-03
  • centos7 搭建yum服务器

    准备工作接下来就要开始正式的安装工作了,不过在正式开始之前,还需稍作准备,以确保实验的成功。由于yum服务器是在局域网里面为众多的客户机提供访问服务,所以要在防火墙上打开相应的访问端口,客户机才能进行访问,如果不在防火墙上打开相应的端口或关闭防火墙,即使服务器配置成功,客户机也无法进行访问。所以为了实验的简单易懂,我在这里就为大家直接演示如何关闭Linux上…

    2018-08-20