CentOS6 Linux系统添加永久静态路由的方法

一、使用route命令添加route 命令

设置和查看路由表都可以用 route 命令,设置内核路由表的命令格式是:

# route  [add|del] [-net|-host] target [netmask Nm] [gw Gw] [[dev] If]

其中:

  • add : 添加一条路由规则
  • del : 删除一条路由规则
  • -net : 目的地址是一个网络
  • -host : 目的地址是一个主机
  • target : 目的网络或主机
  • netmask : 目的地址的网络掩码
  • gw : 路由数据包通过的网关
  •  route 命令的输出项说明 输出项  说明
    Destination目标网段或者主机
    Gateway网关地址,”*” 表示目标是本主机所属的网络,不需要路由
    Genmask网络掩码
    Flags标记。一些可能的标记如下:
     U — 路由是活动的
     H — 目标是一个主机
     G — 路由指向网关
     R — 恢复动态路由产生的表项
     D — 由路由的后台程序动态地安装
     M — 由路由的后台程序修改
     ! — 拒绝路由
    Metric路由距离,到达指定网络所需的中转数(linux 内核中没有使用)
    Ref路由项引用次数(linux 内核中没有使用)
    Use此路由项被路由软件查找的次数
    Iface该路由表项对应的输出接口
        
  • dev : 为路由指定的网络接口
  •  
  • 使用route 命令添加的路由,机器重启或者网卡重启后路由就失效了,方法:
    A、添加到主机的路由
    # route add –host 192.168.1.10 dev eth0
    # route add –host 192.168.1.10 gw 192.168.1.1
    B、添加到网络的路由
    # route add –net 192.168.1.0  netmask 255.255.255.0 eth0
    # route add –net 192.168.1.0  netmask 255.255.255.0 gw 192.168.1.1
    # route add –net 192.168.1.0/24 eth1
    C、添加默认网关
    # route add default gw 192.168.1.1
    D、删除路由
    # route del –host 192.168.1.10 dev eth0
     
    二、添加永久路由
     
    A、# vi /etc/rc.local(添加到末尾)
    语句:
    route add -net 192.168.3.0/24 dev eth0
    route add -net 192.168.2.0/24 gw 192.168.2.254
     
    B、# vi /etc/sysconfig/network (添加到末尾)
    语句:GATEWAY=gw-ip 或者 GATEWAY=gw-dev
     
    C、# vi /etc/sysconfig/static-routes (没有static-routes的话就手动建立一个这样的文件)
    语句:
    any net 192.168.3.0/24 gw 192.168.3.254
    any net 10.250.228.128 netmask 255.255.255.192 gw 10.250.228.129
     
    D、开启 IP 转发:
    # echo "1" >/proc/sys/net/ipv4/ip_forward (临时)
    # vi /etc/sysctl.conf --> net.ipv4.ip_forward=1 (永久开启)
     
        如果在rc.local中添加路由会造成NFS无法自动挂载问题,所以使用static-routes的方法是最好的。无论重启系统和service network restart 都会生效。
     
        按照linux启动的顺序,rc.local里面的内容是在linux所有服务都启动完毕,最后才被执行的,也就是说,这里面的内容是在netfs之后才被执行的,那也就是说在netfs启动的时候,服务器上的静态路由是没有被添加的,所以netfs挂载不能成功。static-routes文件又是什么呢,这个是network脚本执行时调用的一个文件,这个文件的放在/etc/sysconfig目录下,在network脚本中的位置是:
     
    # Add non interface-specific static-routes.
      if [ -f /etc/sysconfig/static-routes ]; then
         grep "^any" /etc/sysconfig/static-routes | while read ignore args ; do
             /sbin/route add -$args
          done
       fi
     
    从这段脚本可以看到,这个就是添加静态路由的方法,static-routes的写法是:
     
    any net 192.168.1.0/16 gw 网关ip
     
        这样的话,在启动network脚本的时候路由就自动添加上了,又因为network是在netfs前面启动的,自然在挂载nfs的时候就正常了。这样看来,如果需要添加静态路由,使用static-routes文件要比使用rc.local好,而且当改变了网络配置,需要重启network脚本的时候,相应的静态路由是可以自动添加上的,但这时如果使用rc.local的话,在重启network服务的时候,原本添加好的静态路由就消失了。

本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2012-05/61253.htm

 

Linux添加永久路由可以使用“route”命令和编辑“/etc/sysconfig/network-scripts/route-<interface>”文件的方式进行操作,下面分别介绍。 1. 使用“route”命令添加永久路由 在终端中输入以下命令添加永久路由: ``` sudo route add -net <目标网络地址> netmask <子网掩码> gw <网关地址> dev <网络接口名称> ``` 其中,<目标网络地址>是需要添加路由的目标网络地址,<子网掩码>是子网掩码,<网关地址>是下一跳路由的网关地址,<网络接口名称>是本地网络接口的名称。 例如,添加一个路由到192.168.1.0/24网络,网关地址为192.168.0.1,网络接口为eth0,命令如下: ``` sudo route add -net 192.168.1.0 netmask 255.255.255.0 gw 192.168.0.1 dev eth0 ``` 该命令只是暂时生效,重启后会失效。如果需要永久生效,需要在“/etc/rc.local”文件中添加上述命令。 2. 编辑“/etc/sysconfig/network-scripts/route-<interface>”文件添加永久路由 另一种方式是编辑“/etc/sysconfig/network-scripts/route-<interface>”文件添加永久路由。该文件是网络接口配置文件的一部分,每个网络接口都有一个对应的route文件,修改该文件可添加此接口的静态路由。 步骤如下: 1. 执行以下命令打开文件: ``` sudo vi /etc/sysconfig/network-scripts/route-<interface> ``` 其中,<interface>是需要添加静态路由的网络接口名称,可以通过运行“ip addr”命令查看。 2. 在文件中添加以下内容: ``` <目标网络地址>/<子网掩码> via <网关地址> dev <网络接口名称> ``` 例如,添加一个路由到192.168.1.0/24网络,网关地址为192.168.0.1,网络接口为eth0,内容如下: ``` 192.168.1.0/24 via 192.168.0.1 dev eth0 ``` 3. 保存文件并退出。路由会在下次重启后生效。 总结 上述两种方式都可以添加永久路由,但是推荐使用第二种方式。因为第一种方式要在“/etc/rc.local”文件中添加命令,如果该文件被配置错误或重启机器后重新配置了iptables/网络、IP等信息后,可能会导致命令失效或无法执行。而第二种方式在文件中添加路由,更清晰可读,且添加的路由会随着网络接口的连接和断开而自动添加和删除,更加方便。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值