Настройка DNS сервера (BIND) — различия между версиями

Материал из ARK-HOSTER.RU | Документация хостинга
Перейти к: навигация, поиск
(Новая страница: «= Настройка DNS сервера (BIND) = == 1. Подготовка системы == * Войдите в систему под учетной запи…»)
 
 
(не показана 1 промежуточная версия этого же участника)
Строка 6: Строка 6:
 
* Убедитесь, что у вас есть доступ к серверу через SSH или консоль.
 
* Убедитесь, что у вас есть доступ к серверу через SSH или консоль.
  
== 2. Установка BIND ===
+
== 2. Установка BIND ==
  
 
=== Установка пакета ===
 
=== Установка пакета ===
  
 
1. Обновите список пакетов:
 
1. Обновите список пакетов:
<code>
+
<pre>sudo apt update</pre>
sudo apt update
 
</code>
 
  
 
2. Установите BIND9:
 
2. Установите BIND9:
<code>
+
<pre>sudo apt install bind9 bind9utils bind9-doc</pre>
sudo apt install bind9 bind9utils bind9-doc
 
</code>
 
  
 
3. Запустите и включите автозапуск BIND:
 
3. Запустите и включите автозапуск BIND:
<code>
+
<pre>sudo systemctl start bind9</pre>
sudo systemctl start bind9
+
<pre>sudo systemctl enable bind9</pre>
sudo systemctl enable bind9
 
</code>
 
  
 
=== Проверка установки ===
 
=== Проверка установки ===
  
 
1. Проверьте статус сервиса:
 
1. Проверьте статус сервиса:
<code>
+
<pre>sudo systemctl status bind9</pre>
sudo systemctl status bind9
 
</code>
 
  
 
2. Проверьте, что BIND слушает на порту 53:
 
2. Проверьте, что BIND слушает на порту 53:
<code>
+
<pre>sudo netstat -tlnp | grep :53</pre>
sudo netstat -tlnp | grep :53
 
</code>
 
  
 
3. Проверьте версию BIND:
 
3. Проверьте версию BIND:
<code>
+
<pre>named -v</pre>
named -v
 
</code>
 
  
== 3. Базовая настройка BIND ===
+
== 3. Базовая настройка BIND ==
  
 
=== Основная конфигурация ===
 
=== Основная конфигурация ===
  
 
1. Создайте резервную копию конфигурации:
 
1. Создайте резервную копию конфигурации:
<code>
+
<pre>sudo cp /etc/bind/named.conf /etc/bind/named.conf.backup</pre>
sudo cp /etc/bind/named.conf /etc/bind/named.conf.backup
 
</code>
 
  
 
2. Отредактируйте основной файл конфигурации:
 
2. Отредактируйте основной файл конфигурации:
<code>
+
<pre>sudo nano /etc/bind/named.conf</pre>
sudo nano /etc/bind/named.conf
 
</code>
 
  
 
3. Настройте основные параметры:
 
3. Настройте основные параметры:
<code>
+
<pre>// Основные настройки</pre>
// Основные настройки
+
<pre>options {</pre>
options {
+
<pre>directory "/var/cache/bind";</pre>
    directory "/var/cache/bind";
+
<pre>recursion yes;</pre>
    recursion yes;
+
<pre>allow-recursion { localnets; };</pre>
    allow-recursion { localnets; };
+
<pre>listen-on { any; };</pre>
    listen-on { any; };
+
<pre>listen-on-v6 { any; };</pre>
    listen-on-v6 { any; };
+
<pre>allow-transfer { none; };</pre>
    allow-transfer { none; };
+
<pre>allow-query { any; };</pre>
    allow-query { any; };
+
<pre>forwarders {</pre>
    forwarders {
+
<pre>8.8.8.8;</pre>
        8.8.8.8;
+
<pre>8.8.4.4;</pre>
        8.8.4.4;
+
<pre>};</pre>
    };
+
<pre>dnssec-validation auto;</pre>
    dnssec-validation auto;
+
<pre>auth-nxdomain no;</pre>
    auth-nxdomain no;
+
<pre>listen-on port 53 { any; };</pre>
    listen-on port 53 { any; };
+
<pre>};</pre>
};
 
</code>
 
  
 
=== Настройка зон ===
 
=== Настройка зон ===
  
 
1. Создайте файл зоны:
 
1. Создайте файл зоны:
<code>
+
<pre>sudo nano /etc/bind/named.conf.local</pre>
sudo nano /etc/bind/named.conf.local
 
</code>
 
  
 
2. Добавьте конфигурацию зоны:
 
2. Добавьте конфигурацию зоны:
<code>
+
<pre>// Прямая зона</pre>
// Прямая зона
+
<pre>zone "example.com" {</pre>
zone "example.com" {
+
<pre>type master;</pre>
    type master;
+
<pre>file "/etc/bind/db.example.com";</pre>
    file "/etc/bind/db.example.com";
+
<pre>allow-update { none; };</pre>
    allow-update { none; };
+
<pre>};</pre>
};
+
<pre>// Обратная зона</pre>
 +
<pre>zone "1.168.192.in-addr.arpa" {</pre>
 +
<pre>type master;</pre>
 +
<pre>file "/etc/bind/db.192.168.1";</pre>
 +
<pre>allow-update { none; };</pre>
 +
<pre>};</pre>
  
