<?xml version="1.0" encoding="ISO_8859-1" standalone="no"?>
<?xml-stylesheet href="docbook.xsl" type="text/xsl"?>
<!DOCTYPE article PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">
<article lang="pt_BR">
  <articleinfo>
    <title>Rndc utilizando assinatura digital para acessar o servidor BIND</title>
    <authorgroup>
      <author>
        <firstname>Leonardo</firstname>
        <othername>Serra Maciel de</othername>
        <surname>Campos</surname>
        <affiliation>
          <address>
            <email>linuxbh@brfree.com.br</email>
          </address>
        </affiliation>
      </author>
    </authorgroup>
    <revhistory>
      <revision>
        <revnumber>0.1</revnumber>
        <date>2004-09-27 22:20:45 -0300</date>
        <authorinitials>Leonardo Serra Maciel de Campos</authorinitials>
      </revision>
      <revision>
        <revnumber>0.2</revnumber>
        <date>2004-09-27 23:06:18 -0300</date>
        <authorinitials>Leonardo Serra Maciel de Campos</authorinitials>
      </revision>
      <revision>
        <revnumber>0.3</revnumber>
        <date>2004-09-27 11:46:21 -0300</date>
        <authorinitials>Leonardo Serra Maciel de Campos</authorinitials>
      </revision>
      <revision>
        <revnumber>0.4</revnumber>
        <date>2005-01-12 20:41:02 -0300</date>
        <authorinitials>Leonardo Serra Maciel de Campos</authorinitials>
      </revision>
    </revhistory>
    <copyright>
      <year>2004-2005</year>
      <holder>Leonardo Serra Maciel de Campos</holder>
    </copyright>
    <legalnotice>
      <para>Este documento é licenciado sobre a licença de Atribuição-Compartilhamento da Creative Commons. Para ver uma cópia desta licença, visite <ulink url="http://creativecommons.org/licenses/by-sa/2.0/"/> ou envie uma carta para Creative Commons, 559 Nathan Abbott Way, Stanford, California 94305, USA.</para>
    </legalnotice>
    <abstract>
      <para>Este documento visa ensinar como configurar o utilitário rndc para usar assinatura digital durante a conexão com o servidor BIND.</para>
    </abstract>
  </articleinfo>
  <sect1>
    <title>Introdução</title>
    <sect2>
      <title>O que é rndc?</title>
      <para> O rndc é um utilitário que controla as operações do servidor BIND. O rndc comunica com o servidor BIND através de uma conexão TCP, opcionalmente enviando os comandos autenticados com assinatura digital.</para>
    </sect2>
    <sect2>
      <title>O que é BIND?</title>
      <para>BIND (Berkeley Internet Name Domain) é uma implementação do protoloco DNS (Domain Name System).</para>
    </sect2>
    <sect2>
      <title>O que é DNS?</title>
      <para> O sistema de nomes de domínios, ou DNS, é uma parte fundamental da Internet. É responsável para traduzir nome dos endereços, distribuir o correio eletrônico a seu destino apropriado, e muitos outros serviços.</para>
    </sect2>
  </sect1>
  <sect1>
    <title>Ambiente</title>
    <para>Será presumido que o seu sistema <glossterm baseform="Debian GNU/Linux">Debian GNU/Linux</glossterm> e o aptitude estão corretamente configurados.</para>
    <warning>
      <para>Todos os comandos deverão ser executados pelo usuário root!</para>
    </warning>
    <para>A tabelo abaixo mostra as versões de cada <glossterm baseform="Logicial">logicial</glossterm> usado.</para>
    <table>
      <title>Versão dos logiciais</title>
      <tgroup cols="2">
        <thead>
          <row>
            <entry>
              <glossterm baseform="Logicial">Logicial</glossterm>
            </entry>
            <entry>Versão</entry>
          </row>
        </thead>
        <tbody>
          <row>
            <entry>bind9</entry>
            <entry>9.2.4-1</entry>
          </row>
        </tbody>
      </tgroup>
    </table>
    <para>A tabelo abaixo mostra as principais características do ambiente onde foi feito esta documentação.</para>
    <table>
      <title>Ambiente</title>
      <tgroup cols="2">
        <tbody>
          <row>
            <entry>Distribuição GNU/Linux</entry>
            <entry>Debian Sarge</entry>
          </row>
        </tbody>
      </tgroup>
    </table>
    <note>
      <para>Usaremos palavras <replaceable>desta maneira</replaceable> para indicar substituição.</para>
    </note>
  </sect1>
  <sect1>
    <title>Instalação</title>
    <warning>
      <para>O servidor BIND já deve estar instalado, configurado e sendo executado de maneira correta!</para>
    </warning>
  </sect1>
  <sect1>
    <title>Configuração</title>
    <orderedlist numeration="arabic">
      <listitem>
        <para>É necessário parar o servidor BIND, para isto execute:</para>
        <screen><prompt>#</prompt> <userinput>invoke-rc.d bind9 stop</userinput></screen>
        <warning>
          <para>É necessário parar o servidor BIND pois não é possivel utilizar o utilitario <userinput>rndc</userinput> para recarregar as configurações do servidor BIND, pois estaremos configurando o utilitario <userinput>rndc</userinput> e o servidor BIND para somente aceitar e realizar acesso através da assinatura digital.</para>
        </warning>	
      </listitem>
      <listitem>
        <para>Precisamos criar o arquivo <filename>/etc/bind/rndc.conf</filename> onde será armazenada a assinatura digital gerada aleatoriamente, para isto execute:</para>
        <screen><prompt>#</prompt> <userinput>rndc-confgen -a -c <filename>/etc/bind/rndc.conf</filename> -k rndc-key -b 256</userinput></screen>
        <note>
          <itemizedlist>
            <listitem>
              <para>A opção <userinput>-k</userinput> é o nome da assinatura digital que será gerada. O padrão é <userinput>rndc-key</userinput>. É altamente recomendado alterar o nome da assinatura digital quando você quiser utilizar o <userinput>rndc</userinput> para acessar um servidor BIND em outra máquina.</para>
            </listitem>
            <listitem>
              <para>A opção <userinput>-b</userinput> é o tamanho da assinatura digital que será gerada, em bits. Por padrão , o tamanho da assinatura digital é 128 bits, entretando o tamanho pode variar de 1 até 512 bits. É recomendado que se utilize assinaturas digitais maiores que 256 bits se o servidor BIND for usado fora da rede local.</para>
            </listitem>
          </itemizedlist>
        </note>
      </listitem>
      <listitem>
        <para>Edite o arquivo <filename>/etc/bind/rndc.conf</filename>.</para>
        <itemizedlist>
          <listitem>
            <para>O arquivo estará parecido com o conteúdo abaixo:</para>
            <screen>
