docker Compose 介绍
用途:管理多个容器的交互、可以在一个yml 文件中配置多个容器,使用一个命令
就可以启动和停止配置中的一组容器
。
Compose 中连个重要的概念介绍: - 服务(service):就是一个运行时容器 (可以比较docker-compose.yml 学习) - 项目(project):多个服务构成一个完整业务,即项目。
docker Compose 的安装
- 前提:docker 环境已经安装好了
安装
#下载
sudo curl -L https://github.com/docker/compose/releases/download/1.20.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
#安装
chmod +x /usr/local/bin/docker-compose
#查看版本
docker-compose version
docker-compose version 1.8.0, build f3628c7
补全工具安装(命令行)
#安装
yum install bash-completion
#下载docker-compose脚本
curl -L https://raw.githubusercontent.com/docker/compose/$(docker-compose version --short)/contrib/completion/bash/docker-compose > /etc/bash_completion.d/docker-compose
常用命令
#查看帮助
docker-compose -h
# -f 指定使用的 Compose 模板文件,默认为 docker-compose.yml,可以多次指定。
docker-compose -f docker-compose.yml up -d
#启动所有容器,-d 将会在后台启动并运行所有的容器
docker-compose up -d
#停用移除所有容器以及网络相关
docker-compose down
#查看服务容器的输出
docker-compose logs
#列出项目中目前的所有容器
docker-compose ps
#构建(重新构建)项目中的服务容器。服务容器一旦构建后,将会带上一个标记名,例如对于 web 项目中的一个 db 容器,可能是 web_db。可以随时在项目目录下运行 docker-compose build 来重新构建服务
docker-compose build
#拉取服务依赖的镜像
docker-compose pull
#重启项目中的服务
docker-compose restart
#删除所有(停止状态的)服务容器。推荐先执行 docker-compose stop 命令来停止容器。
docker-compose rm
#在指定服务上执行一个命令。
docker-compose run ubuntu ping docker.com
#设置指定服务运行的容器个数。通过 service=num 的参数来设置数量
docker-compose scale web=3 db=2
#启动已经存在的服务容器。
docker-compose start
#停止已经处于运行状态的容器,但不删除它。通过 docker-compose start 可以再次启动这些容器。
docker-compose stop
实例演示
-
编排服务(容器)介绍: service1: mysql service2: nginx service3: springboot项目
-
功能:记录当前IP 访问次数,记录到mysql数据库,显示到网页主界面。
mysql 服务提供数据支持
,nginx负责转发请求
文件目录结构如下:
dockercompose-springboot-mysql-nginx
|-app
|-src
|-Dockerfile
|-pom.xml
|-nginx
|-conf.d
|-app.conf
docker-compose.yaml
docker-compose.yaml
文件详解
version: '3'
services:
nginx:
container_name: v-nginx
image: nginx:1.13
restart: always
ports:
- 80:80
- 443:443
volumes:
- ./nginx/conf.d:/etc/nginx/conf.d
mysql:
container_name: v-mysql
image: mysql/mysql-server:5.7
environment:
MYSQL_DATABASE: test
MYSQL_ROOT_PASSWORD: root
MYSQL_ROOT_HOST: '%'
ports:
- "3306:3306"
restart: always
app:
restart: always
build: ./app
working_dir: /app
volumes:
- ./app:/app
- ~/.m2:/root/.m2
expose:
- "8080"
depends_on:
- nginx
- mysql
command: mvn clean spring-boot:run -Dspring-boot.run.profiles=docker
version: '3'
: 表示使用第三代语法来构建 docker-compose.yaml 文件。services
: 用来表示 compose 需要启动的服务,我们可以看出此文件中有三个服务分别为:nginx、mysql、app。container_name
: 容器名称environment
: 此节点下的信息会当作环境变量传入容器,此示例中 mysql 服务配置了数据库、密码和权限信息。ports
: 表示对外开放的端口restart
: always 表示如果服务启动不成功会一直尝试。volumes
: 加载本地目录下的配置文件到容器目标地址下depends_on
:可以配置依赖服务,表示需要先启动 depends_on 下面的服务后,再启动本服务。command: mvn clean spring-boot:run -Dspring-boot.run.profiles=docker:
表示以这个命令来启动项目,-Dspring-boot.run.profiles=docker表示使用 application-docker.properties文件配置信息进行启动。
Nginx 文件解读
nginx 在目录下面有一个app.conf ,主要配置了服务转发信息
server {
listen 80;
charset utf-8;
access_log off;
location / {
proxy_pass http://app:8080;
proxy_set_header Host $host:$server_port;
proxy_set_header X-Forwarded-Host $server_name;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
location /static {
access_log off;
expires 30d;
alias /app/static;
}
}
这个配置信息表示:监听宿主机80 端口,将80端口的网络请求转发到app的8080端口。proxy_pass http://app:8080
使用app 而不适用 localhost,因为是不同容器,so 应该使用services 名称进行访问。
配置文件docker-compose化
app 根目录下新建Dockerfile ,app的启动依赖于Maven 和 jdk1.8 。 配置文件内容如下:
FROM maven:3.5-jdk-8
app 的资源文件resources 下新建 docker 配置文件,application-docker.properties 信息基本和application-dev.properties 一致,改造部分: jdbc:mysql://localhost:3306/test
改为jdbc:mysql://mysql:3306/test
部署
将项目copy 到 Linux 服务器(docker 和docker-compose 环境已经安装成功)
运行:
# 进入项目根目录
cd dockercompose-springboot-mysql-nginx
# 启动服务
docker-compose up
查看效果:
访问:http://host/, 返回:I have been seen ip 172.19.0.2 1 times.
表示整体服务启动成功