Introduction to Unbound
Unbound is a validating,
recursive, and caching DNS resolver. It is designed as a set of
modular components that incorporate modern features, such as
enhanced security (DNSSEC) validation, Internet Protocol Version 6
(IPv6), and a client resolver library API as an integral part of
This package is known to build and work properly using an LFS-8.0
Download (HTTP): http://www.unbound.net/downloads/unbound-1.6.0.tar.gz
Download MD5 sum: 78409eccf7260d260b6463f85e59c66b
Download size: 4.8 MB
Estimated disk space required: 67 MB (with tests, add 57 MB
Estimated build time: 0.8 SBU (with tests)
Python-2.7.13, SWIG-3.0.12 (for
Python bindings), Doxygen-1.8.13 (for html documentation),
Sphinx (for Python
User Notes: http://wiki.linuxfromscratch.org/blfs/wiki/unbound
Installation of Unbound
There should be a dedicated user and group to take control of the
unbound daemon after
it is started. Issue the following commands as the
groupadd -g 88 unbound &&
useradd -c "Unbound DNS resolver" -d /var/lib/unbound -u 88 \
-g unbound -s /bin/false unbound
Install Unbound by running the
./configure --prefix=/usr \
If you have Doxygen-1.8.13 package installed and want to
build html documentation, run the following command:
To test the results, issue make
Now, as the
make install &&
mv -v /usr/sbin/unbound-host /usr/bin/
If you built html documentation, install it by running the
following commands as the
install -v -m755 -d /usr/share/doc/unbound-1.6.0 &&
install -v -m644 doc/html/* /usr/share/doc/unbound-1.6.0
switch prevents installation of static versions of the libraries.
--with-libevent: This option enables
libevent support allowing use of large outgoing port ranges.
--with-pyunbound: This option enables
building of the Python bindings.
In the default configuration, unbound will bind to localhost
(127.0.0.1 IP address) and allow recursive queries only from
localhost clients. If you want to use unbound for local DNS
resolution, run the following command as the
echo "nameserver 127.0.0.1" > /etc/resolv.conf
If you are using a DHCP client for connecting to a network,
/etc/resolv.conf gets overwritten
with values provided by DHCP server. You can override this, for
example in DHCP-4.3.5, by running the following command as
sed -i '/request /i\supersede domain-name-servers 127.0.0.1;' \
For advanced configuration see
/etc/unbound/unbound.conf file and the
When Unbound is installed, some
package builds fail if the file
/etc/unbound/root.key is not found. This file
is created by running the boot script (install instructions
below). Alternatively, it can be created by running the following
command as the
If you want the Unbound server
to start automatically when the system is booted, install the
script included in the blfs-bootscripts-20170225 package.
unbound-checkconf, unbound-control, unbound-control-setup, and
libunbound.so and (optional)
is a DNS resolver daemon.
performs setup or update of the root trust anchor for
checks unbound configuration
file for syntax and other errors.
performs remote administration on the unbound DNS resolver.
generates self-signed certificate and private keys for
the server and client.
is a DNS lookup utility similar to host from BIND Utilities-9.11.0-P3.
provides the Unbound API
functions to programs.
Last updated on 2017-02-22 09:52:51 -0800