...

Bind что это за программа

Bind что это за программа

BIND logo

BIND is an open source DNS software system including an authoritative server, a recursive resolver and related utilities.

We welcome you to submit issues and contribute patches.

BIND 9.11 — ESV- EOL

BIND 9.11 is now End of Life. First released in 2016, this Extended Support Version will be supported (with security fixes ONLY) through March, 2022.

BIND 9.16 — Stable/Extended Support

BIND 9.16 introduced the KASP (Key and Signing Policy) tool, and also incorporated substantial refactoring of the network sockets, although this change is not user-visible. This version is recommended for production use. This is the 2020-2022 current stable branch. It will be supported for 4 years in total. Current ARM

BIND 9.18 — New Stable branch

BIND 9.18 is the new stable branch for 2022. This version will eventually be declared ESV and supported for 4 years in total. In addition to completing the network socket refactoring, this branch also includes BIND support for DNS over HTTPS (DoH) and DNS over TLS (DoT) two new encrypted transports for DNS. Current ARM

License

BIND 9 is licensed under MPL2.0.

An Overview of BIND 9 Documentation

For the benefit of our users, ISC maintains several documentation resources for BIND 9 and updates them as appropriate for each new release.

The BIND 9 Administrator Reference Manual

For documentation covering configuration syntax, detailed feature descriptions, command usage, and basic troubleshooting and security considerations, the best place to start is the BIND 9 Administrator Reference Manual, also known as «the ARM.» Every source archive of BIND 9 distributed by ISC contains copies of the Administrator Reference Manual in HTML and PDF formats. They can be obtained by downloading the source, or they can be read with a browser directly from the ISC downloads server. Recent versions of BIND also have online documentation at ReadTheDocs.io.

Be sure to choose a version that applies to your major branch of BIND, as feature sets, command syntax, and default options for settings often differ between major branches (e.g. 9.11-ESV, 9.16, and 9.18).

These links provide access to the most recently released version of each major public branch of BIND currently undergoing development.

  • BIND 9.16 Administrator Reference Manual (latest version, PDF format)
  • BIND 9.18 Administrator Reference Manual (latest version, PDF format)
  • BIND 9.19 Administrator Reference Manual (latest version, PDF format)

To find a copy of the ARM for any other versions of BIND, visit the source archives, under the «/doc/arm» subdirectory of each specific version.

BIND 9 Release Notes

In addition to the comprehensive documentation in the BIND Administrator Reference Manual, ISC also publishes release notes for each official release of BIND 9. These notes highlight security fixes, bug fixes, new features, and feature changes and are intended to highlight the differences between each release version of BIND 9 and the version that preceded it.

Release notes can be found with the BIND 9 source distributions on the ISC downloads server.

CHANGES Files

CHANGES is a record of source code changes included in that specific version. Unlike the release notes, which cover only the changes since the last stable release version, the list in CHANGES goes back to the base version from which a specific BIND version was forked.

For more information about ISC’s comprehensive BIND support services, please visit https://www.isc.org/support/.

What’s Next

DNS сервер BIND (теория)

Основная цель DNS — это отображение доменных имен в IP адреса и наоборот — IP в DNS. В статье я рассмотрю работу DNS сервера BIND (Berkeley Internet Name Domain, ранее: Berkeley Internet Name Daemon), как сАмого (не побоюсь этого слова) распространенного. BIND входит в состав любого дистрибутива UNIX. Основу BIND составляет демон named, который для своей работы использует порт UDP/53 и для некоторых запросов TCP/53.

Основные понятия Domain Name System

image

Исторически, до появления доменной системы имен роль инструмента разрешения символьных имен в IP выполнял файл /etc/hosts, который и в настоящее время играет далеко не последнюю роль в данном деле. Но с ростом количества хостов в глобальной сети, отслеживать и обслуживать базу имен на всех хостах стало нереально затруднительно. В результате придумали DNS, представляющую собой иерархическую, распределенную систему доменных зон. Давайте рассмотрим структуру Системы Доменных Имён на иллюстрации:

Доменная структура DNS представляет собой древовидную иерархию, состоящую из узлов, зон, доменов, поддоменов и др. элементов, о которых ниже пойдет речь. «Вершиной» доменной структуры является корневая зона. Настройки корневой зоны расположены на множестве серверов/зеркал, размещенных по всему миру и содержат информацию о всех серверах корневой зоны, а так же отвечающих за домены первого уровня (ru, net, org и др). Информация о серверах корневой зоны расположена на данном сайте корневых серверов. Настройки корневой зоны всегда доступны тут. Серверы корневой зоны обрабатывают и отвечают на запросы, выдавая информацию только о доменах первого уровня (то есть отвечают на любые запросы, как на нерекурсивные)! Итак, уже много раз повторилось слово зона. Пора этот термин объяснить.

Зона — это любая часть дерева системы доменных имен, размещаемая как единое целое на некотором DNS-сервере. Зону, для бОльшего понимания, можно назвать «зоной ответственности». Целью выделения части дерева в отдельную зону является передача ответственности (Делегирование) за эту ветвь другому лицу или организации. На иллюстрации, примеры зон выделены синим градиентом (зона name., зона k-max.name. со всем подчиненными ресурсами, www.openoffice.org со всем подчиненными поддоменами и ресурсами). На иллюстрации выделены не все зоны, а лишь некоторые для общего понимания и представления. В каждой зоне имеется, по крайней мере, один авторитетный сервер DNS, который хранит ВСЮ информацию о зоне, за которую он отвечает.

