【Docker】Docker Swarm集群+Portainer控制台配置安装

简介: Docker Swarm集群+Portainer控制台配置安装

Docker Swarm Docker 的集群管理工具。它将Docker 主机池转变为单个虚拟 Docker 主机。swarm 集群由管理节点(manager)和工作节点(work node)构成。

swarm mananger:负责整个集群的管理工作包括集群配置、服务管理等所有跟集群有关的工作。

work node:即图中的 available node,主要负责运行相应的服务来执行任务(task)。


开启Docker API

修改配置文件

vim /lib/systemd/system/docker.service
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock 
修改为 
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock

image.jpeg

重启服务

[root@master ~]# systemctl daemon-reload

[root@master ~]# systemctl restart docker

 

swarm集群创建

主节点开启

[root@master ~]# docker swarm init --advertise-addr 192.168.1.10

#创建好主节点时会提示—token配置参数,在配置子节点时需要使用该参数(如图)

image.jpeg

 

子节点开启

使用命令docker swarm join --token

[root@node ~]# docker swarm join --token SWMTKN-1-55cvdjet5qrnkayuaa70aozysu3ztjh1ic21y0x8gw9sb5fgcb-b2om9dp4scs452l4gkqmd0814 192.168.1.10:2377
This node joined a swarm as a worker.

 

可使用命令查询join使用的token

docker swarm join-token worker

image.jpeg

 

 

使用docker node ls查询节点状态

[root@master ~]# docker node ls
ID                            HOSTNAME            STATUS              AVAILABILITY        MANAGER STATUS      ENGINE VERSION
y8xp0iwjwkmfbxq4rc6qfekpc *   master              Ready               Active              Leader              18.09.6
cscxignpj1qb60c4y8dsgf7s7     node                Ready               Active                                  18.09.6

image.jpeg

 

swarm集群使用

部署服务

部署一个httpdservice,创建名称为web-server

[root@master ~]# docker service create --name web-server httpd
iwjwdip5t893m58tetpegh6wu
overall progress: 1 out of 1 tasks 
1/1: running  [==================================================>] 
verify: Service converged

 

查看服务状态

查看当前集群中的service

[root@master ~]# docker service ls
ID                  NAME                MODE                REPLICAS            IMAGE                        PORTS
iwjwdip5t893        web-server          replicated          1/1                 httpd:latest

         

 

查看部署的web-server状态

[root@master ~]# docker service ps web-server
ID                  NAME                IMAGE               NODE                DESIRED STATE       CURRENT STATE            ERROR               PORTS
ggrt8ldrjts3        web-server.1        httpd:latest        node                Running             Running 45 seconds ago      
#此时web-server的NODE为node节点,状态为running

 

 

服务伸缩/拓展副本

将服务数增加副本,同时运行多个实例

service scale可调整副本数,增加或减少

 

[root@master ~]# docker service scale web-server=5
web-server scaled to 5
overall progress: 5 out of 5 tasks 
1/5: running  [==================================================>] 
2/5: running  [==================================================>] 
3/5: running  [==================================================>] 
4/5: running  [==================================================>] 
5/5: running  [==================================================>] 
verify: Service converged


 

#此时查看服务状态就有5web-server部署在node节点或master节点

[root@master ~]# docker service ps web-server
ID                  NAME                IMAGE               NODE                DESIRED STATE       CURRENT STATE             
ggrt8ldrjts3        web-server.1        httpd:latest        node                Running             Running 6 minutes ago                            
ue2rls32fdyi        web-server.2        httpd:latest        master              Running             Running 41 seconds ago                           
n5e626vifmv8        web-server.3        httpd:latest        node                Running             Running about a minute ago                       
iq7y8ru24oy5        web-server.4        httpd:latest        master              Running             Running 41 seconds ago                           
tp56mrrszkel        web-server.5        httpd:latest        node                Running             Running about a minute ago

 

服务访问

web-server80端口映射到外部

[root@master ~]# docker service update --publish-add 80:80 web-server
web-server
overall progress: 5 out of 5 tasks 
1/5: running  [==================================================>] 
2/5: running  [==================================================>] 
3/5: running  [==================================================>] 
4/5: running  [==================================================>] 
5/5: running  [==================================================>] 
verify: Service converged

 