// Обратная зона
+
== 4. Создание зон ==
zone "1.168.192.in-addr.arpa" {
 
    type master;
 
    file "/etc/bind/db.192.168.1";
 
    allow-update { none; };
 
};
 
</code>
 
 
 
== 4. Создание зон ===
 
  
 
=== Создание прямой зоны ===
 
=== Создание прямой зоны ===
  
 
1. Создайте файл зоны:
 
1. Создайте файл зоны:
<code>
+
<pre>sudo nano /etc/bind/db.example.com</pre>
sudo nano /etc/bind/db.example.com
 
</code>
 
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>
+
<pre>$TTL    604800</pre>
$TTL    604800
+
<pre>@      IN      SOA    ns1.example.com. admin.example.com. (</pre>
@      IN      SOA    ns1.example.com. admin.example.com. (
+
<pre>1        ; Serial</pre>
                              1        ; Serial
+
<pre>604800        ; Refresh</pre>
                        604800        ; Refresh
+
<pre>86400        ; Retry</pre>
                          86400        ; Retry
+
<pre>2419200        ; Expire</pre>
                        2419200        ; Expire
+
<pre>604800 )      ; Negative Cache TTL</pre>
                        604800 )      ; Negative Cache TTL
+
<pre>;</pre>
;
+
<pre>@      IN      NS      ns1.example.com.</pre>
@      IN      NS      ns1.example.com.
+
<pre>@      IN      NS      ns2.example.com.</pre>
@      IN      NS      ns2.example.com.
+
<pre>@      IN      A      192.168.1.10</pre>
@      IN      A      192.168.1.10
+
<pre>ns1    IN      A      192.168.1.10</pre>
ns1    IN      A      192.168.1.10
+
<pre>ns2    IN      A      192.168.1.11</pre>
ns2    IN      A      192.168.1.11
+
<pre>www    IN      A      192.168.1.10</pre>
www    IN      A      192.168.1.10
+
<pre>mail    IN      A      192.168.1.10</pre>
mail    IN      A      192.168.1.10
+
<pre>ftp    IN      A      192.168.1.10</pre>
ftp    IN      A      192.168.1.10
 
</code>
 
  
 
=== Создание обратной зоны ===
 
=== Создание обратной зоны ===
  
 
1. Создайте файл обратной зоны:
 
1. Создайте файл обратной зоны:
<code>
+
<pre>sudo nano /etc/bind/db.192.168.1</pre>
sudo nano /etc/bind/db.192.168.1
 
</code>
 
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>
+
<pre>$TTL    604800</pre>
$TTL    604800
+
<pre>@      IN      SOA    ns1.example.com. admin.example.com. (</pre>
@      IN      SOA    ns1.example.com. admin.example.com. (
+
<pre>1        ; Serial</pre>
                              1        ; Serial
+
<pre>604800        ; Refresh</pre>
                        604800        ; Refresh
+
<pre>86400        ; Retry</pre>
                          86400        ; Retry
+
<pre>2419200        ; Expire</pre>
                        2419200        ; Expire
+
<pre>604800 )      ; Negative Cache TTL</pre>
                        604800 )      ; Negative Cache TTL
+
<pre>;</pre>
;
+
<pre>@      IN      NS      ns1.example.com.</pre>
@      IN      NS      ns1.example.com.
+
<pre>@      IN      NS      ns2.example.com.</pre>
@      IN      NS      ns2.example.com.
+
<pre>10      IN      PTR    ns1.example.com.</pre>
10      IN      PTR    ns1.example.com.
+
<pre>10      IN      PTR    www.example.com.</pre>
10      IN      PTR    www.example.com.
+
<pre>10      IN      PTR    mail.example.com.</pre>
10      IN      PTR    mail.example.com.
+
<pre>10      IN      PTR    ftp.example.com.</pre>
10      IN      PTR    ftp.example.com.
 
</code>
 
  
== 5. Настройка безопасности ===
+
== 5. Настройка безопасности ==
  
 
=== Настройка файрвола ===
 
=== Настройка файрвола ===
  
 
1. Разрешите DNS трафик:
 
1. Разрешите DNS трафик:
<code>
+
<pre>sudo ufw allow 53/tcp</pre>
sudo ufw allow 53/tcp
+
<pre>sudo ufw allow 53/udp</pre>
sudo ufw allow 53/udp
 
</code>
 
  
 
2. Проверьте статус:
 
2. Проверьте статус:
<code>
+
<pre>sudo ufw status</pre>
sudo ufw status
 
</code>
 
  
 
=== Настройка доступа ===
 
=== Настройка доступа ===
  
 
1. Отредактируйте конфигурацию:
 
1. Отредактируйте конфигурацию:
<code>
+
<pre>sudo nano /etc/bind/named.conf.options</pre>
sudo nano /etc/bind/named.conf.options
 
</code>
 
  
 
2. Добавьте настройки безопасности:
 
