Лучшие вопросы
Таймлайн
Чат
Перспективы

Round robin DNS

Из Википедии, свободной энциклопедии

Remove ads

DNS с циклическим перебором — метод балансировки нагрузки или повышения отказоустойчивости сети, связанный с использованием нескольких серверов. Метод основан на управлении ответами DNS-сервера в соответствии с определённой статистической моделью[1].

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

Существуют различные подходы к определению того, какие адреса будут использоваться запрашивающим приложением, для чего некоторые серверы пытаются изменить порядок в списке, отдавая приоритет численно «более близким» сетям[5][6][7]. Некоторые клиенты пытаются получить альтернативные адреса после ошибки при попытке соединения в течение 30[2]-45 секунд.

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

Хотя циклический DNS прост в реализации, алгоритм имеет ряд недостатков, связанных с кэшированием иерархических записей DNS, а также с кэшированием опубликованного адреса на стороне клиента и его повторным использованием, что затрудняет управление циклическим DNS[9].

Кроме того, циклический DNS — не лучший выбор для самобалансировки нагрузки, поскольку он изменяет порядок адресов только при каждом запросе имени сервера. При этом не учитываются IP-адрес и географическое местоположение пользователя, время выполнения, нагрузка на сервер, перегруженность сети и т. д[10].

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

Remove ads

Примечания

Источники

Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.

Remove ads