docker compose用法
什么是compose
Compose是一个定义和管理多容器的工具,使用Python语言编写。使用Compose配置文件描述多个容器应用的架构,比如使用什么镜像、数据卷、网络、映射端口等;然后一条命令管理所有服务,比如启动、停止、重启等。
安装compose
curl -L https://github.com/docker/compose/releases/download/1.15.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
或者
pip install docker-compose
compose使用yaml文件格式
YAML是一种标记语言很直观的数据序列化格式,可读性高。类似于XML数据描述语言,语法比XML简单的很多。
YAML数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号括起来,hash用花括号括起来。
YAML文件格式注意事项:
- 不支持制表符tab键缩进,需要使用空格缩进
- 通常开头缩进2个空格
- 字符后缩进1个空格,如冒号、逗号、横杆
- 用井号注释
- 如果包含特殊字符用单引号引起来
- 布尔值(true、false、yes、no、on、off)必须用引号括起来,这样分析器会将他们解释为字符串。
compose配置文件常用字段
compose常用命令
一键部署LNMP网站平台
项目目录结构
docker-compose.yaml是主配置文件,mysql中有一个配置文件和一个空的数据目录。
nginx和php中包含配置文件、dockerfile和源码包。
wwwroot是网站的根目录。
docker-compose.yml
version: '3'
services:
nginx:
hostname: nginx
build:
context: ./nginx
dockerfile: Dockerfile
ports:
- 81:80
networks:
- lnmp
volumes:
- ./wwwroot:/usr/local/nginx/html
php:
hostname: php
build:
context: ./php
dockerfile: Dockerfile
networks:
- lnmp
volumes:
- ./wwwroot:/usr/local/nginx/html
mysql:
hostname: mysql
image: mysql:5.6
ports:
- 3306:3306
networks:
- lnmp
volumes:
- ./mysql/conf:/etc/mysql/conf.d
- ./mysql/data:/var/lib/mysql
command: --character-set-server=utf8
environment:
MYSQL_ROOT_PASSWORD: 123456
MYSQL_DATABASE: wordpress
MYSQL_USER: user
MYSQL_PASSWORD: user123
networks:
lnmp:
部署
docker-compose -f docker-compose.yml up
部署完成后通过浏览器访问81端口进行测试,可以看到php的测试页面。
后台运行
目前是在前台运行,退出终端后进程结束,可以增加-d
选项来在后台运行。
docker-compose -f docker-compose.yml up -d
然后查看容器运行情况:
docker-compose ps
这里注意在执行docker-compose时会读取yaml文件,所以一定要在yaml文件所在目录下执行命令或者指定文件路径,否则会报错。
安装wordpress测试
删除发布目录中的php测试页面,下载wordpress源码到网站根目录并解压。
通过浏览器直接访问81端口的wordpress,可以进入wordpress设置页面
设置的时候的数据库名、用户名和密码就是在yaml文件中设置的,数据库主机直接写容器的名字便会自动连接到容器中的服务。
之后设置一下用户名密码就可以完成并登录了:
一键部署nginx反向代理Tomcat集群
目录结构
平台架构
user –> nginx –> tomcat(可能有n个) –> mysql
docker-compose.yml
version: '3'
services:
nginx:
hostname: nginx
build:
context: ./nginx
dockerfile: Dockerfile
ports:
- 82:80
networks:
- lnmt
volumes:
- ./webapps:/opt/webapps
tomcat01:
hostname: tomcat01
build: ./tomcat
networks:
- lnmt
volumes:
- /usr/local/jdk1.8.0_45:/usr/local/jdk1.8.0_45
- ./webapps:/usr/local/apache-tomcat-8.0.46/webapps
tomcat02:
hostname: tomcat02
build: ./tomcat
networks:
- lnmt
volumes:
- /usr/local/jdk1.8.0_45:/usr/local/jdk1.8.0_45
- ./webapps:/usr/local/apache-tomcat-8.0.46/webapps
mysql:
hostname: mysql
image: mysql:5.6
ports:
- 3307:3306
networks:
- lnmt
volumes:
- ./mysql/conf:/etc/mysql/conf.d
- ./mysql/data:/var/lib/mysql
environment:
MYSQL_ROOT_PASSWORD: 123456
MYSQL_DATABASE: db
MYSQL_USER: user
MYSQL_PASSWORD: user123
networks:
lnmt:
在nginx的配置文件中,设定了一个负载均衡策略:
upstream www.example.com {
#ip_hash;
server tomcat01:8080;
server tomcat02:8080;
}
创建项目
首先下载jdk到当前目录下,以便容器引用
然后将jdk包放到/usr/local下
docker-compose -f docker-compose.yml up -d
访问测试
首先查看容器的状态:
然后通过浏览器访问82端口应该看见如下页面: