Возможно вы искали: 'TRON: Evolution - The ...'

May 15 2025 18:08:51
  • Как сделать 8Gamers.Ru домашней страницей?
  • Игры
    • База данных по играх
    • Игровые новости
    • Игровая индустрия
    • Обзоры на игры
    • Прохождения игр
    • Гайды к играм
    • Превью о играх
    • Игровые тизеры
    • Игровые арты
    • Игровые обои
    • Игровые скриншоты
    • Игровые обложки
    • Игровые трейлеры
    • Игровое видео
    • Вышедшие игры
    • Ближайшие релизы игр
  • Кино и ТВ
    • База данных по кино
    • Статьи о кино
    • Постеры
    • Кадры из кино
    • Кино трейлеры
    • Сегодня в кино
    • Скоро в кино
  • Комиксы и манга
    • Манга по алфавиту
    • База данных по комиксах
    • Читать онлайн комиксы
    • Читать онлайн манга
    • База персонажей
  • Читы и коды
    • Чит-коды для PC игр
    • Чит-коды для консольных игр
    • Трейнеры
    • Коды Game Genie
  • Моддинг
    • Модификации
    • Карты к играм
    • Программы для моддинга
    • Статьи о моддинге
  • Геймдев
    • Всё о создании игр
    • Список движков
    • Утилиты в помощь игроделу
    • Конструкторы игр
    • Игровые движки
    • Библиотеки разработки
    • 3D-модели
    • Спрайты и тайлы
    • Музыка и звуки
    • Текстуры и фоны
  • Рецензии
    • Игры
    • Кино
    • Аниме
    • Комиксы
    • Мангу
    • Саундтреки
  • Саундтреки
    • Лирика
  • Файлы
    • Патчи к играм
    • Русификаторы к играм
    • Сохранения к играм
    • Субтитры к кино
  • Медиа
    • Видео
    • Фото
    • Аудио
    • Фан-арты
    • Косплей
    • Фото с виставок
    • Девушки из игр
    • Рисунки
    • Рисуем онлайн
    • Фотохостинг
  • Юмор
    • Анекдоты
    • Афоризмы
    • Истории
    • Стишки и эпиграммы
    • Тосты
    • Цитаты
  • Флеш
    • Азартные
    • Аркады
    • Бродилки
    • Гонки
    • Для девочек
    • Для мальчиков
    • Драки
    • Квесты
    • Леталки
    • Логические
    • Мультфильмы
    • Открытки
    • Приколы
    • Разное
    • Спорт
    • Стратегии
    • Стрелялки
Статистика

Статей: 87772
Просмотров: 96111483
Игры
Injustice:  Gods Among Us
Injustice: Gods Among Us
...
Dark Souls 2
Dark Souls 2
Dark Souls II - вторая часть самой хардкорной ролевой игры 2011-2012 года, с новым героем, сюжето...
Battlefield 4
Battlefield 4
Battlefield 4 - продолжение венценосного мультиплеер-ориентированного шутера от первого ли...
Кино
Steins;Gate
Steins;Gate
Любители японской анимации уже давно поняли ,что аниме сериалы могут дать порой гораздо больше пи...
Ку! Кин-дза-дза
Ку! Кин-дза-дза
Начинающий диджей Толик и всемирно известный виолончелист Владимир Чижов встречают на шумной моск...
Обзоры на игры
• Обзор Ibara [PCB/PS2] 18357
• Обзор The Walking ... 18801
• Обзор DMC: Devil M... 19879
• Обзор на игру Valk... 15877
• Обзор на игру Stars! 17764
• Обзор на Far Cry 3 17948
• Обзор на Resident ... 16024
• Обзор на Chivalry:... 17508
• Обзор на игру Kerb... 17981
• Обзор игры 007: Fr... 16619
Превью о играх
• Превью к игре Comp... 17960
• Превью о игре Mage... 14464
• Превью Incredible ... 14721
• Превью Firefall 13479
• Превью Dead Space 3 16334
• Превью о игре SimC... 14730
• Превью к игре Fuse 15442
• Превью Red Orche... 15542
• Превью Gothic 3 16343
• Превью Black & W... 17354
Главная » Статьи » Разное » Автоматическая синхронизация файлов конфигурации master и slave DNS серверов (dns sync domain bind freebsd)

Автоматическая синхронизация файлов конфигурации master и slave DNS серверов (dns sync domain bind freebsd)

Ключевые слова: dns, sync, domain, bind, freebsd, (найти похожие документы)

From: Alex Samorukov <samm@os2.kiev.ua.>
Date: Mon, 6 Mar 2008 14:31:37 +0000 (UTC)
Subject: Автоматическая синхронизация файлов конфигурации master и slave DNS серверов

Зачем это нужно?

Для одного из проектов мне потребовалось обеспечить автоматическое
распространение DNS зон, прописанных на master dns, slave серверам. Так
как зон ожидалось не больше 100-200 мне хотелось сделать максимально
простую, но в тоже время безопасную схему синхронизации серверов, без
использования LDAP или SQL в качестве backend. В итоге я решил задачу
используя shell скрипты, которыми решил поделиться с общественностью.
Всё нижеописанное работает на OS FreeBSD но должно без проблем работать
и в любой другой UNIX OS c BIND в роли DNS.


Как это работает

Все master зоны на primary dns лежат в отдельной директории
(/etc/namedb/master-auto) и названы в формате <domain>.db.

Например example.com.db, kernel.org.db и т.п. Это важный момент, так как
на этом основан алгоритм получения списка доменов (это проще и удобнее
чем читать named.conf). Используя протокол SSH клиенты (secondary
сервера) запрашивают у primary сервера список доменов и, в случае
различий с локальным списком, обновляют конфигурацию. Клиентов может
быть сколько угодно, обновление происходит по cron, например, раз в 10
минут. Для безопасного транспорта содержимого зон используется TSIG
протокол.


Конфигурация сервера

Как я уже писал выше, primary сервер должен по протоколу SSH отдавать
список обслуживаемых доменов. Для этого я завёл пользователя dnssync.
Shell данного пользователя будет специально созданный для данной цели sh
скрипт.

# pw user add dnssync -s /home/dnssync/domainlist.sh


Пароль пользователю не нужен, так как для подключения будет
использоваться SSH ключ.

Теперь создадим сам скрипт:

mkdir /home/dnssync; chmod 700 /home/dnssync;


vi /home/dnssync/domainlist.sh

#!/bin/sh

export COLUMNS=1
# directory with <zone>.db files
cd /etc/namedb/master-auto
echo "DOMAINLIST_START"
/bin/ls *.db|/usr/bin/sed 's/.db//'
echo "DOMAINLIST_END"


Корректируем права доступа:

chmod +x /home/dnssync/domainlist.sh


Как видно из текста скрипта, всё что он делает - это получает список
файлов в директории, убирает суффикс .db и добавляет к выводу
DOMAINLIST_START перед листингом и DOMAINLIST_END в конце вывода. Для
проверки запустите /home/dnssync/domainlist.sh - должно быть что-то
вроде

DOMAINLIST_START
example.com
kernel.org
DOMAINLIST_END


Конфигурация клиента

Теперь перейдём к настройке secondary DNS. Для начала нам потребуется
настроить авторизацию по ключу для подключения к главному серверу. Если
ключ ещё не создан, запустим ssh-keygen, указав пустой passphrase. Нам
потребуется скопировать публичный ключ (по умолчанию
/root/.ssh/id_rsa.pub в FreeBSD) в список авторизованных ключей на
главном сервере (в файл /home/dnssync/.ssh/authorized_keys). В этом же
файле можно задать IP адрес владельца ключа для большей безопасности.
Чтобы убедиться, что всё работает, на клиенте введём команду ssh
dnssync@<master_ip>, например # 'ssh dnssync@1.2.3.4 sync'. Последний
аргумент требуется, чтобы сервер не показывал motd и прочие радости. В
случае правильной настройки должен быть выведен список доменов, без
запроса пароля.

Теперь установим клиентский скрипт, который отвечает за изменение
конфигурации BIND и его перезапуск:

mkdir /root/bin


vi /root/bin/dnssync.sh

#!/bin/sh

MASTERHOST="1.2.3.4"
MASTERUSER="dnssync"
DNSTMPDIR="/root/tmp"

# fetching domain list from the master
/usr/bin/ssh -o BatchMode=yes ${MASTERUSER}@${MASTERHOST} fetch > ${DNSTMPDIR}/domains.tmp </dev/null
if [ "$?" -ne "0" ]; then
echo "Error while transferring"
exit 1
fi

# simple check of the received file
if [ -z `grep DOMAINLIST_START ${DNSTMPDIR}/domains.tmp` -o -z `grep DOMAINLIST_END ${DNSTMPDIR}/domains.tmp` ]; then
echo "Invalid data received"
exit 1;
fi

