Error[8]: Undefined offset: 3, File: /www/wwwroot/outofmemory.cn/tmp/plugin_ss_superseo_model_superseo.php, Line: 121
File: /www/wwwroot/outofmemory.cn/tmp/plugin_ss_superseo_model_superseo.php, Line: 473, decode(

概述我们将服务器从一个非常过时的发行版更新为现代的基于Debian Jessie的系统,包括lightdm / xfce,当然还有systemd(和udisks2).一个关键点是自动挂载USB驱动器.我们过去通过一些udev规则来实现这一点.旧规则几乎仍然有效 – 挂载点已创建并且驱动器安装正常,但几秒钟后,systemd正在执行一些破坏挂载的 *** 作,因此后续访问尝试会导致“传输端点未连接”错误. 通过 我们将服务器从一个非常过时的发行版更新为现代的基于Debian JessIE的系统,包括lightdm / xfce,当然还有systemd(和udisks2).一个关键点是自动挂载USB驱动器.我们过去通过一些udev规则来实现这一点.旧规则几乎仍然有效 – 挂载点已创建并且驱动器安装正常,但几秒钟后,systemd正在执行一些破坏挂载的 *** 作,因此后续访问尝试会导致“传输端点未连接”错误.

通过命令行手动安装驱动器工作正常.那么让一个文件管理器(thunar和thunar-volman,它反过来使用udisks2).但那些不是可行的选择 – 这些系统大多是无头的,所以thunar通常不会运行.我们需要能够为无人值守的基于cron的备份插入磁盘驱动器.

我认为修改udev脚本以生成一个在执行挂载之前等待几秒钟的分离作业可能会有所帮助,但是systemd似乎不顾一切地阻止它 – 它仍然等待分离的作业完成之前持续.

也许让udev脚本以某种方式搔痒udisks2是正确的方法?我很失败,所以任何建议都非常感激.

解决方法 经过几次错误的开始,我想出了这个.关键是在udev和安装脚本之间添加systemd单元服务.

(为了记录,我无法使用udeks2(通过类似udisksctl mount -b / dev / sdb1之类的东西)直接从udev规则或系统单元文件中调用它.这似乎有竞争条件和设备节点还没有准备就绪,导致查找设备/ dev / sdb1的对象时出错.不幸的是,因为udisks2可以处理所有挂载点杂乱……)

繁重的工作由shell脚本完成,该脚本负责创建和删除安装点,以及安装和卸载驱动器.

/usr/local/bin/usb-mount.sh

#!/bin/bash# This script is called from our systemd unit file to mount or unmount# a USB drive.usage(){    echo "Usage: 
[Unit]Description=Mount USB Drive on %i[Service]Type=oneshotRemainAfterExit=trueExecStart=/usr/local/bin/usb-mount.sh add %iExecStop=/usr/local/bin/usb-mount.sh remove %i
{add|remove} device_name (e.g. sdb1)" exit 1}if [[ $# -ne 2 ]]; then usagefiACTION=DEVBASE=DEVICE="/dev/${DEVBASE}"# See if this drive is already mounted,and if so whereMOUNT_POINT=$(/bin/mount | /bin/grep ${DEVICE} | /usr/bin/awk '{ print }')do_mount(){ if [[ -n ${MOUNT_POINT} ]]; then echo "Warning: ${DEVICE} is already mounted at ${MOUNT_POINT}" exit 1 fi # Get info for this drive: $ID_FS_LABEL,$ID_FS_UUID,and $ID_FS_TYPE eval $(/sbin/blkID -o udev ${DEVICE}) # figure out a mount point to use LABEL=${ID_FS_LABEL} if [[ -z "$
" ]]; then LABEL=${DEVBASE} elif /bin/grep -q " /media/$

" /etc/mtab; then # Already in use,make a unique one LABEL+="-${DEVBASE}" fi MOUNT_POINT="/media/$

" echo "Mount point: ${MOUNT_POINT}" /bin/mkdir -p ${MOUNT_POINT} # Global mount options OPTS="rw,relatime" # file system type specific mount options if [[ ${ID_FS_TYPE} == "vfat" ]]; then OPTS+=",users,gID=100,umask=000,shortname=mixed,utf8=1,flush" fi if ! /bin/mount -o ${OPTS} ${DEVICE} ${MOUNT_POINT}; then echo "Error mounting ${DEVICE} (status = $?)" /bin/rmdir ${MOUNT_POINT} exit 1 fi echo "**** Mounted ${DEVICE} at ${MOUNT_POINT} ****"}do_unmount(){ if [[ -z ${MOUNT_POINT} ]]; then echo "Warning: ${DEVICE} is not mounted" else /bin/umount -l ${DEVICE} echo "**** Unmounted ${DEVICE}" fi # Delete all empty dirs in /media that aren't being used as mount # points. This is kind of overkill,but if the drive was unmounted # prior to removal we no longer kNow its mount point,and we don't # want to leave it orphaned... for f in /media/* ; do if [[ -n $(/usr/bin/find "$f" -maxdepth 0 -type d -empty) ]]; then if ! /bin/grep -q " $f " /etc/mtab; then echo "**** Removing mount point $f" /bin/rmdir "$f" fi fi done}case "${ACTION}" in add) do_mount ;; remove) do_unmount ;; *) usage ;;esac

反过来,脚本由systemd单元文件调用.我们使用“@”文件名语法,因此我们可以将设备名称作为参数传递.
  
/etc/systemd/system/usb-mount@.service

KERNEL=="sd[a-z][0-9]",SUBSYstemS=="usb",ACTION=="add",RUN+="/bin/systemctl start usb-mount@%k.service"KERNEL=="sd[a-z][0-9]",ACTION=="remove",RUN+="/bin/systemctl stop usb-mount@%k.service"

最后,一些udev规则在hotplug / unplug上启动和停止systemd单元服务:

/etc/udev/rules.d/99-local.rules

[+++]

这似乎可以解决问题!一些有用的命令用于调试这样的东西:

> udevadm control -l deBUG打开详细日志记录/ var / log / syslog,这样你就可以看到发生了什么.>修改文件后的udevadm控制–reload-rulesrules.dir(可能没有必要,但不能伤害……).>修改systemd单元文件后的systemctl守护程序重新加载.

总结

以上是内存溢出为你收集整理的linux – 使用systemd自动挂载USB驱动器全部内容,希望文章能够帮你解决linux – 使用systemd自动挂载USB驱动器所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
)
File: /www/wwwroot/outofmemory.cn/tmp/route_read.php, Line: 126, InsideLink()
File: /www/wwwroot/outofmemory.cn/tmp/index.inc.php, Line: 166, include(/www/wwwroot/outofmemory.cn/tmp/route_read.php) File: /www/wwwroot/outofmemory.cn/index.php, Line: 30, include(/www/wwwroot/outofmemory.cn/tmp/index.inc.php) linux – 使用systemd自动挂载USB驱动器_系统运维_内存溢出