2. Добавьте настройки безопасности:
<code>
+
<pre>options {</pre>
options {
+
<pre>directory "/var/cache/bind";</pre>
    directory "/var/cache/bind";
+
<pre>recursion yes;</pre>
    recursion yes;
+
<pre>allow-recursion { 192.168.1.0/24; 10.0.0.0/8; };</pre>
    allow-recursion { 192.168.1.0/24; 10.0.0.0/8; };
+
<pre>listen-on { 192.168.1.10; };</pre>
    listen-on { 192.168.1.10; };
+
<pre>allow-transfer { 192.168.1.11; };</pre>
    allow-transfer { 192.168.1.11; };
+
<pre>allow-query { 192.168.1.0/24; 10.0.0.0/8; };</pre>
    allow-query { 192.168.1.0/24; 10.0.0.0/8; };
+
<pre>forwarders {</pre>
    forwarders {
+
<pre>8.8.8.8;</pre>
        8.8.8.8;
+
<pre>8.8.4.4;</pre>
        8.8.4.4;
+
<pre>};</pre>
    };
+
<pre>dnssec-validation auto;</pre>
    dnssec-validation auto;
+
<pre>auth-nxdomain no;</pre>
    auth-nxdomain no;
+
<pre>};</pre>
};
 
</code>
 
  
== 6. Управление BIND ===
+
== 6. Управление BIND ==
  
 
=== Основные команды управления ===
 
=== Основные команды управления ===
  
 
* '''Запуск BIND''':
 
* '''Запуск BIND''':
<code>
+
<pre>sudo systemctl start bind9</pre>
sudo systemctl start bind9
 
</code>
 
  
 
* '''Остановка BIND''':
 
* '''Остановка BIND''':
<code>
+
<pre>sudo systemctl stop bind9</pre>
sudo systemctl stop bind9
 
</code>
 
  
 
* '''Перезапуск BIND''':
 
* '''Перезапуск BIND''':
<code>
+
<pre>sudo systemctl restart bind9</pre>
sudo systemctl restart bind9
 
</code>
 
  
 
* '''Проверка статуса''':
 
* '''Проверка статуса''':
<code>
+
<pre>sudo systemctl status bind9</pre>
sudo systemctl status bind9
 
</code>
 
  
 
* '''Проверка конфигурации''':
 
* '''Проверка конфигурации''':
<code>
+
<pre>sudo named-checkconf</pre>
sudo named-checkconf
 
</code>
 
  
 
* '''Проверка зоны''':
 
* '''Проверка зоны''':
<code>
+
<pre>sudo named-checkzone example.com /etc/bind/db.example.com</pre>
sudo named-checkzone example.com /etc/bind/db.example.com
 
</code>
 
  
 
=== Перезагрузка зон ===
 
=== Перезагрузка зон ===
  
 
1. Перезагрузите зону:
 
1. Перезагрузите зону:
<code>
+
<pre>sudo rndc reload example.com</pre>
sudo rndc reload example.com
 
</code>
 
  
 
2. Перезагрузите все зоны:
 
2. Перезагрузите все зоны:
<code>
+
<pre>sudo rndc reload</pre>
sudo rndc reload
 
</code>
 
  
 
3. Проверьте статус зон:
 
3. Проверьте статус зон:
<code>
+
<pre>sudo rndc status</pre>
sudo rndc status
 
</code>
 
  
== 7. Мониторинг и логирование ===
+
== 7. Мониторинг и логирование ==
  
 
=== Настройка логирования ===
 
=== Настройка логирования ===
  
 
1. Отредактируйте конфигурацию:
 
1. Отредактируйте конфигурацию:
<code>
+
<pre>sudo nano /etc/bind/named.conf.local</pre>
sudo nano /etc/bind/named.conf.local
 
</code>
 
  
 
2. Добавьте настройки логирования:
 
2. Добавьте настройки логирования:
<code>
+
<pre>logging {</pre>
logging {
+
<pre>channel default_log {</pre>
    channel default_log {
+
<pre>file "/var/log/bind/named.log" versions 3 size 5m;</pre>
        file "/var/log/bind/named.log" versions 3 size 5m;
+
<pre>severity info;</pre>
        severity info;
+
<pre>print-time yes;</pre>
        print-time yes;
+
<pre>print-severity yes;</pre>
        print-severity yes;
+
<pre>print-category yes;</pre>
        print-category yes;
+
<pre>};</pre>
    };
+
<pre>category default { default_log; };</pre>
    category default { default_log; };
+
<pre>category queries { default_log; };</pre>
    category queries { default_log; };
+
<pre>};</pre>
};
 
</code>
 
  
 
3. Создайте директорию для логов:
 
3. Создайте директорию для логов:
<code>
+
<pre>sudo mkdir -p /var/log/bind</pre>
sudo mkdir -p /var/log/bind
+
<pre>sudo chown bind:bind /var/log/bind</pre>
sudo chown bind:bind /var/log/bind
 
</code>
 
  
 
=== Просмотр логов ===
 
=== Просмотр логов ===
  
 
1. Просмотрите логи BIND:
 
1. Просмотрите логи BIND:
<code>
+
<pre>sudo tail -f /var/log/bind/named.log</pre>
sudo tail -f /var/log/bind/named.log
 
</code>
 
  
 
2. Просмотрите системные логи:
 
2. Просмотрите системные логи:
<code>
+
<pre>sudo journalctl -u bind9 -f</pre>
sudo journalctl -u bind9 -f
 
</code>
 
  
 
3. Просмотрите логи запросов:
 
