Docker基础学习——使用Compose编排多容器应用
一、前言
Docker compose 是docker容器编排的工具,定义和运行多个容器的应用,可以一条命令启动多个容器。
使用Compose 基本上分为三步:
- Dockerfile 定义应用的运行环境
- docker-compose.yml 定义组成应用的各服务
- docker-compose up 启动整个应用
二、安装Compose
直接从github下载即可,前提要先安装Docker,版本要1.9.1以上
#curl -L https://github.com/docker/compose/releases/download/1.8.0/docker-compose-
uname -s
-uname -m
> /usr/local/bin/docker-compose
#chmod a+x /usr/local/bin/docker-compose
安装后确认
docker-composer --version #输出composer版本信息
三、使用Composer
创建一个ghost博客应用,使用nginx做web服务,mysql做数据存储
建立三个容器的目录 ghost、nginx、data 以及docker-composer.yml应用服务文件
[aaa@qq.com ghost]# ls
data docker-compose.yml ghost nginx
//编写ghost容器dockerfile镜像文件
[aaa@qq.com ghost]# ls
config.js Dockerfile
[aaa@qq.com ghost]# cat Dockerfile
FROM ghost #ghost做基础镜像
COPY config.js /var/lib/ghost/content/config.js #复制当前目录config.js文件到容器中
#CMD [“npm”,“start”,"–production"] //最新ghost版本可以省略该命令,改命令为启动node.js程序
EXPOSE 2368 #暴露2368端口
//config.js文件内容 (ghost应用时Node.js程序则添加该配置文件)
var path = require('path'),
config;
config = {
production: {
url:'http://mytestblog.com',
mail: {},
database: { //数据库配置
client:'mysql',
connection:{
host:'db', //mysql服务名称(后面容器编排服务mysql服务定义为db)
user:'ghost',
password:'ghost',
database:'ghost',
port:'3306',
charset:'utf8'
},
debug:false
},
paths:{
contentPath:path.join(process.env.GHOST_CONTENT,'/')
},
server:{
host:'0.0.0.0', //主机
port:'2368' //端口
}
}
};
module.exports = config;
//编写nginx容器dockerfile镜像文件
[aaa@qq.com nginx]# ls
Dockerfile nginx.conf
[aaa@qq.com nginx]# cat Dockerfile
FROM nginx #以nginx官方镜像作为基础镜像
COPY nginx.conf /etc/nginx/nginx.conf #复制本地nginx配置文件到容器中
EXPOSE 80 #监听80端口
//nginx.conf 文件内容
[aaa@qq.com nginx]# cat nginx.conf
worker_processes 4; #开启4个worker进程
events {worker_connections 1024;} #worker进程最大连接数1024
http {
server {
listen 80;
location / {
proxy_pass http://ghost-app:2368; #这里直接将访问指向到ghost应用
}
}
}
version: '2' //compose文件格式版本 docker版本1.10.0+
networks: //指定应用网络ghost
ghost:
services: //设置应用服务
ghost-app:
build: ghost //ghost-app容器通过本地ghost目录下Dockerfile生成
networks:
- ghost //属于ghost网络
depends_on:
- db //依赖db容器
ports:
- "2368:2368" //将容器的2368端口映射到本地的2368端口
nginx:
build: nginx //nginx容器通过本地nginx目录下Dockerfile生成
networks:
- ghost
depends_on:
- ghost-app //依赖ghost-app容器
ports:
- "80:80" //将容器的80端口映射到本地的80端口
db:
image: "mysql:5.7.15" //使用mysql官方镜像做基础镜像
networks:
- ghost
environment: //设置mysql环境变量
MYSQL_ROOT_PASSWORD: mysqlroot
MYSQL_USER: ghost
MYSQL_PASSWORD: ghost
volumes: //设置数据卷
- $PWD/data:/var/lib/mysql //将当前目录下data目录作为容器mysql目录文件共享
ports:
- "3306:3306" //将容器的3306端口映射到本地的3306端口
启动应用
执行编排脚本,分别制作和抓取mysql镜像,启动容器
#docker-composer up (-d守护进程方式启动)
查看信息
查看容器服务进程
访问应用
composer命令总结
docker-composer up #启动应用
docker-composer build #重新生成镜像(在修改文件后需重新生成)
docker-composer stop #停止所有容器服务
docker-composer rm #删除所有容器
docker-composer ps #查看服务信息
推荐阅读
-
使用Docker compose编排Laravel应用的方法
-
Docker系列之使用Docker Compose编排容器
-
应用容器引擎之 docker 学习 (九) 多容器管理工具Docker-compose实现 haproxy+nginx的负载均衡
-
Docker基础学习——使用Compose编排多容器应用
-
使用Docker Compose和Swarm的多容器应用程序
-
docker学习-基础篇6-docker容器数据卷-使用dockerfile
-
使用Docker compose编排Laravel应用的方法
-
使用Docker compose编排Laravel应用
-
使用Docker compose编排Laravel应用
-
docker3-compose多容器应用