key "rndc-key" {
        algorithm hmac-md5;
        secret <replaceable>"v0pp2yXAw7VIDEAy4G2HucjQrauIF7mqoNc4br9/pzc="</replaceable>;
};
</screen>
            <note>
              <para>O que está no parâmetro <userinput>secret</userinput> é a assinatura digital gerada aleatoriamente pelo comando <userinput>rndc-config</userinput>, mais abaixo precisaremos colocar ela nas configurações do servidor BIND.</para>
            </note>
          </listitem>
          <listitem>
            <para>Acrescente ao fim as seguintes linhas:</para>
            <screen>
options {
    default-key "rndc-key";
    default-server 127.0.0.1;
};
</screen>
          </listitem>
        </itemizedlist>
      </listitem>
      <listitem>
        <para>Edite o arquivo <filename>/etc/bind/named.conf.options</filename>. Acrescente ao seu fim o seguinte:</para>
        <screen>
key "rndc-key" {
    algorithm hmac-md5;
    secret <replaceable>"v0pp2yXAw7VIDEAy4G2HucjQrauIF7mqoNc4br9/pzc="</replaceable>;
};

controls {
    inet * allow { 127.0.0.1; } keys { "rndc-key"; };
}; 
</screen>
        <warning>
          <para>Não esqueça de colocar no parâmetro <userinput>secret</userinput> a assinatura digital gerada aleatoriamente pelo comando <userinput>rndc-config</userinput> que foi gravada no arquivo <filename>/etc/bind/rndc.conf</filename>.</para>
        </warning>
      </listitem>
      <listitem>
        <para>É necessário que apenas o usuário root possa ler e gravar o arquivo de configuração e que apenas os usuários do grupo bind possam ler estes arquivos. Para isto execute:</para>
        <screen>
