Docker Compose与Docker Swarm的简介和区别

这篇具有很好参考价值的文章主要介绍了Docker Compose与Docker Swarm的简介和区别。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

背景

之前公司很多都是单体的spring boot服务,使用Docker的时候,只需要定义Dockerfile 文件,然后打成镜像把容器启动起来就ok了。但是现在的微服务架构应用系统一般包含若干个微服务,每个微服务一般都会部署多个实例,如果每个微服务都要手动启停,那么效率会非常低,维护量也很大。

使用 Docker Compose / Swarm可以轻松、高效的管理容器,它是一个用于定义和运行多容器 Docker 的应用程序工具

Compose 简介

Compose 是用于定义和运行多容器 Docker 应用程序的工具。通过 Compose,可以使用 YML 文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从 YML 文件配置中创建并启动所有服务。

Compose 使用的三个步骤:

使用 Dockerfile 定义应用程序的环境。
使用 docker-compose.yml 定义构成应用程序的服务,这样它们可以在隔离环境中一起运行。
最后,执行 docker-compose up 命令来启动并运行整个应用程序。

# yaml 配置实例
version: '3'
services:
  web:
    build: .
    ports:
   - "5000:5000"
    volumes:
   - .:/code
    - logvolume01:/var/log
    links:
   - redis
  redis:
    image: redis
volumes:
  logvolume01: {}

Swarm 简介

Swarm是Docker公司推出的用来管理docker集群的平台,Docker Engine 1.12及后续版本集成了SwarmKit编排服务,且swarm几乎全部用GO语言来完成的开发的,代码开源在https://github.com/docker/swarm, 它是将一群Docker宿主机变成一个单一的虚拟主机,Swarm使用标准的Docker API接口作为其前端的访问入口。

swarm基本结构图:
Docker Compose与Docker Swarm的简介和区别
在结构图可以看出 Docker Client使用Swarm对集群(Cluster)进行调度使用。

上图可以看出,Swarm是典型的master-slave结构,通过发现服务来选举manager。manager是中心管理节点,各个node上运行agent接受manager的统一管理,集群会自动通过Raft协议分布式选举出manager节点,无需额外的发现服务支持,避免了单点的瓶颈问题,同时也内置了DNS的负载均衡和对外部负载均衡机制的集成支持。

Compose 和 Swarm区别

Docker Swarm 和 Docker Compose 一样,都是 Docker 官方容器编排项目,但不同的是:

  • Docker Compose 是一个在单个服务器或主机上创建多个容器的工具
  • Docker Swarm 则可以在多个服务器或主机上创建容器集群服务

因此,对于微服务的部署,显然 Docker Swarm 会更加适合。


docker swarm简单使用及常用命令

背景:

有两台虚拟机,机器A的IP分为192.168.56.103,机器B的IP为192.168.57.103

初始化集群

首先我选择机器B为master节点,去初始化swarm集群

docker swarm init --advertise-addr 192.168.57.103

如果docker主机有多块网卡,必须使用 --advertise-addr 指定IP
执行 docker swarm init 命令的节点自动成为manager管理节点

节点加入

docker swarm join --token SWMTKN-1-0pps4hiaqttlw38w5jknj0byezfrdpwan3cq4v7wl7ow69bf02-5t1of59p2xh0bosnza0lhxn2z 192.168.57.103:2377

启动docker程序,nginx服务1.22版本

docker service create --replicas 2 -p 8081:80 --name nginx nginx:1.22

#删除服务
docker service rm nginx

查看服务

docker service ls

查看某个服务的详情

docker service ps nginx

服务伸缩

docker service scale nginx=3

docker service scale nginx=1

删除service服务

docker service rm nginx

创建密钥secret

#openssl rand -base64 20 | docker secret create mysql_password -
#openssl rand -base64 20 | docker secret create mysql_root_password -

echo -n "raypick" | base64 | docker secret create mysql_password -

echo -n "root" | base64 | docker secret create mysql_root_password -

查看secret

docker secret ls

docker inspect mysql_password

使用secret

docker network create -d overlay mysql_private

#如果没有在target中显示指定路径,secret默认通过tmpfs文件系统挂载到容器的/run/secrets目录下

docker service create \
	--name mysql \
	--replicas 1 \
	--network mysql_private \
	--secret source=mysql_root_password,target=mysql_root_password \
	--secret source=mysql_password,target=mysql_password \
	-e MYSQL_ROOT_PASSWORD_FILE="/run/secrets/mysql_root_password" \
	-e MYSQL_PASSWORD_FILE="/run/secrets/mysql_password" \
	-e MYSQL_USER="zx1" \
	-e MYSQL_DATABASE="wordpress" \
	mysql:5.7

这里最后创建的两个登录用户,密码都是base64之后的内容,而不是base64之前的原文

#创建config
新建redis.conf文件
首先确保redis.conf存在,命令最后的那个redis.conf是文件路径

这里我的文件中随便写了一点内容
Docker Compose与Docker Swarm的简介和区别
然后根据这个文件创建config

docker config create redis.conf ./redis.conf

通过命令查看

docker config inspect redis.conf

Docker Compose与Docker Swarm的简介和区别

