我正在迁移到 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 调用,这就是为什么它似乎更早地做了一些事情。我仍然没有找到一种简单有效的方法,给定一个设备,它是主要/次要数字,找出哪些资源(内核或用户空间)正在使用它。有任何想法吗?