我在尝试在mesos群集上运行mesos-dns时遇到了一些麻烦。
我在Windows 8.1主机上设置了2个带有ubuntu可信任的虚拟机。 我的虚拟机名为 docker-vm 和 docker-sl-vm ;第一个运行mesos-master而第二个运行mesos-slave。
虚拟机有2个网卡;一个运行NAT用于通过主机访问Internet,另一个是用于内部通信的仅主机适配器。
虚拟机的IP是:
MESOS群集运行正常。
我正在尝试关注this tutorial。所以,我正在使用以下马拉松描述运行 mesos-dns :
{
"args": [
"/mesos-dns",
"-config=/config.json"
],
"container": {
"docker": {
"image": "mesosphere/mesos-dns",
"network": "HOST"
},
"type": "DOCKER",
"volumes": [
{
"containerPath": "/config.json",
"hostPath": "/usr/local/mesos-dns/config.json",
"mode": "RO"
}
]
},
"cpus": 0.5,
"mem": 256,
"id": "mesos-dns",
"instances": 1,
"constraints": [["hostname", "CLUSTER", "docker-sl-vm"]]
}
和 config.json :
{
"zk": "zk://192.168.56.101:2181/mesos",
"refreshSeconds": 60,
"ttl": 60,
"domain": "mesos",
"port": 53,
"resolvers": ["8.8.8.8"],
"timeout": 5,
"email": "root.mesos-dns.mesos"
}
我还在运行一个名为 peek 的测试提案应用程序,其中包含以下描述:
{
"id": "peek",
"cmd": "env >env.txt && python3 -m http.server 8080",
"cpus": 0.5,
"mem": 32.0,
"container": {
"type": "DOCKER",
"docker": {
"image": "python:3",
"network": "BRIDGE",
"portMappings": [
{ "containerPort": 8080, "hostPort": 0 }
]
}
}
}
问题
在教程中,诸如dig _peek._tcp.marathon.mesos SRV
之类的挖掘命令得到了以下答案:
; <<>> DiG 9.9.5-3ubuntu0.5-Ubuntu <<>> _peek._tcp.marathon.mesos SRV
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 57329
;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 1
;; QUESTION SECTION:
;_peek._tcp.marathon.mesos. IN SRV
;; ANSWER SECTION:
_peek._tcp.marathon.mesos. 60 IN SRV 0 0 31000 peek-27346-s0.marathon.mesos.
;; ADDITIONAL SECTION:
peek-27346-s0.marathon.mesos. 60 IN A 10.141.141.10
;; Query time: 4 msec
;; SERVER: 127.0.0.1#53(127.0.0.1)
;; WHEN: Sat Oct 24 23:21:15 UTC 2015
;; MSG SIZE rcvd: 160
当我在我的奴隶机器上运行此操作时,我们可以清楚地看到端口和IP绑定到_peek._tcp.marathon.mesos SRV
,但 - 运行此容器 - 我得到了这样的结果:
docker@docker-sl-vm:~$ dig _peek._tcp.marathon.mesos SRV
; <<>> DiG 9.9.5-3ubuntu0.5-Ubuntu <<>> _peek._tcp.marathon.mesos SRV
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NXDOMAIN, id: 33415
;; flags: qr rd ra; QUERY: 1, ANSWER: 0, AUTHORITY: 1, ADDITIONAL: 1
;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 1280
;; QUESTION SECTION:
;_peek._tcp.marathon.mesos. IN SRV
;; AUTHORITY SECTION:
. 10791 IN SOA a.root-servers.net. nstld.verisign-grs.com. 2015102801 1800 900 604800 241
;; Query time: 1 msec
;; SERVER: 10.10.11.1#53(10.10.11.1)
;; WHEN: Wed Oct 28 17:06:30 BRT 2015
;; MSG SIZE rcvd: 129
看起来 mesos-dns 无法解析_peek._tcp.marathon.mesos SRV。
有谁知道为什么以及如何解决这个问题?
提前谢谢你......
更新
命令/etc/resolv.conf
的结果:
nameserver 10.10.11.1
nameserver 10.10.10.7
答案 0 :(得分:1)
查看有关从属设置的Mesos DNS docs:
要允许Mesos任务使用Mesos-DNS作为主DNS服务器,您必须编辑每个从属服务器中的文件
/etc/resolv.conf
并添加新的名称服务器。例如,如果mesos-dns在IP地址为10.181.64.13的服务器上运行,则应在每个从属节点的/etc/resolv.conf
开头添加行名称服务器10.181.64.13。
我认为192.168.56.102
中缺少本地IP(/etc/resolv.conf
)地址。
否则,您也可以尝试my minimal Mesos DNS image,但仍然需要编辑上述文件。