Raspberry Pi 通常在启动时安装两个分区;这里是/etc/fstab
:
proc /proc proc defaults 0 0
PARTUUID=8a6020b5-01 /boot/firmware vfat defaults 0 2
PARTUUID=8a6020b5-02 / ext4 defaults,noatime 0 1
我遇到一个问题,在很多情况下,/boot/firmware
(vfat)分区(显然是随机的)变为“未安装”状态;我在输出中注意到了这一点lsblk --fs
:
# 'boot/firmware' mounted correctly:
$ lsblk --fs
NAME FSTYPE FSVER LABEL UUID FSAVAIL FSUSE% MOUNTPOINTS
nvme0n1
├─nvme0n1p1 vfat FAT32 bootfs 146B-AD94 444.8M 13% /boot/firmware
└─nvme0n1p2 ext4 1.0 rootfs ece25014-1cd7-4874-9bfc-f91e486bc000 364.9G 2% /
# 'boot/firmware' becomes "un-mounted":
$ lsblk --fs
NAME FSTYPE FSVER LABEL UUID FSAVAIL FSUSE% MOUNTPOINTS
nvme0n1
├─nvme0n1p1 vfat FAT32 bootfs 146B-AD94 444.8M 13%
└─nvme0n1p2 ext4 1.0 rootfs ece25014-1cd7-4874-9bfc-f91e486bc000 364.9G 2% /
在考虑了一些有助于“解决”此问题的选项之后,我认为使用--poll
带有选项findmnt
是一个不错的选择;即:
$ nohup /usr/bin/findmnt -n --poll=umount,mount --target /boot/firmware &
我已经运行了此命令,并使用umount
和mount
触发对其进行了测试findmnt --poll
:
$ nohup /usr/bin/findmnt --poll=umount,mount --target /boot/firmware &
[1] 10904
# wait a while, then
$ sudo umount /boot/firmware
$ sudo mount -a
# check nohup.out:
$ cat nohup.out
umount /boot/firmware /dev/nvme0n1p1 vfat rw,relatime,fmask=0022,dmask=0022,codepage=437,iocharset=ascii,shortname=mixed,errors=remount-ro
mount /boot/firmware /dev/nvme0n1p1 vfat rw,relatime,fmask=0022,dmask=0022,codepage=437,iocharset=ascii,shortname=mixed,errors=remount-ro
我需要做的是在输出产生时触发例程umount ...
。到目前为止,我还无法做到这一点,这就是我需要帮助的地方。我需要一个启动findmnt --poll
命令的脚本,然后等待以 开头的输出umount
。当该输出到达时,我想运行dmesg
(?),将该输出捕获到日志文件,也许还有一些其他诊断,最后发出sudo mount -a
。
findmnt --poll
在输出另一行之后mount
,我认为脚本应该返回到“等待”状态以捕获下一个umount
事件。
我已经阅读了一些有关wait
命令的内容,但想知道这是否是正确的方法,因为:
wait 命令使 shell 脚本或终端会话等待后台进程完成。
在这种情况下,它findmnt --poll
不会完成- 它会继续运行,轮询另一个可报告的状态变化。关于如何处理这个问题有什么建议吗?
感谢@muru 的建议,我得到了一个答案: