如何检测网线/连接器的物理连接状态?
在 Linux 环境中,我需要检测 RJ45 连接器与其插座的物理连接或断开状态。 最好仅使用 BASH 脚本。
其他站点上提出的以下解决方案不适用于此目的:
- 使用“ifconfig” - 因为可能已连接网络电缆,但网络未正确配置或当前未启动。
- Ping 主机 - 因为该产品将位于使用未知网络配置和未知主机的 LAN 中。
/proc 文件系统中是否没有可以使用的状态(其他所有内容都在那里)?
Linux 世界怎么会有自己版本的 Windows 气泡,从图标托盘中弹出,表明您刚刚拔掉了网络电缆?
Kent Fredric和lothar,你们的回答都满足了我的需要...非常感谢! 我会使用哪一个...我仍然不知道。
我想我不能把你们俩都列为正确答案吗? 我选择其中之一对你来说可能是公平的。 我猜抛硬币? 再次感谢!
In a Linux environment, I need to detect the physical connected or disconnected state of an RJ45 connector to its socket. Preferably using BASH scripting only.
The following solutions which have been proposed on other sites do NOT work for this purpose:
- Using 'ifconfig' - since a network cable may be connected but the network not properly configured or not currently up.
- Ping a host - since the product will be within a LAN using an unknown network configuration and unknown hosts.
Isn't there some state which can be used in the /proc file system (everything else is in there)?
How is the Linux world suppose to have their own version of the Windows bubble that pop up from the icon tray indicating that you've just unplugged the network cable?
Kent Fredric and lothar, both of your answers satisfy my need... thanks a lot! Which one I'll use... I still don't know.
I guess I can't put you both down as the correct answer? And its probably fair for you that I do choose one. Flip a coin I guess? Again, thanks!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(16)
我使用此命令来检查电线
是否已连接:结果是向上还是向下。 有时显示未知,那么你需要检查
它显示0或1
I use this command to check a wire is connected:
If the result will be up or down. Sometimes it shows unknown, then you need to check
It shows 0 or 1
有两个守护进程可以检测这些事件:
ifplugd 和 netplugd
There exists two daemons that detect these events:
ifplugd and netplugd
大多数现代 Linux 发行版都使用 NetworkManager 来实现此目的。 您可以使用 D-BUS 来监听事件。
如果您想要一个命令行工具来检查状态,您也可以使用
mii-tool
,因为您考虑的是以太网。Most modern Linux distributions use NetworkManager for this. You could use D-BUS to listen for the events.
If you want a command-line tool to check the status, you can also use
mii-tool
, given that you have Ethernet in mind.一些精度和技巧
我以普通用户(不是root)的身份完成所有这些
从
dmesg
获取信息使用
dmesg
是查询系统当前状态的第一件事:<前><代码>dmesg | sed '/eth.*链接为/h;${x;p};d'
可以回答如下:
或
根据状态,消息可能会因所使用的硬件和驱动程序而异。
注意:这可以通过编写
dmesg|grep eth.*Link.is|tail -n1
但我更喜欢使用sed
。<前><代码>dmesg | sed '/eth.*链接为/h;${x;s/^.*链接为//;p};d'
高达 100 Mbps 全双工,流量控制:Rx/Tx
dmesg | sed '/eth.*链接为/h;${x;s/^.*链接为//;p};d'
向下
围绕
/sys
伪文件系统进行测试在
/sys
下读取或写入可能会破坏您的系统,特别是如果以root身份运行! 您已收到警告;-)这是一种池化方法,而不是真正的事件跟踪。
<前><代码>cd /tmp
grep -H 。 /sys/class/net/eth0/* 2>/dev/null>ethstate
尽管 ! 读-t 1;做
grep -H 。 /sys/class/net/eth0/* 2>/dev/null | /sys/class/net/eth0/* 2>/dev/null |
diff -u ethstate - | 差异
三通>(补丁-p0)|
查找^+
完毕
可以呈现类似的内容(一旦拔下插头并重新插回,具体取决于):
<前><代码>+++ - 2016-11-18 14:18:29.577094838 +0100
+/sys/class/net/eth0/运营商:0
+/sys/class/net/eth0/Carrier_changes:9
+/sys/class/net/eth0/duplex:未知
+/sys/class/net/eth0/operstate:down
+/sys/class/net/eth0/速度:-1
+++ - 2016-11-18 14:18:48.771581903 +0100
+/sys/class/net/eth0/运营商:1
+/sys/class/net/eth0/Carrier_changes:10
+/sys/class/net/eth0/duplex:full
+/sys/class/net/eth0/operstate:up
+/sys/class/net/eth0/速度:100
(按Enter退出循环)
注意:这需要安装
补丁
。好吧,这肯定已经有一些事情了......
根据 Linux 安装,您可以添加
if-up
和if-down
脚本,以便能够对此类事件做出反应.在基于 Debian 的系统上(例如 Ubuntu),您可以将脚本存储到
有关更多信息,请参阅
man 接口
。Some precisions and tricks
I do all this as normal user (not root)
Grab infos from
dmesg
Using
dmesg
is one of the 1st things to do for inquiring current state of system:could answer something like:
or
depending on state, message could vary depending on hardware and drivers used.
Nota: this could by written
dmesg|grep eth.*Link.is|tail -n1
but I prefer usingsed
.Test around
/sys
pseudo filesystemReading or writting under
/sys
could break your system, especially if run as root! You've been warned ;-)This is a pooling method, not a real event tracking.
Could render something like (once you've unplugged and plugged back, depending ):
(Hit Enter to exit loop)
Nota: This require
patch
to be installed.In fine, there must already be something about this...
Depending on Linux Installation, you could add
if-up
andif-down
scripts to be able to react to this kind of events.On Debian based (like Ubuntu), you could store your scripts into
see
man interfaces
for more infos.不知何故,如果你想在命令“ifconfig eth0 down”之后检查以太网电缆是否插入Linux。
我找到一个解决方案:
使用 ethtool 工具。
如果电缆已连接,则链路测试为 0,否则为 1。
Somehow if you want to check if the ethernet cable plugged in linux after the commend:" ifconfig eth0 down".
I find a solution:
use the ethtool tool.
if cable is connected,link test is 0,otherwise is 1.
在 Arch Linux 上。 (我不确定其他发行版)您可以查看操作状态。 如果已连接则显示,如果未连接则显示关闭,操作状态继续存在
on arch linux. (im not sure on other distros) you can view the operstate. which shows up if connected or down if not the operstate lives on
您可以使用ifconfig。
如果条目显示 RUNNING,则该接口已物理连接。 无论是否配置接口,都会显示此信息。
这只是获取
/sys/class/net/eth0/operstate
中信息的另一种方法。You can use ifconfig.
If the entry shows RUNNING, the interface is physically connected. This will be shown regardless if the interface is configured.
This is just another way to get the information in
/sys/class/net/eth0/operstate
.或者对我来说更快:
它将监听系统日志文件。
结果(如果断开连接,4 秒后再次连接):
or for me faster gets:
It will listen to the syslog file.
Result (if disconnect and after 4 seconds connect again):
此命令检查“ip a”命令的第二个接口中的“state UP”。 我已经检查了 2 台运行 wifi 的计算机,列出的第二台是有线以太网。 如果您想检查不同的接口,只需将下面命令中的“2”更改为正确的索引位置即可。
This command checks for "state UP" in the 2nd interface of the "ip a" command. I have checked in 2 computers running wifi, the 2nd listed is the cable ethernet. Case you want to check a different interface, just change the "2" in the command below to be the correct index position.
在 OpenWRT 上,至少对我来说,可靠地执行此操作的唯一方法是运行以下命令:
这将在交换机的每个端口上显示“link:down”或“link:up”。
On OpenWRT the only way to reliably do this, at least for me, is by running these commands:
This will show either "link:down" or "link:up" on every port of your switch.
我使用 OpenWRT 增强型设备作为中继器(添加了虚拟以太网和无线局域网功能),发现 /sys/class/net/eth0 运营商和 opstate 值不可靠。 我也玩过 /sys/class/net/eth0.1 和 /sys/class/net/eth0.2 以及(至少我发现)没有可靠的方法来检测某些东西是否已物理插入并在任何设备上进行通信以太网端口。 我想出了一种有点粗略但看似可靠的方法来检测至少自上次重新启动/开机状态以来是否插入了任何东西(在我的情况下,它的工作原理与我所需要的完全一样)。
如果没有插入任何东西并且有东西 > >,您将得到 0。 如果自上次开机或重新启动周期以来已插入任何设备(即使已插入并已移除),则为 0。
希望这至少可以帮助某人!
I was using my OpenWRT enhanced device as a repeater (which adds virtual ethernet and wireless lan capabilities) and found that the /sys/class/net/eth0 carrier and opstate values were unreliable. I played around with /sys/class/net/eth0.1 and /sys/class/net/eth0.2 as well with (at least to my finding) no reliable way to detect that something was physically plugged in and talking on any of the ethernet ports. I figured out a bit crude but seemingly reliable way to detect if anything had been plugged in since the last reboot/poweron state at least (which worked exactly as I needed it to in my case).
You'll get a 0 if nothing has been plugged in and something > 0 if anything has been plugged in (even if it was plugged in and since removed) since the last power on or reboot cycle.
Hope this helps somebody out at least!
你想看看
我用我的实验中的节点:
电线插入:
电线移除:
电线再次插入:
Side Trick:以简单的方式立即收获所有属性:
这形成了一个很好的列表
键:值
对。You want to look at the nodes in
I experimented with mine:
Wire Plugged in:
Wire Removed:
Wire Plugged in Again:
Side Trick: harvesting all properties at once the easy way:
This forms a nice list of
key:value
pairs.您可以使用 ethtool:
要仅获取链接状态,您可以使用 grep :
You can use ethtool:
To only get the Link status you can use grep:
使用“ip Monitor”获取实时链接状态变化。
Use 'ip monitor' to get REAL TIME link state changes.
cat /sys/class/net/ethX
是迄今为止最简单的方法。但接口必须处于启动状态,否则您将收到无效参数错误。
所以首先:
然后:
cat /sys/class/net/ethX
is by far the easiest method.The interface has to be up though, else you will get an invalid argument error.
So first:
Then:
在低级别上,可以使用 捕获这些事件rtnetlink 套接字,没有任何轮询。 旁注:如果您使用 rtnetlink,则必须与 udev 一起工作,否则当 udev 重命名新的网络接口时,您的程序可能会感到困惑。
使用 shell 脚本进行网络配置的问题在于 shell 脚本对于事件处理来说很糟糕(例如插入和拔出网线)。 如果您需要更强大的东西,请查看我的 NCD 编程语言,这是一种专为网络配置而设计的编程语言。
例如,一个简单的 NCD 脚本会将“cable in”和“cable out”打印到 stdout(假设接口已经启动):(
在内部,
net.backend.waitlink()
使用 rtnetlink,并且net.backend.waitdevice()
使用 udev)NCD 的想法是专门使用它来配置网络,因此通常情况下,配置命令会出现在两者之间,例如
:请注意,执行允许回归; 例如,在第二个示例中,如果拔出电缆,则 IP 地址将自动删除。
On the low level, these events can be caught using rtnetlink sockets, without any polling. Side note: if you use rtnetlink, you have to work together with udev, or your program may get confused when udev renames a new network interface.
The problem with doing network configurations with shell scripts is that shell scripts are terrible for event handling (such as a network cable being plugged in and out). If you need something more powerful, take a look at my NCD programming language, a programming language designed for network configurations.
For example, a simple NCD script that will print "cable in" and "cable out" to stdout (assuming the interface is already up):
(internally,
net.backend.waitlink()
uses rtnetlink, andnet.backend.waitdevice()
uses udev)The idea of NCD is that you use it exclusively to configure the network, so normally, configuration commands would come in between, such as:
The important part to note is that execution is allowed to regress; in the second example, for instance, if the cable is pulled out, the IP address will automatically be removed.