quarta-feira, 27 de janeiro de 2016

Como desmontar sistemas de arquivos em uso

Colaboração: Rubens Queiroz de Almeida

Para desmontar sistemas de arquivos em uso, a melhor opção é combinar a saída do programa lsof com o comando kill. É claro que você vai avisar seus usuários antes para que eles possam encerrar suas tarefas com antecedência.

O comando lsof, ou List Open Files, indica todos os processos que estão acessando determinado arquivo ou filesystem. Veja um exemplo da saída deste programa:


% lsof /home

  COMMAND     PID     USER   FD   TYPE     DEVICE   SIZE/OFF      INODE NAME
  lsof      19958  queiroz  cwd   VDIR    10,   8       5120       1024 /home (/d)
  ksh       26800  queiroz  cwd   VDIR    10,   8       5120       1024 /home (/d)
  ksh       26800  queiroz   63u  VREG    10,   8       2384       1060 /home (/d)
  lsof      28152  queiroz  cwd   VDIR    10,   8       5120       1024 /home (/d)


A segunda coluna indica a identificação do processo, o que nos interessa mais diretamente. Vejamos então o script:

#!/bin/sh
  for pid in ""lsof /home | grep -v COMMAND | awk '{print $2}'""
  do
  kill -9 $pid
  done
  umount /home


O umount tem que ser dado imediatamente após o falecimento dos processos que estão acessando o filesystem em questão para evitar que novos processos sejam criados, novamente impedindo o umount.

O pacote lsof pode ser encontrado no servidor de ftp anônimo da Unicamp em http://ftp.unicamp.br/pub/unix-tools/lsof.





Nenhum comentário:

Postar um comentário