Docker Compose

Docker Compose是一个用于管理多容器应用的工具,通过YAML配置文件docker-compose.yml定义服务间的关系。它使得启动和关闭一组关联的容器变得简单。在示例中,展示了如何配置一个包含微服务、Redis和MySQL的项目,通过容器间的依赖关系和端口映射,实现服务间的通信。Docker-Compose解决了在多个容器环境中管理复杂性的挑战。

https://docs.docker.com/compose/install/
https://docs.docker.com/compose/compose-file/compose-file-v3/
[写于2022年11月下旬,使用的新版本]
Compose 是 Docker 公司推出的一个工具软件,可以管理多个 Docker 容器组成一个应用。你需要定义一个 YAML 格式的配置文件docker-compose.yml,写好多个容器之间的调用关系。然后,只要一个命令,就能同时启动/关闭这些容器。

Docker-Compose是Docker官方的开源项目, 负责实现对Docker容器集群的快速编排。

docker建议我们每一个容器中只运行一个服务,因为docker容器本身占用资源极少,所以最好是将每个服务单独的分割开来但是这样我们又面临了一个问题?

如果我需要同时部署好多个服务,难道要每个服务单独写Dockerfile然后在构建镜像,构建容器,这样累都累死了,所以docker官方给我们提供了docker-compose多服务部署的工具

例如要实现一个Web微服务项目,除了Web服务容器本身,往往还需要再加上后端的数据库mysql服务容器,redis服务器,注册中心eureka,甚至还包括负载均衡容器等等。。。。。。

Compose允许用户通过一个单独的docker-compose.yml模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。

可以很容易地用一个配置文件定义一个多容器的应用,然后使用一条指令安装这个应用的所有依赖,完成构建。Docker-Compose 解决了容器与容器之间如何管理编排的问题。

docker-compose.yml

version: "3"

services:
  microService:
    image: java_docker:1.1
    container_name: ms01
    ports:
      - "8899:8899"
    volumes:
      - /app/microService:/data
    networks:
      - my_net
    depends_on:
      - redis
      - mysql
  redis: #微服务中的redis地址无需是ip,用redis
    image: redis:6.0.8
    ports:
      - "6399:6379" #微服务中的ip是服务名称的话,端口要用此容器内的6379,不可用前面的,切记
    volumes:
      - /home/yourfriend/redis/redis.conf:/etc/redis/redis.conf
      - /home/yourfriend/redis/data:/data
    networks:
      - my_net
    command: redis-server /etc/redis/redis.conf
  mysql: #微服务中的  mysql地址无需是ip,用 mysql
    image: mysql
    environment:
      MYSQL_ROOT_PASSWORD: 'root'
      MYSQL_ALLOW_EMPTY_PASSWORD: 'no'
      MYSQL_DATABASE: 'db2022'
      MYSQL_USER: 'aaa'
      MYSQL_PASSWORD: 'root'
    ports:
      - "3399:3306" #微服务中的ip是服务名称的话,端口要用此容器内的3306,不可用前面的,切记
    volumes:
      - /app/mysql/db:/var/lib/mysql
      - /app/mysql/conf/my.cnf:/etc/my.cnf
      - /app/mysql/init:/docker-entrypoint-initdb.d
    networks:
      - my_net
    command: --default-authentication-plugin=mysql_native_password #解决外部无法访问

networks:
  my_net:

微服务中的配置文件

