02: docker高级篇
1.1 Docker Compose
1、什么是docker compose
1. Compose是一个定义和管理多容器的工具,使用Python语言编写。
2. 使用Compose配置文件描述多个容器应用的架构,比如使用什么镜像、数据卷、网络、映射端口等;
3. 然后一条命令管理所有服务,比如启动、停止、重启等。
2、docker compose作用
1. 现在我们要部署django项目,需要 nginx+mysql+redis+nginx等
2. 我们需要开启四个docker容器进行部署每一个组件,如果每个容器单独管理太过于复杂,而且可能是给客户部署项目
3. docker compose就是一个可以同时管理一个项目中的多个docker容器的工具,一键部署启动
3、安装docker compose
1、法1:下载 并安装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
或者
pip install docker-compose
2、法2:直接解压安装
unzip docker-compose-linux-x86_64.zip # 解压后只有一个文件 docker-compose
chmod +x docker-compose
mv docker-compose /usr/bin/
4、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)必须用引号括起来,这样分析器会将他们解释为字符串。
5、compose 配置常用字段

[root@linux-node1 mysql-docker]# vim docker-compose.yml
version: ''
services:
mysql:
image: mysql:5.7
volumes:
- ./data:/var/lib/mysql
ports:
- "3306:3306"
environment:
- MYSQL_ROOT_PASSWORD=root
- MYSQL_DATABASE=djangodb
[root@linux-node1 mysql-docker]# docker-compose -f docker-compose.yml up
docker-compose.yml 部署mysql简单测试
version: '' # docker-compose版本号 services: # 一级服务名称
mysql: # 服务名,可以通过服务名对容器进行管理(自己定义)
#1.docker容器主机名
hostname: mysql #2.指定拉取镜像或者使用Dockerfile构建
image: mysql:5.7 # 指定拉取的镜像版本(方法1)
build: # 构建nginx 容器(方法2)
context: ./nginx # 指定环境在当前目录的 nginx文件夹中
dockerfile: Dockerfile # 指定使用nginx文件夹中的Dockerfile进行构建 #3.执行命令
command: python manage.py migrate && python manage.py runserver 0.0.0.0:80
command: uwsgi --ini uwsgi.ini # 启动uwsgi #4.指定容器挂载路径进行持久化
volumes: # 将mysql的 /var/lib/mysql数据路径挂载到本地进行持久化
- ./mysql:/var/lib/mysql #5. 暴露端口 或者 映射端口
expose: # 开放的端口号,给docker容器之间通信访问
- "3306"
ports:
- "80:80" # 把端口映射给宿主机,提供服务 #6.指定使用的网络
networks:
- lnmp
#7.当宿主机重启docker容器也自动重启
restart: always
#8. 添加环境变量
environment:
- MYSQL_ROOT_PASSWORD=root # root密码
- MYSQL_DATABASE=djangodocker # 创建数据库
- MYSQL_USER=django # 创建一个普通用户
- MYSQL_PASSWORD=django # 普通用户密码
#9. 添加依赖,必须先启动redis容器
depends_on:
- redis
networks: # 创建网络
lnmp:
6、常用命令

