Skip to content

xianlubird/single-docker-mesos

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

xianlubird/single-docker-mesos

基于Docker快速搭建单节点Mesos/Marathon集群,增加支持marathon管理运行docker功能

##一. 简介

Mesos是集群资源管理系统,Marathon是运行在Mesos之上的集群计算架构。将Mesos和Marathon打包到Docker镜像中,开发者便可以在本机上快速搭建Mesos/Marathon集群,进行学习和测试。

kiwenlau/single-mesos镜像非常简单。Docker容器运行在Ubuntu主机之上,Mesos和Marathon运行在该容器之中。具体来讲,Docker容器中运行了一个Mesos Master和一个Mesos Slave,以及Marathon和ZooKeeper。集群架构如下图:

##二. 搭建Mesos/Marathon集群

1. 下载Docker镜像:

docker pull index.alauda.cn/a352193394/single-docker-mesos

2. 运行Docker容器:

docker run -p 8080:8080 -p 5050:5050 --name mesos -ti -w /root -v /sys/fs/cgroup:/sys/fs/cgroup -v /var/run/docker.sock:/var/run/docker.sock single-docker-mesos

docker run命令运行成功后即进入容器内部,以下为输出:

Start ZooKeeper...
Start Mesos master...
Start Mesos slave...
Start Marathon...

##三. 测试Mesos/Marathon集群

1. 通过curl命令调用Marathon的REST API, 创建一个hello程序:

curl -v -H "Content-Type: application/json" -X POST --data "@hello.json" http://127.0.0.1:8080/v2/apps

下面为hello.json。这个程序使用docker运行了一个简单的python服务。

{
  "id": "basic-3",
  "cmd": "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 }
      ]
    }
  }
}

About

快速部署mesos+marathon+docker单节点集群,便于开发和调试

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages