Linux环境下如何添加路由的详细步骤与方法?

在Linux系统中,路由表是网络通信的核心,它决定了数据包的转发路径,正确配置路由可以确保跨网段通信、实现负载均衡或指定特定出口,本文将详细介绍Linux下添加路由的方法,包括临时路由和永久路由的配置,涵盖不同发行版的操作差异,并通过表格对比关键参数,最后解答常见问题。

.linux 下如何添加路由

临时路由添加(重启失效)

临时路由适用于测试场景或临时需求,重启系统或网络服务后配置会丢失,主要使用ip route add命令(推荐,现代Linux发行版默认)或route命令(传统工具,逐渐被替代)。

使用ip route add命令

基本语法为:
sudo ip route add <目标网络/子网掩码> via <网关地址> dev <网络接口> [metric <跃点数>] [table <路由表>]

  • 目标网络/子网掩码:要到达的网络,如168.2.0/24(表示目标网段为192.168.2.0,子网掩码255.255.255.0)。
  • via <网关地址>:下一跳路由器的IP,如168.1.1
  • dev <网络接口>:出站网络接口,如eth0ens33,可通过ip a查看。
  • metric <跃点数>:路由优先级,值越小优先级越高,默认0。
  • table <路由表>:指定路由表(默认为main),用于策略路由。

示例

  • 添加默认路由(所有未知网段流量通过网关10.0.0.1):
    sudo ip route add default via 10.0.0.1 dev eth0
  • 添加特定网段路由(目标192.168.3.0/24通过网关192.168.1.254,接口ens33,跃点数100):
    sudo ip route add 192.168.3.0/24 via 192.168.1.254 dev ens33 metric 100
  • 添加主机路由(仅目标主机192.168.1.100通过网关192.168.1.1):
    sudo ip route add 192.168.1.100/32 via 192.168.1.1 dev eth0

使用route命令(传统工具)

语法为:
sudo route add -net <目标网络> netmask <子网掩码> gw <网关地址> dev <网络接口>

示例
sudo route add -net 192.168.2.0 netmask 255.255.255.0 gw 192.168.1.1 dev eth0

临时路由的删除与查看

  • 查看路由表:ip route showroute -n-n表示以数字形式显示,避免DNS解析延迟)。
  • 删除路由:sudo ip route del <目标网络/子网掩码>,如sudo ip route del 192.168.3.0/24

永久路由添加(重启生效)

临时路由无法满足长期需求,需通过修改配置文件实现永久保存,不同Linux发行版的配置方式差异较大,主要分为systemd-networkdNetplan(Ubuntu/Debian)和NetworkManager(CentOS/RHEL)等。

.linux 下如何添加路由

Ubuntu/Debian(Netplan配置,较新版本)

Netplan使用YAML配置文件,通常位于/etc/netplan/目录下(如01-netcfg.yaml)。

步骤

  1. 编辑配置文件:sudo nano /etc/netplan/01-netcfg.yaml
  2. 添加路由配置,示例如下:
    network:
      version: 2
      ethernets:
        eth0:
          dhcp4: no
          addresses: [192.168.1.10/24]  # 本机IP
          gateway4: 192.168.1.1         # 默认网关
          routes:
            - to: 192.168.2.0/24        # 目标网段
              via: 192.168.1.254         # 下一跳网关
              metric: 100                # 优先级
            - to: 10.0.0.0/8             # 另一个目标网段
              via: 192.168.1.254
              metric: 150
          nameservers:
            addresses: [8.8.8.8, 114.114.114.114]
  3. 应用配置:sudo netplan apply

CentOS/RHEL(NetworkManager配置)

NetworkManager通过nmcli命令或配置文件管理路由。

方法1:使用nmcli命令

# 添加静态路由(目标192.168.3.0/24,网关192.168.1.254,接口eth0,跃点数100)
sudo nmcli connection modify "eth0" +ipv4.routes "192.168.3.0/24 192.168.1.254 100"
# 激活配置(无需重启,立即生效)
sudo nmcli connection up "eth0"

方法2:修改NetworkManager配置文件
编辑/etc/sysconfig/network-scripts/route-<接口名>(如route-eth0),添加:

ADDRESS0=192.168.3.0
NETMASK0=255.255.255.0
GATEWAY0=192.168.1.254
METRIC0=100

重启网络服务:sudo systemctl restart network

