使用nmcli命令在Linux系统上配置各种网络(有线、无线、vlan、vxlan、路由、网桥等)

前言:原文在我的博客网站中,持续更新数通、系统方面的知识,欢迎来访!

使用nmcli命令在Linux系统上配置各种网络(有线、无线、vlan、vxlan、路由、网桥等)icon-default.png?t=N7T8https://myweb.myskillstree.cn/123.html

        你是否会遇到在不同的Linux系统中配置网络时,修改的配置文件和语法都不一样的烦恼呢?

        各种不同的文件路径和语法,甚至Ubuntu系统中每隔几代网络配置文件就会变换位置和语法,这种情况非常不利于我们日常对系统的维护和管理。

        对于这种情况,我们可以使用NetworkManager工具在不同的系统上进行统一语法的配置与管理

        现阶段所发行的Linux版本基本都支持NetworkManager工具进行统一管理

        如果配置时发生语法错误,该工具将会暂停修改该网络,不会造成配置文件错误而导致的一系列问题

        甚至当你将原网络配置文件删除后,只要使用命令创建一个和原先参数一样的网络接口,该配置文件就会自动的重新生成

        使用该工具配置的所有网络配置文件会存于/etc/NetworkManager/system-connections/目录下

        PS:network-manager接管网络后使用nmcli命令修改网卡的相关配置后会永久生效(重启网卡后依旧生效)

目录

一、配置NetworkManager接管网络(选)

二、nmcli的相关配置

有线网络配置

使用nmcli添加一个网卡并配置静态ip地址

激活/关闭网卡

使用nmcli修改一个网卡的地址

使用nmcli添加一个网卡配置使其获取动态ip地址

使用nmcli将已有的静态网卡配置修改为动态网卡配置

使用nmcli将已有的动态网卡配置修改为静态网卡配置

使用nmcli删除一个网卡配置信息

使用nmcli为一张网卡配置多个ip地址

使用nmcli修改网卡设备的连接名称

无线网络配置(需要有无线网卡)

打开/关闭无线网络开关

查看无线网络开关状态:

连接无线网络

        扫描可用的无线网络

连接到无线网络

查看连接状态

查看连接的详细信息

开启无线热点(AP模式)

查看当前无线网卡是否支持AP模式:

为无线网卡接口配置地址

安装dhcp服务

进行源地址转换SNAT

开启路由转发

重启DHCP服务和新建WiFi热点

其他设置:

VLAN相关配置

创建vlan

网桥Bridge配置

创建名为br-vxlan的网桥

VXLAN配置

单播模式(点对点)

多播模式(点对多点)

在host1配置,使用多播模式

在host2配置,使用多播模式

互ping测试

VXLAN+网桥网络(Bridge)+组播

host1创建vxlan+bridge+组播网络:

host2创建vxlan+bridge+组播网络:

静态路由相关配置

三、总结


一、配置NetworkManager接管网络(选)

如果系统默认自带了NetworkManager工具就不用做此步,如果是后期手动安装的就需要配置接管网络

安装Network-Manager并启动

apt install network-manager -y
systemctl restart NetworkManager
systemctl enable NetworkManager

配置NetworkManager接管网络

        语法:

nmcli net <on/off>

        示例:

nmcli net on

此时已经可以通过nmcli管理网络了

        使用nmcli -p device查看设备状态  

nmcli -p device
============设备状态
============
DEVICE  TYPE      STATE   CONNECTION 
--------------------------------------------------
ens32   ethernet  已连接  有线连接 1 
lo      loopback  未托管  --         

二、nmcli的相关配置

有线网络配置

使用nmcli添加一个网卡并配置静态ip地址

        语法:

nmcli con add con-name <连接名> ifname <网卡名> type <连接类型> ipv4.method manual ipv4.addresses <ipv4地址> ipv4.gateway <ipv4网关地址> ipv4.dns <ipv4 dns服务器>

        注意:如果想要添加两个dns地址应该用双引号" "将两个地址包起来,表示两个地址都是DNS地址

        示例:

nmcli con add con-name test ifname ens32 type ethernet ipv4.method manual ipv4.addresses 192.168.10.10/24 ipv4.gateway 192.168.10.2 ipv4.dns 192.168.10.2连接 "test" (3ceeec8a-d92c-42dd-ae10-2f5478eda991) 已成功添加

        此时静态地址就配置完成了,如果不进行指定则NetworkManager默认会在接口创建的时候自动开启该接口,当然我们也可以指定某个接口的打开和关闭状态

激活/关闭网卡

        语法:

nmcli con {up/down} <连接名>

        示例:

