USBデバイスが接続されると自動的にマウントするudevルールがあります。
ルールは次のとおりです。
# 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ルールでオーバーライドすることはできません。
ファイルシステム固有のマウントオプションを保存する方法を知っている人がいる場合は、喜んでお知らせします。
そうでない場合は、最適でなくてもこの回避策で十分です。