'''1.docker-compose常用命令'''
docker-compose -f docker-compose.yml up -d # 启动docker-compose管理的所有容器
docker-compose ps # 列出 Compose 应用中的各个容器,类似docker ps
docker-compose logs web # 查看web服务日志
docker-compose down # 停止并移除容器、网络、镜像和数据卷.比stop更彻底
docker-compose images # 列出所有镜像 '''2.docker-compose其他命令 '''
docker-compose stop # 停止 Compose 应用相关的所有容器,但不会删除它们
docker-compose restart # 重启YAML文件中定义的服务
docker-compose kill # 停止服务
docker-compose rm # 删除指定已经停止服务的容器(它会删除容器和网络,但是不会删除卷和镜像)
docker-compose build # 构建或重建服务
docker-compose pull # 拉去并下载指定服务镜像
docker-compose push # push服务镜像
docker-compose top # 显示各个容器内运行的进程
docker-compose常用管理命令
1.2 使用Docker Compose 一键部署LNMP网站平台
参考官方: 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 # 网站根目录
version: ''
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.yml
[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
mysql/conf/my.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;"]
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;"]
[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;
}
}
}
nginx/nginx.conf
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"]
php/Dockerfile
<?php phpinfo();?>
wwwroot/index.php
3、执行一键部署命令
docker-compose -f docker-compose.yml up
docker-compose -f docker-compose.yml up -d # -d参数让程序运行在后台
4、说明
http://192.168.0.211:81/ # 运行上面命令即可在页面打开php页面
注:如果想要使用其他页面直接将 wwwroot中的index.php问价进行替换即可
5、对docker-compose.yml说明
1. 这里定义了部署LNMP环境的三个容器,Nginx、php、mysql
2. 其中nginx和php使用我们自己定义的dockerfile从头构建,mysql直接使用官方仓库进行构建
version: '' # 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: # 创建一个网络
1.3 docker、docker-compose、docker swarm和k8s的区别
1、Docker-Compose
1. Docker-Compose 是用来管理你的容器的,想象一下当你的Docker中有成百上千的容器需要启动,如果一个一个的启动那得多费时间。
2. 有了Docker-Compose你只需要编写一个文件,在这个文件里面声明好要启动的容器,配置一些参数
3. 执行一下这个文件,Docker就会按照你声明的配置去把所有的容器启动起来,只需docker-compose up即可启动所有的容器
3. 但是Docker-Compose只能管理当前主机上的Docker,也就是说不能去启动其他主机上的Docker容器
2、Docker Swarm
1. Docker Swarm 是一款用来管理多主机上的Docker容器的工具,可以负责帮你启动容器,监控容器状态
2. 如果容器的状态不正常它会帮你重新帮你启动一个新的容器,来提供服务,同时也提供服务之间的负载均衡
3、Kubernetes
1. Kubernetes它本身的角色定位是和Docker Swarm 是一样的,都是一个跨主机的容器管理平台
2. k8s是谷歌公司根据自身的多年的运维经验研发的一款容器管理平台,而Docker Swarm则是由Docker 公司研发的。
核心作用:快速迭代、服务自愈
02: docker高级篇的更多相关文章
- Devops 开发运维高级篇之Jenkins+Docker+SpringCloud微服务持续集成(上)
Devops 开发运维高级篇之Jenkins+Docker+SpringCloud微服务持续集成(上) Jenkins+Docker+SpringCloud持续集成流程说明 大致流程说明: 1) 开发 ...
- Devops 开发运维高级篇之Jenkins+Docker+SpringCloud微服务持续集成——部署方案优化
Devops 开发运维高级篇之Jenkins+Docker+SpringCloud微服务持续集成--部署方案优化 之前我们做的方案部署都是只能选择一个微服务部署并只有一台生产服务器,每个微服务只有一个 ...
- Android 之窗口小部件高级篇--App Widget 之 RemoteViews
Android 之窗口小部件高级篇--App Widget 之 RemoteViews 在之前的一篇博文(Android 之窗口小部件详解--App Widget)中,已经介绍了App Widget的 ...
- 谷粒商城--分布式高级篇P102~P128
谷粒商城--分布式高级篇P102~P128 由于学习的时间也比较少,只有周六周末才有时间出来学习总结,所以一篇一篇慢慢更新吧,本次总结内容为Elasticsearch(相关内容:kibana,es,n ...
- 3 - 基于ELK的ElasticSearch 7.8.x技术整理 - 高级篇( 偏理论 )
4.ES高级篇 4.1.集群部署 集群的意思:就是将多个节点归为一体罢了( 这个整体就有一个指定的名字了 ) 4.1.1.window中部署集群 - 了解即可 把下载好的window版的ES中的dat ...
- Devops 开发运维高级篇之容器管理
Devops 开发运维高级篇之容器管理 安装docker Dockerfile镜像脚本入门制作 Harbor镜像仓库安装及使用 不过多解释docker直接秀基操 安装docker:(jenkins服务 ...
- C#高级知识点&(ABP框架理论学习高级篇)——白金版
前言摘要 很早以前就有要写ABP高级系列教程的计划了,但是迟迟到现在这个高级理论系列才和大家见面.其实这篇博客很早就着手写了,只是楼主一直写写停停.看看下图,就知道这篇博客的生产日期了,谁知它的出厂日 ...
- 【.net深呼吸】动态类型(高级篇)
前面老周给大家介绍了动态类型使用的娱乐级别用法,其实,在很多情景下,娱乐级别的用法已经满足需求了. 如果,你想自己来控制动态类型的行为和数据的存取,那么,就可以考虑用今天所说的高大上技术了.比如,你希 ...
- 【转载】Spark性能优化指南——高级篇
前言 数据倾斜调优 调优概述 数据倾斜发生时的现象 数据倾斜发生的原理 如何定位导致数据倾斜的代码 查看导致数据倾斜的key的数据分布情况 数据倾斜的解决方案 解决方案一:使用Hive ETL预处理数 ...
随机推荐
- cocos2d-x c++ (多种屏幕Android与iOS的适配原理)
1.AppDelegate.cpp 文件中 bool AppDelegate::applicationDidFinishLaunching() { // initialize director aut ...
- Python实现selenium回放时间设置
一般在做selenium时会有,回放快慢的需求. 实现思路: 1.一般写selenium会自定义findelement函数,来实现查找元素. 2.在查找函数上加个睡眠时间的装饰器,函数执行完等待若干秒 ...
- 用int还是用Integer?
昨天例行code review时大家有讨论到int和Integer的比较和使用. 这里做个整理,发表一下个人的看法. [int和Integer的区别] int是java提供的8种原始类型之一,ja ...
- C# 深拷贝和浅拷贝
在编码中.经常会遇到赋值操作.值类型就不说了.如果是引用类型赋值.其实是引用传递,即赋值的是一个引用.比如: Person p1 = new Person("张三", " ...
- 移动端的rem适配
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- C# Control.Invoke匿名委托
if (txbValue.InvokeRequired) txbValue.Invoke(new MethodInvoker(delegate() { ...
- org.joda.time.DateTime 日期格式
最近一直在使用Java,偶尔一次遇到日期(util)的格式转换,心里还是规矩的写着记忆里面的代码,但是在自己测试的时候发现不正确,具体看了下代码,发现这里使用jota的方式编写,顺道查了一下,做了笔记 ...
- 水题C
某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,……,L,都种有一棵树. ...
- 准备mybatis-spring
spring-mybatis下载:https://mvnrepository.com/artifact/org.mybatis/mybatis-spring 导入mybatis-spring-2.0. ...
- Runtime(IV) - 序列化与反序列化
准备条件 父类 Biology Biology.h #import <Foundation/Foundation.h> @interface Biology : NSObject { NS ...