<prompt>#</prompt> <userinput>chown root:bind /etc/bind/rndc.conf</userinput>
<prompt>#</prompt> <userinput>chmod 640 /etc/bind/rndc.conf</userinput>
</screen>
      </listitem>
      <listitem>
        <para>É necessário iniciar o servidor BIND, para isto execute:</para>
        <screen><prompt>#</prompt> <userinput>invoke-rc.d bind9 start</userinput></screen>
      </listitem>
    </orderedlist>
  </sect1>
  <sect1>
    <title>Comandos úteis</title>
    <itemizedlist>
      <listitem>
        <para>Para recarregar os arquivos de configuração e as zonas do servidor BIND execute:</para>
        <screen><prompt>#</prompt> <userinput>rndc reload</userinput></screen>
      </listitem>
      <listitem>
        <para>Para visualizar o estado do servidor BIND execute:</para>
        <screen><prompt>#</prompt> <userinput>rndc status</userinput></screen>
      </listitem>
    </itemizedlist>
  </sect1>
  <sect1>
    <title>Apêndice</title>
    <sect2>
      <title>Bibliografia</title>
      <para>Os seguintes sítios foram usados como base para a criação desta documentação</para>
      <itemizedlist>
        <listitem>
          <para>
            <ulink url="http://www.bind9.net/Bv9ARM.html">BIND 9 Administrator Reference Manual</ulink>
          </para>
        </listitem>
        <listitem>
          <para>
            <ulink url="http://www.bind9.net/"/>
          </para>
        </listitem>
        <listitem>
          <para>
            <ulink url="http://www.zytrax.com/books/dns/"/>
          </para>
        </listitem>
        <listitem>
          <para>
            <ulink url="http://www.rnp.br/newsgen/0105/bind9.html"/>
          </para>
        </listitem>
      </itemizedlist>
    </sect2>
    <sect2>
      <title>Glossário</title>
      <glosslist>
        <glossentry>
          <glossterm>Debian GNU/Linux</glossterm>
          <glossdef>
            <para>O <ulink url="http://www.debian.org">Debian</ulink> é um sistema operacional (SO) livre para seu computador. Um sistema operacional é um conjunto de programas básicos e utilitários que fazem seu computador funcionar. O Debian usa o kernel (núcleo de um sistema operacional), <ulink url="http://www.kernel.org">Linux</ulink>, mas a maior parte das ferramentas do SO vêm do projeto <ulink url="http://www.gnu.org">GNU</ulink>; daí o nome GNU/Linux.</para>
          </glossdef>
        </glossentry>
        <glossentry>
          <glossterm>Logicial</glossterm>
          <glossdef>
            <para>Conjunto de instruções lógicas. Na informática designa um conjunto de instruções lógicas e suas dependências, também conhecido como programa ou sistema de computador.</para>
            <para>Esta palavra é pouco usada no Brasil, onde se usa muito a expressão "Software".</para>
            <para>Origem: <ulink url="http://pt.wikipedia.org/wiki/Logicial">Wikipédia, a enciclopédia livre.</ulink></para>
          </glossdef>
        </glossentry>
      </glosslist>
    </sect2>
  </sect1>
</article>