测试

image.png

 

 

 

 

 

 

Portainer安装

Portainer Docker 的图形化管理工具,提供状态显示面板、应用模板快速部署、容器镜像网络数据卷的基本操作(包括上传和下载镜像、创建容器等操作)、事件日志显示、容器控制台操作、Swarm 集群和服务等集中管理和操作、登录用户管理和控制等功能。功能 十分全面,基本能满足中小型企业对容器管理的全部需求。

 

Master 节点,安装 Portainer

[root@master ~]# docker service create --name portainer --publish 9000:9000 --replicas=1 --constraint 'node.role == manager' --mount type=bind,src=//var/run/docker.sock,dst=/var/run/docker.sock --mount type=volume,src=portainer_data,dst=/data portainer/portainer -H unix:///var/run/docker.sock 
wbpvqhg13fzrqrwl7epcbhqgo
overall progress: 1 out of 1 tasks 
1/1: running  [==================================================>] 
verify: Service converged

 

portainer以一个容器服务开启,可在容器进程中查询

[root@master ~]# docker ps

image.jpeg

 

 

网页访问http://ip:9000

首次登陆设置用户密码

image.jpeg

登陆后控制台首页

image.jpeg

相关文章
|
8天前
|
应用服务中间件 nginx Docker
Docker Swarm、Docker Stack和Portainer的使用
Docker Swarm、Docker Stack 和 Portainer 各有其独特的功能和优势。Docker Swarm 适用于分布式服务的管理和编排,Docker Stack 便于多容器应用的定义和部署,而 Portainer 提供了直观的 UI,简化了 Docker 环境的管理。结合使用这些工具,可以大大提高容器化应用的部署和管理效率。希望本文对您理解和应用这些工具有所帮助。
18 5
|
24天前
|
负载均衡 应用服务中间件 网络安全
docker swarm添加更多的服务
【10月更文挑战第16天】
19 6
|
24天前
|
Docker 容器
docker swarm启动服务并连接到网络
【10月更文挑战第16天】
21 5
|
9天前
|
API Docker 容器
【赵渝强老师】构建Docker Swarm集群
本文介绍了如何使用三台虚拟主机构建Docker Swarm集群。首先在master节点上初始化集群,然后通过特定命令将node1和node2作为worker节点加入集群。最后,在master节点上查看集群的节点信息,确认集群构建成功。文中还提供了相关图片和视频教程,帮助读者更好地理解和操作。
|
9天前
|
调度 Docker 容器
【赵渝强老师】Docker Swarm集群的体系架构
Docker Swarm自1.12.0版本起集成至Docker引擎,无需单独安装。它内置服务发现功能,支持跨多服务器或宿主机创建容器,形成集群提供服务。相比之下,Docker Compose仅限于单个宿主机。Docker Swarm采用主从架构,Swarm Manager负责管理和调度集群中的容器资源,用户通过其接口发送指令,Swarm Node根据指令创建容器运行应用。
|
22天前
|
负载均衡 安全 调度
深入调查研究Docker Swarm
【10月更文挑战第19天】
28 0
|
6月前
|
Ubuntu 网络安全 数据安全/隐私保护
百度搜索:蓝易云【docker通过dockerfile安装sftp教程。】
现在,你已经通过 Dockerfile 成功安装了 SFTP,并且可以使用指定的用户名和公钥进行远程访问。请确保替换示例中的用户名、密码和公钥为自己的实际值。
174 1
|
消息中间件 Shell RocketMQ
百度搜索:蓝易云 ,常用环境部署—Docker安装RocketMQ教程!
通过按照上述步骤,您可以在Docker中成功安装和部署RocketMQ。请注意,上述命令仅提供了一个基本的安装和配置过程,具体配置和使用可以根据您的需求进行进一步调整。确保在执行命令之前,您已经安装并配置好Docker环境。
181 0
|
1月前
|
数据可视化 数据挖掘 Docker
Docker Desktop 安装 ClickHouse 超级简单教程
Docker Desktop 安装 ClickHouse 超级简单教程
46 1
|
3月前
|
Linux 测试技术 Docker
Docker CE for CentOS 安装教程
Docker CE for CentOS 安装教程
133 1