De acordo com as Leis 12.965/2014 e 13.709/2018, que regulam o uso da Internet e o tratamento de dados pessoais no Brasil, ao me inscrever na newsletter do portal DICAS-L, autorizo o envio de notificações por e-mail ou outros meios e declaro estar ciente e concordar com seus Termos de Uso e Política de Privacidade.

A Babá do named

Colaboração: Rubens Queiroz de Almeida

Data de Publicação: 08 de novembro de 2010

Se você é o responsável pelo serviço DNS que responde pelos seus domínios (eu sou), não existe nada pior do que uma falha do servidor. Você some da face da Terra e ninguém mais consegue encontrá-lo, o que não é nem um pouco bom.

Existe um pequeno script em perl, chamado nanny.pl, que faz este monitoramento. Se o serviço named estiver fora do ar por alguma razão, ele o reativa.

Como podemos ver pelo código, o script verifica se o processo named está no ar executando o comando kill -0 tomando como argumento a identificação do processo (PID) sob o qual está rodando o named.

Vejamos como funciona:

# kill -0 25629
# echo $?
0

O comando kill -0 na verdade não faz nada, apenas verifica se o processo existe e se um sinal pode ser enviado a ele. O resultado, em bash, fica na variável $?. Se o processo existe, o código de retorno é 0 e tudo está bem. Se não existir, o código de retorno é 1 e, neste caso, o processo deve ser reiniciado.

$  # kill -9 25629

Matei o processo named.

# kill -0 25629
-su: kill: (25629) - Processo inexistente
# echo $?
1

E como esperávamos, o kill -0 retornou um erro.

Mas não é só isto. É feito também um teste com o comando dig. Se der erro, o processo named é reiniciado.

nanny.pl

  #!/usr/bin/perl
  #
  # Copyright (C) 2004  Internet Systems Consortium, Inc. ("ISC")
  # Copyright (C) 2000, 2001  Internet Software Consortium.
  #
  # Permission to use, copy, modify, and distribute this software for any
  # purpose with or without fee is hereby granted, provided that the above
  # copyright notice and this permission notice appear in all copies.
  #
  # THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
  # REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
  # AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
  # INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  # LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
  # OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  # PERFORMANCE OF THIS SOFTWARE.
  
  # $Id: nanny.pl,v 1.9 2004/03/05 05:04:27 marka Exp $
  
  # A simple nanny to make sure named stays running.
  
  $pid_file_location = '/var/run/named.pid';
  $nameserver_location = 'localhost';
  $dig_program = 'dig';
  $named_program =  'named';
  
  fork() && exit();
  
  for (;;) {
  	$pid = 0;
  	open(FILE, $pid_file_location) || goto restart;
  	$pid = <FILE>;
  	close(FILE);
  	chomp($pid);
  
  	$res = kill 0, $pid;
  
  	goto restart if ($res == 0);
  
  	$dig_command =
  	       "$dig_program +short . \@$nameserver_location > /dev/null";
  	$return = system($dig_command);
  	goto restart if ($return == 9);
  
  	sleep 30;
  	next;
  
   restart:
  	if ($pid != 0) {
  		kill 15, $pid;
  		sleep 30;
  	}
  	system ($named_program);
  	sleep 120;
  }

Adicionar comentário

* Campos obrigatórios
5000
Powered by Commentics

Comentários

Nenhum comentário ainda. Seja o primeiro!


Veja a relação completa dos artigos de Rubens Queiroz de Almeida