Docker入门与应用系列(八)Docker图形界面管理之Shipyard

Shipyard基于Docker API实现的容器图形管理系统,支持container、images、engine、cluster等功能,可满足我们基本的容器部署需求
可堆栈的Docker管理
基于Docker Swarm,Shipyard可让您管理Docker资源,包括容器,图像,私人注册表等等。
Shipyard与其他管理应用程序的不同之处在于它提高了可组合性,并与Docker Remote API 100%兼容。
Shipyard管理container、images、engine、cluste范围内的私人注册管理机构以及提供身份验证和基于角色的访问控制。
官网:
https://www.shipyard-project.com/docs/deploy/
https://www.shipyard-project.com/docs/deploy/manual/

镜像名称

运行服务

描述

rethinkdb

shipyard数据库

一个Nosql数据库,用于存储shipyard系统的数据,比如账号、节点、容器等信息

microbox/etcd

服务注册、发现系统

k/v存储系统,用于swarm节点实现服务注册、发现。也支持consul、zookeeper

shipyard/docker-proxy

docker API代理

连接本地/var/run/docker.sock代理,用于让swarm agent连接api管理

swarm

swarm集群

官方管理docker集群工具,使得多个engine为一个整体管理,对外提供swarm manager api 用户就像操作单台engine一样

shipyard/shipyard

shipyard前端

容器web管理系统,内部连接swarm manager管理容器和 rethinkdb存储数据

自动化部署

curl -sSL https://shipyard-project.com/deploy |bash -s

手动部署

Datastore
Shipyard使用RethinkDB作为数据存储。
首先我们将启动一个RethinkDB容器。

$> docker run \
-ti \
-d \
--restart=always \
--name shipyard-rethinkdb \
rethinkdb

Datastore

Discovery
要启用Swarm leader选举,我们必须使用来自Swarm容器的外部键值存储。
对于这个例子,我们将使用etcd,但是可以使用Swarm支持的任何键/值后端。

$> docker run \
-ti \
-d \
-p : \
-p : \
--restart=always \
--name shipyard-discovery \
microbox/etcd -name discovery

Discovery

Proxy
默认情况下,Docker引擎只侦听套接字。 我们可以重新配置引擎来使用TLS,也可以使用代理容器。
这是一个非常轻量级的容器,它只是将来自TCP的请求转发给Docker侦听的Unix套接字。
注意:如果使用手动TCP / TLS配置,则不需要此项。

$> docker run \
-ti \
-d \
-p : \
--hostname=$HOSTNAME \
--restart=always \
--name shipyard-proxy \
-v /var/run/docker.sock:/var/run/docker.sock \
-e PORT= \
shipyard/docker-proxy:latest

Proxy

Swarm Manager
这将运行一个Swarm容器配置为管理。

$> docker run \
-ti \
-d \
--restart=always \
--name shipyard-swarm-manager \
swarm:latest \
manage --host tcp://0.0.0.0:3375 etcd://192.168.1.82:4001

Swarm Manager

Swarm Agent
这运行一个Swarm代理,允许节点调度容器。

$> docker run \
-ti \
-d \
--restart=always \
--name shipyard-swarm-agent \
swarm:latest \
 etcd://192.168.1.82:4001

Swarm Agent

Controller
这将运行Shipyard控制器。

$> docker run \
-ti \
-d \
--restart=always \
--name shipyard-controller \
--link shipyard-rethinkdb:rethinkdb \
--link shipyard-swarm-manager:swarm \
-p : \
shipyard/shipyard:latest \
server \
-d tcp://swarm:3375

Controller

安装完毕后,进程查看

root@linux-node3:~# docker ps -a
CONTAINER ID        IMAGE                          COMMAND                  CREATED             STATUS              PORTS                                            NAMES
7ff955eb2507        shipyard/shipyard:latest        minutes ago       Up  minutes        ->/tcp                           shipyard-controller
5b911657956d        swarm:latest                    minutes ago       Up  minutes        /tcp                                         shipyard-swarm-agent
1c7da1f43873        swarm:latest                    minutes ago       Up  minutes        /tcp                                         shipyard-swarm-manager
f812939ee6b2        shipyard/docker-proxy:latest    minutes ago       Up  minutes        ->/tcp                           shipyard-proxy
629a2015e02d        microbox/etcd                   minutes ago       Up  minutes        ->/tcp, ->/tcp   shipyard-discovery
7a877074bc14        rethinkdb                       minutes ago      Up  minutes       /tcp, /tcp, /tcp                   shipyard-rethinkdb

浏览器访问
IP+端口
192.168.1.82:8080
用户名:admin
密码:shipyard

Docker入门与应用系列(八)Docker图形界面管理之Shipyard

Docker入门与应用系列(八)Docker图形界面管理之Shipyard

Docker入门与应用系列(八)Docker图形界面管理之Shipyard

Docker入门与应用系列(八)Docker图形界面管理之Shipyard

Docker入门与应用系列(八)Docker图形界面管理之Shipyard

Docker入门与应用系列(八)Docker图形界面管理之Shipyard

Docker入门与应用系列(八)Docker图形界面管理之Shipyard

上一篇:設置Linux保留物理內存並使用 (1)


下一篇:osg复制多个相同物体修改材质属性问题