Docker And Swarm Mode(一)
(一)节点的创建和配置
前言
虽然工作中一直在用Docker和Docker Swarm,但是总感觉有点陌生,总想自己亲手来写写和配置Docker 容器相关的事情,这篇文章主要是参考了Los Techies 中关于Docker 和 Docker Swarm 的一些内容,然后自己做一个尝试和练习。
本文主要讲的就是使用VirtualBox 来建立 Docker node ,然后组合成 Docker Swarm。
环境配置
因为之前一直是在Linux的环境下操作的,这次是想在家里的Windows上用Docker来试试的。由于Hyper-V啦,Virtualization等各类问题,也可能是对Docker 的不熟悉,折腾了两个晚上之后放弃了,最后决定在Mac上进行操作。
Docker 及其版本:
- Docker:Docker version 17.12.0-ce, build c97c6d6
- Docker-machine: docker-machine version 0.13.0, build 9ba6da9
- Docker-compose:docker-compose version 1.18.0, build 8dd22a9
然后还需要安装Virtualbox 来模拟多个服务器,根据自己机器的环境安装对应的版本。
创建节点
for N in 1 2 3 4 5;
do docker-machine create --driver virtualbox node$N;
done
可能需要花费一点时间,然后使用
docker-machine ls
接下来就会看到下面的这张图。
如果我们要进入某个node,则需要执行docker-machine ssh node1
之前一直卡在docker-compose上面,因为我在Windows上一直无法安装,使用docker pull docker/compose:1.8.0 没想到这个坑,这个是之前的,目前只要安装好docker 的Mac 或者Windows客户端就自动安装好了 docker-machine 和docke-compose
开始Swarmkit
做好上面的准备之后,我们已经可以开始创建Docker Swarm 了,Docker ,理解Swarm clusters:
A swarm is a group of machines that are running Docker and joined into a cluster.. After that has happened, you continue to run the Docker commands you’re used to, but now they are executed on a cluster by a swarm manager. The machines in a swarm can be physical or virtual. After joining a swarm, they are referred to as nodes.
接下来我们就创建一个Swarm,
首先进行node1
docker-machine ssh node1执行
docker swarm init --advertise-addr [node1-ip-address]比如我的node1 的ip地址是192.168.99.100,则命令为docker swarm init --advertise-addr 192.168.99.100执行完之后就会看到控制台:$ docker swarm init --advertise-addr 192.168.99.100
Swarm initialized: current node (ddec2zwjaes2kpkmnshkmpstq) is now a manager. To add a worker to this swarm, run the following command:
docker swarm join --token SWMTKN-1-4kxfjieyyjdab91c9sxunj75ivke51y4geoucu7g4cvl7g2p1u-7m00eooi3obknk2cjx8zexkea 192.168.99.100:2377 To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.执行完这个命令后,node1 就成为了leader,你可以依次进入每个容器然后执行
docker swarm join --token SWMTKN-1-4kxfjieyyjdab91c9sxunj75ivke51y4geoucu7g4cvl7g2p1u-7m00eooi3obknk2cjx8zexkea 192.168.99.100:2377加入到Swarm中。执行完上述命令后,则我们有一个5个node 的Swarm了。一个node1 leader 节点,然后4个worker 节点。
In a production environment we should have at least 3 master nodes for high availability since master nodes store all the information about the swarm and its state.
我们可以通过
docker node promote node2 node3来把worker 节点提升为leader节点
关于这个Reachable是什么意思呢?当我们现在的node2 节点由于某种原因挂了,或者停止了,那么在node1和node3中就会自动选择一个当作leader,然后等node2恢复后,就变成了Reachable状态了。
Service
有了上面关于的那些基础设施后,接下来可以了解Service了,在了解早起爱你,我们先来说说Node,个人感觉node就像一台服务器一样,然后加入到Swarm里面,一堆的node然后就可以组建成一个Swarm。
A node is an instance of Docker Engine participating in a swarm.
在Swarm里面,node 有两种形式,一种是 worker,另一种是manager。woker的权限就少的有点可怜了,连docker service ls 都看不了。
说起Service服务,首先它是跑在node上面的,我觉得吧它就像比如一个应用,比如登陆站点服务。
A service is the definition of the tasks to execute on the worker nodes. It is the central structure of the swarm system and the primary root of user interaction with the swarm.
Services are really just “containers in production.” A service only runs one image, but it codifies the way that image runs—what ports it should use, how many replicas of the container should run so the service has the capacity it needs, and so on. Scaling a service changes the number of container instances running that piece of software, assigning more computing resources to the service in the process.
使用 docker-compose.yml 来定义,运行和配置服务
docker rmi $(docker images -q -f dangling=true)
Docker使用过程中的一些命令
docker ps / docker container ls 查看当前容器列表
docker image ls / docker images 查看当前镜像列表
docker build -t imageName . 建立镜像命令
docker run -p 4000:80 imageName 运行容器命令
docker run -d -p 4000:80 imageName 后台运行容器命令
docker container stop containerId 停止容器命令
docker swarm init 初始化swarm
docker stack deploy -c docker-compose.yml appName 建立名为appName 的App Stack,若调整了docker-compose.yml ,也可用该命令进行站点的更新
docker service ls 查看当前运行的服务的信息
docker service ps servicename 列出当前服务所运行的节点及其状态
docker stack rm appName 下线名为appName 的app
docker swarm leave --force 离开Swarm
docker-machine ls 列出当前的虚拟机信息
docker-machine ssh machine_name 进入名为 machine_name 的虚拟机中,如果无法进行,则使用docker-machine --native-ssh ssh machine_name
docker node ls 查看当前Swarm的节点信息,需要在Swarm 中执行该命令,否则报错
这两个命令和起来很有用,相当于附加到当前的Shell控制台上,可以不进入虚拟机,然后直接操作该虚拟机。
docker-machine env <machine>
eval $(docker-machine env <machine>)get the command to configure your shell to talk to
<machine>.eval $(docker-machine env -u) 取消绑定
当镜像是存储在私人Registry上时,这需要 login 然后deploy时加上
--with-registry-auth命令
docker login registry.example.com
docker stack deploy --with-registry-auth -c docker-compose.yml appName
Docker And Swarm Mode(一)的更多相关文章
- 小白学Docker之Swarm
承接上篇文章:小白学Docker之Compose,自学网站来源于https://docs.docker.com/get-started 系列文章: 小白学Docker之基础篇 小白学Docker之Co ...
- 【Docker】 Swarm简单介绍
[Swarm] Swarm是Docker官方提供的一款集群管理工具,其主要作用是把若干台Docker主机抽象为一个整体,并且通过一个入口统一管理这些Docker主机上的各种Docker资源.Swarm ...
- Docker - 使用 swarm 部署 services
前言 经过之前一段时间学习与思考,我们已经大概明确了一些感念: Docker image/container, service and node 简单来说,swarm允许我们以节点(node)的方式 ...
- Docker - 创建Swarm
1. 准备 我们需要: Docker Engine 1.12 or later installed the IP address of the manager machine open ports b ...
- docker学习------swarm集群虚机异常关机,node状态为down
1.因昨天虚机异常关闭,导致今天上去查看时,node节点状态显示为down 2.查了些相关资料,找到处理办法(因我的节点没有任何数据,所以直接对其进行清除) docker swarm leave -- ...
- docker kubernetes Swarm容器编排k8s CICD部署
1docker版本 docker 17.09 https://docs.docker.com/ appledeAir:~ apple$ docker version Client: Docker En ...
- Docker之Swarm
Docker学习笔记 — Swarm搭建Docker集群 Swarm在schedule节点运行容器的时候,会根据指定的策略来计算最适合运行容器的节点,目前支持的策略有:spread, binpack, ...
- Docker: 如何将node.js的项目部署到docker的swarm上面去
前提条件: Docker创建虚机和swarm 如何用Docker建立一个Node.js的开发环境 正文: 将如何用Docker建立一个Node.js的开发环境文中创建的nodehello image发 ...
- docker探索-swarm搭建docker集群(七)
前言 Swarm 在 Docker 1.12 版本之前属于一个独立的项目,在 Docker 1.12 版本发布之后,该项目合并到了 Docker 中,成为 Docker 的一个子命令,docker s ...
随机推荐
- GLES2学习VBO和VAO的使用
在GLES2中使用VBO和VAO对象,已经简单vs,ps绘制一个三角形. 1. 初始化操作代码,创建VBO.VAO,编译和链接shader program. void DebugApplication ...
- Java基础学习笔记二十四 MySQL安装图解
.MYSQL的安装 1.打开下载的mysql安装文件mysql-5.5.27-win32.zip,双击解压缩,运行“setup.exe”. 2.选择安装类型,有“Typical(默认)”.“Compl ...
- 福州大学软工1715|W班-启航
新的一学期即将开启,而在仅剩的几天的时间内,我将为接下来的软工实践助教事宜忙碌起来.要学习的东西很多,要关注的东西也很多. 虽然我现在还在茫然阶段,虽然我对<构建之法>还不太熟悉,但是,我 ...
- C语言的第二次作业
一.PTA实验作业 题目1. 计算分段函数 本题目要求计算下列分段函数f(x)的值: 1.本题代码 #include<stdio.h> #include<math.h> int ...
- 20162318 实验四 Android程序设计
北京电子科技学院(BESTI) 实 验 报 告 课程:程序设计与数据结构 班级:1623班 姓名:张泰毓 指导老师:娄老师.王老师 实验日期:2017年5月26日 实验密级:非密级 实验器材:带Lin ...
- 使用XIB的UITableViewCell自适应,以及出现的问题进行解决
1.首先需要定义一个属性 @property (nonatomic, strong) UITableViewCell *prototypeCell; 2.在创建完tableView后加上如下代码 se ...
- Beta冲刺Day1
项目进展 李明皇 今天解决的进度 点击首页list相应条目将信息传到详情页 明天安排 优化信息详情页布局 林翔 今天解决的进度 前后端连接成功 明天安排 开始微信前端+数据库写入 孙敏铭 今天解决的进 ...
- vue 保留两位小数 不能直接用toFixed(2) ?
用vue做项目的时候多多少少都会遇到这个问题 刚开始我是用toFixed()这个方法来写的 效果是有的 但是控制台一直是红红的围绕着我 突然想到 vue和jquery混搭 的 问题 于是乎 看了一下 ...
- TFTP通信原理
TFTP的通信流程 TFTP共定义了五种类型的包格式,格式的区分由包数据前两个字节的Opcode字段区分,分别是: · l 读文件请求包:Read request,简写为RRQ,对应Opcode字段值 ...
- 帧动画的创建方式 - 纯Java代码方式
废话不多说,先看东西 帧动画的创建方式主要以下2种: * 用xml创建动画: * 纯Java代码创建动画: 本文内容主要关注 纯java代码创建帧动画 的方式: 用xml创建帧动画:http:// ...