nmcli con up test 连接已成功激活(D-Bus 活动路径:/org/freedesktop/NetworkManager/ActiveConnection/2)

        查看网卡信息

nmcli con show
NAME        UUID                                  TYPE      DEVICE 
test        3ceeec8a-d92c-42dd-ae10-2f5478eda991  ethernet  ens32  
有线连接 1   b640bf63-ac94-3547-be75-8fac06083304  ethernet  --    

使用nmcli修改一个网卡的地址

        语法:

nmcli con modify <连接名> ipv4.method manual ipv4.addresses <新的ipv4地址> ipv4.gateway <新的ipv4网关地址> ipv4.dns <dns服务器>

        示例:

nmcli con modify ens33 ipv4.method manual ipv4.addresses 192.168.10.20/24 ipv4.gateway 192.168.10.2 ipv4.dns 192.168.10.2

        刷新网卡并查看信息

nmcli con up test
ip add

使用nmcli添加一个网卡配置使其获取动态ip地址

        语法:

nmcli con add con-name <连接名> ifname <网卡名> type <连接类型> ipv4.method auto

        示例:

nmcli con add con-name test ifname ens32 type ethernet ipv4.method auto
nmcli con up test                        # 激活网卡

使用nmcli将已有的静态网卡配置修改为动态网卡配置

        语法:

nmcli con modify <连接名> ipv4.method auto

        示例:

nmcli con modify test ipv4.method auto
nmcli con up test

        然后需要将静态地址删除,否则使用ip add查看时会有两个地址出现

nmcli connection modify test ipv4.addresses "" ipv4.gateway ""  ipv4.dns ""       # 将test的静态地址设置为空,也就不存在了,只剩下了动态地址

        PS:需要先获取到dhcp地址才能删除原静态配置,否则会提示"ipv4.method=manual 不允许这个属性为空"

        当然,如果觉得麻烦,也可以将原静态连接删除后直接添加新的动态地址配置,如下:

nmcli con del test
nmcli con add con-name test ifname ens32 type ethernet ipv4.method auto

使用nmcli将已有的动态网卡配置修改为静态网卡配置

        语法:

nmcli con modify <连接名> ipv4.method manual ipv4.address <IP地址/子网掩码> ipv4.gateway <网关> ipv4.dns <dns地址>

        示例:

nmcli con modify test ipv4.method manual ipv4.address 192.168.10.20/24 ipv4.gateway 192.168.10.2 ipv4.dns 192.168.10.2
nmcli con up test

使用nmcli删除一个网卡配置信息

        语法:

nmcli con del <连接名> 

        示例:

nmcli con del test成功删除连接 "test" (3ceeec8a-d92c-42dd-ae10-2f5478eda991)

        查看网卡信息

nmcli con show
NAME        UUID                                  TYPE      DEVICE 
有线连接 1  b640bf63-ac94-3547-be75-8fac06083304  ethernet  ens32 

使用nmcli为一张网卡配置多个ip地址

首先需要先创建一个连接使其获得静态或动态ip地址才能在此基础上增加地址,这里不再讲述配置静态或动态地址的命令,直接进行增加地址的配置

        语法:

nmcli con modify <连接名> +ipv4.address <ipv4地址> ipv4.gateway <网关> ipv4.dns <dns地址>

        示例:

nmcli con modify ens32 +ipv4.address 192.168.10.160/24 ipv4.gateway 192.168.10.254 ipv4.dns 114.114.114.114
nmcli con up ens32

使用nmcli修改网卡设备的连接名称

        语法:

nmcli con modify <原连接名或UUID值> connection.id <新连接名>

        示例:

        先查看网卡设备的各项信息

nmcli con show
NAME        UUID                                  TYPE      DEVICE 有线连接 1   b640bf63-ac94-3547-be75-8fac06083304  ethernet  ens32   

        修改网卡设备的连接名称为ens32

nmcli con modify b640bf63-ac94-3547-be75-8fac06083304 connection.id ens32

        再次查看网卡设备的各项信息,可以发现NAME这一栏的名称被修改了

nmcli con show
NAME        UUID                                  TYPE      DEVICE ens32       b640bf63-ac94-3547-be75-8fac06083304  ethernet  ens32   

无线网络配置(需要有无线网卡)

打开/关闭无线网络开关

        语法:

nmcli radio all <on/off>

        示例:

nmcli radio all on

查看无线网络开关状态:

        语法:

nmcli radio <all--默认>

        示例:

nmcli radio WIFI-HW  WIFI    WWAN-HW  WWAN   已启用   已启用  已启用   已启用 

连接无线网络

        扫描可用的无线网络
nmcli device wifi list

        这个命令会列出所有可用的无线网络及其详细信息。

