文档章节

测试mesos-dns是否生效方案(mesos-dns服务)

testwork
 testwork
发布于 2016/05/20 10:44
字数 657
阅读 131
收藏 1

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

© 著作权归作者所有

共有 人打赏支持
testwork
粉丝 4
博文 74
码字总数 21048
作品 0
崇明
程序员
私信 提问
基于Zookeeper+Mesos+Marathon搭建Docker集群管理平台

Mesos概述 Apache Mesos 是一款基于多资源(内存、CPU、磁盘、端口等)调度的开源集群管理套件,能使容错和分布式系统更加容易使用。其采用了Master/Slave结构来简化设计,将Master做的尽可能...

小樱桃Cherry
2018/08/24
0
0
配置单台Mesos-master与Mesos-slave

Apache Mesos是一个集群管理器,可跨分布式应用程序或框架提供有效的资源隔离和共享。它位于应用程序层和操作系统之间,可以更加轻松地在大规模集群环境中更有效地部署和管理应用程序。它可以...

cchenyz
2018/08/15
0
0
飞驰在Mesos的涡轮引擎上

回想起第一次接触Mesos, 当时有很多困惑: "这到底是用来做啥的?跟YARN比有什么优势?有哪些大公司在使用么?"。 然而现在技术日新月异地发展, Mesos这个生态圈也开始被越来越多的团队熟悉关注...

力谱宿云
2016/08/11
313
3
Kubernetes on DC/OS最佳实践

考虑大家的知识背景有所不同,在介绍Kubernetes on DC/OS的原理与技术实现之前,我觉得还是有必要先简单地介绍一下Mesos,DC/OS以及Kubernetes之间的关系与区别。 准确的说Mesos与Kubernete...

Docker
2018/04/23
0
0
在CentOS7上部署Apache Mesos

概述 Apache Mesos是一款基于多资源(内存、磁盘、CPU、端口等)调度的开源集群管理套件,能使容错和分布式系统更加容易。 工作原理 Apache Mesos采用了Master/Slave结构来简化设计,将Maste...

何以重见
2018/08/17
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Windows同步对象Event和Linux的条件变量

最近在看一些同步对象模拟的东东,特别对在Windows下如何模拟条件变量折腾了很久。 1 Windows同步对象Event 微软有一个很有意思的同步对象,某种程度上和Linux的条件变量很相似。但秉承微软一...

shzwork
18分钟前
1
0
从上往下打印出二叉树的每个节点,同层节点从左至右打印。

//第一种做法 public class Solution { public ArrayList<Integer> PrintFromTopToBottom(TreeNode root) { ArrayList <Integer> li=new ArrayList<Integer>(); ArrayList <TreeN......

南桥北木
28分钟前
1
0
linux 服务管理 Crontba、Ntpdate、Logrotate、Supervisor

crond linux 系统则是由 cron (crond) 这个系统服务来控制的。Linux 系统上面原本就有非常多的计划性工作,因此这个系统服务是默认启动的。 另外, 由于使用者自己也可以设置计划任务,所以,...

狼王黄师傅
58分钟前
3
0
Sobel算子和Scharr滤波器

Sobel算子在数学上的本质是微分,对离散信号,是求邻域内的增量。 基本原理:在图像上,对图像信号在某点进行微分,表示图像的某个特征(如,强度、色调或者饱和度)在该点的变换程度。以强度...

yepanl
今天
2
0
Jenkins API 使用

Jenkins 是一款流行的开源持续集成工具,可以用来做一些软件开发的自动化工作,如打包,测试,自动部署等。 Jenkins 中有 view 和 job 的概念, view 相当于组, job 则是具体的任务。 view...

YanWen
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部