3. Просмотрите логи запросов:
<code>
+
<pre>sudo tail -f /var/log/bind/queries.log</pre>
sudo tail -f /var/log/bind/queries.log
 
</code>
 
  
 
=== Создание скрипта мониторинга ===
 
=== Создание скрипта мониторинга ===
  
 
1. Создайте скрипт мониторинга:
 
1. Создайте скрипт мониторинга:
<code>
+
<pre>sudo nano /usr/local/bin/dns-monitor.sh</pre>
sudo nano /usr/local/bin/dns-monitor.sh
 
</code>
 
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>
+
<pre>if systemctl is-active --quiet bind9; then</pre>
#!/bin/bash
+
<pre>echo "BIND is running"</pre>
 
+
<pre>QUERIES=$(sudo rndc stats && grep "queries" /var/cache/bind/named.stats | awk '{print $1}')</pre>
# Проверка статуса BIND
+
<pre>echo "Total queries: $QUERIES"</pre>
if systemctl is-active --quiet bind9; then
+
<pre>MEMORY=$(ps aux | grep named | grep -v grep | awk '{print $6}')</pre>
    echo "BIND is running"
+
<pre>echo "Memory usage: $MEMORY KB"</pre>
   
+
<pre>else</pre>
    # Проверка запросов
+
<pre>echo "BIND is not running"</pre>
    QUERIES=$(sudo rndc stats && grep "queries" /var/cache/bind/named.stats | awk '{print $1}')
+
<pre>echo "BIND is down" | mail -s "DNS Alert" admin@example.com</pre>
    echo "Total queries: $QUERIES"
+
<pre>fi</pre>
   
 
    # Проверка использования памяти
 
    MEMORY=$(ps aux | grep named | grep -v grep | awk '{print $6}')
 
    echo "Memory usage: $MEMORY KB"
 
   
 
else
 
    echo "BIND is not running"
 
    # Отправка уведомления
 
    echo "BIND is down" | mail -s "DNS Alert" admin@example.com
 
fi
 
</code>
 
  
 
3. Сделайте скрипт исполняемым:
 
3. Сделайте скрипт исполняемым:
<code>
+
<pre>sudo chmod +x /usr/local/bin/dns-monitor.sh</pre>
sudo chmod +x /usr/local/bin/dns-monitor.sh
 
</code>
 
  
== 8. Настройка мастер-слейв ===
+
== 8. Настройка мастер-слейв ==
  
 
=== Настройка мастер сервера ===
 
=== Настройка мастер сервера ===
  
 
1. Отредактируйте конфигурацию зоны:
 
1. Отредактируйте конфигурацию зоны:
<code>
+
<pre>sudo nano /etc/bind/db.example.com</pre>
sudo nano /etc/bind/db.example.com
 
</code>
 
  
 
2. Добавьте настройки для слейв сервера:
 
2. Добавьте настройки для слейв сервера:
<code>
+
<pre>$TTL    604800</pre>
$TTL    604800
+
<pre>@      IN      SOA    ns1.example.com. admin.example.com. (</pre>
@      IN      SOA    ns1.example.com. admin.example.com. (
+
<pre>1        ; Serial</pre>
                              1        ; Serial
+
<pre>604800        ; Refresh</pre>
                        604800        ; Refresh
+
<pre>86400        ; Retry</pre>
                          86400        ; Retry
+
<pre>2419200        ; Expire</pre>
                        2419200        ; Expire
+
<pre>604800 )      ; Negative Cache TTL</pre>
                        604800 )      ; Negative Cache TTL
+
<pre>;</pre>
;
+
<pre>@      IN      NS      ns1.example.com.</pre>
@      IN      NS      ns1.example.com.
+
<pre>@      IN      NS      ns2.example.com.</pre>
@      IN      NS      ns2.example.com.
+
<pre>ns1    IN      A      192.168.1.10</pre>
ns1    IN      A      192.168.1.10
+
<pre>ns2    IN      A      192.168.1.11</pre>
ns2    IN      A      192.168.1.11
 
</code>
 
  
 
=== Настройка слейв сервера ===
 
=== Настройка слейв сервера ===
  
 
1. На слейв сервере отредактируйте конфигурацию:
 
1. На слейв сервере отредактируйте конфигурацию:
<code>
+
<pre>sudo nano /etc/bind/named.conf.local</pre>
sudo nano /etc/bind/named.conf.local
 
</code>
 
  
 
2. Добавьте конфигурацию слейв зоны:
 
2. Добавьте конфигурацию слейв зоны:
<code>
+
<pre>zone "example.com" {</pre>
zone "example.com" {
+
<pre>type slave;</pre>
    type slave;
+
<pre>masters { 192.168.1.10; };</pre>
    masters { 192.168.1.10; };
+
<pre>file "/var/cache/bind/db.example.com";</pre>
    file "/var/cache/bind/db.example.com";
+
<pre>};</pre>
};
 
</code>
 
  
== 9. Настройка DNSSEC ===
+
== 9. Настройка DNSSEC ==
  
 
=== Генерация ключей ===
 
=== Генерация ключей ===
  
 
1. Создайте KSK ключ:
 
1. Создайте KSK ключ:
<code>
+
<pre>sudo dnssec-keygen -a RSASHA256 -b 2048 -n ZONE example.com</pre>
sudo dnssec-keygen -a RSASHA256 -b 2048 -n ZONE example.com
 
