Encontré este pequeño paquete NPM que hace un trabajo maravilloso al acelerar lsof para archivos: https://www.npmjs.com/package/lsof-mac-fast .
Creé un script de envoltura para usarlo:
node ~/tools/MacOs/lsof.js db.mv.db 1000
repeating using interval: 1000
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
java 7336 jumar 256u REG 1,4 194465792 53854404
db.mv.db
Este es mi guión:
// https://www.npmjs.com/package/lsof-mac-fast
var fastLsof = require('lsof-mac-fast');
var myArgs = process.argv.slice(2);
var fileToCheck = myArgs[0];
var repeatIntervalMs = myArgs[1];
// console.log('myArgs: ', myArgs);
function lsofFile(file) {
fastLsof.lsof([file], function(err, stdout, stderr) {process.stdout.write(stdout)});
}
if (repeatIntervalMs) {
// repeat until killed
// https://javascript.info/settimeout-setinterval
console.log('repeating using interval: ' + repeatIntervalMs);
var timerId = setInterval(() => lsofFile(fileToCheck), repeatIntervalMs);
} else {
// just one time
lsofFile(fileToCheck);
}
El intervalo de repetición puede ser realmente bajo, por ejemplo, 10 ms parece funcionar bien.
lsof
muestra? ¿Cuántos procesos e hilos tiene abierto ese archivo? ¿Cuál es la carga de la CPU cuando no se ejecuta lsof?