NotePublic/Software/System/Linux/Modules/Network/Linux_网络配置.md

6.2 KiB
Raw Blame History

Linux 网络配置

1. 路由表配置

简单来说,路由器就是一个公交站台,公交站台上面有很多路公交。每条线路公交车又有很多站台(路由器),你就会选择最近的一条公交出行方案,当然啦,站牌上面的路线是会经常更新,更新的事,有当地部门更新。这就是路由。一台电脑主机有路由表,路由器也有路由表,一般来说,一台主机电脑如果只有一个网卡的话,应该会有最少两条路由信息,一条是公网路由,一条是局域网路由(它是不会经过路由器的路由表的,因为它走的是链路层,所以可以解析我们在局域网内传数据,速度是很快的)。

1.1. Linux 内核的路由种类

1.1.1. 主机路由

路由表中指向单个 IP 地址或主机名的路由记录,其 Flags 字段为 H。下面示例中对于 10.0.0.10 这个主机,通过网关 10.139.128.1 网关路由:

[root@VM_139_74_centos ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
10.0.0.10       10.139.128.1    255.255.255.255 UGH   0      0        0 eth0
...

1.1.2. 网络路由

主机可以到达的网络。下面示例中,对于 10.0.0.0/24 这个网络,通过网关 10.139.128.1 网关路由:

[root@VM_139_74_centos ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
10.0.0.0        10.139.128.1    255.255.255.0   UG    0      0        0 eth0

1.1.3. 默认路由

当目标主机的 IP 地址或网络不在路由表中时,数据包就被发送到默认路由(默认网关)上。默认路由的 Destination 是 default 或 0.0.0.0。

[root@VM_139_74_centos ~]# route
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
default         gateway         0.0.0.0         UG    0      0        0 eth0

1.2. Route 命令

route 命令可以显示或设置 Linux 内核中的路由表,主要是静态路由。

对于局域网中的 Linux 主机,要想访问 Internet需要将局域网的网关 IP 地址设置为这个主机的默认路由。在命令行中通过 route 命令添加的路由在网卡重启或机器重启后失效。可以在 /etc/rc.local 中添加 route 命令来保证路由设置永久有效。

选项:

  • -A设置地址类型
  • -C打印 Linux 内核的路由缓存
  • -v显示详细信息
  • -n不执行 DNS 反向查找,直接显示数字形式的 IP 地址
  • -enetstat 格式显示路由表
  • -net到一个网络的路由表
  • -host到一个主机的路由表

参数:

  • add增加路由记录
  • del删除路由记录
  • target目的网络或目的主机
  • gw设置默认网关
  • mss设置TCP的最大区块长度MSS单位MB
  • window指定通过路由表的TCP连接的TCP窗口大小
  • dev路由记录所表示的网络接口

1.2.1. 添加路由 add

可以添加一条可用路由,或添加一条要屏蔽的路由。

1.2.1.1. 添加主机路由

添加主机路由时,需要指定网络 ID 和主机 ID此时需要设置 netmask 255.255.255.255

[root@VM_139_74_centos ~]# route add -net 10.0.0.10 netmask 255.255.255.255 gw 10.139.128.1 dev eth0
[root@VM_139_74_centos ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
10.0.0.10       10.139.128.1    255.255.255.255 UGH   0      0        0 eth0
...
1.2.1.2. 添加网络路由

添加网络路由时,只需指定网络 ID通过 netmask 设置掩码长度:

[root@VM_139_74_centos ~]# route add -net 10.0.0.0 netmask 255.255.255.0 gw 10.139.128.1 dev eth0
[root@VM_139_74_centos ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
10.0.0.0        10.139.128.1    255.255.255.0   UG    0      0        0 eth0
...
1.2.1.3. 添加添加同一个局域网的主机

不指定 gw 选项时,添加的路由记录不使用网关:

[root@VM_139_74_centos ~]# route add -net 224.0.0.0 netmask 240.0.0.0 dev eth0
[root@VM_139_74_centos ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
224.0.0.0       0.0.0.0         240.0.0.0       U     0      0        0 eth0
...

1.2.2. 屏蔽路由

[root@VM_139_74_centos ~]# route add -net 224.0.0.0 netmask 240.0.0.0 reject
[root@VM_139_74_centos ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
224.0.0.0       -               240.0.0.0       !     0      -        0 -
...

1.2.3. 删除路由记录

跟添加路由类似,可以删除一条可用路由,或删除一条屏蔽的路由。

1.2.3.1. 删除可用路由
route del -net 224.0.0.0 netmask 240.0.0.0
1.2.3.2. 删除屏蔽的路由
route del -net 224.0.0.0 netmask 240.0.0.0 reject

1.2.4. 删除和添加设置默认网关

添加或删除默认网关时Linux 会自动检查网关的可用性:

[root@VM_139_74_centos ~]# route add default gw 192.168.1.1
SIOCADDRT: Network is unreachable
[root@VM_139_74_centos ~]# route del default gw 192.168.1.1
SIOCDELRT: No such process

2. DNS 配置

/etc/resolv.conf 文件中包含了域名解析服务器配置信息,格式如下:

nameserver <name server addr>

修改完该文件后重启网络服务即可,例如:

sudo systemctl restart networking.service

一般而言,/etc/resolv.conf 文件是个软链接,其配置比较复杂,推荐使用 resolvconf 工具进行配置。

桥接

# Create a new bridge and change its state to up
ip link add name <bridge name> type bridge
ip link set <bridge name> up
# To add an interface (e.g. eth0) into the bridge, its state must be up
ip link set <eth interface> up
ip link set <eth interface> master <bridge name>
# Show the existing bridges and associated interfaces
bridge -d link
# OR
brctl show
# This is how to remove an interface from a bridge
ip link set <eth interface> nomaster
ip link delete <bridge name> type bridge