</code>
 
  
 
2. Создайте ZSK ключ:
 
2. Создайте ZSK ключ:
<code>
+
<pre>sudo dnssec-keygen -a RSASHA256 -b 1024 -n ZONE example.com</pre>
sudo dnssec-keygen -a RSASHA256 -b 1024 -n ZONE example.com
 
</code>
 
  
 
=== Подписание зоны ===
 
=== Подписание зоны ===
  
 
1. Подпишите зону:
 
1. Подпишите зону:
<code>
+
<pre>sudo dnssec-signzone -A -N INCREMENT -o example.com -t db.example.com</pre>
sudo dnssec-signzone -A -N INCREMENT -o example.com -t db.example.com
 
</code>
 
  
 
2. Обновите конфигурацию:
 
2. Обновите конфигурацию:
<code>
+
<pre>sudo nano /etc/bind/named.conf.local</pre>
sudo nano /etc/bind/named.conf.local
 
</code>
 
  
 
3. Добавьте настройки DNSSEC:
 
3. Добавьте настройки DNSSEC:
<code>
+
<pre>zone "example.com" {</pre>
zone "example.com" {
+
<pre>type master;</pre>
    type master;
+
<pre>file "/etc/bind/db.example.com.signed";</pre>
    file "/etc/bind/db.example.com.signed";
+
<pre>allow-update { none; };</pre>
    allow-update { none; };
+
<pre>auto-dnssec maintain;</pre>
    auto-dnssec maintain;
+
<pre>inline-signing yes;</pre>
    inline-signing yes;
+
<pre>};</pre>
};
 
</code>
 
  
== 10. Устранение неполадок ===
+
== 10. Устранение неполадок ==
  
 
=== Частые проблемы ===
 
=== Частые проблемы ===
  
 
1. '''BIND не запускается''':
 
1. '''BIND не запускается''':
* Проверьте конфигурацию: <code>sudo named-checkconf</code>
+
* Проверьте конфигурацию: <pre>sudo named-checkconf</pre>
* Проверьте логи: <code>sudo journalctl -u bind9</code>
+
* Проверьте логи: <pre>sudo journalctl -u bind9</pre>
* Проверьте права на файлы: <code>ls -la /etc/bind/</code>
+
* Проверьте права на файлы: <pre>ls -la /etc/bind/</pre>
  
 
2. '''Зоны не загружаются''':
 
2. '''Зоны не загружаются''':
* Проверьте зоны: <code>sudo named-checkzone example.com /etc/bind/db.example.com</code>
+
* Проверьте зоны: <pre>sudo named-checkzone example.com /etc/bind/db.example.com</pre>
 
* Проверьте синтаксис файлов зон
 
* Проверьте синтаксис файлов зон
 
* Проверьте права доступа к файлам
 
* Проверьте права доступа к файлам
  
 
3. '''DNS запросы не работают''':
 
3. '''DNS запросы не работают''':
* Проверьте файрвол: <code>sudo ufw status</code>
+
* Проверьте файрвол: <pre>sudo ufw status</pre>
* Проверьте порты: <code>sudo netstat -tlnp | grep :53</code>
+
* Проверьте порты: <pre>sudo netstat -tlnp | grep :53</pre>
 
* Проверьте настройки клиентов
 
* Проверьте настройки клиентов
  
Строка 429: Строка 327:
  
 
1. Проверьте статус сервиса:
 
1. Проверьте статус сервиса:
<code>
+
<pre>sudo systemctl status bind9</pre>
sudo systemctl status bind9
 
</code>
 
  
 
2. Проверьте конфигурацию:
 
2. Проверьте конфигурацию:
<code>
+
<pre>sudo named-checkconf</pre>
sudo named-checkconf
 
</code>
 
  
 
3. Проверьте зоны:
 
3. Проверьте зоны:
<code>
+
<pre>sudo named-checkzone example.com /etc/bind/db.example.com</pre>
sudo named-checkzone example.com /etc/bind/db.example.com
 
</code>
 
  
 
4. Проверьте DNS запросы:
 
4. Проверьте DNS запросы:
<code>
+
<pre>dig @localhost example.com</pre>
dig @localhost example.com
+
<pre>nslookup example.com localhost</pre>
nslookup example.com localhost
 
</code>
 
  
== 11. Дополнительные настройки ===
+
== 11. Дополнительные настройки ==
  
 
=== Настройка кэширования ===
 
=== Настройка кэширования ===
  
 
1. Отредактируйте конфигурацию:
 
1. Отредактируйте конфигурацию:
<code>
+
<pre>sudo nano /etc/bind/named.conf.options</pre>
sudo nano /etc/bind/named.conf.options
 
</code>
 
  
 
2. Добавьте настройки кэширования:
 
