docker 常用容器启动 docker-compose.yml 配置文件详解

        在平常的开发工作中,我们经常需要部署项目。项目开发完成后,部署测试环境、部署生产环境等。以前部署项目,在服务器上安装项目所需的软件,如 nginx、redis 等。可能在测试环境测试没有问题,由于环境配置等不同,部署到生产环境又会产生莫名奇怪的问题。随着 docker 容器的出现,我们可以用 Dockerfile 构建镜像,构建完成后运行,这样可以保证每个地方使用的镜像一致,然后启动使用 docker-compose.yml 文件,保证容器的配置一致。今天总结下常用软件启动的 docker-compose.yml 文件。

      一:概述

        定义和运行多容器 Docker 应用的工具,可以在里面定义多个服务信息,定义每个服务的服务名、端口映射、环境变量、网络模式等。这样可以方便的管理启动命令,方便拓展。可以一次启动多个容器。常用于部署测试环境等。这样可以保证每个环境映射的端口、依赖的镜像等信息一致,减少因环境问题导致的差异。通过 docker-compose.yml 文件,可以确保开发、测试和生产环境的一致性,避免“因部署不同机器存在差异”的问题。

     二:docker-compose.yml 示例

        1:后端服务

services:
  ruoyi-admin:
    image: ruoyi-admin:v1.0
    container_name : ruoyi-admin
    ports:
      - "9016:9016"
    environment:
      - SERVER_PORT=9016
      - TZ=Asia/Shanghai
    restart: always
    networks:
      - my_network
 
networks:
 my_network:
   external: true

        2:mysql

services:
  mysql:
    image: mysql:8.0.33
    restart: always
    container_name: mysql
    environment:
      MYSQL_ROOT_PASSWORD: your_password
      TZ: Asia/Shanghai
      
    ports:
      - "3306:3306"
      
    volumes:
      - /docker/mysql/log:/var/log/mysql
      - /docker/mysql/data:/var/lib/mysql 
      - /docker/mysql/conf:/etc/mysql/conf.d
      
    command:
      --max_connections=1000
      --default-authentication-plugin=mysql_native_password
      --character-set-server=utf8mb4
      --collation-server=utf8mb4_general_ci
	  
	privileged: true
    network_mode: "host"

        3:nginx

services:
  nginx:
    image: nginx:latest
    container_name: nginx-web
    environment:
      TZ: Asia/Shanghai
    ports:
      - "80:80"
      - "443:443"
    volumes:
      # 配置文件映射
      - /docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
      - /docker/nginx/conf:/etc/nginx/conf
      # 页面目录
      - /docker/nginx/html:/usr/share/nginx/html
 
    privileged: true
    network_mode: "host"

        4:redis

services:
  redis:
    image: redis:6.2.6
    container_name: redis6.2.6
    ## 设置持久化,允许远程访问,密码等
    command: redis-server --appendonly yes --bind 0.0.0.0 --requirepass your_password
    ports:
      - 6379:6379
    volumes:
      # - ./data/:/data
      - /docker/redis/conf/redis.conf:/etc/redis/redis.conf 
      - /docker/redis/data:/data
    environment:
      - TZ=Asia/Shanghai
    restart: always
 
    # 获取宿主机 root 权限
    privileged: true
    # # 设置容器网络为本机网络
    network_mode: "host"

        5:nacos

nacos:
    image: nacos/nacos-server:v2.0.3
    container_name: nacos
    restart: always
    ports:
      # web 界面访问端口
      - 8848:8848
    environment:
      - MODE=standalone
      # 连接 mysql 数据库,主要是为了配置的持久化
      - SPRING_DATASOURCE_PLATFORM=mysql # 定义使用的数据库是 mysql
      - MYSQL_SERVICE_HOST=mysql
      - MYSQL_SERVICE_PORT=3306
      - MYSQL_SERVICE_DB_NAME=nacos_dev
      - MYSQL_SERVICE_USER=root
      - MYSQL_SERVICE_PASSWORD=root
    volumes:
      - /docker/nacos/logs:/home/nacos/logs

        6:rabbitmq

rabbitmq:
    # 带有管理界面的 rabbitmq 镜像
    image: rabbitmq:management  
    container_name: rabbitmq
    ports:
      # AMQP 协议端口
      - "5672:5672" 
      # rabbitmq 管理界面端口 
      - "15672:15672"  
    volumes:
      # 数据持久化目录
      - /usr/local/docker/rabbitmq/data:/var/lib/rabbitmq
       # 日志目录
      - /usr/local/docker/rabbitmq/logs:/var/log/rabbitmq 
    environment:
      # 设置用户名
      RABBITMQ_DEFAULT_USER: guest
      # 设置密码
      RABBITMQ_DEFAULT_PASS: 123456
    restart: always

     三:docker compose 常用命令

        (1):docker compose up -d:启动新的容器,会先拉取镜像等然后创建新的容器。带上 -d 是非阻塞的,不阻塞当前的命令窗口,不带 -d 是阻塞的,会阻塞当前的命令窗口。

        (2):docker compose down:停止所有运行中的容器

        (3):docker compose start:启动一个停止的容器

        (4):docker compose restart:重启容器

        (5):docker compose build:构建镜像

        (6):docker compose config:查看配置

        (7):docker compose logs:查看容器日志

        (8):docker compose exec service-name command:进入运行中的容器

     四:总结

        docker-compose.yml 可以更好的管理启动命令,这样可以保持测试环境、生产环境等端口,配置等一致性,防止项目部署因配置不同导致的问题。包括镜像来源、容器名称、端口映射、环境变量、数据卷挂载等。使用 docker run 启动,要输入很长的命令,而且容易出错。使用 docker-compose.yml 管理命令,启动方便快捷,也降低了配置出错的概率。

### Docker Compose YAML 文件概述 Docker Compose 是一种用于定义和运行多容器 Docker 应用程序的工具。通过 `docker-compose.yml` 文件,可以配置应用程序的服务、网络和卷等资源。 #### 用途 `docker-compose.yml` 文件的主要目的是简化复杂应用环境的一键启动过程。此文件允许用户在一个声明式的配置文件中描述多个服务及其依赖关系,从而实现一键构建、启动或停止整个分布式系统的功能[^1]。 #### 示例 下面是一个简单的 `docker-compose.yml` 文件示例: ```yaml version: '3' services: web: build: context: ./dir dockerfile: Dir/Dockerfile ports: - "5000:5000" volumes: - .:/code labels: com.example.description: "Information about the service" com.example.department: "Sales" ``` 在这个例子中: - **版本**: 定义使用的 compose 文件格式版本。 - **服务 (services)**: 描述了名为 `web` 的服务。 - **build**: 设置镜像构建参数,其中 `context` 表明相对路径为根目录下的子文件夹 `./dir`;而 `dockerfile` 则指定了自定义 Dockerfile 所在位置。 - **端口映射 (ports)**: 将主机上的 5000 端口绑定到容器内的相同端口号上。 - **挂载点 (volumes)**: 把当前工作目录挂载至容器内部 `/code` 路径下。 - **标签 (labels)**: 向容器添加元数据信息,类似于 Dockerfile 中的 LABEL 指令[^2]。 #### 配置说明 当设置上下文 (`context`) 和 Dockerfile 路径时,应确保这些路径相对于 `docker-compose.yml` 文件的位置是正确的。如果需要访问父级或其他上级目录,则可以通过调整路径来完成,例如使用 `../` 来表示上层目录。 对于更复杂的场景,还可以利用其他选项来自定义服务行为,比如健康检查、重启策略以及环境变量传递等功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值