Linux UDEV配置与Oracle环境设备名稳定性实践

需积分: 9 4 下载量 57 浏览量 更新于2024-09-14 收藏 2KB TXT 举报
"这篇文章主要介绍了在Linux环境下,特别是与Oracle结合时如何解决设备名变化的问题,重点探讨了使用UDEV规则来确保设备命名的稳定性。" 在Linux系统中,特别是那些运行Oracle数据库的环境,设备名的变化可能会引起一系列的问题,如数据丢失、系统不稳定等。在传统的Linux系统中,SCSI设备的命名是基于顺序(例如sda、sdb等),这可能导致当设备插入顺序改变或新设备添加时,设备名发生混乱。为了解决这个问题,Linux引入了UDEV,这是一个设备管理器,负责动态管理和命名硬件设备。 UDEV的主要功能是基于设备的属性(如UUID、序列号)而非设备的物理位置进行设备命名,这样可以保证即使设备顺序发生变化,其名称也能保持一致。在Linux+Oracle环境下,设备名的稳定性对于Oracle ASM(Automatic Storage Management)尤其重要,因为ASM依赖于设备的特定名称来识别和管理磁盘。 文章提到了三种解决设备名变化的方法: 1. 使用`/etc/multipath/bindings`配置文件:这个文件可以用来绑定设备的WWN(World Wide Name)或UUID到固定的设备名,以防止多路径软件导致的设备名变更。 2. 配置ASMLIB(ASM Library):ASMLIB是一种Oracle提供的驱动程序,它允许直接通过设备的UUID而不是设备名访问磁盘,这样即使设备名改变,Oracle仍然能找到对应的磁盘。 3. 利用RHEL的UDEV规则:创建自定义的UDEV规则文件,如`99-oracle-asmdevices.rules`,在这个文件中定义设备的KERNEL(设备类型)、BUS(总线类型)、PROGRAM(用于获取设备特性,如UUID)和RESULT(设备的UUID),并设置设备的名称、所有者、组和其他权限。 在示例中,作者展示了如何创建和应用UDEV规则。首先,他们使用`scsi_id`工具获取设备的UUID,然后在`/etc/udev/rules.d/`目录下创建一个规则文件,定义了当检测到特定UUID的设备时,应如何命名该设备。接着,通过`udevcontrol reload_rules`命令重新加载规则,并使用`start_udev`启动udev服务,使新规则生效。最后,通过`ll /dev/mysdb*`确认设备是否按预期被命名。 通过以上步骤,可以确保即使设备顺序改变,Oracle也可以正确识别和使用磁盘,从而保证系统的稳定性和数据的安全性。UDEV的使用极大地增强了Linux环境中设备管理的灵活性和可靠性,特别是在有严格需求的Oracle数据库系统中。
2009-12-24 上传
将可移动设备连入系统时,系统的后台中会依次发生如下事件: l 内核检测到新硬件插入,然后分别通知hotplug和udev。前者用来装入相应的内核模块(如usb-storage),而后者用来在/dev中创建相应的设备节点(如/dev/sda1)。 l udev创建了相应的设备节点之后,会将这一消息通知hal的守护程序(hald)。当然udev还得保证新创建的设备节点可以被普通用户访问。 l hotplug装入了相应的内核模块之后,会把这一消息通知给hald。 l hald在受到hotplug和udev发出的消息之后,认为新硬件已经正式被系统认可了。此时它会通过一系列精心编写的规则文件(就是传说中的xxx-policy.fdi),把发现新硬件的消息通过dbus发送出去,同时还会调用update-fstab或fstab-sync来更新/etc/fstab,为相应的设备节点创建适合的挂载点。 l 卷管理器会监听dbus中发现新硬件的消息。根据所插入的硬件(区分U盘和数码相机等)不同,卷管理器会先将相应的设备节点挂载到hald创建的挂载点上,然后再打开不同的应用程序。 当然,如果是在CDROM中插入光盘,过程可能比较简单。因为CDROM本身就是一个固定的硬件,无需hotplug和udev的协助: l hald会自己监视CDROM,并且将光盘托架开合的消息通过dbus发出去。 l 卷管理器负责检查CDROM中的盘片内容,进行挂载,并调用合适的应用程序。 要注意,hald的工作是从上游得到硬件就绪的消息,然后将这个消息转发到dbus中。尽管它会调用程序来更新fstab,但实际上它自己并不执行挂载的工作。