2. Добавьте настройки кэширования:
<code>
+
<pre>options {</pre>
options {
+
<pre>directory "/var/cache/bind";</pre>
    directory "/var/cache/bind";
+
<pre>recursion yes;</pre>
    recursion yes;
+
<pre>allow-recursion { localnets; };</pre>
    allow-recursion { localnets; };
+
<pre>listen-on { any; };</pre>
    listen-on { any; };
+
<pre>forwarders {</pre>
    forwarders {
+
<pre>8.8.8.8;</pre>
        8.8.8.8;
+
<pre>8.8.4.4;</pre>
        8.8.4.4;
+
<pre>};</pre>
    };
+
<pre>dnssec-validation auto;</pre>
    dnssec-validation auto;
+
<pre>auth-nxdomain no;</pre>
    auth-nxdomain no;
+
<pre>max-cache-size 256m;</pre>
    max-cache-size 256m;
+
<pre>max-ncache-ttl 3600;</pre>
    max-ncache-ttl 3600;
+
<pre>};</pre>
};
 
</code>
 
  
 
=== Настройка мониторинга ===
 
=== Настройка мониторинга ===
  
 
1. Добавьте задачу мониторинга в crontab:
 
1. Добавьте задачу мониторинга в crontab:
<code>
+
<pre>*/5 * * * * /usr/local/bin/dns-monitor.sh</pre>
# Проверка DNS каждые 5 минут
 
*/5 * * * * /usr/local/bin/dns-monitor.sh
 
</code>
 
  
== 12. Оптимизация производительности ===
+
== 12. Оптимизация производительности ==
  
 
=== Настройки производительности ===
 
=== Настройки производительности ===
  
 
1. Отредактируйте конфигурацию:
 
1. Отредактируйте конфигурацию:
<code>
+
<pre>sudo nano /etc/bind/named.conf.options</pre>
sudo nano /etc/bind/named.conf.options
 
</code>
 
  
 
2. Добавьте настройки производительности:
 
2. Добавьте настройки производительности:
<code>
+
<pre>options {</pre>
options {
+
<pre>directory "/var/cache/bind";</pre>
    directory "/var/cache/bind";
+
<pre>recursion yes;</pre>
    recursion yes;
+
<pre>allow-recursion { localnets; };</pre>
    allow-recursion { localnets; };
+
<pre>listen-on { any; };</pre>
    listen-on { any; };
+
<pre>forwarders {</pre>
    forwarders {
+
<pre>8.8.8.8;</pre>
        8.8.8.8;
+
<pre>8.8.4.4;</pre>
        8.8.4.4;
+
<pre>};</pre>
    };
+
<pre>dnssec-validation auto;</pre>
    dnssec-validation auto;
+
<pre>auth-nxdomain no;</pre>
    auth-nxdomain no;
+
<pre>max-cache-size 512m;</pre>
    max-cache-size 512m;
+
<pre>max-ncache-ttl 3600;</pre>
    max-ncache-ttl 3600;
+
<pre>cleaning-interval 60;</pre>
    cleaning-interval 60;
+
<pre>interface-interval 0;</pre>
    interface-interval 0;
+
<pre>statistics-interval 0;</pre>
    statistics-interval 0;
+
<pre>};</pre>
};
 
</code>
 
  
 
=== Мониторинг производительности ===
 
=== Мониторинг производительности ===
  
 
1. Создайте скрипт мониторинга:
 
1. Создайте скрипт мониторинга:
<code>
+
<pre>sudo nano /usr/local/bin/dns-stats.sh</pre>
sudo nano /usr/local/bin/dns-stats.sh
 
</code>
 
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>
+
<pre>echo "=== BIND DNS Server Statistics ==="</pre>
#!/bin/bash
+
<pre>echo "Server Status: $(systemctl is-active bind9)"</pre>
 
+
<pre>echo "Uptime: $(systemctl show bind9 --property=ActiveEnterTimestamp --value)"</pre>
echo "=== BIND DNS Server Statistics ==="
+
<pre>echo "Memory Usage: $(ps aux | grep named | grep -v grep | awk '{print $4"%"}')"</pre>
echo "Server Status: $(systemctl is-active bind9)"
+
<pre>echo "CPU Usage: $(ps aux | grep named | grep -v grep | awk '{print $3"%"}')"</pre>
echo "Uptime: $(systemctl show bind9 --property=ActiveEnterTimestamp --value)"
+
<pre>echo "Active Connections: $(netstat -an | grep :53 | wc -l)"</pre>
echo "Memory Usage: $(ps aux | grep named | grep -v grep | awk '{print $4"%"}')"
 
echo "CPU Usage: $(ps aux | grep named | grep -v grep | awk '{print $3"%"}')"
 
echo "Active Connections: $(netstat -an | grep :53 | wc -l)"
 
</code>
 
  
 
3. Сделайте скрипт исполняемым:
 
3. Сделайте скрипт исполняемым:
<code>
+
<pre>sudo chmod +x /usr/local/bin/dns-stats.sh</pre>
sudo chmod +x /usr/local/bin/dns-stats.sh
 
</code>
 
  
 
== Заключение ==
 
== Заключение ==

Текущая версия на 10:31, 15 октября 2025

Содержание

Настройка DNS сервера (BIND)

1. Подготовка системы

  • Войдите в систему под учетной записью с правами root или пользователя с правами sudo.
  • Убедитесь, что у вас есть доступ к серверу через SSH или консоль.

2. Установка BIND

Установка пакета

1. Обновите список пакетов:

sudo apt update

2. Установите BIND9:

sudo apt install bind9 bind9utils bind9-doc

3. Запустите и включите автозапуск BIND:

sudo systemctl start bind9
sudo systemctl enable bind9

Проверка установки