server.port=8899
# ========================alibaba.druid=====================
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#spring.datasource.url=jdbc:mysql://192.168.75.131:3399/db2022?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&useSSL=false
spring.datasource.url=jdbc:mysql://mysql:3306/db2022?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&useSSL=false
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.druid.test-while-idle=false
# ========================redis=====================
spring.redis.database=0
spring.redis.host=redis
spring.redis.port=6379
#spring.redis.host=192.168.75.131
#spring.redis.port=6399
spring.redis.password=123
spring.redis.lettuce.pool.max-active=8
spring.redis.lettuce.pool.max-wait=-1ms
spring.redis.lettuce.pool.max-idle=8
spring.redis.lettuce.pool.min-idle=0
# ========================mybatis===================
mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.type-aliases-package=com.demo.docker.entities
# ========================swagger=====================
spring.swagger2.enabled=true
# 基础镜像使用java
FROM java:8
# 作者
MAINTAINER yourfriend
# VOLUME 指定临时文件目录为/tmp,在主机/var/lib/docker目录下创建了一个临时文件并链接到容器的/tmp
VOLUME /tmp
# 将jar包添加到容器中并更名为java_docker.jar
ADD docker_boot-0.0.1-SNAPSHOT.jar java_docker.jar
# 运行jar包
RUN bash -c 'touch /java_docker.jar'
ENTRYPOINT ["java","-jar","/java_docker.jar"]
#暴露8899端口作为微服务
EXPOSE 8899
docker build -t java_docker:1.1 .
docker compose up
Docker Compose 是一种 Docker 编排工具,合理使用它能为 Docker 镜像的编排和管理带来诸多好处,提升 Docker 的运维效率[^2]。 ### 概述 Docker Compose 用于定义和运行多容器 Docker 应用程序。通过一个 YAML 文件(通常为 `docker-compose.yml`)来配置应用的服务,然后使用一条命令就能根据配置启动或停止所有服务[^1]。 ### 运转过程 虽然引用中未详细提及运转过程,但大致是读取 `docker-compose.yml` 文件中的配置信息,根据这些信息构建或拉取镜像,然后创建并启动容器,使多个容器协同工作。 ### `docker-compose.yml` 简单示例 引用未给出具体示例,但在实际使用中,一个简单的 `docker-compose.yml` 可能如下: ```yaml version: "3.9" services: web: image: nginx:latest ports: - "80:80" redis: image: redis:latest ``` ### 兼容性建议 如果使用的是 Docker Compose V2(大多数用户),可以省略 `version`;若需要保持兼容性(如部署在服务器上),建议使用 `version: "3.9"` [^3]。 ### 常用命令速查表 | 命令 | 功能说明 | 示例 | | --- | --- | --- | | `docker compose up` | 构建并启动所有服务 | `docker compose up` | | `docker compose up -d` | 后台运行(detach 模式),推荐用于开发 | `docker compose up -d` | | `docker compose down` | 停止并删除所有容器、网络、匿名卷 | `docker compose down` | | `docker compose stop` | 停止服务,但不删除容器 | `docker compose stop` | | `docker compose start` | 启动已停止的服务容器 | `docker compose start` | | `docker compose restart` | 重启所有服务 | `docker compose restart` | | `docker compose build` | 手动构建服务镜像 | `docker compose build` | | `docker compose pull` | 拉取最新镜像 | `docker compose pull` | | `docker compose push` | 推送镜像到远程仓库 | `docker compose push` | | `docker compose ps` | 查看服务容器状态 | `docker compose ps` | | `docker compose logs` | 查看日志 | `docker compose logs redis` | | `docker compose logs -f` | 实时追踪日志 | `docker compose logs -f app` | | `docker compose exec` | 在容器中执行命令(支持交互) | `docker compose exec redis redis-cli` | | `docker compose run` | 启动一个一次性容器运行命令 | `docker compose run app npm install` | | `docker compose config` | 查看合并后的配置(调试用) | `docker compose config` | | `docker compose top` | 查看容器的进程信息 | `docker compose top` | [^3] ### 安装方法 由于可能需要进行离线部署,可进行下载安装,以下是官网流程: 1. 下载并安装 Compose CLI 插件: ```bash DOCKER_CONFIG=${DOCKER_CONFIG:-$HOME/.docker} mkdir -p $DOCKER_CONFIG/cli-plugins curl -SL https://github.com/docker/compose/releases/download/v2.20.3/docker-compose-linux-x86_64 -o $DOCKER_CONFIG/cli-plugins/docker-compose ``` 2. 为二进制文件添加可执行权限: ```bash chmod +x $DOCKER_CONFIG/cli-plugins/docker-compose # install Compose for all users: sudo chmod +x /usr/local/lib/docker/cli-plugins/docker-compose ``` 3. 测试安装: ```bash docker compose version ``` [^4]
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值