自动使用 udev 规则挂载 exfat

自动使用 udev 规则挂载 exfat

我正在尝试使用 udev 规则自动安装各种 SD 卡。我已开始有了这些规则,在以下的帮助下解决了一个问题这个问题,现在我有以下情况:

ext4 和 vfat 格式的设备工作正常,但是当我插入 exfat 或 NTFS 格式的磁盘时,我得到以下行mount

/dev/sda1 on /media/GoPro type fuseblk (rw,nosuid,nodev,noatime,user_id=0,group_id=0,default_permissions,allow_other,blksize=4096)

目录列表如下所示:

$ ls -l /media/
ls: cannot access '/media/GoPro': Transport endpoint is not connected
total 0
d????????? ? ? ? ?            ? GoPro

我无法在该挂载点下执行任何操作,即使作为 root 也无法执行:

$ sudo ls -l /media/GoPro
ls: cannot access '/media/GoPro': Transport endpoint is not connected

我从其他人那里找到的唯一有错误消息的问题Transport endpoint is not connected似乎是在磁盘未正确卸载之后发生的。但我在安装磁盘时遇到问题。

我当前的 udev 规则如下所示:

KERNEL!="sd[a-z][0-9]", GOTO="media_by_label_auto_mount_end"
ACTION=="add", PROGRAM!="/sbin/blkid %N", GOTO="media_by_label_auto_mount_end"

# Do not mount devices already mounted somewhere else to avoid entries for all your local partitions in /media
ACTION=="add", PROGRAM=="/bin/grep -q ' /dev/%k ' /proc/self/mountinfo", GOTO="media_by_label_auto_mount_end"

# Global mount options
ACTION=="add", ENV{mount_options}="noatime"
# Filesystem-specific mount options
ACTION=="add", PROGRAM=="/sbin/blkid -o value -s TYPE %E{device}", RESULT=="vfat|ntfs", ENV{mount_options}="%E{mount_options},utf8,uid=1000,gid=100,umask=002"
ACTION=="add", PROGRAM=="/sbin/blkid -o value -s TYPE %E{device}", RESULT=="exfat", ENV{mount_options}="%E{mount_options},utf8,allow_other,umask=002,uid=1000,gid=1000"

# Get label if present, otherwise assign one
ENV{ID_FS_LABEL}!="", ENV{dir_name}="%E{ID_FS_LABEL}"
ENV{ID_FS_LABEL}=="", ENV{dir_name}="usbhd-%k"

# Mount the device
ACTION=="add", ENV{dir_name}!="", RUN+="/bin/mkdir -p '/media/%E{dir_name}'", RUN+="/bin/mount -o %E{mount_options} /dev/%k '/media/%E{dir_name}'"

# Clean up after removal
ACTION=="remove", ENV{dir_name}!="", RUN+="/bin/umount -l '/media/%E{dir_name}'"
ACTION=="remove", ENV{dir_name}!="", RUN+="/bin/rmdir '/media/%E{dir_name}'"

# Exit
LABEL="media_by_label_auto_mount_end"

我尝试使用user_idandgroup_id代替uidandgid但无济于事。

手动安装设备工作正常:

$ sudo mount -o noatime,utf8,allow_other,umask=002,uid=1000,gid=1000 /dev/sdb1 /media/GoPro/
FUSE exfat 1.2.5
$ ls -l /media/
total 132
drwxrwxr-x 1 pi   pi   131072 Jan  1  1970 GoPro

答案1

TL;DR:udev 和 fusion 并不真正兼容


在注意到这个问题不仅出现在 exfat 上,而且出现在 NTFS 格式的设备上之后,我开始专门寻找 udev 和 fusion 的问题。

关于我发现的组合的一些评论:

我认为熔丝进程正在被终止。您无法从 udev 规则启动长期进程,这应该由 systemd 处理。

来自 Debian 开发

警告:要挂载可移动驱动器,请勿从 udev 规则调用挂载。如果是 FUSE 文件系统,您将收到传输端点未连接错误。相反,您可以使用正确处理自动挂载的 udisks 或使挂载在 udev 规则内工作,将 /usr/lib/systemd/system/systemd-udevd.service 复制到 /etc/systemd/system/systemd-udevd.service 并替换 MountFlags =从属到MountFlags=共享。[3]请记住,udev 并不是为了调用长时间运行的进程。

来自ArchWiki

还有更多。

我最终使用了这个答案中的脚本和配置文件。它与所有文件系统类型完美配合。我希望我早点发现这一点,这样我就可以省去几天的调试、试验和错误。

相关内容