转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你,欢迎[点赞、收藏、关注]哦~ 原文链接:https://xfxuezhang.blog.csdn.net/article/details/145945224
目录
有两台主机通过网线与交换机相连。主机操作系统是“ubuntu”,主机A连接交换机的网卡接口是“ens1f1、ens1f0”,主机B连接交换机的网卡接口是“ens2f1、ens2f0”。交换机没有额外的连接(如没有接入互联网),它仅与两台主机有网线连接。基于以上信息,如何配置使得两台主机能通过交换机进行通信?
在每台主机上,使用以下命令查看可用的网络接口(其实就是网卡):
ip link show | grep ens*f*
这将列出所有网络接口。例如,可能会看到类似 ens1f0
和 ens1f1
的接口名称。(一般enoXX的是板载网卡)
可以通过以下指令来详细查看网口信息和类型:
需先安装nmcli: # Debian/Ubuntu 系统 sudo apt install network-manager network-manager-gnome # CentOS 7 系统 sudo yum install NetworkManager # CentOS/RHEL 系统 sudo yum install NetworkManager
还需要启动NetworkManager服务: sudo systemctl start NetworkManager
nmcli device status # 查看网络设备状态
DEVICE
:网络接口的名称。
TYPE
:网络接口的类型(如以太网、桥接、隧道、环回)。
STATE
:网络接口的当前状态(如已连接、未管理)。
CONNECTION
:与该设备关联的连接配置名称。
Wired connection 1
。
Wired connection 2
。
netplan-ens1f0
。
Wired connection 5
。
注意:
unmanaged
,可能该网卡可能被系统配置为不被 NetworkManager 管理,可以使用"sudo nmcli device set ens1f0 managed yes"来手动设置网卡为 managed。
注意改ens1f0为你的。不过在设置前需要特别注意,检查这个网卡是不是有其他用处!
nmcli c show # 网络连接配置
NAME
:连接配置的名称。
UUID
:连接配置的唯一标识符。
TYPE
:连接类型(如以太网、桥接、隧道)。
DEVICE
:当前使用的网络接口(如果没有绑定设备,则显示 --
)。
eno1
。
eno2
。
docker0
。
ens1f0
。
ens1f1
。
通过以上检测,就可以看出:
eno1
、eno2
、ens1f0
、ens1f1
是物理以太网接口,分别绑定到不同的连接配置。
docker0
是 Docker 的桥接设备,用于容器网络。
ztk4jieaxm
和 ztklhzrkoh
是隧道接口(如 VPN)。
veth3001267
是虚拟以太网接口(通常用于容器)。
lo
是本地回环接口,未管理。
Wired connection 3
和 Wired connection 4
是未绑定设备的以太网连接配置。
这表明系统中有多个物理和虚拟网络接口,配置了多种网络连接(包括以太网、桥接、隧道等)。
更进一步地,要查看特定连接配置的详细信息,可以用:
nmcli connection show 'Wired connection 4'
要查看特定网卡的详细信息,可以用:
nmcli device show ens1f0
更多说明:
步骤 命令 说明 查看网络连接 nmcli connection show
显示当前所有网络连接 配置静态IP地址 nmcli connection modify "Wired connection 1" ipv4.addresses "192.168.1.100/24" ipv4.gateway "192.168.1.1" ipv4.dns "8.8.8.8 8.8.4.4" ipv4.method manual
设置IP地址、网关和DNS 激活网络连接 nmcli connection up "Wired connection 1"
激活网络连接 检查连接状态 nmcli device status
查看设备连接状态 查看IP配置 nmcli device show eth0
显示设备的IP配置信息 测试网络连通性 ping -c 4 192.168.1.1
测试与网关的连通性 查看路由表 ip route
显示当前路由表 检查DNS解析 nslookup google.com
测试DNS解析是否正常 修改默认网关 nmcli connection modify "Wired connection 1" ipv4.gateway "192.168.1.1"
如果默认网关配置错误,可以通过该命令修改
如果想看网卡的型号或者支持的速率,可以用:
sudo apt install ethtool
sudo ethtool ens1f0
关键输出字段:
1000Mb/s
)。
Full
或 Half
)。
如果需要调整网卡速率,可以执行: # 强制设置为 40Gbps(需确保链路支持) sudo ethtool -s ens1f0 speed 40000 duplex full autoneg off # 验证设置:检查 Speed 是否更新为目标值,并确认 Link detected: yes(链路正常) sudo ethtool ens1f0 | grep -E "Speed|Link detected" # 恢复自动协商 sudo ethtool -s ens1f0 autoneg on
通过 ethtool
的命令在重启后会失效。若需永久生效,需将配置写入系统文件:
# 在 `/etc/network/interfaces` 中添加: post-up ethtool -s ens1f0 autoneg off speed 40000 duplex full
以上步骤是为了更好的了解现有的连接配置和网卡信息。
要确定两台未配置IP地址且无法访问交换机的服务器是否连接至同一台交换机,可以利用LLDP/CDP协议。LLDP(Link Layer Discovery Protocol)是一种网络发现协议,如果交换机支持 LLDP,并且服务器网卡的驱动支持 LLDP,可以使用 lldpd
来发现交换机信息。
安装LLDP工具:
lldpad
:
apt install lldpd # Debian/Ubuntu
yum install lldpd # CentOS/RHEL
sudo systemctl start lldpad
查询交换机信息:
lldpctl
查看交换机信息sudo lldpctl
lldpctl
输出解释: 接口信息 Interface: ens1f1, via: LLDP, RID: 1, Time: 0 day, 00:00:01
ens1f1
。交换机(Chassis)信息 Chassis: ChassisID: mac 1c:34:da:a8:b5:40 SysName: switch-a48bbc SysDescr: MSN2100,Onyx,SWv3.9.0300 Capability: Bridge, on Capability: Router, off
1c:34:da:a8:b5:40
。端口(Port)信息 Port: PortID: ifname Eth1/1 PortDescr: TTL: 120
ens1f1
连接到了交换机的 Eth1/1 端口。对比方法:
SysName
(交换机名称)是否相同?ChassisID
(MAC 地址)是否相同?PortID
是否不同? EthX/X
端口,则说明两台服务器连接到了同一台交换机的不同端口。PortID
完全相同,那可能是一个 LAG/LACP 端口组,或者是错误配置。找到主机上ChassisID相同的网口,表示他们连接的是同一个交换机。注意,如果不是连接的同一个交换机,那么后续的配置即使完成了,主机之间也是无法通信的。
先查看那些网段被占用了:
ifconfig
先安装nmtui,后面要用到: # Debian/Ubuntu 系统 sudo apt install network-manager network-manager-gnome # CentOS 7 系统 sudo yum install NetworkManager-tui # CentOS/RHEL 系统 sudo yum install nm-connection-editor
假设选择在每台主机上使用 ens1f0
接口进行通信,按照以下步骤配置静态 IP 地址:
主机 A:
打开终端,输入以下命令:
sudo nmtui
按以下步骤执行:
修正说明:修改后,上图中要“手动Deactivate、再Activate一下”,不然可能不会生效。
如果要用nmcli进行设置,参考命令: nmcli connection modify "Wired connection 4" ipv4.addresses "192.168.3.10/24" ipv4.method manual
激活该配置: nmcli connection up "Wired connection 4"
然后就可以看到设置完成了:
主机 B:
与主机A的操作一样,只是在设置ip时候,注意不要用一样的。比如主机A是192.168.3.10/24,那么主机B可以设置为192.168.3.11/24。
先清空arp表:
sudo ip -s -s neigh flush all
在完成上述配置后,您可以通过 ping
命令测试两台主机之间的连接:
如果配置正确,您将看到来自对方主机的响应,表示两台主机已经通过交换机成功建立通信。
注意,如果你的交换机不支持或者关闭了router,那需要通过arp方式:
sudo apt install arping
sudo arping 192.168.3.11
这里测试一下这两台主机之间的通信速率。
1、首先在两台主机上安装 iperf
# Debian/Ubuntu 系统
sudo apt install iperf
# CentOS/RHEL 系统
sudo yum install iperf
2、在主机A上启动一个 iperf
服务器,监听端口 5001
:
iperf -s -p 5001
3、在主机B上运行 iperf 客户端
iperf -c 192.168.3.11 -p 5001 -t 10
-c
:指定服务器的 IP 地址。
-p
:指定服务器的端口号。
-t
:指定测试时间(单位:秒)。
在主机 B 上,iperf
会显示测试结果,包括带宽、延迟等信息。
可能你设置的静态ip与其他服务的ip冲突了。通过以下指令来查看arp表:
arp -a
可以看到192.168.3.x的网段已经被用了。因此在配置静态IP时候,可以选择其他网段,如192.168.4.x。
如果以下命令输出显示了网卡的驱动程序信息,则说明驱动已安装。
ethtool -i ens2f0np0
如果交换机设置的不是vlan模式,那么就不用看这块了。
有些交换机默认设置了VLAN,要知道不同的VLAN之间是会隔离访问的,所以需要进入到交换机配置界面进行配置。
如果不需要用到vlan,直接改为access模式即可。
a. 确认系统支持 802.1q VLAN 功能
使用以下命令检查系统是否支持 802.1q VLAN 功能:
modinfo 8021q
如果命令输出显示 802.1q 模块已加载,则说明系统支持 VLAN 功能。
如果不存在,尝试加载模块:
sudo modprobe 8021q
b. 网卡不支持 VLAN 功能
某些网卡可能不支持 VLAN 标签,或者需要特定的驱动程序支持。需要检查是否支持。如果网卡不支持VLAN功能,那么建议将交换机配置为Access模式。
c. 主机没有配置 VLAN 接口
注意,交换机的VLAN ID是否需要与主机的VLAN ID相同。
扩展学习资料:
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。