在 Linux 中,如何确定哪些进程正在使用块设备?

在 Linux 中,如何确定哪些进程正在使用块设备?

我正在将服务器中的一个磁盘迁移到 LVM 卷组。以前,它使用传统的 DOS 磁盘分区hdb[1-5]

我已经从 卸载了所有文件系统hdb,使用 关闭了交换hdb,已在设备上删除了一个较小的 VG,并使用 fdisk 对其进行了重新分区,删除了现有分区,并创建了 2 个分区,但在写出时,linux 拒绝重新读取分区表。使用hdparm -z报告重试:BLKRRPART failed: Device or resource busy.

我检查了以下地方以确保该设备及其分区没有在任何地方列出:

  • /proc/swaps
  • /proc/mdadm
  • ‘pvs’ 命令的输出
  • “mount”命令的输出
  • /etc/mtab
  • lsof | grep hdb

cat /proc/partitions仍然列出了分区,并且hdparm -z /dev/hdb仍然显示设备繁忙。

是不是我遗漏了什么东西,或者还不知道有哪个秘密地方可以找到仍然保留在我的块设备上的东西?更重要的是,我怎样才能释放它的保留,以便重新加载分区表?

值得一提的是,在这种特定情况下,我可以简单地重新启动服务器而不必担心,但这之前也困扰过我,我很好奇是否有更好的方法。

(编辑:添加更精确的措辞)(编辑:重新分区的详细信息)

更新:我使用了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将其......

更新 2:FWIW,我还没有纠正这个问题,幸运的是它并不紧急。我了解到 partprobe 正在使用较新的 API 调用,这就是为什么它似乎在早些时候做了一些事情。我仍然没有找到一种简单有效的方法,给定一个设备及其主/次编号,找出哪些资源(内核或用户空间)正在使用它。有什么想法吗?

答案1

尝试使用定影器

fuser -vam /dev/hdb1

答案2

lsof是您要查找的命令。您通常需要将其与挂载点一起通过管道传输到 grep。

示例 lsof | grep var将列出所有打开路径或文件名包含“var”的进程

答案3

Eddy 的fuser -vam /dev/hdb1例子基本上是正确的,但缺乏完整性。就我而言,我在从 raid1 阵列的最后一个驱动器中恢复文件时遇到了类似的问题,其中保存数据的分区位于 LVM 中。

在这种情况下,我开始photorec检查驱动器,看到有一个卷组,然后关闭正在运行的终端photorec。我不知道,photorec我仍在坚持/dev/mapper/vg0-lv0。所以,以后,试着使用fuser,但在内容上/dev/mapper/

fuser -vam /dev/mapper/*

这可能仍然不是最好的答案,但请记住尝试检查 /dev/ 下的任何文件是否以某种方式映射到您尝试使用的块设备。

答案4

该命令的输出是什么mount。不确定这是否适用于您的情况,但我知道我曾经使用过绑定挂载多次。从绑定挂载中卸载源文件系统不会卸载绑定挂载。在这种情况下,mount 的输出对于让您了解正在发生的事情没有多大用处。

相关内容