1. Проверьте статус сервиса:

sudo systemctl status bind9

2. Проверьте, что BIND слушает на порту 53:

sudo netstat -tlnp | grep :53

3. Проверьте версию BIND:

named -v

3. Базовая настройка BIND

Основная конфигурация

1. Создайте резервную копию конфигурации:

sudo cp /etc/bind/named.conf /etc/bind/named.conf.backup

2. Отредактируйте основной файл конфигурации:

sudo nano /etc/bind/named.conf

3. Настройте основные параметры:

// Основные настройки
options {
directory "/var/cache/bind";
recursion yes;
allow-recursion { localnets; };
listen-on { any; };
listen-on-v6 { any; };
allow-transfer { none; };
allow-query { any; };
forwarders {
8.8.8.8;
8.8.4.4;
};
dnssec-validation auto;
auth-nxdomain no;
listen-on port 53 { any; };
};

Настройка зон

1. Создайте файл зоны:

sudo nano /etc/bind/named.conf.local

2. Добавьте конфигурацию зоны:

// Прямая зона
zone "example.com" {
type master;
file "/etc/bind/db.example.com";
allow-update { none; };
};
// Обратная зона
zone "1.168.192.in-addr.arpa" {
type master;
file "/etc/bind/db.192.168.1";
allow-update { none; };
};

4. Создание зон

Создание прямой зоны

1. Создайте файл зоны:

sudo nano /etc/bind/db.example.com

2. Добавьте содержимое:

$TTL    604800
@       IN      SOA     ns1.example.com. admin.example.com. (
1         ; Serial
604800         ; Refresh
86400         ; Retry
2419200         ; Expire
604800 )       ; Negative Cache TTL
;
@       IN      NS      ns1.example.com.
@       IN      NS      ns2.example.com.
@       IN      A       192.168.1.10
ns1     IN      A       192.168.1.10
ns2     IN      A       192.168.1.11
www     IN      A       192.168.1.10
mail    IN      A       192.168.1.10
ftp     IN      A       192.168.1.10

Создание обратной зоны

1. Создайте файл обратной зоны:

sudo nano /etc/bind/db.192.168.1

2. Добавьте содержимое:

$TTL    604800
@       IN      SOA     ns1.example.com. admin.example.com. (
1         ; Serial
604800         ; Refresh
86400         ; Retry
2419200         ; Expire
604800 )       ; Negative Cache TTL
;
@       IN      NS      ns1.example.com.
@       IN      NS      ns2.example.com.
10      IN      PTR     ns1.example.com.
10      IN      PTR     www.example.com.
10      IN      PTR     mail.example.com.
10      IN      PTR     ftp.example.com.

5. Настройка безопасности

Настройка файрвола

1. Разрешите DNS трафик:

sudo ufw allow 53/tcp
sudo ufw allow 53/udp

2. Проверьте статус:

sudo ufw status

Настройка доступа

1. Отредактируйте конфигурацию:

sudo nano /etc/bind/named.conf.options

2. Добавьте настройки безопасности:

options {
directory "/var/cache/bind";
recursion yes;
allow-recursion { 192.168.1.0/24; 10.0.0.0/8; };
listen-on { 192.168.1.10; };
allow-transfer { 192.168.1.11; };
allow-query { 192.168.1.0/24; 10.0.0.0/8; };
forwarders {
8.8.8.8;
8.8.4.4;
};
dnssec-validation auto;
auth-nxdomain no;
};

6. Управление BIND

Основные команды управления

  • Запуск BIND:
sudo systemctl start bind9
  • Остановка BIND:
sudo systemctl stop bind9
  • Перезапуск BIND:
sudo systemctl restart bind9
  • Проверка статуса:
sudo systemctl status bind9
  • Проверка конфигурации:
sudo named-checkconf
  • Проверка зоны:
sudo named-checkzone example.com /etc/bind/db.example.com

Перезагрузка зон

1. Перезагрузите зону:

sudo rndc reload example.com

2. Перезагрузите все зоны:

sudo rndc reload

3. Проверьте статус зон:

sudo rndc status

7. Мониторинг и логирование

Настройка логирования

1. Отредактируйте конфигурацию:

sudo nano /etc/bind/named.conf.local

2. Добавьте настройки логирования:

logging {
channel default_log {
file "/var/log/bind/named.log" versions 3 size 5m;
severity info;
print-time yes;
print-severity yes;
print-category yes;
};
category default { default_log; };
category queries { default_log; };
};

3. Создайте директорию для логов:

sudo mkdir -p /var/log/bind
sudo chown bind:bind /var/log/bind

Просмотр логов

1. Просмотрите логи BIND:

sudo tail -f /var/log/bind/named.log

2. Просмотрите системные логи:

sudo journalctl -u bind9 -f

3. Просмотрите логи запросов:

sudo tail -f /var/log/bind/queries.log

Создание скрипта мониторинга

1. Создайте скрипт мониторинга:

sudo nano /usr/local/bin/dns-monitor.sh

2. Добавьте содержимое:

if systemctl is-active --quiet bind9; then
echo "BIND is running"
QUERIES=$(sudo rndc stats && grep "queries" /var/cache/bind/named.stats | awk '{print $1}')
echo "Total queries: $QUERIES"
MEMORY=$(ps aux | grep named | grep -v grep | awk '{print $6}')
echo "Memory usage: $MEMORY KB"
else
echo "BIND is not running"
echo "BIND is down" | mail -s "DNS Alert" admin@example.com
fi

