centos7 下使用 Docker Compose

文章目录

介绍

Docker Compose 是一个用于定义和运行多容器 Docker 应用程序的工具。它允许你通过一个 YAML 文件来配置应用程序的服务、网络和卷,然后使用一条命令即可创建和启动所有服务。Docker Compose 使得管理复杂的应用程序变得简单,特别适合开发和测试环境。

特点

  • 声明式配置:使用 YAML 文件(通常命名为 docker-compose.yml)来声明应用程序的服务、网络和卷,使得配置更加清晰和易于管理。

  • 一键启动和停止:通过 docker-compose up 命令可以启动所有定义的服务,通过 docker-compose down 命令可以停止并移除所有服务。

  • 依赖管理:Docker Compose 支持服务之间的依赖关系,可以指定服务的启动顺序。

  • 环境变量和配置文件:可以使用 .env 文件来定义环境变量,还可以将配置文件挂载到容器中。

  • 网络管理:支持定义自定义网络,使得容器之间可以方便地进行通信。

  • 卷管理:支持定义数据卷,用于持久化数据和共享数据。

基本使用

1.编写 docker-compose.yml 文件

创建docker compose文件存放目录

复制代码
mkdir /home/docker-work 

创建docker-compose.yml 文件

复制代码
vi docker-compose.yml

编写文件

复制代码
# 名称
name: myblog
# 服务
services:
# 服务名称
  mysql:
  # 容器名称
    container_name: mysql
    # 使用镜像
    image: mysql:8.0
    # 端口映射
    ports:
      - "3306:3306"
      # 环境变量设置
    environment:
      - MYSQL_ROOT_PASSWORD=123456
      - MYSQL_DATABASE=wordpress
      # 数据挂载,注意如果是定义了数据卷,则必须在下面数据卷下声明
    volumes:
      - mysql-data:/var/lib/mysql
      - /app/myconf:/etc/mysql/conf.d
    # 设置开机自启
    restart: always
    # 使用网络
    networks:
      - blog

  wordpress:
    image: wordpress
    ports:
      - "8080:80"
    environment:
      WORDPRESS_DB_HOST: mysql
      WORDPRESS_DB_USER: root
      WORDPRESS_DB_PASSWORD: 123456
      WORDPRESS_DB_NAME: wordpress
    volumes:
      - wordpress:/var/www/html
    restart: always
    networks:
      - blog
    depends_on:
      - mysql
# 数据卷
volumes:
  mysql-data:
  wordpress:
# 网络
networks:
  blog:

更多详细配置请参考官网文档:https://docs.docker.com/reference/compose-file/

2.在文件夹下运行 docker-compose.yml 文件

docker compose -f [要运行的docker-compose文件名称] up -d

复制代码
docker compose -f docker-compose.yml up -d

3.验证

复制代码
docker ps

4.停止docker-compose

docker compose -f [运行的docker-compose文件名称] down

复制代码
docker  compose -f compose.yaml down

小结

Docker Compose 是 Docker 生态系统中的一个重要工具,它极大地简化了多容器应用程序的部署和管理。通过使用 Docker Compose,你可以更加高效地构建和运行复杂的应用程序。

相关推荐
小羊Linux客栈几秒前
自动化:批量文件重命名
运维·人工智能·python·自动化·游戏程序
伤不起bb1 小时前
MySQL 高可用
linux·运维·数据库·mysql·安全·高可用
意倾城3 小时前
Docker数据卷
docker·容器
whgjjim3 小时前
docker迅雷自定义端口号、登录用户名密码
运维·docker·容器
瀚高PG实验室6 小时前
连接指定数据库时提示not currently accepting connections
运维·数据库
QQ2740287566 小时前
Soundness Gitpod 部署教程
linux·运维·服务器·前端·chrome·web3
淡忘_cx6 小时前
【frp XTCP 穿透配置教程
运维
南方以南_7 小时前
Ubuntu操作合集
linux·运维·ubuntu
爱吃芝麻汤圆7 小时前
k8s之Kubebuilder 的设计哲学
云原生·容器·kubernetes
裁二尺秋风8 小时前
k8s(12) — 版本控制和滚动更新(金丝雀部署理念)
云原生·容器·kubernetes