Домен — это именованная ветвь или поддерево в дереве имен DNS, то есть это определенный узел, включающий в себя все подчиненные узлы. Следующая цитата из книги Linux Network Administrators Guide хорошо проясняет картину относительно разницы между зоной и доменом:

Таким образом, пространство имен раздроблено на зоны ( zones), каждая из которых управляется своим доменом. Обратите внимание на различие между зоной (zone) и доменом (domain): домен groucho.edu затрагивает все машины в университете Groucho Marx, в то время как зона groucho.edu включает только хосты, которые работают в непосредственно компьютерном центре, например в отделе математики. Хост в отделе физики принадлежат другой зоне, а именно physics.groucho.edu.

Каждый узел в иерархии DNS отделен от своего родителя точкой. Если провести аналогию с файловой системой Linux, система доменных имен имеет похожую структуру, за тем исключением, что разделитель в файловой системе — слэш, а в DNS — точка. А так же DNS адрес читается справа налево (от корневого домена к имени хоста) в отличии от пути в файловой системе Linux. Доменное имя начинается с точки (корневого домена) и проходит через домены первого, второго и если нужно третьего и т.д. уровней и завершается именем хоста. Т.о. доменное имя полностью отражает структуру иерархии DNS. Часто (я бы сказал — всегда в повседневной жизни), последняя точка (обозначение корневого домена) в доменном имени опускается (то есть в браузере мы вводим не k-max.name., а k-max.name). Итак, разобрав структуру доменного имени, мы незаметно подошли к понятию FQDN.

FQDN (англ. Fully Qualifed Domain Name, полностью определённое имя домена) — это имя домена, однозначно определяющее доменное имя и включающее в себя имена всех родительских доменов иерархии DNS, в том числе и корневого. Своеобразный аналог абсолютного пути в файловой системе. Давайте разберем вышесказанное на примере имени домена mail.k-max.name:

mail.k-max.name. | | | | | | | | | +-корневой домен | | | +---домен первого уровня | | +------точка, разделяющая домены/части FQDN | +---------домен второго уровня +---------------поддомен/домен третьего уровня, возможно - имя хоста

Различие между FQDN и обычным доменным (неFQDN) именем появляется при именовании доменов второго, третьего (и т. д.) уровня. Для получения FQDN требуется обязательно указать в доменном имени домены более высокого уровня (например, mail является доменным именем, однако FQDN имя выглядит как mail.k-max.name.). Максимальный размер FQDN — 255 байт, с ограничением в 63 байта на каждое имя домена.

Поддомены, коротко говоря, это — подчиненные домены. По большому счету, все домены в интернете являются подчиненными за исключением корневого. Например домен k-max является поддоменом домена name, а name, в свою очередь — поддоменом корневого домена.

Итак, на схеме выше мы рассмотрели корневой домен, следующим в иерархии идут домены первого/верхнего уровня, они же TLD, они же Top-Level Domain. К данным доменам относятся национальные домены (ru., ua. и др) и общие домены (com., net., и др). Существуют так же специализированные домены, которые не опубликованы в системе DNS, но используются программами (домен .onion используется анонимной сетью Tor для перехвата и последующей маршрутизации обращений к скрытым сервисам этой сети). Еще есть т.н. зарезервированные доменные имена, определенные в RFC 2606 (Reserved Top Level DNS Names — Зарезервированные имена доменов верхнего уровня) определяет названия доменов, которые следует использовать в качестве примеров (например, в документации), а также для тестирования. К таким именам относятся например example.com, example.org и example.net, а также test, invalid и др. Ниже по иерархии, как видно, идут домены третьего уровня и т.д. Заканчивается доменная иерархия — именами хостов, которые задаются соответствующими ресурсными записями или хостовыми записями.

Ресурсные записи

Ресурсная запись — это то, собственно ради чего в конечном счете и существует DNS. Ресурсная запись — это единица хранения и передачи информации в DNS. Каждая такая запись несет в себе информацию соответствия какого-то имени и служебной информации в DNS, например соответствие имени домена — IP адреса.

Запись ресурса состоит из следующих полей:
  • имя (NAME) — доменное имя, к которому привязана или которому «принадлежит» данная ресурсная запись, либо IP адрес. При отсутствии данного поля, запись ресурса наследуется от предыдущей записи.
  • Time To Live (TTL) — дословно «время жизни» записи, время хранения записи в кэше DNS (после указанного времени запись удаляется), данное поле может не указываться в индивидуальных записях ресурсов, но тогда оно должно быть указано в начале файла зоны и будет наследоваться всеми записями.
  • класс (CLASS) — определяет тип сети, (в 99,99% случаях используется IN (что обозначает — Internet). Данное поле было создано из предположения, что DNS может работать и в других типах сетей, кроме TCP/IP)
  • тип (TYPE) — тип записи синтаксис и назначение записи
  • данные (DATA) — различная информация, формат и синтаксис которой определяется типом.
  • ; — Вводит комментарий
  • # — Также вводит комментарии (только в версии BIND 4.9)
  • @ — Имя текущего домена
  • ( ) — Позволяют данным занимать несколько строк
  • * — Метасимвол (только в поле имя)
k-max.name. 86400 IN A 81.177.139.65
ftp 86400 IN CNAME www.k-max.name.

При подготовке материала использовались источники:
https://bind.isc.org/
https://kb.isc.org/docs/aa-01031
https://habr.com/ru/articles/137587/

Оцените статью