Knot DNS - DNS autoritaire haute performance
Find a file
2024-12-18 09:24:03 +01:00
distro libknot: add knot_dname_with_null() 2024-12-10 14:56:57 +01:00
doc doc: improvements in key management section 2024-12-10 14:56:57 +01:00
m4 m4: change the non-release versioning to comply with PEP 440 2023-06-21 20:13:29 +02:00
python knot_exporter: avoid faulty escape sequence interpretation 2024-11-24 20:47:40 +01:00
samples samples: port samples/dbus_client.py to dasbus library which allows connection to the address 2023-10-18 21:12:27 +02:00
scripts Add python-sphinx-panels to dependencies where necessary 2023-08-17 09:10:56 +02:00
src dnssec/rollovers: prevent increasing confusion when 2 active ZSKs 2024-12-10 14:56:57 +01:00
tests tests: longer lasting RRSIGs to prevent test breakage by expiration 2024-08-22 13:36:20 +02:00
tests-extra tests: compatibility with new Bind9 2024-12-10 14:56:57 +01:00
tests-fuzz tests-fuzz: use the same style for setting a buffer size 2023-07-31 18:52:20 +02:00
.dir-locals.el added surmised C indentation rules for emacs users 2017-03-25 13:15:24 -05:00
.dockerignore docker: Transfer much less data for build 2021-02-09 14:21:46 +01:00
.gitattributes Add .gitattributes export-ignore 2011-11-02 14:58:23 +01:00
.gitignore gitignore: add qtcreator junk 2024-12-10 14:56:57 +01:00
.gitlab-ci.yml CI: replace Fedora 39 with Fedora 41 2024-12-10 14:56:57 +01:00
.gitmodules Update links to gitlab.nic.cz 2020-07-28 16:41:05 +02:00
autogen.sh add autogen.sh 2014-12-17 14:14:56 +01:00
configure.ac Bump version 3.3.10 2024-12-12 07:15:00 +01:00
COPYING COPYING: remove obsolete OpenSSL exception as we no longer use OpenSSL 2019-09-30 21:48:46 +02:00
Dockerfile docker: add (inter-container) support for D-Bus signaling 2023-10-18 21:12:27 +02:00
Doxyfile.in Doxyfile: remove obsolete options 2022-03-16 15:24:42 +01:00
Knot.config Try to solve undetected defines from config.h in QTcreator 2017-08-22 09:06:53 +02:00
Knot.creator Added QtCreator project files 2011-02-28 11:19:59 +01:00
Knot.files libdnssec: move sample keys from tests to libdnssec 2024-07-21 08:08:28 +02:00
Knot.includes contrib: remove embedded libbpf 0.0.6, which no longer works with BTF and old kernels 2022-12-19 20:45:25 +01:00
Makefile.am Include README.md in distribution package 2020-05-25 12:29:19 +02:00
NEWS NEWS: fix typos 2024-12-18 09:24:03 +01:00
README.md Add python-sphinx-panels to dependencies where necessary 2023-08-17 09:10:56 +02:00

Coverity Status Fuzzing Status Documentation Status

Requirements

doc/requirements.rst

Installation

doc/installation.rst

1. Install prerequisites

Debian based distributions

Update the system:

sudo apt-get update
sudo apt-get upgrade

Install prerequisites:

sudo apt-get install \
  libtool autoconf automake make pkg-config liburcu-dev libgnutls28-dev libedit-dev liblmdb-dev

Install optional packages:

sudo apt-get install \
  libcap-ng-dev libsystemd-dev libidn2-0-dev libprotobuf-c-dev protobuf-c-compiler libfstrm-dev libmaxminddb-dev libnghttp2-dev libbpf-dev libxdp-dev libmnl-dev python3-sphinx python3-sphinx-panels

Fedora like distributions

Update the system:

dnf upgrade

Install basic development tools:

dnf install @buildsys-build

Install prerequisites:

dnf install \
  libtool autoconf automake pkgconfig userspace-rcu-devel gnutls-devel libedit-devel lmdb-devel

Install optional packages:

dnf install \
  libcap-ng-devel systemd-devel libidn2-devel protobuf-c-devel fstrm-devel libmaxminddb-devel libnghttp2-devel libbpf-devel libxdp-devel libmnl-devel python-sphinx python-sphinx-panels

When compiling on RHEL based system, the Fedora EPEL repository has to be enabled.

2. Install Knot DNS

Get the source code:

git clone https://gitlab.nic.cz/knot/knot-dns.git

Or extract source package to knot-dns directory.

Compile the source code:

cd knot-dns
autoreconf -if
./configure
make

Install Knot DNS into system:

sudo make install
sudo ldconfig

Running

1. Ensure some configuration

doc/configuration.rst

Please see samples/knot.sample.conf, project documentation, or man 5 knot.conf for more details. Basically the configuration should specify:

  • network interfaces
  • served zones

E.g. use the default configuration file:

cd /etc/knot
mv knot.sample.conf knot.conf

Modify the configuration file:

editor knot.conf

2. Prepare working directory

mv example.com.zone /var/lib/knot/

3. Start the server

doc/operation.rst

This can be done by running the knotd command. Alternatively, your distribution should have an init script available, if you installed Knot DNS from a binary package.

Start the server in foreground to see if it runs:

knotd -c /etc/knot/knot.conf