阅读 19

linux – 使用systemd自动挂载USB驱动器,第1张

概述我们将服务器从一个非常过时的发行版更新为现代的基于Debian Jessie的系统,包括lightdm / xfce,当然还有systemd(和udisks2).一个关键点是自动挂载USB

驱动器

.我们过去通过一些udev规则来实现这一点.旧规则几乎仍然有效 – 挂载点已创建并且驱动器安装正常,但几秒钟后,systemd正在执行一些破坏挂载的 *** 作,因此后续访问尝试会导致“传输端点未连接”错误. 通过 我们将服务器从一个非常过时的发行版更新为现代的基于Debian JessIE的系统,包括lightdm / xfce,当然还有systemd(和udisks2).一个关键点是自动挂载USB驱动器.我们过去通过一些udev规则来实现这一点.旧规则几乎仍然有效 – 挂载点已创建并且驱动器安装正常,但几秒钟后,systemd正在执行一些破坏挂载的 *** 作,因此后续访问尝试会导致“传输端点未连接”错误.

通过命令行手动安装驱动器工作正常.那么让一个文件管理器(thunar和thunar-volman,它反过来使用udisks2).但那些不是可行的选择 – 这些系统大多是无头的,所以thunar通常不会运行.我们需要能够为无人值守的基于cron的备份插入磁盘驱动器.

我认为修改udev脚本以生成一个在执行挂载之前等待几秒钟的分离作业可能会有所帮助,但是systemd似乎不顾一切地阻止它 – 它仍然等待分离的作业完成之前持续.

也许让udev脚本以某种方式搔痒udisks2是正确的方法?我很失败,所以任何建议都非常感激.

解决方法 经过几次错误的开始,我想出了这个.关键是在udev和安装脚本之间添加systemd单元服务.

(为了记录,我无法使用udeks2(通过类似udisksctl mount -b / dev / sdb1之类的东西)直接从udev规则或系统单元文件中调用它.这似乎有竞争条件和设备节点还没有准备就绪,导致查找设备/ dev / sdb1的对象时出错.不幸的是,因为udisks2可以处理所有挂载点杂乱……)

繁重的工作由shell脚本完成,该脚本负责创建和删除安装点,以及安装和卸载驱动器.
  
