# 下载docker-compose到/usr/local/bin$ sudo curl -L https://github.com/docker/compose/releases/download/1.25.5/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose# 将docker-compose文件状态改为可执行文件$ sudo chmod +x /usr/local/bin/docker-compose
$ curl -L https://raw.githubusercontent.com/docker/compose/1.25.5/contrib/completion/bash/docker-compose > /etc/bash_completion.d/docker-compose
$ sudo rm /usr/local/bin/docker-compose
$ docker-compose --versiondocker-compose version 1.25.5, build 4667896b#注意:如果没有显示版本试试docker-compose -v 或者 docker compose version
#进入你的项目[root@centos ~]# cd 项目的目录#创建docker-compose.yml模板文件[root@centos ~]# touch docker-compose.yml
version: "3.2"services:tomcat01: #服务名称container_name: tomcat01 # 相当于run 的 --nameimage: tomcat:8.0-jre8 #使用哪个镜像 相当于run imageports: #用来完成host与容器的端口映射关系 相当于run -p- "8080:8080"volumes: #完成宿主机与容器中目录数据卷共享 相当于run -v#- /root/apps:/usr/local/tomcat/webapps #使用自定义路径映射- tomcatwebapps01:/usr/local/tomcat/webappsnetworks: #代表当前服务使用哪个网络桥 相当于run --networ- hellotomcat02: #服务名称container_name: tomcat02image: tomcat:8.0-jre8 #使用哪个镜像ports: #用来完成host与容器的端口映射关系- "8081:8080"volumes: #完成宿主机与容器中目录数据卷共享#- /root/apps:/usr/local/tomcat/webapps #使用自定义路径映射(绝对路径)- tomcatwebapps02:/usr/local/tomcat/webapps #别名方式networks: #代表当前服务使用哪个网络桥- hellomysql:image: mysql:5.7.32container_name: mysqlports:- "3307:3306"volumes:- mysqldata:/var/lib/mysql- mysqlconf:/etc/mysqlenvironment:- MYSQL_ROOT_PASSWORD=rootnetworks:- helloredis:image: redis:5.0.10container_name: redisports:- "6379:6379"volumes:- redisdata:/datanetworks:- hellocommand: "redis-server --appendonly yes" #run 镜像之后用来覆盖容器内容默认命令volumes: #声明上面服务所使用的自动创建的卷名tomcatwebapps01: #声明指令的卷名 compose自动创建该卷名但是会在之前加入项目名external: #使用自定义卷名(默认为false不使用外部数据卷,因为docker compose会自动创建的数据卷,名称是以项目名开头的)true #true确定使用指定卷名 注意:一旦使用外部自定义卷名启动服务之前必须手动创建,必须存在该数据卷tomcatwebapps02:mysqldata:mysqlconf:redisdata:networks: #定义服务用到桥hello: #定义上面的服务用到的网桥名称 默认创建就是 bridgeexternal: #使用自定义网桥(默认为false不使用外部网桥, 因为docker compose会自动创建的网桥,名称是以项目名开头的)true #使用外部指定网桥 注意:网桥必须存在
#启动[root@centos ~]# docker-compose up //前台启动一组服务[root@centos ~]# docker-compose up -d //后台启动一组服务#注意:执行docker-compose up命令必须在 docker-compose.yml文件所在目录执行
version: "3"services:webapp:image: examples/webports:- "80:80"volumes:- "/data"
version: '3'services:webapp:build:context: ./dirdockerfile: Dockerfile-alternateargs:buildno: 1
command: echo "hello world"
container_name: docker-web-container
注意: 指定容器名称后,该服务将无法进行扩展(scale),因为 Docker 不允许多个容器具有相同的名称。
version: '3'services:web:build: .depends_on:- db- redisredis:image: redisdb:image: postgres
注意: web 服务不会等待 redis db 「完全启动」之后才启动。
env_file: .envenv_file:- ./common.env- ./apps/web.env- /opt/secrets.env
mysql:image: mysql:5.7.39ports:- "3306:3306"volumes:- /root/mysql:/var/lib/mysqlenv_file:- .env #在当前目录创建了一个文件名为.env,以点开头的原因是,这样不容易被发现,只有使用ll -a才能查看到networks:- xinke
# common.env: Set development environmentPROG_ENV=development
environment:RACK_ENV: developmentSESSION_SECRET:environment:- RACK_ENV=development- SESSION_SECRET
y|Y|yes|Yes|YES|n|N|no|No|NO|true|True|TRUE|false|False|FALSE|on|On|ON|off|Off|OFF
healthcheck:test: ["CMD", "curl", "-f", "http://localhost"]interval: 1m30stimeout: 10sretries: 3
image: ubuntuimage: orchardup/postgresqlimage: a4bc65fd
version: "3"services:some-service:networks:- some-network- other-networknetworks:some-network:other-network:
ports:- "3000"- "8000:8000"- "49100:22"- "127.0.0.1:8001:8001"
sysctls:net.core.somaxconn: 1024net.ipv4.tcp_syncookies: 0sysctls:- net.core.somaxconn=1024
ulimits:nproc: 65535nofile:soft: 20000hard: 40000
volumes:- /var/lib/mysql- cache/:/tmp/cache- ~/configs:/etc/configs/:ro
version: "3"services:my_src:image: mysql:8.0volumes:- mysql_data:/var/lib/mysqlvolumes:mysql_data:
具体使用参考
docker-compose [-f=...] [options] [COMMAND] [ARGS...]