Docker的安装方法及运行Docker Swarm模式的使用

2020-06-17 07:09:04易采站长站整理

ExecStart=/usr/bin/dockerd $DOCKER_OPTS

在[Service]中增加配置文件路径的配置

EnvironmentFile=-/etc/sysconfig/docker

把配置文件加载路径指定到第一步创建的配置文件/etc/sysconfig/docker

重启docker守护进程

sudo systemctl stop docker
sudo systemctl start docker

检查配置是否生效

ps -ef|grep docker

如果配置生效,会在dockerd进程后边加上刚才配置的参数。

启动swarm模式

只需要在一个docker节点上初始化swarm集群, 其他节点加入这个集群就行了。

选择一台docker节点作为swarm模式的leader,运行

docker swarm init –advertise-addr 主机ip

按照提示信息在其他节点上执行命令加入swarm集群

在leader节点上执行docker node ls 查看节点信息

创建集群网络

在swarm集群中的任意一个节点上运行

docker network ls 查看当前网络状况

scope为local的网络只能作用于本机,下边创建swarm集群使用的网络。

运行 docker network create –driver overlay my-network

创建一个名为my-network的集群网络

再次运行 docker network ls,可以看到刚才创建的my-network ,scope为swarm,这个网络可以用于swarm模式,并让多个节点上的容器可以互通。

在swarm中创建service时可以通过 –network 网络名称 指定使用的网络。多个service如果使用同一个scope为swarm的network,可以通过service的名称互相通信。

docker swarm简单使用

下边简单介绍docker swarm的使用,有兴趣的可以查看docker官方文档进行深入了解。

下边的命令全部是在swarm的leader节点运行!!

docker service create –replicas 1 –name tomcat –publish 9090:8080 tomcat:latest

这里创建了一个名为tomcat 的service,swarm把容器封装为service,类似于kubernates中的pod,一个service是一个可供swarm调度的容器组合。

这里的–replicas 1指定了service的副本数。

–publish 9090:8080把容器中的8080端口发布到宿主机的9090端口

运行 docker service ls 查看当前的服务列表,可以看到有一个名为tomcat的服务。

运行 docker service ps tomcat 可以看到tomcat服务运行在哪个swarm节点,以及当前运行的状态。

切换到tomcat服务运行的节点,运行 docker ps 可以看到容器的ID,以及端口映射的情况。

运行 docker logs -f 容器ID 查看tomcat运行日志。

tomcat启动成功后,可以在浏览器中访问tomcat主页,地址是docker节点的ip(随便哪一个节点都可以),端口是9090,是在创建服务时指定的publish。

上边已经成功运行了一个tomcat服务,这里对这个服务进行扩展部署。

运行 docker service scale tomcat=2 把tomcat服务扩展为两个实例。

运行 docker service ls 可以看到tomcat服务的replicas变成了1/2,第二个实例启动成功之后会变为2/2。