栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

docker-compose常用模板

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

docker-compose常用模板

文章目录
  • 前言
  • 一、docker-compose一些模板
      • 多个服务
      • 单个服务
  • 二、一些可能会碰到的问题
      • docker-compose拉取不下来
      • docker-compose -v报找不到
      • docker镜像拉取太慢
      • network以路径为前缀
  • 三. 一些可能存在的需求
      • 加入一个存在的网络, 同时创建一个新的网络
      • 将已经运行的容器, 新增到一个新的网络中
      • 将当前镜像备份
  • 四.查看network
      • docker network inspect docker_mysql, 查看网络里面有哪些容器


前言
  1. docker-compose版本: 3
  2. 博客里面会放少量的模板, 具体的详细的在项目里面会有
  3. 一些可能会碰到的问题
  4. 一些可能存在的需求
  5. 查看network
  6. 项目地址: https://gitee.com/xmaxm/docker_mysql_redis

一、docker-compose一些模板 多个服务
# Compose 版本 Version 2支持更多的指令。Version 1将来会被弃用。
version: "3"

# 定义服务
services:

  # 为project定义服务
  redis:
    # 服务的镜像名称或镜像ID。如果镜像在本地不存在,Compose将会尝试拉取镜像
    image: redis:4.0
    # 配置端口 - "宿主机端口:容器暴露端口"
    ports:
      - 6379:6379
    # 配置容器连接的网络,引用顶级 networks 下的条目(就是最下面配置的networks(一级目录))
    networks:
      network_name:
       # 为单redis创建别名, REDIS_URL标记为redis服务的地址. (不配置aliases也可以, 这样就通过定义的服务名: redis链接)
       aliases:
         - REDIS_URL
    # 挂载
    volumes:
      - "/docker/redis/conf/redis.conf:/etc/redis/redis.conf"
      - "/docker/redis/data:/data"
    # 容器总是重新启动
    restart: always
    # 相当于执行一些命令
    command:
      redis-server /etc/redis/redis.conf --appendonly yes
    # 指定一个自定义容器名称,而不是生成的默认名称。
    container_name: redis
    # 使用该参数,container内的root拥有真正的root权限。
    privileged: true

  db:
    image: mysql:5.7
    ports:
      - 3306:3306
    # 添加环境变量
    environment:
      MYSQL_ROOT_PASSWORD: "123456"
    volumes:
      - "/docker/mysql/conf/my.cnf:/etc/mysql/conf.d/my.cnf"
      - "/docker/mysql/logs:/var/log/mysql"
      - "/docker/mysql/data:/var/lib/mysql"
      - "/docker/mysql/sql/init.sql:/docker-entrypoint-initdb.d/init.sql"
      - "/etc/localtime:/etc/localtime"
    networks:
      network_name:
        aliases:
         - MYSQL_URL
    restart: always
    command: --init-file /docker-entrypoint-initdb.d/init.sql
    container_name: mysql
    privileged: true
    
  project-name:
    # 服务的镜像名称或镜像ID。如果镜像在本地不存在,Compose将会尝试拉取镜像
    image: project-name:1.0.0
    # 构建镜像
    build:
      # 指定项目的地址
      context: /root/docker_mysql_redis
      # 指定Dockerfile
      dockerfile: Dockerfile
    ports:
      - 8080:8080
    # 从文件添加环境变量
    env_file:
      - /root/environment.env
    networks:
      network_name:
       aliases:
        - PROJECT_URL
    privileged: true
    restart: always
    container_name: test-name
    
  # ........可以继续添加


networks:
  # bridge:默认,需要单独配置ports映射主机port和服务的port,并且开启了容器间通信
  network_name:
    driver: bridge

单个服务
version: "3"

services:

  nacos:
    image: nacos/nacos-server:1.2.1
    ports:
      - 8848:8848
    # 加入已存在的网络 docker_network_mysql(docker-mysql.yaml), 并创建一个新的网络 network_nacos
    networks:
      network_nacos:
        aliases:
         - NACOS_URL
      # 通过docker network ls 进行获取
      docker_network_mysql:
    restart: always
    environment:
      MODE: standalone
    container_name: nacos
    privileged: true

networks:
  docker_network_mysql:
    external: true
  network_nacos:
    driver: bridge


二、一些可能会碰到的问题 docker-compose拉取不下来
    更换yum源:
    wget -O /etc/yum.repos.d/CentOS-base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
    hosts添加解析:
    52.216.16.16 github-production-release-asset-2e65be.s3.amazonaws.com
    重新安装
docker-compose -v报找不到
    sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
docker镜像拉取太慢
    更换镜像源
    建议配置阿里云的镜像地址: https://developer.aliyun.com/article/29941  
network以路径为前缀
    # -p Specify an alternate project name (default: directory name) 比如配置的network, 会以路径为前缀, 配置该值, 可以代替
    # -f Specify an alternate compose file (default: docker-compose.yml) 指定yaml文件
    # -d 后台运行
    docker-compose -p docker -f /root/docker-init.yaml up -d

三. 一些可能存在的需求 加入一个存在的网络, 同时创建一个新的网络
    # 加入已存在的网络 docker_network_mysql(docker-mysql.yaml), 并创建一个新的网络 network_nacos
services:
  nacos:
    # 加入已存在的网络 docker_network_mysql(docker-mysql.yaml), 并创建一个新的网络 network_nacos
    networks:
      network_nacos:
        aliases:
         - NACOS_URL
      # 通过docker network ls 进行获取
      docker_network_mysql:
networks:
  docker_network_mysql:
    external: true
  network_nacos:
    driver: bridge
    参考文件:individually/docker-nacos.yaml
    先执行docker-mysql.yaml, 然后执行docker-nacos.yaml
    docker exec -it nacos bash
    ping MYSQL_URL / ping db            
将已经运行的容器, 新增到一个新的网络中
     创建一个网络docker_mysql: docker network create docker_mysql
     将已运行的容器mysql加入该网络: docker network connect --alias MYSQL_URL docker_mysql mysql
     --alias MYSQL_URL可以通过别名通信. 也可以不要, 但是这样就只能通过容器的ID或者通信
     docker network connect 一个已存在网络 容器名/容器ID
将当前镜像备份
    docker tag docker.io/chaim2436/sentinel-dashboard:1.7.1 chaim2436/sentinel-dashboard:1.7.1
    docker rmi docker.io/chaim2436/sentinel-dashboard:1.7.1后chaim2436/sentinel-dashboard:1.7.1会依旧存在
    这里不能rmi id, 因为tag之后两个镜像的ID将会是一样的

四.查看network docker network inspect docker_mysql, 查看网络里面有哪些容器

这些容器之间都是可以相互通信的, 服务名或者别名都是可行的


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/581985.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号