udevからマウントするとumaskが適用されない

udevからマウントするとumaskが適用されない

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ルールでオーバーライドすることはできません。

ファイルシステム固有のマウントオプションを保存する方法を知っている人がいる場合は、喜んでお知らせします。

そうでない場合は、最適でなくてもこの回避策で十分です。

関連情報