/usr/local/bin/usb-mount.sh
#!/bin/bash# This script is called from our systemd unit file to mount or unmount# a USB drive.usage(){ echo "Usage:

[Unit]Description=Mount USB Drive on %i[Service]Type=oneshotRemainAfterExit=trueExecStart=/usr/local/bin/usb-mount.sh add %iExecStop=/usr/local/bin/usb-mount.sh remove %i

{add|remove} device_name (e.g. sdb1)" exit 1}if [[ $# -ne 2 ]]; then usagefiACTION=DEVBASE=DEVICE="/dev/${DEVBASE}"# See if this drive is already mounted,and if so whereMOUNT_POINT=$(/bin/mount | /bin/grep ${DEVICE} | /usr/bin/awk '{ print }')do_mount(){ if [[ -n ${MOUNT_POINT} ]]; then echo "Warning: ${DEVICE} is already mounted at ${MOUNT_POINT}" exit 1 fi # Get info for this drive: $ID_FS_LABEL,$ID_FS_UUID,and $ID_FS_TYPE eval $(/sbin/blkID -o udev ${DEVICE}) # figure out a mount point to use LABEL=${ID_FS_LABEL} if [[ -z "$

" ]]; then LABEL=${DEVBASE} elif /bin/grep -q " /media/$

" /etc/mtab; then # Already in use,make a unique one LABEL+="-${DEVBASE}" fi MOUNT_POINT="/media/$
"    echo "Mount point: ${MOUNT_POINT}"    /bin/mkdir -p ${MOUNT_POINT}    # Global mount options    OPTS="rw,relatime"    # file system type specific mount options    if [[ ${ID_FS_TYPE} == "vfat" ]]; then        OPTS+=",users,gID=100,umask=000,shortname=mixed,utf8=1,flush"    fi    if ! /bin/mount -o ${OPTS} ${DEVICE} ${MOUNT_POINT}; then        echo "Error mounting ${DEVICE} (status = $?)"        /bin/rmdir ${MOUNT_POINT}        exit 1    fi    echo "**** Mounted ${DEVICE} at ${MOUNT_POINT} ****"}do_unmount(){    if [[ -z ${MOUNT_POINT} ]]; then        echo "Warning: ${DEVICE} is not mounted"    else        /bin/umount -l ${DEVICE}        echo "**** Unmounted ${DEVICE}"    fi    # Delete all empty dirs in /media that aren't being used as mount    # points. This is kind of overkill,but if the drive was unmounted    # prior to removal we no longer kNow its mount point,and we don't    # want to leave it orphaned...    for f in /media/* ; do        if [[ -n $(/usr/bin/find "$f" -maxdepth 0 -type d -empty) ]]; then            if ! /bin/grep -q " $f " /etc/mtab; then                echo "**** Removing mount point $f"                /bin/rmdir "$f"            fi        fi    done}case "${ACTION}" in    add)        do_mount        ;;    remove)        do_unmount        ;;    *)        usage        ;;esac

反过来,脚本由systemd单元文件调用.我们使用“@”文件名语法,因此我们可以将设备名称作为参数传递.

/etc/systemd/system/usb-mount@.service

KERNEL=="sd[a-z][0-9]",SUBSYstemS=="usb",ACTION=="add",RUN+="/bin/systemctl start usb-mount@%k.service"KERNEL=="sd[a-z][0-9]",ACTION=="remove",RUN+="/bin/systemctl stop usb-mount@%k.service"

最后,一些udev规则在hotplug / unplug上启动和停止systemd单元服务:

/etc/udev/rules.d/99-local.rules

这似乎可以解决问题!一些有用的命令用于调试这样的东西:

> udevadm control -l deBUG打开详细日志记录/ var / log / syslog,这样你就可以看到发生了什么.>修改文件后的udevadm控制–reload-rulesrules.dir(可能没有必要,但不能伤害……).>修改systemd单元文件后的systemctl守护程序重新加载.

总结 以上是内存溢出为你收集整理的linux – 使用systemd自动挂载USB驱动器全部内容,希望文章能够帮你解决linux – 使用systemd自动挂载USB驱动器所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:

内存溢出
微信扫一扫 支付宝扫一扫 打赏
微信扫一扫
支付宝扫一扫
上一篇
下一篇
2022-05-24

发表评论
请登录后评论...
登录
后才能评论

提交
评论列表(0条)
[单项选择题] 在窗体上画一个命令按钮和一个文本框,其名称分别为Commandl和Text1,把文本框的 Text属性设置为空白,然后编写如下事件过程:Private Sub Commandl_c

2022-4-12

晓辉
飞走了
参谋部
{label} {label}保存{label} {label} {label} {label}