Ubuntu Server 17.04 - правила udev для дисков Blu-Ray

Я пытаюсь создать udev правило, которое позволит пользователям без полномочий root монтировать диск, вставленный в дисковод Blu-Ray, в произвольную точку монтирования.

Так как диск является постоянным, а диски нет, я не использую /etc/fstab моё понимание, которое может быть неверным, заключается в том, что /etc/fstab не подходит для этой ситуации.

Я создал файл с именем 10-bluray.rules в моем доме без полномочий root и вставил ссылку /etc/udev/rules.d/10-bluray.rules, Правило, которое я определил:

ACTION=="change", SUBSYSTEM=="block", KERNEL=="sr[0-9]*", ENV{ID_CDROM_MEDIA_STATE}=="complete", GROUP="users"

Еще после бега sudo udevadm control --reload-rulesи извлекая и вставляя диск, мой /dev все еще выглядит так:

brw-rw---- 1 root cdrom    11,   0 2017-09-09 00:52 sr0
lrwxrwxrwx 1 root root           3 2017-09-09 00:52 dvdrw -> sr0
lrwxrwxrwx 1 root root           3 2017-09-09 00:52 dvd -> sr0
lrwxrwxrwx 1 root root           3 2017-09-09 00:52 cdrw -> sr0
lrwxrwxrwx 1 root root           3 2017-09-09 00:52 cdrom -> sr0

С группой, установленной на cdrom вместо users как указано в udev править.

Я даже проверил с sudo udevadm test /dev/sr0 и это не указывает на какие-либо проблемы с правилами:

