Настройка Docker Dnsmasq

Я пытаюсь настроить контейнер Docker dnsmasq, чтобы все мои контейнеры docker искали доменные имена, а не жестко закодированные IP-адреса (если они находятся на одном хосте). Это устраняет проблему с тем, что невозможно изменить файл/etc / hosts в docker контейнеры, и это позволяет мне легко обновлять все мои контейнеры за один раз, изменяя один файл, на который ссылается контейнер dnsmasq.

похоже, кто-то уже сделал тяжелая работа для меня и создал контейнер dnsmasq. К сожалению, это не "работает" для меня. Я написал bash-скрипт для запуска контейнера, как показано ниже:

name="dnsmasq_"
timenow=$(date +%s)
name="$name$timenow"

sudo docker run 
-v="$(pwd)/dnsmasq.hosts:/dnsmasq.hosts" 
--name=$name 
-p='127.0.0.1:53:5353/udp' 
-d sroegner/dnsmasq

прежде чем запускать это, я создал dnsmasq.каталог hosts и вставил в него один файл под названием hosts.txt со следующим содержанием:

192.168.1.3 database.mydomain.com

к сожалению, всякий раз, когда я пытаюсь пинговать этот домен изнутри:

  • хоста
  • на сервер dnsmasq контейнер
  • другой контейнер на том же хосте

Я всегда получаю ping: unknown host сообщение об ошибке.

Я попытался запустить контейнер dnsmasq без режима демона, чтобы я мог отладить его вывод, который ниже:

dnsmasq: started, version 2.59 cachesize 150
dnsmasq: compile time options: IPv6 GNU-getopt DBus i18n DHCP TFTP conntrack IDN
dnsmasq: reading /etc/resolv.dnsmasq.conf
dnsmasq: using nameserver 8.8.8.8#53
dnsmasq: read /etc/hosts - 7 addresses
dnsmasq: read /dnsmasq.hosts//hosts.txt - 1 addresses

Я предполагаю, что я не указал

1 ответов


сценарий сборки для службы Docker dnsmasq необходимо изменить, чтобы привязка к публичному IP-адресу вашего сервера, который в этом случае является 192.168.1.12 на моем интерфейсе eth0

#!/bin/bash

NIC="eth0"

name="dnsmasq_"
timenow=$(date +%s)
name="$name$timenow"

MY_IP=$(ifconfig $NIC | grep 'inet addr:'| grep -v '127.0.0.1' | cut -d: -f2 | awk '{ print }')


sudo docker run \
-v="$(pwd)/dnsmasq.hosts:/dnsmasq.hosts" \
--name=$name \
-p=$MY_IP:53:5353/udp \
-d sroegner/dnsmasq

на хосте (в данном случае ubuntu 12) необходимо обновить resolv.conf или/etc/network / interfaces файл, так что вы зарегистрировали свой публичный IP (eth0 или eth1 устройство) в качестве сервера имен.

enter image description here

вы можете установить дополнительный сервер имен чтобы быть google, когда контейнер не работает, изменив строку на dns-nameservers xxx.xxx.xxx.xxx 8.8.8.8 Е. Г. не там запятую или другой линии.

затем вам необходимо перезапустить сетевую службу sudo /etc/init.d/networking restart Если вы обновили файл/etc/network /interfaces, чтобы это автоматическое обновление/etc / resolve.conf-файл, который docker скопирует в контейнер во время сборки.

теперь перезапустите все контейнеры

  • sudo docker stop $CONTAINER_ID
  • sudo docker start $CONTAINER_ID

это вызывает их/etc / resolv.файлы conf обновляются, поэтому они указывают на новые настройки сервера имен.

DNS-запросы во всех контейнерах docker (которые вы создали с момента внесения изменений) теперь должны работать с помощью контейнера dnsmasq!

в качестве примечания, это означает, что Docker containers на других узлах может также воспользоваться вашим сервисом dnsmasq на этом хосте как если параметры сервера имен хоста настроены на использование общедоступного IP-адреса этого сервера.