序言
在当今的软件开发中,容器化技术的使用已经很普遍了。而 Docker 作为其中最流行的容器化平台之一,为开发者提供了方便、快捷、一致的开发和部署环境。但是,当我们的应用开始变得更加复杂,涉及到多个容器时,手动管理这些容器之间的依赖关系和部署过程将会变得非常繁琐。这时候,Docker Compose 就能帮助我们解决这些问题。
一、什么是 Docker Compose
Docker Compose 是 Docker 官方推出的一个工具,用于定义和运行多容器 Docker 应用。通过使用 Docker Compose,开发者可以通过一个简单的 YAML
文件来定义多个容器之间的关系、配置信息、网络设置等,从而实现一键式的应用部署。
二、安装 Docker Compose
Docker Compose 需要额外安装,安装的方式有两种:
- 插件方式安装
- standalone 方式安装
2.1 插件安装 Docker Compose
-
执行以下命令安装 Docker Compose 插件
# Ubuntu 命令 sudo apt-get install docker-compose-plugin# CentOS 命令 yum install docker-compose-plugin
-
执行以下命令验证安装
docker compose version
安装结果:
2.2 standalone 方式安装
-
执行以下命令安装 Docker Compose 独立版本
# 以下命令 linux 通用 curl -SL https://github.com/docker/compose/releases/download/v2.27.0/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose# 添加执行权限 sudo chmod +x /usr/local/bin/docker-compose
-
执行以下命令验证安装
docker-compose --version
安装结果:
三、使用 Docker Compose
Docker Compose 的使用一般分为以下 3 步:
- 编写 Docker Compose 文件:创建一个名为
docker-compose.yml
的 YAML 格式文件,并在其中定义各个服务的配置信息,包括镜像、端口映射、环境变量、依赖关系等。 - 启动应用:在 Docker Compose 文件所在目录下,运行命令
docker-compose up
,Docker Compose 将会根据配置文件启动所有的容器。 - 停止应用:运行命令
docker-compose down
,Docker Compose 将会停止并移除所有的容器。
四、使用案例
场景假设:我们需要部署两个容器,分别是 Kibana 和 Elasticsearch。其中,Kibana 依赖 Elasticsearch(注:我们采用 standalone 方式部署的 Docker Compose)
-
编写
docker-compose.yml
文件# 指定 Docker Compose 文件的版本 version: '3.7'# 定义服务 services:# Elasticsearch 服务es:# 使用 Elasticsearch 镜像image: docker.elastic.co/elasticsearch/elasticsearch:7.15.1# 指定容器名称container_name: es# 设置环境变量environment:- ES_JAVA_OPTS=-Xms512m -Xmx512m- discovery.type=single-node# 挂载卷volumes:- es-data:/usr/share/elasticsearch/data- es-logs:/usr/share/elasticsearch/logs- es-plugins:/usr/share/elasticsearch/plugins# 授予特权权限privileged: true# 指定网络networks:- es-net# 端口映射ports:- "9200:9200"- "9300:9300"# Kibana 服务kibana:# 使用 Kibana 镜像image: docker.elastic.co/kibana/kibana:7.15.1# 指定容器名称container_name: kibana# 设置环境变量environment:- ELASTICSEARCH_HOSTS=http://es:9200# 指定网络networks:- es-net# 端口映射ports:- "5601:5601"# 依赖关系,确保 Elasticsearch 服务先于 Kibana 服务启动depends_on:- es# 定义网络 networks:# 定义名为 es-net 的网络,使用 bridge 驱动es-net:driver: bridge# 定义卷 volumes:# 定义名为 es-data 的卷es-data:# 定义名为 es-logs 的卷es-logs:# 定义名为 es-plugins 的卷es-plugins:
-
在
docker-compose.yml
文件所在目录执行命令启动应用# 根据 docker-compose.yml 文件启动服务, 前台启动 docker-compose up# 后台启动 docker-compose up -d
正常启动日志:
打开浏览器输入网址
localhost:5601
查看 Kibana 容器启动情况 -
停止应用
# 停止后台运行的应用 docker-compose down
五、FAQ
Docker Compose 如果以插件方式安装,那么执行命令是 docker compose [选项]
的格式,若是以 standalone 方式安装,那么执行命令的格式是 docker-compose [选项]
。
推荐阅读
- RabbitMQ(Docker 单机部署)
- 深入理解 Java 并发:AbstractQueuedSynchronizer 源码分析
- 深入了解 Arthas:Java 应用程序诊断利器
- 基于 AI 的数据库助手-Chat2DB
- EasyExcel 处理 Excel