• linux -- 添加、修改、删除路由


    在日常的使用中,或者在服务器中,有两个网卡配置两个地址,访问不同的网络段,这种情况是非常常见的现象,但是,我们需要额外的添加路由表来决定发送的数据包经过正确的网关和interface才能正确的进行通信
     

    显示现在所有路由

    #route
    root@Ubuntu:~# route
    Kernel IP routing table
    Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
    10.147.9.0      *               255.255.255.0   U     1      0        0 eth0
    192.168.1.0     *               255.255.255.0   U     2      0        0 wlan0
    192.168.122.0   *               255.255.255.0   U     0      0        0 virbr0
    link-local      *               255.255.0.0     U     1000   0        0 eth0
    192.168.0.0     192.168.1.1     255.255.0.0     UG    0      0        0 wlan0
    default         10.147.9.1      0.0.0.0         UG    0      0        0 eth0
    root@ubuntu:~# 
    结果是自上而下, 就是说, 哪条在前面, 哪条就有优先, 前面都没有, 就用最后一条default

    Destination:为路由目标,可以是网络或主机的IP地址;

    Gateway:包含默认网关或通过其可访问主机或网络的网关;

    Genmask:包含网关后的网络或主机的子网掩码;

    Iface:表示该条路由从哪个设备出去。


    举例, 添加一条路由(发往192.168.62这个网段的全部要经过网关192.168.1.1)
    route add -net 192.168.62.0 netmask 255.255.255.0 gw 192.168.1.1


    删除一条路由
    route del -net 192.168.122.0 netmask 255.255.255.0

    删除的时候不用写网关

    linux下添加路由的方法:

    一:使用 route 命令添加
    使用route 命令添加的路由,机器重启或者网卡重启后路由就失效了,方法:
    //添加到主机的路由
    # route add –host 192.168.168.110 dev eth0
    # route add –host 192.168.168.119 gw 192.168.168.1
    //添加到网络的路由
    # route add –net IP netmask MASK eth0
    # route add –net IP netmask MASK gw IP
    # route add –net IP/24 eth1
    //添加默认网关
    # route add default gw IP
    //删除路由
    # route del –host 192.168.168.110 dev eth0

    二:在linux下设置永久路由的方法: 
    1.在/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 

    route add –net 180.200.0.0 netmask 255.255.0.0 gw 10.200.6.201 dev eth0 metric 1

    route add:命令关键字,表示增加路由,若要删除路由,则为route del;

    -host/-net:表示路由目标是主机还是网段;

    netmask:表示路由目标为网段时才会使用到,表示路由目标网段的子网掩码;

    gw:命令关键字,后面跟下一跳网关;

    dev:命令关键字,后面跟具体设备名,表示路由是从该设备出去。

    metric:为路由指定所需跃点数的整数值(范围是 1 ~ 9999),它用来在路由表里的多个路由中选择与转发包中的目标地址最为匹配的路由。所选的路由具有最少的跃点数。跃点数能够反映跃点的数量、路径的速度、路径可靠性、路径吞吐量以及管理属性。


    2.在/etc/sysconfig/network里添加到末尾 
    方法:GATEWAY=gw-ip 或者 GATEWAY=gw-dev 


    3./etc/sysconfig/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 


    如果在rc.local中添加路由会造成NFS(网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源)无法自动挂载问题,所以使用static-routes的方法是最好的。无论重启系统和service network restart 都会生效 

    以下是解决NFS问题的描述: 

    按照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.0.0/16 gw 网关ip

    这样的话,在启动network脚本的时候路由就自动添加上了,又因为network是在netfs前面启动的,自然在挂载nfs的时候就正常了。 
    这样看来,如果需要添加静态路由,使用static-routes文件要比使用rc.local好,而且当改变了网络配置,需要重启network脚本的 时候,相应的静态路由是可以自动添加上的,但这时如果使用rc.local的话,在重启network服务的时候,原本添加好的静态路由就消失了。

  • 相关阅读:
    第09组 Beta版本演示
    第09组 Beta冲刺(5/5)
    第09组 Beta冲刺(4/5)
    网络对抗技术 2017-2018-2 20155215 Exp9 Web安全基础
    网络对抗技术 2017-2018-2 20152515 Exp 8 Web基础
    网络对抗技术 2017-2018-2 20152515 Exp7 信息搜集与漏洞扫描
    网络对抗技术 2017-2018-2 20152515 Exp6 信息搜集与漏洞扫描
    网络对抗技术 2017-2018-2 20152515 Exp5 MSF基础应用
    网络对抗技术 2017-2018-2 20152515 Exp4 恶意代码分析
    网络对抗技术 2017-2018-2 20152515 Exp3 免杀原理与实践
  • 原文地址:https://www.cnblogs.com/hf8051/p/4530906.html
Copyright © 2020-2023  润新知