连接到无线网络

        如果您知道无线网络的 SSID(网络名称)和密码,可以直接连接:

        语法:

nmcli dev wifi connect <SSID> password <network-password>

        示例:

nmcli device wifi con 李李密制十三香 password MySkillstree设备 "wlx0013ef6f25bd" 成功以 "c2d01c8d-47e5-41ee-8a3c-171aaddf53a8" 激活。

        如果您知道无线网络的 SSID(网络名称)但不想显示密码,可以加入-a 或 --ask参数,此参数会询问缺少的参数

        语法:

nmcli -a device wifi con <SSID>

        示例:

nmcli -a device wifi con 李李密制十三香密码: ••••••••••••设备 "wlx0013ef6f25bd" 成功以 "afc44524-ba51-452b-ae51-21f2cd2b2f6f" 激活。
查看连接状态

        连接尝试后,您可以检查连接状态:

nmcli connection showNAME            UUID                                   TYPE      DEVICE          李李密制十三香   afc44524-ba51-452b-ae51-21f2cd2b2f6f   wifi      wlx0013ef6f25bd
查看连接的详细信息

        语法:

nmcli connection show <connetcion-name>

        示例:

nmcli connection show  李李密制十三香

 

开启无线热点(AP模式)

查看当前无线网卡是否支持AP模式:

安装iw命令

apt install iw -y

使用iw命令查看当前无线网卡是否支持AP模式

iw list
或
# iw list | grep -A 20 "Supported interface modes:" | grep -B 10 "Band 1:"

查找到Supported interface modes:字段下是否有AP字样,有则代表该无线网卡支持AP模式

添加无线网络并关闭自动连接

        语法:

nmcli con add con-name <连接名> ifname <网卡名> type wifi 802-11-wireless.ssid <SSID> 802-11-wireless-security.key-mgmt <wpa-psk/wpa-eap/ieee8021x/none> 802-11-wireless-security.psk <预共享密钥> autoconnect <on/off>

        wpa-psk:这是使用预共享密钥(PSK)的WPA(Wi-Fi Protected Access)安全模式。这种模式要求所有客户端都使用相同的密码进行身份验证,是家庭和小型企业网络中常用的安全方式。wpa-psk后加psk参数和预共享密钥

        wpa-eap:这是使用扩展认证协议(EAP)的WPA安全模式。结合WPA的安全性和802.1X的认证机制,通常用于需要更高安全性的场景,如企业网络。wpa-eap后可加的参数有:802-1x.eap、802-1x.phase2-auth、802-11-wireless-security.psk、802-1x.cert-path/802-1x.private-key-path、用户名和密码等

        ieee8021x:这是使用802.1X认证协议的安全模式。在这种模式下,客户端需要通过认证服务器(如RADIUS服务器)进行身份验证。ieee8021x后可加的参数有:认证方法(如:802-1x.eap)、证书和私钥(如:EAP-TLS)、认证服务器(如:RADIUS服务器)、用户身份和密码(802-1x.identity指定用户名和802-1x.password指定密码)等

        none:这表示不使用密钥管理,即无线网络不使用加密或身份验证。这种方式非常不安全,不建议在公共或未受保护的环境中使用

        示例:

        使用wpa-psk模式创建一个最常用的无线网络连接安全模式,我这里的无线网卡设备名为:wlx0013ef6f25bd

nmcli con add con-name MySkillstree ifname wlx0013ef6f25bd type wifi 802-11-wireless.ssid MySkillstree  802-11-wireless.mode ap 802-11-wireless-security.key-mgmt wpa-psk 802-11-wireless-security.psk a1234567 autoconnect no连接 "MySkillstree" (7f0c422d-644e-4c98-b615-8eac99304139) 已成功添加。

        以上配置命令过长和繁琐,可以简写为以下命令:

nmcli con add con-name MySkillstree ifname wlx0013ef6f25bd type wifi ssid MySkillstree mode ap wifi-sec.key-mgmt wpa-psk wifi-sec.psk a1234567 autoconnect no连接 "MySkillstree" (7f0c422d-644e-4c98-b615-8eac99304139) 已成功添加。

其中:

        802-11-wireless.ssid 可缩写为 ssid

        802-11-wireless.mode ap 可缩写为 mode ap

        802-11-wireless-security 可缩写为 wifi-sec

当然如果就只使用wpa-psk模式创建简单的个人热点,也可以使用device参数进行快速创建