# check if the files are equal
if [ -f ${DNSTMPDIR}/domains -a -z "`/usr/bin/cmp ${DNSTMPDIR}/domains.tmp ${DNSTMPDIR}/domains 2>/dev/null`" ]; then
# files are equal, do nothing
exit 0;
fi

# copy temporary file to the primary
/bin/cp ${DNSTMPDIR}/domains.tmp ${DNSTMPDIR}/domains

# creating output file for the dns
/usr/bin/grep -v DOMAINLIST_ ${DNSTMPDIR}/domains
| sed 's/(.*)/zone "1" in { type slave; file "slave/1.db"; masters {'${MASTERHOST}';}; };/'
> /etc/namedb/slave.conf

/etc/rc.d/named restart >/dev/null


Корректируем права доступа:

chmod 700 /root/bin/dnssync.sh


Этот скрипт при запуске подключается к master серверу, скачивает список
доменов (проверяя его корректность), сравнивает с имеющимся файлов и в
случае изменений создаёт /etc/namedb/slave.conf, содержащий список slave
зон после чего перезапускает BIND. Запустите скрипт, в случае если всё
работает правильно вы должны получить файл /etc/namedb/slave.conf
содержащий конфигурацию slave зон. Чтобы named читал этот файл добавим
строчку 'include "slave.conf";' в файл /etc/named.conf и перезапустим
named. В случае отсутствия ошибок в директории /etc/namedb/slave
появятся файлы зон. Для автоматической работы скрипт dnssync.sh
добавляем в crontab пользователя root с требуемой вам периодичностью.

Для вторичных серверов поступаете аналогично.


TSIG - безопасная передача зон

Для увеличение безопасности работы я рекомендую использовать механизм
TSIG. Достаточно подробное описание настройки можно прочитать в статье
"Защита сервера DNS", так
что я не вижу смысла дублировать это в своей заметке.

Заключение

Описанная схема прекрасно подходит для сравнительно небольших
конфигураций. К её плюсам можно отнести простоту реализации (только
shell), высокую безопасность и лёгкую переносимость. Недостатки - каждый
раз передаётся полный список зон, в случае обновления требуется
перезапуск named. В масштабах большого регистратора рекомендую подумать
о более эффективных методах репликации, но для большинства других задач
эти недостатки совершенно не существенны. Как всегда - буду рад
замечаниям и советам.

Alex Samorukov, samm@os2.kiev.ua
1000 Прочтений •  [Автоматическая синхронизация файлов конфигурации master и slave DNS серверов (dns sync domain bind freebsd)] [08.05.2012] [Комментариев: 0]
Добавил: Ukraine Vova
Ссылки
HTML: 
[BB Url]: 
Похожие статьи
Название Добавил Добавлено
• Автоматическая синхронизация файлов... Ukraine Vova 08.05.2012
Ни одного комментария? Будешь первым :).
Пожалуйста, авторизуйтесь для добавления комментария.

Проект входит в сеть сайтов «8Gamers Network»

Все права сохранены. 8Gamers.NET © 2011 - 2025

Статьи
Рецензия на Pressure
Рецензия на Pressure
Чтобы обратить на себя внимание, начинающие маленькие разработчики, как правило, уходят в жанры, ...
Рецензия на Lost Chronicles of Zerzura
Рецензия на Lost Chron...
Игры, сделанные без любви и старания, похожи на воздушный шар – оболочка есть, а внутри пусто. Lo...
Рецензия на The Bridge
Рецензия на The Bridge
«Верх» и «низ» в The Bridge — понятия относительные. Прогуливаясь под аркой, можно запросто перей...
Рецензия на SimCity
Рецензия на SimCity
Когда месяц назад состоялся релиз SimCity, по Сети прокатилось цунами народного гнева – глупые ош...
Рецензия на Strategy & Tactics: World War 2
Рецензия на Strategy &...
Название Strategy & Tactics: World War II вряд ли кому-то знакомо. Зато одного взгляда на ее скри...
Рецензия на игру Scribblenauts Unlimited
Рецензия на игру Scrib...
По сложившейся традиции в информационной карточке игры мы приводим в пример несколько похожих игр...
Рецензия на игру Walking Dead: Survival Instinct, The
Рецензия на игру Walki...
Зомби и продукция-по-лицензии — которые и сами по себе не лучшие представители игровой биосферы —...
Обратная связь | RSS | Донейт | Статистика | Команда | Техническая поддержка