man.rndc.conf.html revision 23967fcd6e214ac5194222a6b7f41fe869db4f9c
2129N/A<!--
2362N/A - Copyright (C) 2004-2011 Internet Systems Consortium, Inc. ("ISC")
2129N/A - Copyright (C) 2000-2003 Internet Software Consortium.
2129N/A -
2129N/A - Permission to use, copy, modify, and/or distribute this software for any
2129N/A - purpose with or without fee is hereby granted, provided that the above
2362N/A - copyright notice and this permission notice appear in all copies.
2129N/A -
2362N/A - THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
2129N/A - REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
2129N/A - AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
2129N/A - INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
2129N/A - LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
2129N/A - OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
2129N/A - PERFORMANCE OF THIS SOFTWARE.
2129N/A-->
2129N/A<!-- $Id: man.rndc.conf.html,v 1.216 2011/10/28 12:23:40 tbox Exp $ -->
2129N/A<html>
2129N/A<head>
2129N/A<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
2362N/A<title>rndc.conf</title>
2362N/A<meta name="generator" content="DocBook XSL Stylesheets V1.71.1">
2362N/A<link rel="start" href="Bv9ARM.html" title="BIND 9 Administrator Reference Manual">
2129N/A<link rel="up" href="Bv9ARM.ch10.html" title="Manual pages">
2129N/A<link rel="prev" href="man.rndc.html" title="rndc">
2129N/A<link rel="next" href="man.rndc-confgen.html" title="rndc-confgen">
2129N/A</head>
2129N/A<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
2129N/A<div class="navheader">
2129N/A<table width="100%" summary="Navigation header">
2129N/A<tr><th colspan="3" align="center"><code class="filename">rndc.conf</code></th></tr>
2129N/A<tr>
2129N/A<td width="20%" align="left">
2129N/A<a accesskey="p" href="man.rndc.html">Prev</a>�</td>
2129N/A<th width="60%" align="center">Manual pages</th>
2129N/A<td width="20%" align="right">�<a accesskey="n" href="man.rndc-confgen.html">Next</a>
2129N/A</td>
2129N/A</tr>
2129N/A</table>
2129N/A<hr>
2129N/A</div>
2129N/A<div class="refentry" lang="en">
2129N/A<a name="man.rndc.conf"></a><div class="titlepage"></div>
2129N/A<div class="refnamediv">
2129N/A<h2>Name</h2>
2129N/A<p><code class="filename">rndc.conf</code> &#8212; rndc configuration file</p>
2129N/A</div>
2129N/A<div class="refsynopsisdiv">
2129N/A<h2>Synopsis</h2>
2129N/A<div class="cmdsynopsis"><p><code class="command">rndc.conf</code> </p></div>
2129N/A</div>
2129N/A<div class="refsect1" lang="en">
2129N/A<a name="id2641918"></a><h2>DESCRIPTION</h2>
2129N/A<p><code class="filename">rndc.conf</code> is the configuration file
2129N/A for <span><strong class="command">rndc</strong></span>, the BIND 9 name server control
2129N/A utility. This file has a similar structure and syntax to
2129N/A <code class="filename">named.conf</code>. Statements are enclosed
2129N/A in braces and terminated with a semi-colon. Clauses in
2129N/A the statements are also semi-colon terminated. The usual
2129N/A comment styles are supported:
2129N/A </p>
2129N/A<p>
2129N/A C style: /* */
2129N/A </p>
2129N/A<p>
2129N/A C++ style: // to end of line
2129N/A </p>
2129N/A<p>
2129N/A Unix style: # to end of line
2129N/A </p>
2129N/A<p><code class="filename">rndc.conf</code> is much simpler than
2129N/A <code class="filename">named.conf</code>. The file uses three
2129N/A statements: an options statement, a server statement
2129N/A and a key statement.
2129N/A </p>
2129N/A<p>
2129N/A The <code class="option">options</code> statement contains five clauses.
2129N/A The <code class="option">default-server</code> clause is followed by the
2129N/A name or address of a name server. This host will be used when
2129N/A no name server is given as an argument to
2129N/A <span><strong class="command">rndc</strong></span>. The <code class="option">default-key</code>
2129N/A clause is followed by the name of a key which is identified by
2129N/A a <code class="option">key</code> statement. If no
2129N/A <code class="option">keyid</code> is provided on the rndc command line,
2129N/A and no <code class="option">key</code> clause is found in a matching
2129N/A <code class="option">server</code> statement, this default key will be
2129N/A used to authenticate the server's commands and responses. The
2129N/A <code class="option">default-port</code> clause is followed by the port
2129N/A to connect to on the remote name server. If no
2129N/A <code class="option">port</code> option is provided on the rndc command
2129N/A line, and no <code class="option">port</code> clause is found in a
2129N/A matching <code class="option">server</code> statement, this default port
2129N/A will be used to connect.
2129N/A The <code class="option">default-source-address</code> and
2129N/A <code class="option">default-source-address-v6</code> clauses which
2129N/A can be used to set the IPv4 and IPv6 source addresses
2129N/A respectively.
2129N/A </p>
2129N/A<p>
2129N/A After the <code class="option">server</code> keyword, the server
2129N/A statement includes a string which is the hostname or address
2129N/A for a name server. The statement has three possible clauses:
2129N/A <code class="option">key</code>, <code class="option">port</code> and
2129N/A <code class="option">addresses</code>. The key name must match the
2129N/A name of a key statement in the file. The port number
2129N/A specifies the port to connect to. If an <code class="option">addresses</code>
2129N/A clause is supplied these addresses will be used instead of
2129N/A the server name. Each address can take an optional port.
2129N/A If an <code class="option">source-address</code> or <code class="option">source-address-v6</code>
2129N/A of supplied then these will be used to specify the IPv4 and IPv6
2129N/A source addresses respectively.
2129N/A </p>
2129N/A<p>
2129N/A The <code class="option">key</code> statement begins with an identifying
2129N/A string, the name of the key. The statement has two clauses.
2129N/A <code class="option">algorithm</code> identifies the encryption algorithm
2129N/A for <span><strong class="command">rndc</strong></span> to use; currently only HMAC-MD5
2129N/A is
2129N/A supported. This is followed by a secret clause which contains
2129N/A the base-64 encoding of the algorithm's encryption key. The
2129N/A base-64 string is enclosed in double quotes.
2129N/A </p>
2129N/A<p>
2129N/A There are two common ways to generate the base-64 string for the
2129N/A secret. The BIND 9 program <span><strong class="command">rndc-confgen</strong></span>
2129N/A can
2129N/A be used to generate a random key, or the
2129N/A <span><strong class="command">mmencode</strong></span> program, also known as
2129N/A <span><strong class="command">mimencode</strong></span>, can be used to generate a
2129N/A base-64
2129N/A string from known input. <span><strong class="command">mmencode</strong></span> does
2129N/A not
2129N/A ship with BIND 9 but is available on many systems. See the
2129N/A EXAMPLE section for sample command lines for each.
2129N/A </p>
2129N/A</div>
2129N/A<div class="refsect1" lang="en">
2129N/A<a name="id2642090"></a><h2>EXAMPLE</h2>
2129N/A<pre class="programlisting">
2129N/A options {
2129N/A default-server localhost;
2129N/A default-key samplekey;
2129N/A };
2129N/A</pre>
2129N/A<p>
2129N/A </p>
2129N/A<pre class="programlisting">
2129N/A server localhost {
2129N/A key samplekey;
2129N/A };
2129N/A</pre>
2129N/A<p>
2129N/A </p>
2129N/A<pre class="programlisting">
2129N/A server testserver {
2129N/A key testkey;
2129N/A addresses { localhost port 5353; };
2129N/A };
2129N/A</pre>
2129N/A<p>
2129N/A </p>
2129N/A<pre class="programlisting">
2129N/A key samplekey {
2129N/A algorithm hmac-md5;
2129N/A secret "6FMfj43Osz4lyb24OIe2iGEz9lf1llJO+lz";
2129N/A };
2129N/A</pre>
2129N/A<p>
2129N/A </p>
2129N/A<pre class="programlisting">
2129N/A key testkey {
2129N/A algorithm hmac-md5;
2129N/A secret "R3HI8P6BKw9ZwXwN3VZKuQ==";
2129N/A };
2129N/A </pre>
2129N/A<p>
2129N/A </p>
2129N/A<p>
2129N/A In the above example, <span><strong class="command">rndc</strong></span> will by
2129N/A default use
2129N/A the server at localhost (127.0.0.1) and the key called samplekey.
2129N/A Commands to the localhost server will use the samplekey key, which
2129N/A must also be defined in the server's configuration file with the
2129N/A same name and secret. The key statement indicates that samplekey
2129N/A uses the HMAC-MD5 algorithm and its secret clause contains the
2129N/A base-64 encoding of the HMAC-MD5 secret enclosed in double quotes.
2129N/A </p>
2129N/A<p>
2129N/A If <span><strong class="command">rndc -s testserver</strong></span> is used then <span><strong class="command">rndc</strong></span> will
2129N/A connect to server on localhost port 5353 using the key testkey.
2129N/A </p>
2129N/A<p>
2129N/A To generate a random secret with <span><strong class="command">rndc-confgen</strong></span>:
2129N/A </p>
2129N/A<p><strong class="userinput"><code>rndc-confgen</code></strong>
2129N/A </p>
2129N/A<p>
2129N/A A complete <code class="filename">rndc.conf</code> file, including
2129N/A the
2129N/A randomly generated key, will be written to the standard
2129N/A output. Commented-out <code class="option">key</code> and
2129N/A <code class="option">controls</code> statements for
2129N/A <code class="filename">named.conf</code> are also printed.
2129N/A </p>
2129N/A<p>
2129N/A To generate a base-64 secret with <span><strong class="command">mmencode</strong></span>:
2129N/A </p>
2129N/A<p><strong class="userinput"><code>echo "known plaintext for a secret" | mmencode</code></strong>
2129N/A </p>
2129N/A</div>
2129N/A<div class="refsect1" lang="en">
2129N/A<a name="id2642280"></a><h2>NAME SERVER CONFIGURATION</h2>
2129N/A<p>
2129N/A The name server must be configured to accept rndc connections and
2129N/A to recognize the key specified in the <code class="filename">rndc.conf</code>
2129N/A file, using the controls statement in <code class="filename">named.conf</code>.
2129N/A See the sections on the <code class="option">controls</code> statement in the
2129N/A BIND 9 Administrator Reference Manual for details.
2129N/A </p>
2129N/A</div>
2129N/A<div class="refsect1" lang="en">
2129N/A<a name="id2642306"></a><h2>SEE ALSO</h2>
2129N/A<p><span class="citerefentry"><span class="refentrytitle">rndc</span>(8)</span>,
2129N/A <span class="citerefentry"><span class="refentrytitle">rndc-confgen</span>(8)</span>,
2129N/A <span class="citerefentry"><span class="refentrytitle">mmencode</span>(1)</span>,
2129N/A <em class="citetitle">BIND 9 Administrator Reference Manual</em>.
2129N/A </p>
2129N/A</div>
2129N/A<div class="refsect1" lang="en">
2129N/A<a name="id2642822"></a><h2>AUTHOR</h2>
2129N/A<p><span class="corpauthor">Internet Systems Consortium</span>
2129N/A </p>
2129N/A</div>
2129N/A</div>
2129N/A<div class="navfooter">
<hr>
<table width="100%" summary="Navigation footer">
<tr>
<td width="40%" align="left">
<a accesskey="p" href="man.rndc.html">Prev</a>�</td>
<td width="20%" align="center"><a accesskey="u" href="Bv9ARM.ch10.html">Up</a></td>
<td width="40%" align="right">�<a accesskey="n" href="man.rndc-confgen.html">Next</a>
</td>
</tr>
<tr>
<td width="40%" align="left" valign="top">
<span class="application">rndc</span>�</td>
<td width="20%" align="center"><a accesskey="h" href="Bv9ARM.html">Home</a></td>
<td width="40%" align="right" valign="top">�<span class="application">rndc-confgen</span>
</td>
</tr>
</table>
</div>
</body>
</html>