一、DockerCompose介绍
1.What(什么是DockerCompose)?
1.它是一个管理多容器的docker工具,用Python编写
2.它可以在配置文件描述多个容器的应用架构(将各个容器整理组合并应用,比如这个项目中使用什么镜像,数据卷,网络,映射端口等等)
3.配置好dockercompose后可以一键(一条命令)执行或管理服务(启动,停止,重启等等)
2.Why&Where(为什么要用DockerCompose,用在哪里去)?
现在的项目中我们部署时需要同时开启的服务很多(例如:部署Django项目中需要同时部署
nginx+mysql+redis+nginx等等)此时我们就需要开启四个容器对每一个组件进行部署,
如果项目比较复杂,每个容器单独管理太过于复杂而且如果此时给客户部署项目的话……
不用我说了吧,这破活儿得干多久?
所以此时dockercompose就派上了用场,它可以同时管理一个项目中得多个容器,一键部署项目。你只需要在公司里提前配置好,到了客户那里一条命令启动就好
3.How(如何使用DockerCompose)?
3.1.安装DockerCompose
下载 并安装docker 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
3.2.YAML文件格式及编写注意事项
== 注:docker-compose使用yaml文件对容器进行描述 ==
YAML是一种标记语言很直观的数据序列化格式,可读性高。类似于XML数据描述语言,语法比XML简单的很多。
YAML数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号括起来,hash用花括号括起来。
YAML文件格式注意事项:
1.不支持制表符tab键缩进,需要使用空格缩进
2.通常开头缩进2个空格
3.字符后缩进1个空格,如冒号、逗号、横杆
4.用井号注释
5.如果包含特殊字符用单引号引起来
6.布尔值(true、false、yes、no、on、off)必须用引号括起来,这样分析器会将他们解释为字符串。
3.3.compose 配置常用字段
3.4.常用命令
二、项目示例
参考官方: https://docs.docker.com/compose/compose-file/
项目地址: https://gitee.com/edushiyanlou/compose_lnmp.git
1、一键部署LNMP文件结构
.
├── docker-compose.yml # compose 的yml文件用于描述要构建的容器
├── mysql
│ ├── conf
│ │ └── my.cnf # my.cnf : mysql主配置文件
│ └── data # data 数据目录,当构建的时候会将mysql数据持久化到宿主机上
├── nginx
│ ├── Dockerfile # 构建nginx容器的 Dockerfile 文件
│ ├── nginx-1.12.1.tar.gz
│ └── nginx.conf # nginx的主配置文件
├── php
│ ├── Dockerfile # 构建php容器的 Dockerfile 文件
│ ├── php-5.6.31.tar.gz
│ └── php.ini
└── wwwroot
└── index.php # 网站根目录
#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:
mysql/conf/my.conf中:
[mysqld]
user=mysql
port=3306
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
pid-file=/var/run/mysql/mysql.pid
log_error=/var/log/mysql/error.log
character_set_server = utf8
max_connections=3600
nginx/Dockerfile中:
FROM centos:7
MAINTAINER www.aliangedu.com
RUN yum install -y gcc gcc-c++ make openssl-devel pcre-devel
ADD nginx-1.12.1.tar.gz /tmp
RUN cd /tmp/nginx-1.12.1 && \
./configure --prefix=/usr/local/nginx && \
make -j 2 && \
make install
RUN rm -rf /tmp/nginx-1.12.1* && yum clean all
COPY nginx.conf /usr/local/nginx/conf
WORKDIR /usr/local/nginx
EXPOSE 80
CMD ["./sbin/nginx", "-g", "daemon off;"]
nginx/nginx.conf中:
FROM centos:7
MAINTAINER www.aliangedu.com
RUN yum install -y gcc gcc-c++ make openssl-devel pcre-devel
ADD nginx-1.12.1.tar.gz /tmp
RUN cd /tmp/nginx-1.12.1 && \
./configure --prefix=/usr/local/nginx && \
make -j 2 && \
make install
RUN rm -rf /tmp/nginx-1.12.1* && yum clean all
COPY nginx.conf /usr/local/nginx/conf
WORKDIR /usr/local/nginx
EXPOSE 80
CMD ["./sbin/nginx", "-g", "daemon off;"]
[root@linux-node2 compose_lnmp]# cat nginx/nginx.conf
user root;
worker_processes auto;
error_log logs/error.log info;
pid logs/nginx.pid;
events {
use epoll;
}
http {
include mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log logs/access.log main;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name localhost;
root html;
index index.html index.php;
location ~ \.php$ {
root html;
fastcgi_pass php:9000;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
}
php/Dockerfile中:
FROM centos:7
MAINTAINER www.aliangedu.com
RUN yum install -y gcc gcc-c++ make gd-devel libxml2-devel libcurl-devel libjpeg-devel libpng-devel openssl-devel
ADD php-5.6.31.tar.gz /tmp/
RUN cd /tmp/php-5.6.31 && \
./configure --prefix=/usr/local/php \
--with-config-file-path=/usr/local/php/etc \
--with-mysql --with-mysqli \
--with-openssl --with-zlib --with-curl --with-gd \
--with-jpeg-dir --with-png-dir --with-iconv \
--enable-fpm --enable-zip --enable-mbstring && \
make -j 4 && \
make install && \
cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf && \
sed -i "s/127.0.0.1/0.0.0.0/" /usr/local/php/etc/php-fpm.conf && \
sed -i "21a \daemonize = no" /usr/local/php/etc/php-fpm.conf
COPY php.ini /usr/local/php/etc
RUN rm -rf /tmp/php-5.6.31* && yum clean all
WORKDIR /usr/local/php
EXPOSE 9000
CMD ["./sbin/php-fpm", "-c", "/usr/local/php/etc/php-fpm.conf"]
wwwroot/index.php中:
<?php phpinfo();?>
2.执行一键部署命令
docker-compose -f docker-compose.yml up
docker-compose -f docker-compose.yml up -d # -d参数让程序运行在后台
3.说明
http://192.168.0.211:81/ # 运行上面命令即可在页面打开php页面
注:如果想要使用其他页面直接将 wwwroot中的index.php问价进行替换即可
4.对docker-compose.yml文件的说明
1. 这里定义了部署LNMP环境的三个容器,Nginx、php、mysql
2. 其中nginx和php使用我们自己定义的dockerfile从头构建,mysql直接使用官方仓库进行构建
version: '3' # cocker compose版本号
services: # 顶级配置文件
nginx: # 服务名,可以通过服务名对容器进行管理
hostname: nginx # docker容器主机名
build: # 构建nginx 容器
context: ./nginx # 指定环境在当前目录的 nginx文件夹中
dockerfile: Dockerfile # 指定使用nginx文件夹中的Dockerfile进行构建
ports: # 暴露端口
- 81:80 # 将宿主机的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 # 直接引用mysql官方镜像仓库
ports:
- 3306:3306
networks:
- lnmp
volumes:
- ./mysql/conf:/etc/mysql/conf.d
- ./mysql/data:/var/lib/mysql
command: --character-set-server=utf8 # 接收mysql的命令,比如这里设置mysql的字符集
environment:
MYSQL_ROOT_PASSWORD: 123456
MYSQL_DATABASE: wordpress
MYSQL_USER: user
MYSQL_PASSWORD: user123
networks:
lnmp: # 创建一个网络
docker、docker-compose、docker swarm和k8s的区别
1、Docker-Compose
1. Docker-Compose 是用来管理你的容器的,想象一下当你的Docker中有成百上千的容器需要启动,如果一个一个的启动那得多费时间。
2. 有了Docker-Compose你只需要编写一个文件,在这个文件里面声明好要启动的容器,配置一些参数
3. 执行一下这个文件,Docker就会按照你声明的配置去把所有的容器启动起来,只需docker-compose up即可启动所有的容器
4. 但是Docker-Compose只能管理当前主机上的Docker,也就是说不能去启动其他主机上的Docker容器
2、Docker Swarm
1. Docker Swarm 是一款用来管理多主机上的Docker容器的工具,可以负责帮你启动容器,监控容器状态
2. 如果容器的状态不正常它会帮你重新帮你启动一个新的容器,来提供服务,同时也提供服务之间的负载均衡
3、Kubernetes
1. Kubernetes它本身的角色定位是和Docker Swarm 是一样的,都是一个跨主机的容器管理平台
2. k8s是谷歌公司根据自身的多年的运维经验研发的一款容器管理平台,而Docker Swarm则是由Docker 公司研发的。