Dos posibilidades: lsof
(mi preferencia) o lslk
(específicamente para bloqueos de archivos):
[root@policyServer ~]# lslk | grep "master.lock"
SRC PID DEV INUM SZ TY M ST WH END LEN NAME
master 1650 253,0 12423 33 w 0 0 0 0 0 /var/lib/postfix/master.lock
[root@policyServer ~]# lsof | grep "master.lock"
master 1650 root 10uW REG 253,0 33 12423 /var/lib/postfix/master.lock
La salida de lslk es autoexpansiva pero lsof
coloca la descripción del bloqueo en la columna "FD" (que está 10uW
arriba). Desde la página del manual:
The mode character is followed by one of these lock characters, describing the type of lock applied to the file:
N for a Solaris NFS lock of unknown type;
r for read lock on part of the file;
R for a read lock on the entire file;
w for a write lock on part of the file;
W for a write lock on the entire file;
u for a read and write lock of any length;
U for a lock of unknown type;
x for an SCO OpenServer Xenix lock on part of the file;
X for an SCO OpenServer Xenix lock on the entire file;
space if there is no lock.
Entonces la columna "FD" de lsof
arriba se desglosa en:
10
El descriptor literal de este archivo abierto. ¿A qué está vinculado?/proc/1650/fd/10
u
El archivo está abierto para leer y escribir.
W
El programa tiene un bloqueo de escritura en el archivo.