Протокол DNS
- Bot
- 30.01.2021
- 15 791
- 0
- 04.07.2021
- 23
- 23
- 0
- Содержание статьи
Что такое DNS?
DNS - компьютерная распределённая система преобразование символьного имени в IP-адрес и наоборот. Термин DNS образуется от аббревиатуры Domain Name System (система доменных имён).
DNS была разработана Полом Мокапетрисом в 1983 году.
В сети интернет DNS выполняет важную задачу, для доступа к веб-серверу необходимо знать его IP-адрес. Необходимость использования DNS обусловлена тем, что людям легче запоминать буквенные (обычно осмысленные) адреса, чем последовательность четырех цифр IP-адреса, компьютерам, в свою очередь, удобнее обрабатывать численное представление адреса (IP-адрес). Также наличие символьного имени сервера позволяет использовать так называемые виртуальные серверы , например, HTTP-серверы, отличающиеся друг от друга именем запроса (доменным именем), но использующие один и тот же IP-адрес.
В начале для преобразования IP-адресов в символьные имена использовался текстовый файл hosts , расположенный:
- В Windows:
%SystemRoot%\system32\drivers\etc\hosts
; - В Unix:
/etc/hosts
;
Пример стандартного файла hosts в Windows
Файл hosts заполнялся автоматически и централизовано на каждой ЭВМ в своей локальной вычислительной сети. Но данный подход со временем показал свою несостоятельность, поскольку с ростом сети, количество записей в текстовом файле увеличивалось, как следствие увеличивался размер файла, ко всему прочему частая пересылка файла hosts загружала вычислительную сеть.
В итоге стала необходимость в разработке автоматизированного механизма, которым и стала распределенная система DNS.
Следует учесть, что файл hosts используется до сих пор, в частности, при настройке локального сервера на ЭВМ, в hosts записываются созданные локальные символьные имена. Например:
127.0.0.1 localhost
127.0.1.1 my-pc
Иерархия имен в DNS
В связи с тем, что число узлов интернета растет с каждым днем, для эффективной работы DNS разработана распределенная база данных, поддерживаемая с использование иерархии DNS-серверов. Структура взаимодействия DNS серверов представлена на рисунке.
Данная схема позволяет разгрузить сервер DNS по нескольким серверам DNS, что и выполняет распределенная база данных.
В основе иерархической структуры DNS лежит представление о доменном имени и зонах. Каждый DNS сервер, отвечающий за имя, может передать ответственность за дальнейшую часть домена другому серверу, что позволяет делегировать ответственность за вновь добавленную информацию на серверы различных организаций (людей), ответственных непосредственно только за «свою» часть доменного имени.
Иерархия доменных имен начинается с корневого домена без имени (или еще как его называют «домен точка»), далее идут домены верхнего уровня или домены первого уровня. Домены верхнего уровня поделены на три зоны:
- arpa это специальный домен, используемый для сопоставления адрес - имя
- Семь трехсимвольных доменов называются общими (generic) доменами или организационными (organizational) доменами.
- Двухсимвольные домены, так называемые домены стран или географические домены (ru – Российская Федерация, kz - Казахстан), основанные на кодах стран, в соответствии с ISO 3166.
Поскольку DNS поддерживает иерархию доменных имен, но никак не IP-адресов. Для решения “обратной” задачи есть специальный домен, структура которого совпадает со структурой IP-адресов. Называется этот домен IN-ADDR.ARPA .
in-addr.arpa — специальная доменная зона, предназначенная для определения имени хоста по его IPv4-адресу, используя PTR-запись. Имена в домене IN-ADDR.ARPA образуют иерархию цифр, которые соответствуют IP-адресам. Правда, записываются эти имена в обратном порядке относительно написания IP-адреса.
Например, доменное имя sysadmin.ru, которое имеет адрес 95.213.248.170 должна быть описана в домене in-addr.arpa как 170.248.213.95.in-addr.arpa, то есть адрес записывается в обратном порядке.
Основные типы записей DNS
Основные типы записей используемые в протоколе DNS
A
A запись (address record IPv4 ) или запись адреса - основная запись, выполняет связующую роль между именем хоста (sysadmin.ru) и IP адресом (95.213.248.170). Если меняется только А запись, то это значит, что наш сайт физически будет размещен на другом хостинге, а все остальные записи останутся работать на старом хостинге.
Название | Тип записи | Адрес |
---|---|---|
sysadmin.ru | A | 95.213.248.170 |
AAA
AAA запись (address record IPv6 ) или запись адреса - аналогична записи A, только для IPv6.
Название | Тип записи | Адрес |
---|---|---|
sysadmin.ru | AAA | FFEA::CA28:1210:4362 |
CNAME
CNAME запись (canonical name record) или каноническая запись имени (псевдоним) - используется для перенаправления на другое имя (по аналогии с ссылками), частным примером использования CNAME записи, является создание доменных имен для ftp, mail, ssh, например
Название | Тип записи | Адрес |
---|---|---|
ftp.sysadmin.ru | CNAME | sysadmin.ru |
mail.sysadmin.ru | CNAME | sysadmin.ru |
ssh.sysadmin.ru | CNAME | sysadmin.ru |
MX
MX запись (mail exchange) или почтовый обменник, указывает те сервера, с которыми будет осуществлен обмен для данного домена. То есть определяет сервер, который будет обрабатывать почту для вашего домена. В случае отсутствия MX-записи, запрашивается A-запись
Название | Тип записи | Адрес |
---|---|---|
sysadmin.ru | MX | mx1.beget.ru |
sysadmin.ru | MX | mx2.beget.ru |
NS
NS запись (name server) указывает на DNS сервер текущего домена, так называемые authoritative DNS-серверы. Смена NS-записи, при переходе на другой хостинг, влечёт за собой смену всех записей, соответственно нужно или указывать новые записи или копировать со старого сайта (например, для сохранения почты, нужно скопировать MX-запись со старого хостинга). При неправильном изменении NS записи домена, может привести к остановке работы сайта.
Название | Тип записи | Адрес |
---|---|---|
sysadmin.ru | NS | ns1.beget.ru |
sysadmin.ru | NS | ns2.beget.ru |
TXT
TXT запись текстовая запись содержащая 254 байта любой текстовой информации, в основном используется для подтверждения принадлежности домена для севрисов yandex, google и т.п.
Название | Значение |
---|---|
yandex | validate value for yandex |
Добавить комментарий