linux – 如何编写持久网名的规则?

我知道一个进程根据/lib/udev/rules.d/75-persistent-net-generator.rules中的规则生成持久的网卡名称.我也知道如何用一个简单的方法完全禁用这个过程
echo '#' > /etc/udev/rules.d/75-persistent-net-generator.rules

但我已经读过“我也可以编写自己的规则文件来为接口命名 – 如果已经设置了名称,持久规则生成器会忽略接口”(/etc/udev/rules.d/README确认这个有可能).

您能否提供有关如何编写此类规则的说明和/或示例? (我主要关心的是Debian / Ubuntu,而且对CentOS的关注度较低).在我的情况下,我想添加如下规则:

> MAC A或B的卡应命名为eth0
> MAC C或D卡应命名为eth1
>按照默认命名方案进行其他操作

作为我想编写自定义规则的一个具体示例:我有两个相同的服务器,一个板载LAN和一个PCI LAN.在HW故障的情况下,我希望能够将硬盘从HW#1移动到HW#2,并且eth0继续指向板载卡和eth1到PCI卡是很重要的(没有人想要在中间插入电缆)硬件故障恐慌).我当前的解决方法有效,但是很多工作[1]所以我想知道编写自定义规则是否允许我表达上述规则

[1]在HW#1中安装操作系统并保留/etc/udev/rules.d/70-persistent-net.rules的副本.将磁盘移动到HW#2并保留同一文件的第二个副本.连接两个副本并手动编辑NAME =“ethX”部分.用我的版本替换/etc/udev/rules.d/70-persistent-net.rules.最后禁用使用自动创建新的70-persistent-net.rules

echo '#' > /etc/udev/rules.d/75-persistent-net-generator.rules

解决方法

要回答您的具体问题,请将此添加到persistent-net.rules:
SUBSYSTEM=="net",ACTION=="add",DRIVERS=="?*",ATTR{address}=="AA:AA:AA:AA:AA:AA",ATTR{dev_id}=="0x0",ATTR{type}=="1",KERNEL=="eth*",NAME="eth0"
SUBSYSTEM=="net",ATTR{address}=="BB:BB:BB:BB:BB:BB",ATTR{address}=="CC:CC:CC:CC:CC:CC",NAME="eth1"
SUBSYSTEM=="net",ATTR{address}=="DD:DD:DD:DD:DD:DD",NAME="eth1"

单独留下persistent-net-generator.rules. udev不会覆盖您手动添加的规则,但生成器规则会像往常一样为新卡添加新规则.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


查找全部容器的日志文件 $ sudo find /var/lib/docker/containers -name *.log 查看日志位置 $ docker inspect --format='{{.LogPath}}' <container_name> 实时查询内容 $
Linux日志文件中列属性的详细解析
在Linux系统中没有duf命令,如何有效地管理磁盘空间?
深入探讨EncryptPad在Linux操作系统中的功能和优势
原理和应用场景:Linux中ttyload工具的工作原理和实际用途
深度解析SELinux的三种策略类型
评估Linux系统性能的ttyload工具使用效果
分享在Linux系统中检测SSH版本的方法
介绍Linux平台上的数据加密工具EncryptPad
在Linux系统中,如何查看和诊断块设备信息?
在Linux环境下如何查看块设备信息?
探索Linux操作系统下的数据加密工具EncryptPad
学会在Linux系统中查看硬盘信息
分析SELinux:原理与实践
掌握SELinux策略类别
技巧:有效解读和管理Linux日志文件
查看Linux系统中的所有用户
了解Linux系统中各种不同类型的日志文件
深入理解Linux PS命令
方法:在Linux操作系统中查看用户