Циклический DNS - Round-robin DNS

Циклический DNS это техника распределение нагрузки, Балансировка нагрузки, или же Отказоустойчивость предоставление нескольких резервных протокол Интернета хосты служб, например, веб сервер, FTP серверы, управляя система доменных имен (DNS) ответы на запросы адресов от клиентских компьютеров согласно соответствующей статистической модели.[1]

В своей простейшей реализации циклический DNS работает, отвечая на запросы DNS не только с одним потенциалом. айпи адрес, но со списком потенциальных IP-адресов, соответствующих нескольким серверам, на которых размещены идентичные службы.[2][3]Порядок, в котором возвращаются IP-адреса из списка, является основанием для термина по-круговой. В каждом ответе DNS последовательность IP-адресов в списке переставлен.[4] Обычно IP-клиенты сначала пытаются установить соединение с первым адресом, возвращенным из DNS-запроса,[5] чтобы при разных попытках подключения клиенты получали услуги от разных поставщиков, таким образом распределяя общую нагрузку между серверами.

Здесь нет стандарт Чтобы решить, какой адрес будет использоваться запрашивающим приложением, несколько преобразователей пытаются переупорядочить список, чтобы отдать приоритет численно «более близким» сетям. Некоторые клиенты для настольных ПК действительно пробуют использовать альтернативные адреса после тайм-аута подключения до 30 секунд.[2]

Циклический DNS часто используется для балансировки нагрузки запросов между несколькими Веб-серверы. Например, у компании есть одно доменное имя и три идентичных копии одного и того же веб-сайта, размещенные на трех серверах с тремя IP-адресами. DNS-сервер будет настроен так, чтобы в доменном имени было несколько записей A, по одной для каждого IP-адреса. Когда один пользователь получает доступ к домашней странице, он будет отправлен на первый IP-адрес. Второй пользователь, который получает доступ к домашней странице, будет отправлен на следующий IP-адрес, а третий пользователь будет отправлен на третий IP-адрес. В каждом случае после выдачи IP-адреса он переходит в конец списка. Таким образом, четвертый пользователь будет отправлен на первый IP-адрес и так далее.

DNS-имя с циклическим перебором в редких случаях называется «ротором» из-за ротации альтернативных записей A.

Недостатки

Несмотря на простоту реализации, циклический DNS имеет ряд недостатков, например, связанных с кэшированием записей в самой иерархии DNS, а также с кэшированием и повторным использованием адресов на стороне клиента, сочетание которых может быть трудным для управления. Циклический DNS не следует полагаться исключительно на доступность услуг. Если служба на одном из адресов в списке выйдет из строя, DNS продолжит выдачу этого адреса, и клиенты все равно будут пытаться связаться с неработающей службой.

Циклический DNS может быть не лучшим выбором для Балансировка нагрузки сам по себе, поскольку он просто меняет порядок записей адресов каждый раз, когда запрашивается сервер имен. Поскольку он не принимает во внимание время транзакции, нагрузку на сервер и перегрузку сети, он лучше всего работает для служб с большим количеством равномерно распределенных подключений к серверам эквивалентной мощности. В противном случае это просто распределение нагрузки.[6]

Существуют методы преодоления таких ограничений. Например, модифицированные DNS-серверы (например, lb named[7]) может регулярно опрашивать зеркальные серверы на предмет доступности и коэффициента загрузки. Если сервер не отвечает должным образом, сервер может быть временно удален из пула DNS, пока он не сообщит, что снова работает в соответствии со спецификациями.

Метод DNS GSLB также может использоваться для улучшения простого циклического распределения.[8] Либо работая на полномочном DNS-сервере, проверяя доступность сервера (а иногда и клиентского), либо на границе сети на рекурсивном DNS-сервере, изменяя на лету ответы DNS. Авторитетное решение обычно встроено в решение для балансировки нагрузки и контроллер доставки приложений как стандартное или дополнительное решение. Рекурсивное решение, также называемое Edge DNS GSLB[9], продвигает концепцию, добавляя более простой способ проверки доступности записей в сети с точки зрения клиента, а затем уменьшая ошибки интерпретации.

Рекомендации

  1. ^ «Круговой DNS». Cloudflare. Cloudflare, Inc. Получено 16 августа 2019.
  2. ^ а б Финберг, Дэниел (25 июля 2016 г.). «Циклический перебор DNS для отработки отказа веб-сервера». Получено 10 января, 2020.
  3. ^ «В чем разница между политикой маршрутизации многозначных ответов и простой политикой маршрутизации?». Amazon Web Services, Inc. 3 августа 2018 г.. Получено 10 января, 2020.
  4. ^ Лиска, А .; Стоу, Г. (2016). «Понимание DNS». Безопасность DNS. п. 19.
  5. ^ Пан, Цзяньпин; Хоу, Ю. Томас; Ли, Бо (2003). «Обзор выбора серверов на основе DNS в сетях распространения контента». Компьютерная сеть. 43 (6): 695–711. Дои:10.1016 / S1389-1286 (03) 00293-7.
  6. ^ Бриско, Томас П. (апрель 1995 г.). «RFC 1794 - Поддержка DNS для балансировки нагрузки». Получено 24 августа 2019.
  7. ^ названный, DNS-сервер с балансировкой нагрузки, реализованный на языке программирования Perl
  8. ^ Что такое GSLB?, Глобальная балансировка нагрузки на сервер
  9. ^ Пограничный DNS GSLB