nmcli device wifi hotspot con-name MySkillstree ifname wlx0013ef6f25bd ssid MySkillstree password a1234567设备 "wlan0" 成功以 "1facecb6-bf75-461a-b847-b63911bb3f61" 激活。提示:"nmcli dev wifi show-password" 显示 Wi-Fi 名称和密码。
为无线网卡接口配置地址
nmcli con modify MySkillstree ipv4.method manual ipv4.address 10.0.0.1/24 ipv4.gateway 10.0.0.1 ipv4.dns 114.114.114.114
安装dhcp服务

        用于下发无线热点和管理连接到热点的设备的 DNS 和 DHCP(ubuntu、kali中为isc-dhcp-server,在centos中为dhcpd)

apt install isc-dhcp-server
vim /etc/dhcp/dhcpd.conf
修改以下内容:
subnet 10.0.0.0 netmask 255.255.255.0 {range 10.0.0.1 10.0.0.100; option domain-name-servers 114.114.114.114;option subnet-mask 255.255.255.0;option routers 10.0.0.1; option broadcast-address 10.0.0.255;
}
保存退出

        指定dhcp服务下发地址的物理接口(当系统中存在多个网卡设备,不做会报错)

vim /etc/default/isc-dhcp-server
修改以下内容:
INTERFACESv4="wlx0013ef6f25bd"
保存退出
进行源地址转换SNAT

        网关默认是不知道我们自己创建的这个ip地址的,只有使用地址转换技术NAT将无线网卡上的收到的地址转换成我们连接公网的地址才能正常访问互联网

iptables -t nat -A POSTROUTING -s 10.0.0.0/24 -o ens32 -j MASQUERADE

        查看SNAT转换列表

iptables -t nat -nvL POSTROUTINGChain POSTROUTING (policy ACCEPT 0 packets, 0 bytes)pkts   bytes  target     prot opt  in     out      source               destination         0     0    MASQUERADE   0    --  *      ens32    10.0.0.0/24          0.0.0.0/0
开启路由转发

        Linux系统默认不转发路由,只有开启路由转发后才会转发其他网卡接受到的数据包

echo "net.ipv4.ip_forward = 1" >> /etc/sysctl.conf
重启DHCP服务和新建WiFi热点
systemctl restart isc-dhcp-server
nmcli con up MySkillstree

此时通过手机连接到热点后可以正确获取地址和上网

这里还有一点要注意:

        如果是外接的usb无线网卡到虚拟机内,有可能会导致驱动和内核不匹配,即使无线网卡支持AP模式也能正常连接WiFi,但是在开启个人热点时依旧会报错802.1x认证超时

        当然以上情况会有但是不常见,但还是建议开启个人热点的话还是在自带wifi模块的Linux物理机上进行比较好

其他设置:

        对于其他设置如:动静态地址,修改连接名称,删除连接等均与有线网络设置一样,这里就不在讲述

VLAN相关配置

创建vlan

        创建一个vlan100接口并将物理网卡ens32绑定到vlan100中,这里的vlan是虚拟设备常被用做子接口配置,同样bond和team类型的网络接口也可以被配置为子接口

        语法:

nmcli con add con-name <连接名称> ifname <接口名称> type vlan id <vlan-id> dev <网卡设备> ipv4.method manual ipv4.address <ipv4地址> ipv4.gateway <网关> ipv4.dns <dns地址>

        示例:

nmcli con add con-name vlan100 ifname vlan100 type vlan id 100 dev ens32 ipv4.method manual ipv4.address 192.168.100.100/24 ipv4.gateway 192.168.100.254 ipv4.dns 114.114.114.114

网桥Bridge配置

        bridge 是内核提供的虚拟以太网桥,原理上类似于物理交换机,工作在第二层,可以将多个以太网接口连接在一起,使它们成为一个逻辑上的以太网段。这样,在同一个网桥上的设备可以直接通信,就像它们连接在同一个物理以太网上一样,同样也可以配置生成树(STP)协议

        要注意的是,绑定为bridge上的成员接口都无法配置地址且可以和bridge共用一个地址,如果要配置地址进行通信,可以配置子接口进行通信

创建名为br-vxlan的网桥

创建一个名为br-vxlan的网桥且不设置ip地址

        语法:

nmcli con add con-name <连接名> ifname <接口名> type bridge ipv4.method disabled ipv6.method disabled

        示例:

nmcli con add con-name br0 ifname br0 type bridge ipv4.method disabled ipv6.method disabled

VXLAN配置

        VXLAN可将二层报文用四层协议进行封装,即在四层网络的基础上构建一个虚拟的二层网络进行二层通信,包括广播