可以发现在Spec下的Data存放着文件内容的base64后的内容,我们来解码看看
Docker Compose与Docker Swarm的简介和区别

创建redis服务

docker service create \
	--name redis \
	--config source=redis.conf,target=/etc/redis.conf \
	-p 6388:6380 \
	redis:latest \
	redis-server /etc/redis.conf


	# --config redis.conf \

如果没有在target中显示指定路径,默认的redis.conf会以tmpfs文件系统挂载到容器的 /config.conf


服务升级

先创建5.6的版本服务,再升级到5.7版本

docker service create --replicas 1 -p 3306:3306 -env MYSQL_ROOT_PASSWORD=123456 --name mysql mysql:5.6
docker service update --image mysql:5.7 mysql

当然上面的只是更改了镜像,可选的更改选项有很多,需要自己通过以下命令行手册查看文章来源地址https://www.toymoban.com/news/detail-419945.html

docker service update --help

服务(版本)回退

sudo docker service rollback mysql

到了这里,关于Docker Compose与Docker Swarm的简介和区别的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 深入探讨Docker生态系统,Docker Compose vs. Docker Swarm vs. Kubernetes:深入比较

    🎈个人主页:程序员 小侯 🎐CSDN新晋作者 🎉欢迎 👍点赞✍评论⭐收藏 ✨收录专栏:大数据系列 ✨文章内容:Docker生态系统 🤝希望作者的文章能对你有所帮助,有不足的地方请在评论区留言指正,大家一起学习交流!🤗 Docker已经成为现代容器化应用程序的事实标准,但

    2024年02月07日
    浏览(40)
  • docker swarm 常用命令简介以及使用案例

    Docker Swarm 是Docker官⽅的跨节点的容器编排⼯具。⽤户只需要在单⼀的管理节点上操作,即可管理集群下的所有节点和容器 解决的问题 解决docker server的集群化管理和部署 Swarm通过对Docker宿主机上添加的标签信息来将宿主机资源进⾏细粒度分区,通过分区来帮助⽤户将容器部署

    2024年02月02日
    浏览(60)
  • 【云原生 | 55】Docker三剑客之Docker Swarm简介和安装

    🍁 博主简介 :         🏅云计算领域优质创作者         🏅2022年CSDN新星计划python赛道第一名         🏅2022年CSDN原力计划优质作者         🏅阿里云ACE认证高级工程师         🏅阿里云开发者社区专家博主 💊 交流社区 :CSDN云计算交流社区欢迎您的

    2024年02月11日
    浏览(37)
  • [docker] Compose 简介

    Compose 是用于定义和运行多容器 Docker 应用程序的工具。通过 Compose 使用一个命令,就可以从 YML 文件配置中创建并 启动所有服务 。 Compose 使用的三个步骤: 使用 Dockerfile 定义应用程序的环境。 使用 docker-compose.yml 定义构成应用程序的服务,这样它们可以在隔离环境中一起运

    2024年01月15日
    浏览(31)
  • Docker Compose简介及使用

    1、Docker Compose简介 关于Docker Compose,官方文档(https://docs.docker.com/compose/)里有介绍: 百度翻译: Compose是定义和运行多容器Docker应用程序的工具。使用Compose,您可以使用YAML文件来配置应用程序的服务。然后,使用一个命令,从配置创建并启动所有服务。要了解有关Compose的

    2024年02月04日
    浏览(32)
  • docker-compose和docker compose的区别

    在docker实际使用中,经常会搭配Compose,用来定义和运行多个 Docker 容器。使用时会发现,有时候的指令是docker-compose,有时候是docker compose,下面给出解释。 docker官方文档:https://docs.docker.com/compose/install/linux/ 官方文档中其实已经给出了答案:Compose分为V1和V2版本,安装方式分

    2024年01月19日
    浏览(47)
  • Oracle 简介与 Docker Compose部署

    最近,我翻阅了在之前公司工作时的笔记,偶然发现了一些有关数据库的记录。当初,我们的项目一开始采用的是 Oracle 数据库,但随着项目需求的变化,我们不得不转向使用 SQL Server。值得一提的是,公司之前采用的是 Docker 技术,所有数据库的部署都是通过 Docker Compose 来完

    2024年02月06日
    浏览(48)
  • docker-compose简介以及常用命令

    什么是docker-compose compose 是用来定义和运行一个或多个容器(通常都是多个)运行和应用的工具。使用 compose 可以简化容器镜像的构建以及容器的运行。 安装docker-compose需要在Linux系统上运行以下命令: 1.使用curl命令下载docker-compose二进制文件: 2.为二进制文件添加可执行权限:

    2024年02月10日
    浏览(39)
  • Excalidraw 简介及 Docker Compose 部署指南

    家人们好,我们在工作生活中经常需要画些图,我们往期了已经出过draw-io私有化部署的文章了,今天我要向大家介绍一款名为 Excalidraw 的绘图工具,这款工具了我个人非常喜欢使用,是因为它可以修改成类似于手写体的字体,并且可以直接绘画,这篇文章我将分享如何使用

    2024年02月15日
    浏览(35)
  • docker与docker-compose的区别

    文章最后的引言 第一篇原创文章,若有瑕疵,请诸位大佬指正

    2024年02月11日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包