1) 在marathon中启动mesos-dns
2) 启动一个nginx的docker,里面默认监听的是80端口.
nginx的docker.json
[root@centos7 mywork]# cat docker_nginx.json
{
"id":"nginx",
"cpus":0.2,
"mem":20.0,
"instances": 2,
"container": {
"type":"DOCKER",
"docker": {
"image": "nginx",
"network": "BRIDGE",
"portMappings":[{"containerPort":80,"hostPort":0,"servicePort":0,"protocol":"tcp"}]
}
}
}
docker镜像可以自己制作,或者使用官方的.
注意network是bridge,
这时候使用marathon部署
curl -X POST http://marathon_host:8080/v2/apps -d @docker_nginx.json -H "Content-type: application/json"
注意里面的marathon_host是marathon的主机ip地址
然后启动成功了docker,可以查看docker启动参数
[root@centos7 mywork]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d10449254a57 nginx "nginx -g 'daemon off" 6 minutes ago Up 6 minutes 443/tcp, 0.0.0.0:31762->80/tcp mesos-10d09140-00f7-4c4f-be72-bc3309fa87da-S0.c7737b67-8665-488f-b18c-42273e8b0129
1c3fb8b48ac1 nginx "nginx -g 'daemon off" 6 minutes ago Up 6 minutes 443/tcp, 0.0.0.0:31437->80/tcp mesos-10d09140-00f7-4c4f-be72-bc3309fa87da-S0.8fb96e2a-b92e-44fb-8319-afb4e7a67737
可以了,端口已经映射出来了,启动了2个nginx容器,其中一个是31762对应里面的80,另外一个是31437对应里面的80,这里的hostPort在配置文件里面是0,所以端口是随机的.
使用dig测试,能否发现以上启动的2个镜像主机
[root@centos7 ~]# dig _nginx._tcp.marathon.mesos SRV
; <<>> DiG 9.9.4-RedHat-9.9.4-29.el7_2.3 <<>> _nginx._tcp.marathon.mesos SRV
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 46384
;; flags: qr aa rd ra; QUERY: 1, ANSWER: 2, AUTHORITY: 0, ADDITIONAL: 2
;; QUESTION SECTION:
;_nginx._tcp.marathon.mesos. IN SRV
;; ANSWER SECTION:
_nginx._tcp.marathon.mesos. 60 IN SRV 0 0 31437 nginx-fkt8j-s0.marathon.mesos.
_nginx._tcp.marathon.mesos. 60 IN SRV 0 0 31762 nginx-wgiaq-s0.marathon.mesos.
;; ADDITIONAL SECTION:
nginx-fkt8j-s0.marathon.mesos. 60 IN A 172.17.0.2
nginx-wgiaq-s0.marathon.mesos. 60 IN A 172.17.0.3
;; Query time: 1 msec
;; SERVER: 127.0.0.1#53(127.0.0.1)
;; WHEN: 五 5月 20 10:32:17 CST 2016
;; MSG SIZE rcvd: 204
主要注意,将centos7_1(mesos-dns的主机)
[root@centos7 ~]# cat /etc/resolv.conf
# Generated by NetworkManager
nameserver mesos-dns部署所在的主机ip
其中mesos-dns部署所在的主机ip需要修改一下,
dig的具体指令怎么使用,请查看
http://blog.csdn.net/dyllove98/article/details/8898070
使用 dig _nginx._tcp.marathon.mesos SRV
其中nginx为部署的应用名称, marathon是框架名称, mesos是domain
发现了2台服务器
直接请求服务器后面对应的ip好像不行,因为network设置的是bridge
那就直接请求nginx-fkt8j-s0.marathon.mesos
[root@centos7 ~]# curl nginx-fkt8j-s0.marathon.mesos
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
body {
width: 35em;
margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif;
}
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>
<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>
<p><em>Thank you for using nginx.</em></p>
</body>
</html>
说明dns已经生效,需要在mesos-slave的所有机器上,都加上mesos-dns的主机名到/etc/resolv.conf