注意!!!

        1、请事先关闭或放行防火墙和SELinux等

        2、以下实验如果是两个ubuntu虚拟机且其中一个是克隆,配置VXLAN时当接口名称(ifname)一样时可能会出现两个vxlan接口的MAC地址一样的情况。

        正常来讲Mac地址是唯一的,但是可能因为是vmware的小bug吧,导致罕见的Mac地址会冲突

        此时可以更改接口名称(ifname)为其他的,只要VNI也就是vxlan的id值一样就不影响,或者使用工具将某一vxlan接口的mac地址修改但这种方法通常关机后会恢复

        这种情况下使用wireshark抓包只能抓到对放发来的arp报文,但是没有arp回应报文,因为双方的mac地址一样,会被误以为是自己发的,就不会发送arp回复报文。

单播模式(点对点)

        语法:

nmcli con add con-name <连接名> ifname <接口名> type vxlan id <vni> local <本地地址> remote <对端地址> destination-port <UDP端口,默认为4789> dev <设备名> ipv4.method manual ipv4.address <ipv4地址> ipv4.gateway <网关> ipv4.dns <dns地址>

        示例:

        创建名为 vxlan100 的 vxlan 接口,指定其 vni、对端 ip、目的 udp 端口和本设备上承载 vxlan 流量的物理接口

nmcli con add con-name vxlan100 ifname vxlan100 type vxlan id 100 local 192.168.10.100 remote 192.168.10.200 destination-port 4789 dev ens32 ipv4.method manual ipv4.address 172.16.0.1/24 ipv4.gateway 172.16.0.254
nmcli con up vxlan100 

        查看 vxlan0 的详细信息

ip -d link show vxlan100

        查看系统路由表会发现多了172.16.1.0/24网段的路由表

route -n
内核 IP 路由表
目标            网关            子网掩码        标志  跃点    引用     使用 接口
0.0.0.0         192.168.10.2    0.0.0.0         UG    100    0        0 ens32
0.0.0.0         172.16.0.254    0.0.0.0         UG    20500  0        0 vxlan100
169.254.0.0     0.0.0.0         255.255.0.0     U     1000   0        0 ens32
172.16.0.0      0.0.0.0         255.255.255.0   U     500    0        0 vxlan100
192.168.10.0    0.0.0.0         255.255.255.0   U     100    0        0 ens32

        查看vxlan的fdb表(转发表)

bridge fdb show dev vxlan10000:00:00:00:00:00 dst 192.168.10.200 via ens32 self permanent

        这个表项的意思是,默认的VTEP对端地址为 192.168.10.200。换句话说,原始报文经过vxlan0后,会被内核加上VXLAN头部,而外部UDP头部的目的IP地址为192.168.10.200(源VTEP封包过程)

        此时对端设备也配置vxlan100

        保证VNI也是100,dstport也是4789,并修改VTEP的local和remote IP地址的值

nmcli con add con-name vxlan100 ifname vxlan100 type vxlan id 100 local 192.168.10.200 remote 192.168.10.100 destination-port 4789 dev ens32 ipv4.method manual ipv4.address 172.16.0.2/24 ipv4.gateway 172.16.0.254
nmcli con up vxlan100

        ping测试

ping 172.16.0.2 -I 172.16.0.1

多播模式(点对多点)

        要组成同一个VXLAN网络,VTEP必须能够感知到彼此的存在,多播组本身的功能就是把网络中的某个节点组成一个虚拟的组,所以VXLAN最初想到用多播来实现也是很自然的。

        注意,如果VXLAN要使用多播,那么底层网络结构需要支持多播功能

        本实验与前面的实验比较相似,只不过主机之间不是点对点的连接,而是通过多播组成一个虚拟的整体。

在host1配置,使用多播模式

        此时参数remote应指定相同的多播地址(范围: 224.0.0.0~239.255.255.255)

nmcli con add con-name vxlan101 ifname vxlan101 type vxlan id 101 local 192.168.10.100 remote 239.1.1.1 destination-port 4789 dev ens32 ipv4.method manual ipv4.address 172.17.0.1/24 ipv4.gateway 172.17.0.254
nmcli con up vxlan101
在host2配置,使用多播模式

        此时参数remote应指定相同的多播地址(范围: 224.0.0.0~239.255.255.255)

nmcli con add con-name vxlan101 ifname vxlan101 type vxlan id 101 local 192.168.10.200 remote 239.1.1.1 destination-port 4789 dev ens32 ipv4.method manual ipv4.address 172.17.0.2/24 ipv4.gateway 172.17.0.254
nmcli con up vxlan101
互ping测试

