Привет, %username%! Очень давно я писал о том, как я настраивал dnsmasq для настройки локальной зоны. Сейчас мы настроим systemd-resolved как локальный кэширующий резолвер.

Его настройку я рассматриваю только потому, что systemd-resolved есть в системе (в нормальной свежей системе с systemd).

Для начала установим модуль nss-resolve (библиотека libnss_resolve.so из пакета libnss-resolve) для механизма Name Service Switch (NSS), который будет вызывать службу systemd-resolved для разрешения имён:

sudo apt install libnss-resolve

Установка данного модуля приведет к изменению в файле /etc/nsswitch.conf – строка hosts: files dns будет автоматически заменена на следующую:

...
hosts:          files resolve [!UNAVAIL=return] dns
...

Теперь приступим к настройке самого systemd-resolved. Содержимое файла /etc/systemd/resolved.conf приводим к следующему виду:

#  This file is part of systemd.
#
#  systemd is free software; you can redistribute it and/or modify it
#  under the terms of the GNU Lesser General Public License as published by
#  the Free Software Foundation; either version 2.1 of the License, or
#  (at your option) any later version.
#
# Entries in this file show the compile time defaults.
# You can change settings by editing this file.
# Defaults can be restored by simply deleting this file.
#
# See resolved.conf(5) for details

[Resolve]
DNS=10.20.213.10 10.20.213.20
FallbackDNS=1.1.1.1 8.8.8.8 8.8.4.4
Domains=jtprog.ru jtprog.local
LLMNR=yes
#MulticastDNS=no
#DNSSEC=no
#DNSOverTLS=no
Cache=no-negative
#DNSStubListener=yes
ReadEtcHosts=yes

Сделаем магию для совместимости с приложениями, которые не используют библиотечные вызовы, а обращаются к DNS-серверам напрямую, получая их из /etc/resolv.conf. Создадим символическую ссылку на файл /run/systemd/resolve/resolv.conf, контент которого автоматически генерируется исходя из настроек, заданных нами в /etc/systemd/resolved.conf:

sudo ln -svi /run/systemd/resolve/resolv.conf /etc/resolv.conf
ln: replace '/etc/resolv.conf'? y
'/etc/resolv.conf' -> '/run/systemd/resolve/resolv.conf'

Теперь запускаем службу и включаем автозапуск:

systemctl enable systemd-resolved
systemctl restart systemd-resolved
systemctl status systemd-resolved

На этом всё! Profit!