10

dnsmasq を Docker コンテナー内の DHCP サーバーとして動作させ、ホストの物理ネットワーク上のマシンに DHCP アドレスを発行しようとしています。https://hub.docker.com/r/andyshinn/dnsmasq/の Alpine Linux 6MB コンテナーを使用しています。

ホスト マシンのポート 53 で DNS サーバーとして正常に動作しますが、ポート 67/udp でリッスンするものはありません。これは、DHCP があると予想される場所です。を使用 dhcping 192.168.2.2していますが、「応答なし」となります。telnet 192.168.2.2 67「接続が拒否されました」を返します。

コンテナー内の dnsmasq.conf ファイルは次のようになります。

interface=eth0
user=root
domain-needed
bogus-priv
no-resolv
local=/mydomain.io/
no-poll
server=8.8.8.8
server=8.8.4.4
no-hosts
addn-hosts=/etc/dnsmasq_static_hosts.conf
expand-hosts
domain=mydomain.io
dhcp-range=192.168.2.10,192.168.2.250,255.255.255.0,192.168.2.255,5m
# Have windows machine release on shutdown
dhcp-option=vendor:MSFT,2,1i
# No default route
dhcp-option=3

ホスト マシンの静的アドレスは 192.168.2.2 です。

次のようにコンテナを起動します。

docker run -d --name dns -p 192.168.2.2:67:67/udp -p 192.168.2.2:53:53/udp sitapati/dns

Ubuntu 16.04 を実行しているこのマシンにはファイアウォールはありません。

私が考えたこと/試したこと:

  • コンテナー内の eth0 がまったく別のサブネットにアドレスを持っているためですか? (docker inspectブリッジされたインターフェースでは172.17.0.2だと教えてくれます)
  • 使用する必要があります--net hostか? 私はそれを試しましたが、それでもうまくいきませんでした。
4

1 に答える 1