赞
踩
# 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
更换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
重新安装
sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
更换镜像源
建议配置阿里云的镜像地址: https://developer.aliyun.com/article/29941
# -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将会是一样的
docker-compose -f /root/docker-init.yaml up -d db
这些容器之间都是可以相互通信的, 服务名或者别名都是可行的
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。