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

相关推荐

  • SUSE如何设置默认网关?

    在SUSE Linux和openSUSE上配置默认网关主要有两种方法:通过编辑/etc/sysconfig/network/routes文件永久设置,或使用ip route add default via 命令临时设置(需重启网络服务使永久配置生效)。

    2025年7月23日
    3800
  • Linux读取文件夹失败怎么办?

    确认目录存在与权限检查目录是否存在:使用ls命令查看当前目录内容,确认in文件夹存在:ls -l # 列出当前目录所有内容ls -d */ | grep in # 筛选目录名包含"in"的项验证访问权限:执行ls -ld in查看权限(示例输出):drwxr-xr-x 2 user grou……

    2025年6月16日
    4400
  • 选A还是B更明智?

    在Linux系统中,crond是cron守护进程的核心组件,负责按计划执行定时任务(如备份、清理、脚本运行等),确保crond正常运行对系统自动化至关重要,以下是多种查看crond状态的方法,适用于主流Linux发行版(如CentOS、Ubuntu、Debian):检查crond服务状态(推荐)通过系统服务管理……

    2025年6月24日
    5500
  • Linux GNU系统使用手册如何查找与正确使用?

    GNU/Linux是由GNU项目开发的自由软件工具集与Linux内核结合而成的操作系统,其核心优势在于开放性、稳定性和强大的命令行工具集,掌握GNU/Linux的使用,需要从基础概念、核心工具操作到系统管理逐步深入,以下为详细使用指南,GNU/Linux基础概念与系统安装GNU/Linux系统由内核(Linux……

    2025年10月2日
    1300
  • Linux中如何添加GC日志配置与查看?

    在Linux系统中,为Java应用添加垃圾回收(GC)日志是监控JVM内存管理、排查性能问题的重要手段,GC日志详细记录了GC的发生时间、停顿时长、回收内存大小等关键信息,有助于开发者优化JVM参数、定位内存泄漏或频繁Full GC等问题,以下从基础参数、不同GC类型配置、日志管理及分析工具等方面,详细说明Li……

    2025年10月8日
    1000

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信