VXLAN+网桥网络(Bridge)+组播

        上述的点对点 VXLAN 网络通信双方只有一个 VTEP,且只有一个通信实体,而在实际生产中(主要是云服务器),每台物理机上都有几十台甚至上百台虚拟机或容器需要通信,因此需要一种机制将这些通信实体组织起来,再通过隧道口 VTEP 转发出去。

        方案其实也很常见,Linux Bridge 就可以将多块虚拟网卡连接起来,因此可以选择使用 Bridge 将多个虚拟机或容器放到同一个 VXLAN 网络中。和上面的模式相比,这里只是多了一个 Bridge,用来连接不同 network namespace (网络名称空间)中的 veth pair,同时 VXLAN 网卡也需要连接到该 Bridge。

        其实说大白话就是:

题目:

  • 在两台物理设备上创建网络命名空间ns0和ns1,veth pair
  • 新建vxlan隧道,网桥名称为 br-vxlan,网桥的出口为vxlan103,id为103
  • 设备-1的vxlan隧道地址为172.18.0.1/24,设备-2的vxlan隧道地址为172.18.0.2/24.
  • 新建网桥bridge,将vxlan网络和veth pair绑定到bridge上
  • 测试不同设备中命名空间内网络的二层联通性。

注意!!!

        以下实验如果是在两台ubuntu虚拟机上做的,且一台为克隆,最好将vxlan,bridge,veth pair的ifname修改,否则可能会有mac地址冲突的情况发生,会导致实验结果不通

host1创建vxlan+bridge+组播网络:
# 创建vxlan网络,如果ipv6.method disabled不可用,也可以将disabled换成ignore,主要是为了让其不获取地址
nmcli con add con-name vxlan102 ifname vxlan102 type vxlan id 102 local 192.168.10.100 remote 239.1.1.1 destination-port 4789 dev ens32 ipv4.method disabled ipv6.method disabled
# 然后创建网桥 br0,把 VXLAN 网卡 vxlan102 绑定到上面,如果ipv6.method disabled不可用,也可以将disabled换成ignore,主要是为了让其不获取地址
nmcli con add con-name br0 ifname br0 type bridge ipv4.method disabled ipv6.method disabled
nmcli con modify vxlan102 master br0
# 刷新vxlan102
nmcli con up vxlan102
# 下面创建一对veth pair(veth0和veth1)
ip link add veth0 type veth peer name veth1
# 把veth pair一端veth0绑定到网桥
ip link set veth0 master br0
ip link set veth0 up
# 创建命名空间
ip netns add ns0
# 把veth pair一端veth1放到命名空间
ip link set dev veth1 netns ns0
# 给veth1设置ip
ip netns exec ns0 ip addr add 172.18.0.1/24 dev veth1
# 把veth1 和 lo up
ip netns exec ns0 ip link set lo up
ip netns exec ns0 ip link set veth1 up
# 查看 ns0 的网卡信息
ip netns exec ns0 ip add
host2创建vxlan+bridge+组播网络:
# 创建vxlan网络,如果ipv6.method disabled不可用,也可以将disabled换成ignore,主要是为了让其不获取地址
nmcli con add con-name vxlan102 ifname vxlan102 type vxlan id 102 local 192.168.10.200 remote 239.1.1.1 destination-port 4789 dev ens32 ipv4.method disabled ipv6.method disabled
# 然后创建网桥 br0,把 VXLAN 网卡 vxlan102 绑定到上面,如果ipv6.method disabled不可用,也可以将disabled换成ignore,主要是为了让其不获取地址
nmcli con add con-name br0 ifname br0 type bridge ipv4.method disabled ipv6.method disabled
nmcli con modify vxlan102 master br0
# 刷新vxlan102
nmcli con up vxlan102
# 下面创建一对veth pair(veth0和veth1)
ip link add veth0 type veth peer name veth1
# 把veth pair一端veth0绑定到网桥
ip link set veth0 master br0
ip link set veth0 up
# 创建命名空间
ip netns add ns1
# 把veth pair一端veth1放到命名空间
ip link set dev veth1 netns ns1
# 给veth1设置ip
ip netns exec ns1 ip addr add 172.18.0.2/24 dev veth1
# 把veth1 和 lo up
ip netns exec ns1 ip link set lo up
ip netns exec ns1 ip link set veth1 up
# 查看 ns1 的网卡信息
ip netns exec ns1 ip add

        互ping测试,隧道建立需要一定时间,可以耐心等一会

静态路由相关配置

添加静态路由和优先级

        语法:

nmcli con modify <连接名> ipv4.routes "<目标网段/子网掩码> <下一跳>"
或
nmcli con modify <连接名> ipv4.routes "<目标网段/子网掩码> <下一跳> <优先级>"
nmcli con up <连接名>

        示例:

nmcli con modify ens32 ipv4.routes "10.0.0.0/24 192.168.10.2 99"