3. Сделайте скрипт исполняемым:

sudo chmod +x /usr/local/bin/dns-monitor.sh

8. Настройка мастер-слейв

Настройка мастер сервера

1. Отредактируйте конфигурацию зоны:

sudo nano /etc/bind/db.example.com

2. Добавьте настройки для слейв сервера:

$TTL    604800
@       IN      SOA     ns1.example.com. admin.example.com. (
1         ; Serial
604800         ; Refresh
86400         ; Retry
2419200         ; Expire
604800 )       ; Negative Cache TTL
;
@       IN      NS      ns1.example.com.
@       IN      NS      ns2.example.com.
ns1     IN      A       192.168.1.10
ns2     IN      A       192.168.1.11

Настройка слейв сервера

1. На слейв сервере отредактируйте конфигурацию:

sudo nano /etc/bind/named.conf.local

2. Добавьте конфигурацию слейв зоны:

zone "example.com" {
type slave;
masters { 192.168.1.10; };
file "/var/cache/bind/db.example.com";
};

9. Настройка DNSSEC

Генерация ключей

1. Создайте KSK ключ:

sudo dnssec-keygen -a RSASHA256 -b 2048 -n ZONE example.com

2. Создайте ZSK ключ:

sudo dnssec-keygen -a RSASHA256 -b 1024 -n ZONE example.com

Подписание зоны

1. Подпишите зону:

sudo dnssec-signzone -A -N INCREMENT -o example.com -t db.example.com

2. Обновите конфигурацию:

sudo nano /etc/bind/named.conf.local

3. Добавьте настройки DNSSEC:

zone "example.com" {
type master;
file "/etc/bind/db.example.com.signed";
allow-update { none; };
auto-dnssec maintain;
inline-signing yes;
};

10. Устранение неполадок

Частые проблемы

1. BIND не запускается:

  • Проверьте конфигурацию:
    sudo named-checkconf
  • Проверьте логи:
    sudo journalctl -u bind9
  • Проверьте права на файлы:
    ls -la /etc/bind/

2. Зоны не загружаются:

  • Проверьте зоны:
    sudo named-checkzone example.com /etc/bind/db.example.com
  • Проверьте синтаксис файлов зон
  • Проверьте права доступа к файлам

3. DNS запросы не работают:

  • Проверьте файрвол:
    sudo ufw status
  • Проверьте порты:
    sudo netstat -tlnp | grep :53
  • Проверьте настройки клиентов

Диагностика

1. Проверьте статус сервиса:

sudo systemctl status bind9

2. Проверьте конфигурацию:

sudo named-checkconf

3. Проверьте зоны:

sudo named-checkzone example.com /etc/bind/db.example.com

4. Проверьте DNS запросы:

dig @localhost example.com
nslookup example.com localhost

11. Дополнительные настройки

Настройка кэширования

1. Отредактируйте конфигурацию:

sudo nano /etc/bind/named.conf.options

2. Добавьте настройки кэширования:

options {
directory "/var/cache/bind";
recursion yes;
allow-recursion { localnets; };
listen-on { any; };
forwarders {
8.8.8.8;
8.8.4.4;
};
dnssec-validation auto;
auth-nxdomain no;
max-cache-size 256m;
max-ncache-ttl 3600;
};

Настройка мониторинга

1. Добавьте задачу мониторинга в crontab:

*/5 * * * * /usr/local/bin/dns-monitor.sh

12. Оптимизация производительности

Настройки производительности

1. Отредактируйте конфигурацию:

sudo nano /etc/bind/named.conf.options

2. Добавьте настройки производительности:

options {
directory "/var/cache/bind";
recursion yes;
allow-recursion { localnets; };
listen-on { any; };
forwarders {
8.8.8.8;
8.8.4.4;
};
dnssec-validation auto;
auth-nxdomain no;
max-cache-size 512m;
max-ncache-ttl 3600;
cleaning-interval 60;
interface-interval 0;
statistics-interval 0;
};

Мониторинг производительности

1. Создайте скрипт мониторинга:

sudo nano /usr/local/bin/dns-stats.sh

2. Добавьте содержимое:

echo "=== BIND DNS Server Statistics ==="
echo "Server Status: $(systemctl is-active bind9)"
echo "Uptime: $(systemctl show bind9 --property=ActiveEnterTimestamp --value)"
echo "Memory Usage: $(ps aux | grep named | grep -v grep | awk '{print $4"%"}')"
echo "CPU Usage: $(ps aux | grep named | grep -v grep | awk '{print $3"%"}')"
echo "Active Connections: $(netstat -an | grep :53 | wc -l)"

3. Сделайте скрипт исполняемым:

sudo chmod +x /usr/local/bin/dns-stats.sh

Заключение

DNS сервер BIND успешно установлен и настроен! Теперь вы можете предоставлять DNS услуги.

Для размещения ваших DNS серверов на надежном хостинге рекомендуем воспользоваться услугами [ARK-HOSTER.RU](https://ark-hoster.ru):

Наши специалисты помогут с настройкой DNS и обеспечением безопасности вашего сервера!