我有一个 udev 规则,连接时自动安装 USB 设备
规则如下:
# cat /etc/udev/rules.d/10-usbdetectd.rules
KERNEL!="sd[a-z]*", GOTO="media_by_label_auto_mount_end"
# Import FS infos
IMPORT{program}="/sbin/blkid -o udev -p %N"
# Global mount options
ACTION=="add", ENV{mount_options}="relatime"
# Filesystem-specific mount options
ACTION=="add", ENV{ID_FS_TYPE}=="vfat|ntfs", ENV{mount_options}="$env{mount_options},utf8,uid=1000,gid=1000,umask=022"
# Mount the device
ACTION=="add", RUN+="/bin/mount -o $env{mount_options} /dev/%k /media/usb"
# Clean up after removal
ACTION=="remove", RUN+="/bin/umount -l /media/usb"
# Exit
LABEL="media_by_label_auto_mount_end"
该规则运行良好,但是,我想以完全权限安装设备。为此,我必须设置 umask=000
当我手动尝试时,它按预期工作
# ls -dl /media/usb/
drwxr-xr-x 2 root root 4096 Jan 29 2019 /media/usb/
# mount -o relatime,utf8,uid=1000,gid=1000,umask=000 /dev/sda1 /media/usb/
# df
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/root 6643016 86356 6199492 1% /
devtmpfs 223204 0 223204 0% /dev
tmpfs 256484 0 256484 0% /dev/shm
tmpfs 256484 48 256436 0% /tmp
tmpfs 256484 132 256352 0% /run
/dev/mmcblk0p1 20185 2854 17331 14% /boot
/dev/sda1 1957600 96 1957504 0% /media/usb
# ls -dl /media/usb/
drwxrwxrwx 2 user user 16384 Jan 1 1970 /media/usb/
但是,当 udev 完成挂载时,不会应用掩码
# ls -dl /media/usb/
drwxr-xr-x 2 root root 4096 Jan 29 2019 /media/usb/
[USB drive plug]
# df
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/root 6643016 86356 6199492 1% /
devtmpfs 223204 0 223204 0% /dev
tmpfs 256484 0 256484 0% /dev/shm
tmpfs 256484 52 256432 0% /tmp
tmpfs 256484 132 256352 0% /run
/dev/mmcblk0p1 20185 2854 17331 14% /boot
/dev/sda1 1957600 96 1957504 0% /media/usb
# ls -dl /media/usb/
drwxr-xr-x 2 root root 16384 Jan 1 1970 /media/usb/
似乎当 udev 完成挂载时,没有应用任何挂载选项。
uid=1000 和 gid=1000 对应于我的用户
# cat /etc/passwd
[...]
user:x:1000:1000:- Standard user:/home/user:/bin/bash
[...]
答案1
看来问题出在 udev 规则语法上。
使用外部脚本而不是直接调用/bin/mount
和添加一些日志后,我声明只有relatime
选项被传递给脚本。
将 udev 规则修改为:
[...]
# Global mount options
ACTION=="add", ENV{mount_options}="relatime,utf8,uid=1000,gid=1000,dmask=0000,fmask=0000"
# Mount the device
ACTION=="add", RUN+="/bin/mount -o $env{mount_options} /dev/%k /media/usb"
[...]
udev 规则有效并以预期的权限挂载 USB 驱动器。
因此,一旦定义了环境变量(或者我没有使用正确的语法),就不可能将环境变量覆盖到 udev 规则中。
如果有人知道我如何保留文件系统特定的安装选项,我会很高兴看到它。
否则,这个解决方法对于我的情况来说已经足够了,即使它不是最佳的。