注意:

        1、在命令中如果未设置优先级则默认为100,默认路由为20100

        2、优先级越小越优先,如:100 > 110

        3、默认路由的优先级无法更改

三、总结

        本文所有内容都由我亲自试验并总结,如果有朋友转载,请标明出处

        毕竟网上对于NetworkManager工具的各种解释都过于片面,也没有一个比较全面的示例,所以在本文上我还是耗费了很多的精力和时间的

        这其中当属无线网络的AP模式开启和两个ubuntu系统配置Vxlan上最耗费时间

        因为是虚拟机,会遇到各种各样的不适配或者其他bug,都需要一样找出问题来

        目前这里暂时只展现这些最常用的配置示例,目的是为了让大家在以后面对各式各样的Linux系统时能够更便捷的进行统一的网络配置

        当然后期也会逐渐对本文进行补充和更改,感谢支持!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3031718.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

护眼台灯和普通台灯差别很大吗?专业护眼灯品牌有哪些?

随着科技的不断演进&#xff0c;台灯的设计也日益脱胎换骨&#xff0c;从曾经的笨重造型转变为如今轻盈雅致的外观。它们的功能同样经历了多样化的革新&#xff0c;变得更加人性化和便捷。作为学习、阅读和办公环境中不可或缺的照明工具&#xff0c;台灯所提供的光线舒适度至关…

ChatGLM 本地部署指南(问题解决)

硬件要求&#xff08;模型推理&#xff09;&#xff1a; INT4 &#xff1a; RTX3090*1&#xff0c;显存24GB&#xff0c;内存32GB&#xff0c;系统盘200GB 如果你没有 GPU 硬件的话&#xff0c;也可以在 CPU 上进行推理&#xff0c;但是推理速度会更慢。 模型微调硬件要求更高。…

【ArcGISProSDK】condition属性

示例 通过caption属性可以看出esri_mapping_openProjectCondition的条件是一个工程被打开 condition的作用 由此可知示例中的Tab实在工程被打开才能使用&#xff0c;否则他禁用显示灰色&#xff0c;在未禁用的时候说明条件满足。 参考文档 insertCondition 元素 (arcgis.com…

擦边宣传、质量堪忧、销量惨淡,创维汽车将何去何从?

文/张诗雨 近日&#xff0c;据多家媒体报道&#xff0c;创维汽车创始人黄宏生在公开场合发言称&#xff0c;创维汽车有助于养生&#xff0c;他在创维汽车里午休&#xff0c;高血压没吃药都恢复正常了。该言论引起网友热议。 针对此事件&#xff0c;5月9日&#xff0c;创维汽车…

Java数组(二)

Java数组&#xff08;二&#xff09; 1、多维数组 多维数组可以看成是数组的数组&#xff0c;比如二维数组就是一个特殊的一维数组&#xff0c;其每一个元素都是一个一维数组。二维数组 int a[][] new int[2][5];解析&#xff1a;以上二维数组a可以看成一个两行五列的数组。…

Codeforces Round 217 (Div. 2) A. Rook, Bishop and King(BFS)

Rook, Bishop and King 题面翻译 【题目描述】 佩蒂亚正在学习国际象棋。他已经学会如何移动王、车和象。让我们提示你如何移动国象棋子。棋盘有 64 64 64个棋格&#xff0c;呈 8 8 8\times8 88正方形。一个格子可以用 ( r , c ) (r,c) (r,c)来表示—— r r r指行&#xff…

只需3步,使用Stable Diffusion无限生成AI数字人视频(附安装包)

基本方法 搞一张照片&#xff0c;搞一段语音&#xff0c;合成照片和语音&#xff0c;同时让照片中的人物动起来&#xff0c;特别是头、眼睛和嘴。 语音合成 语音合成的方法很多&#xff0c;也比较成熟了&#xff0c;大家可以选择自己方便的&#xff0c;直接录音也可以&#…

一文了解Simhash原理和用法-计算文章相似度

Simhash原理 1&#xff1a;背景 SimHash算法是Google在2007年发表的论文《Detecting Near-Duplicates for Web Crawling》中提到的一种指纹生成算法&#xff0c;被应用在Google搜索引擎网页去重的工作之中。SimHash值不但提供了原始值是否相等这一信息&#xff0c;还能通过该…

PCIE协议-2-事务层规范---事务描述符

2.2.6.1 概览 事务描述符是请求者和完成器之间传输事务信息的机制。事务描述符由三个字段组成&#xff1a; 事务ID&#xff1a;标识未完成的事务属性字段&#xff1a;定义事务的特征流量类别&#xff08;TC&#xff09;字段&#xff1a;将事务与所需的服务类型关联起来 图2-…