=== trie on-disk ===
tool version:          232
file size:         8775171 bytes
header size             80 bytes
strings            1849483 bytes
nodes              6925608 bytes
Load module index
Found container virtualization none
timestamp of '/etc/systemd/network' changed
timestamp of '/lib/systemd/network' changed
Parsed configuration file /lib/systemd/network/99-default.link
Created link configuration context.
timestamp of '/etc/udev/rules.d' changed
Reading rules file: /etc/udev/rules.d/10-bluray.rules
Reading rules file: /lib/udev/rules.d/40-vm-hotadd.rules
Reading rules file: /lib/udev/rules.d/50-apport.rules
Reading rules file: /lib/udev/rules.d/50-firmware.rules
Reading rules file: /lib/udev/rules.d/50-udev-default.rules
Reading rules file: /etc/udev/rules.d/51-android.rules
Reading rules file: /lib/udev/rules.d/55-dm.rules
Reading rules file: /lib/udev/rules.d/56-lvm.rules
Reading rules file: /lib/udev/rules.d/60-block.rules
Reading rules file: /lib/udev/rules.d/60-bridge-network-interface.rules
Reading rules file: /lib/udev/rules.d/60-cdrom_id.rules
Reading rules file: /lib/udev/rules.d/60-crda.rules
Reading rules file: /lib/udev/rules.d/60-drm.rules
Reading rules file: /lib/udev/rules.d/60-evdev.rules
Reading rules file: /lib/udev/rules.d/60-libgphoto2-6.rules
Reading rules file: /lib/udev/rules.d/60-libsane.rules
Reading rules file: /lib/udev/rules.d/60-open-vm-tools.rules
Reading rules file: /lib/udev/rules.d/60-persistent-alsa.rules
Reading rules file: /lib/udev/rules.d/60-persistent-input.rules
Reading rules file: /lib/udev/rules.d/60-persistent-storage-dm.rules
Reading rules file: /lib/udev/rules.d/60-persistent-storage-tape.rules
Reading rules file: /lib/udev/rules.d/60-persistent-storage.rules
Reading rules file: /lib/udev/rules.d/60-persistent-v4l.rules
Reading rules file: /lib/udev/rules.d/60-qemu-system-common.rules
Reading rules file: /lib/udev/rules.d/60-serial.rules
Reading rules file: /lib/udev/rules.d/60-tvbutler-perms.rules
Reading rules file: /lib/udev/rules.d/60-vlan-network-interface.rules
Reading rules file: /lib/udev/rules.d/61-persistent-storage-android.rules
Reading rules file: /lib/udev/rules.d/63-md-raid-arrays.rules
Reading rules file: /lib/udev/rules.d/64-btrfs-dm.rules
Reading rules file: /lib/udev/rules.d/64-btrfs.rules
Reading rules file: /lib/udev/rules.d/64-md-raid-assembly.rules
Reading rules file: /lib/udev/rules.d/66-snapd-autoimport.rules
Reading rules file: /lib/udev/rules.d/69-bcache.rules
Reading rules file: /lib/udev/rules.d/69-cd-sensors.rules
Reading rules file: /lib/udev/rules.d/69-libmtp.rules
Reading rules file: /lib/udev/rules.d/69-lvm-metad.rules
Reading rules file: /lib/udev/rules.d/70-android-tools-adb.rules
Reading rules file: /lib/udev/rules.d/70-android-tools-fastboot.rules
Reading rules file: /lib/udev/rules.d/70-debian-uaccess.rules
Reading rules file: /lib/udev/rules.d/70-iscsi-network-interface.rules
Reading rules file: /lib/udev/rules.d/70-mouse.rules
Reading rules file: /lib/udev/rules.d/70-power-switch.rules
Reading rules file: /etc/udev/rules.d/70-snap.core.rules
Reading rules file: /lib/udev/rules.d/70-touchpad.rules
Reading rules file: /lib/udev/rules.d/70-uaccess.rules
Reading rules file: /lib/udev/rules.d/71-power-switch-proliant.rules
Reading rules file: /lib/udev/rules.d/71-seat.rules
Reading rules file: /lib/udev/rules.d/71-u-d-c-gpu-detection.rules
Reading rules file: /lib/udev/rules.d/73-seat-late.rules
Reading rules file: /lib/udev/rules.d/73-special-net-names.rules
Reading rules file: /lib/udev/rules.d/73-usb-net-by-mac.rules
Reading rules file: /lib/udev/rules.d/75-net-description.rules
Reading rules file: /lib/udev/rules.d/75-probe_mtd.rules
Reading rules file: /lib/udev/rules.d/78-graphics-card.rules
Reading rules file: /lib/udev/rules.d/78-sound-card.rules
Reading rules file: /lib/udev/rules.d/80-debian-compat.rules
Reading rules file: /lib/udev/rules.d/80-docker.io.rules
Reading rules file: /lib/udev/rules.d/80-drivers.rules
Reading rules file: /lib/udev/rules.d/80-ifupdown.rules
Reading rules file: /lib/udev/rules.d/80-net-setup-link.rules
Reading rules file: /lib/udev/rules.d/80-snappy-assign.rules
Reading rules file: /lib/udev/rules.d/80-udisks2.rules
Reading rules file: /lib/udev/rules.d/85-hdparm.rules
Reading rules file: /lib/udev/rules.d/85-keyboard-configuration.rules
Reading rules file: /lib/udev/rules.d/85-regulatory.rules
Reading rules file: /lib/udev/rules.d/90-alsa-restore.rules
Reading rules file: /lib/udev/rules.d/90-console-setup.rules
Reading rules file: /lib/udev/rules.d/95-cd-devices.rules
Reading rules file: /lib/udev/rules.d/99-systemd.rules
Reading rules file: /lib/udev/rules.d/99-vmware-scsi-udev.rules
rules contain 393216 bytes tokens (32768 * 12 bytes), 31005 bytes strings
21448 strings (173557 bytes), 18376 de-duplicated (145625 bytes), 3073 trie nodes used
unable to open device '/sys/dev/sr0'
Unload module index
Unloaded link configuration context.

Мое понимание udev обработка правил заключается в том, что правила в /etc/udev/rules.d/ переопределить любые правила, определенные в /lib/udev/rules.d/ (где, по-видимому, большинство из них) - это не правильно?

В конечном итоге моя цель - разрешить пользователю выдавать mount /dev/sr0 /<blah>/<blah> без использования sudo - это вообще возможно?

1 ответ

  • AFAIK, правильный способ предоставить обычным пользователям доступ к CDROM, добавив их в cdrom группа.

    1. Добавить существующих пользователей в cdrom группа
    2. добавлять cdrom группа по умолчанию группы useradd в /etc/default/useradd файл. Справка: Причины групп по умолчанию и пользователей в Linux
  • Если вы все еще хотите попробовать udev подход.

    Да правила в /etc переопределить те в /lib но только те, которые соответствуют одному и тому же имени файла в обеих папках. Поэтому все остальные файлы с уникальным именем не опускаются.

    1. Для меня, используя очень низкий порядок 10- не подходит для пользовательских правил. Любое правило с >10- (буквенно-цифровой порядок), который устанавливает GROUP слишком для того же узла переопределит ваше пользовательское правило. Так что попробуйте изменить его на 99- или же 90-по крайней мере.

    2. За ACTION=="change", проверьте, запускается ли это событие при добавлении CD-привода, если у него есть опция "горячего" подключения, используя udevadm monitor, В противном случае используйте ACTION=="add" вместо.

Другие вопросы по тегам