我正在迁移到 LVM 卷组的服务器中有一个磁盘。以前,它使用传统的 DOS 磁盘分区,hdb[1-5]
.
我已经从 卸载了每个文件系统hdb
,使用 关闭了交换hdb
,已经在设备上删除了一个较小的 VG,然后使用 fdisk 对其进行了重新分区,删除了现有分区,并创建了 2 个分区,但是在将其写出后,linux 拒绝重新读取分区表。使用hdparm -z
报告重试:BLKRRPART failed: Device or resource busy.
我检查了以下位置以确保设备及其分区没有在任何地方列出:
- /proc/交换
- /proc/mdadm
- “pvs”命令的输出
- “挂载”命令的输出
- /etc/mtab
- lsof | grep hdb
但cat /proc/partitions
仍然列出了分区,并且hdparm -z /dev/hdb
仍然让我设备忙。
是否有我遗漏的东西,或者我还不知道的秘密地方可以找到仍然保留在我的块设备上的东西?更重要的是,我怎样才能释放它的持有,以便我可以重新加载分区表?
FWIW,在这种特定情况下,我可以简单地重新启动服务器而不必担心,但这以前一直困扰着我,我很好奇是否有更好的方法。
(编辑:添加了更精确的措辞)(编辑:重新划分细节)
更新:我使用partprobe /dev/hdb
了 ,它确实改变了一些事情:在 /dev /hdb1 中,/deb/hdb[3-5] 现在已经消失了,partprobe 正在报告Error: Error informing the kernel about modifications to partition /dev/hdb1 -- Device or resource busy.
<-- 特别是关于 hdb1。hdb1 以前是 LVM 卷组 (VG) 中的物理卷 (PV),但在我重新分区之前我 vgremove + pvremoved em ......
更新2:FWIW,我还没有纠正这个问题,幸运的是它并不紧急。我了解到 partprobe 正在使用更新的 API 调用,这就是为什么它似乎更早地做了一些事情。我仍然没有找到一种简单有效的方法,给定一个设备,它是主要/次要数字,找出哪些资源(内核或用户空间)正在使用它。有任何想法吗?
尝试使用定影器
Eddy 的
fuser -vam /dev/hdb1
例子基本上是正确的,但它缺乏完整性。就我而言,我在从 raid1 阵列的最后一个驱动器中恢复文件时遇到了类似的问题,其中保存数据的分区位于 LVM 中。在这种情况下,我已经开始
photorec
检查驱动器,看到有一个卷组,然后关闭了正在运行的终端photorec
。不知不觉中,photorec
还在坚持/dev/mapper/vg0-lv0
。所以,在未来,尝试使用fuser
, 但在内容上/dev/mapper/
fuser -vam /dev/mapper/*
这可能仍然不是最佳答案,但请记住尝试检查 /dev/ 下的任何文件,这些文件也可能以某种方式映射到您尝试使用的块设备。
lsof
是您要查找的命令。您通常希望通过安装点将其通过管道传送到 grep。示例
lsof | grep var
将列出所有打开文件的进程,其中路径或文件名包含“var”命令的输出是什么
mount
。不确定这是否适用于您的情况,但我知道我曾多次使用绑定安装。从绑定挂载卸载源文件系统不会卸载绑定挂载。在这种情况下, mount 的输出对于让您知道发生了什么并不是很有用。