C语言---使用共用体将double型经纬度存储到无符号数组中

1.在上报经纬度时由于数据协议限制需要将double型数据存储到无符号数组中&#xff0c;下边是写了一个简单C程序进行验证&#xff1b; 2.代码示例如下 #include <stdio.h> typedef union {float data;unsigned char arr[4]; } my_data;int main() {my_data test_data {…

【科学研究】在朋友圈上秀恩爱——“损人利己”

::: block-1 “时问桫椤”是一个致力于为本科生到研究生教育阶段提供帮助的不太正式的公众号。我们旨在在大家感到困惑、痛苦或面临困难时伸出援手。通过总结广大研究生的经验&#xff0c;帮助大家尽早适应研究生生活&#xff0c;尽快了解科研的本质。祝一切顺利&#xff01;—…

【机器学习】 人工智能和机器学习辅助决策在空战中的未来选择

&#x1f680;传送门 &#x1f680;文章引言&#x1f512;技术层面&#x1f4d5;作战结构&#x1f308;替代决策选项&#x1f3ac;选项 1&#xff1a;超级战争&#xff08;Hyperwar&#xff09;&#x1f320;选项 2&#xff1a;超越OODA&#x1f302;选项 3&#xff1a;阻止其他…

C# OpenCvSharp Demo - 最大内接圆

C# OpenCvSharp Demo - 最大内接圆 目录 效果 项目 代码 下载 效果 项目 代码 using OpenCvSharp; using System; using System.Diagnostics; using System.Drawing; using System.Drawing.Imaging; using System.Linq; using System.Windows.Forms; namespace OpenCvSh…

祝贺!触想获评第二十一届“深圳知名品牌”

5月9日&#xff0c;第八届“深圳(湾区)国际品牌周”活动盛大开幕&#xff0c;会上公布并表彰了一批具有高创新力和竞争力的品牌名单。作为工控物联领域优秀品牌代表&#xff0c;触想智能与各级政府领导、国内外品牌界权威专家、知名企业领袖和企业代表同台共庆&#xff0c;并收…

麦肯锡专访 Mistral AI CEO:三五年后的工作,要比现在更有意义

【编者按】总部位于巴黎的人工智能初创公司 Mistral AI 成立仅一年&#xff0c;就被誉为现有大模型巨头的有力挑战者。 今年 2 月&#xff0c;Mistral AI 正式发布了旗舰级大模型 Mistral Large&#xff0c;直接对标 OpenAI 的 GPT-4&#xff1b;几周前&#xff0c;Mistral AI…

TriDet: Temporal Action Detection with Relative Boundary Modeling

标题&#xff1a;TriDet&#xff1a;采用相对边界建模的时间动作检测 原文链接&#xff1a;TriDet: Temporal Action Detection With Relative Boundary Modeling (thecvf.com)https://openaccess.thecvf.com/content/CVPR2023/papers/Shi_TriDet_Temporal_Action_Detection_W…

第五章 5.2【Java类和对象】---封装和构造方法

一、单个对象内存图 二、多个对象内存图 三、多个对象指向相同 四、成员变量和局部变量 4.1 成员变量&#xff1a; 在类里面&#xff0c;方法外面的变量 4.2 局部变量&#xff1a; 在方法中的变量 4.3下面的代码来演示&#xff1a; 4.4两者的区别 五、封装 六、构造方法 6.…

专题六_模拟(3)

目录 1419. 数青蛙 解析 题解 1419. 数青蛙 1419. 数青蛙 - 力扣&#xff08;LeetCode&#xff09; 解析 题解 class Solution { public:int minNumberOfFrogs(string croakOfFrogs) {// 44.专题六_模拟_数青蛙_Cstring t "croak";int n t.size();vector<in…

RabbitMQ的用途

RabbitMQ主要有四个用途&#xff0c;分别是应用解耦、异步提速、削峰填谷、消息分发。详情讲解如下&#xff1a; RabbitMQ介绍、解耦、提速、削峰、分发 详解、RabbitMQ安装 可视化界面讲解 1.应用解耦&#xff1a;提高系统容错性和可维护性 2.异步提速&#xff1a;提升用户体验…

减瘦误区、雷点、陷阱和挑战怎么应对

在减瘦过程中&#xff0c;很多肥胖人群都容易踩到坑。比如陷入误区&#xff0c;认为只有短期快速的减调方式方法&#xff0c;才值得尝试&#xff0c;而忽视身体健康&#xff1b;或是踩到雷点&#xff0c;轻信强速方剂或方法&#xff0c;结果身体产生了排斥或根本没效用白花钱&a…