.linux 下如何添加路由

通用方法(直接修改路由表配置文件)

部分系统可通过修改/etc/rc.local(需赋予执行权限)或创建/etc/network/if-up.d/下的脚本实现开机自动添加路由,但不如上述方法稳定,不推荐。

关键参数对比与示例

下表总结了不同场景下路由配置的核心参数及示例:

场景 命令/配置 说明
添加默认路由 sudo ip route add default via 10.0.0.1 dev eth0 所有未知网段流量通过10.0.0.1
添加特定网段路由 sudo ip route add 192.168.2.0/24 via 192.168.1.254 dev ens33 目标192.168.2.0/24的流量通过192.168.1.254
添加主机路由 sudo ip route add 192.168.1.100/32 via 192.168.1.1 dev eth0 仅目标主机192.168.1.100的流量通过192.168.1.1
永久路由(Ubuntu) routes: - to: 192.168.3.0/24 via: 192.168.1.254 metric: 100(Netplan) 写入Netplan配置文件,重启生效
永久路由(CentOS) nmcli connection modify "eth0" +ipv4.routes "192.168.3.0/24 192.168.1.254" 使用NetworkManager管理,无需重启网络服务

相关问答FAQs

Q1:为什么添加的路由重启后消失了?
A:临时路由(通过ip route add添加)仅在当前会话中生效,重启系统或网络服务后会丢失,要实现永久生效,需根据发行版修改对应配置文件(如Ubuntu的Netplan、CentOS的NetworkManager),或使用nmcli等工具保存配置。

Q2:如何添加一条到达特定主机(而不是网络)的路由?
A:添加主机路由时,需将目标地址的子网掩码设置为32(IPv4)或128(IPv6),表示精确匹配该主机IP,添加到主机168.1.100的路由,命令为:sudo ip route add 192.168.1.100/32 via 192.168.1.1 dev eth0,在Netplan配置中则写为to: 192.168.1.100/32

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/35004.html

(0)
酷番叔酷番叔
上一篇 2025年10月3日 11:13
下一篇 2025年10月3日 11:26

相关推荐

  • Linux中如何终止正在运行的代码?

    在Linux系统中,终止运行中的代码(即进程)是日常管理和运维中的常见操作,无论是由于进程卡死、资源占用过高,还是任务执行错误,都需要通过合适的方式终止进程以释放系统资源,Linux提供了多种终止进程的方法,涵盖命令行工具、信号机制、进程管理工具等,本文将详细介绍这些方法的使用场景、操作步骤及注意事项,基础终止……

    2025年10月7日
    3800
  • 运维工作中Linux的具体应用场景与操作技巧有哪些?

    Linux作为开源操作系统的核心代表,凭借其稳定性、安全性和高度的可定制性,已成为运维工作中不可或缺的基础平台,从服务器管理到自动化部署,从监控告警到安全防护,Linux几乎渗透到运维的每一个环节,为保障业务连续性和系统高效运行提供了核心支撑,在服务器基础管理中,Linux是运维人员最直接的操作环境,通过命令行……

    2025年10月7日
    3100
  • Linux系统如何彻底关闭IPv6网络功能的具体方法?

    在Linux系统中,关闭IPv6功能通常出于兼容性需求、安全策略简化或网络环境限制等考虑,IPv6虽然作为IPv4的替代方案提供了更大的地址空间和更好的性能,但在纯IPv4网络或特定应用场景下,关闭IPv6可以避免潜在的网络配置冲突或安全风险,以下是Linux系统中关闭IPv6的详细方法,涵盖临时关闭、永久关闭……

    2025年8月27日
    4700
  • 虚拟机中linux如何全屏显示

    虚拟机中,可以通过安装VMware Tools或VirtualBox Guest Additions,然后重启虚拟机

    2025年8月17日
    5900
  • 手机如何连接Linux系统软件?详细操作步骤与方法解析

    手机与Linux系统的连接需求在日常工作、开发调试或文件管理中较为常见,无论是通过有线方式快速传输文件,还是通过无线方式远程管理系统,掌握正确的连接方法都能显著提升效率,本文将详细介绍多种连接方式,包括USB有线连接、网络无线连接(如SSH、VNC、SFTP)及第三方工具的使用步骤,帮助用户根据实际场景选择合适……

    2025年9月20日
    4500

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信