Docker compose 介绍 YAML命令,及部署LNMP网站平台 & docker-compose、docker swarm和k8s的区别

目录:

  1. Docker compose介绍,YAML命令
  2. LNMP项目部署-配置文件介绍
  3. docker-compose、docker swarm和k8s的区别


什么是 Docker compose

  1. Compose 是一个定义和管理多容器的工具,使用Python语言编写
  2. 使用Compose配置文件描述多个容器应用的架构,比如使用什么镜像,数据卷,网络罗,映射端口等。
  3. 然后一条命令管理所有服务,比如启动、停止、重启 这些。

Docker compose作用

  1. 部署 Django 项目,需要 nginx + mysql + redis + nginx 等。

  2. 这时候就需要开启四个 docker容器,对每一个组件进行部署。每个容器单独管理的话就很复杂,万一用的服务多了起来,一个一个的跑 那得啥时候,还要靠考虑先后顺序。

  3. docker componse 就是一个可以同时管理一个项目中的 多个docker容器工具,一键部署 启动。

大白话:通过Docker compose-YAML语法 写好的文件,各个文件之间车水马龙相同,然后跑docker compose的命令 就一切ok了


安装 Docker compose

安装docker-compose之前,必须要先安装docker1.3或以上版本

  • 下载 并安装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
    

docker-compose使用yaml文件对容器进行描述

YAML文件格式及编写注意事项

YAML 是一种标记语言很直观的数据序列化格式,可读性高。蕾西与 XML 数据描述语言,语法比 XML 简单很多。
YAML 数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分割,数组用中括号括起来,hash用花括号括起来

YAML文件格式注意事项:

  1. 不支持制表符tab键缩进,需要使用空格缩进
  2. 通常开头缩进2个空格
  3. 字符后缩进1个空格,如冒号、逗号、横杆
  4. 用# 注释
  5. 如果包含特殊字符用单引号引起来
  6. 布尔值(true,false,yes,no,on,off)必须用引号括起来,这样分析器会将他们解释为字符串。
compose 配置常用字段
字段 描述
build
dockerfile
context
制定 Dockerfile 文件名,构建镜像上下文路径
image 指定镜像
command 执行命令,覆盖默认命令
container_name 指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法 False
deploy 指定部署和运行服务相关配置,只能在Swarm模式使用
environment 添加环境变量
networks 加入网络,引用顶级networks下条目
ports 暴露端口,与-p相同,但端口不能低于60
volumes 挂载宿主机路径或命名卷。如果是命名卷在顶级volumes定义卷名称
restart 重启策略,默认no,always
hostname 容器主机名
常用命令
字段 描述
build 重新构建服务
ps 列出容器
up 创建和启动容器
exec 在容器里执行命令
scale 指定一个服务容器启动数量
top 显示容器进程
logs 查看容器输出
down 删除容器、网络、数据卷和镜像
stop / start / restart/ 停止 / 开始 / 重启服务


使用Docker compose 一键部署LNMP网站平台

部署也没什么好说的,就是文件结构。真正在公司用的时候,一般都是要自己写,为了考虑量级问题 就把写好的放在了 gitee上。

这个只是简略的看一下,docker compose 详细的操作步骤在 下一篇文章。

扫描二维码关注公众号,回复: 10079550 查看本文章

参考官方: https://docs.docker.com/compose/compose-file/

项目地址: https://gitee.com/edushiyanlou/compose_lnmp.git

.
├── 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

# 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

# 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

# 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

# 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

# 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

# wwwroot/index.php

<?php phpinfo();?>

一键部署命令

docker-compose -f docker-compose.yml  up

docker-compose -f docker-compose.yml  up -d       # -d参数让程序运行在后台

docker-compose down         # 关闭所有容器

部署成功 即可在浏览器访问
http:// 你的ip

注:如果想要使用其他页面直接将 wwwroot中的index.php问价进行替换即可

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-compose、docker swarm和k8s的区别

  • Docker-Compose
  1. Docker-Compose 是用来管理你的容器的,想象一下当你的Docker中有成百上千的容器需要启动,如果一个一个的启动那得多费时间。

  2. 有了Docker-Compose你只需要编写一个文件,在这个文件里面声明好要启动的容器,配置一些参数

  3. 执行一下这个文件,Docker就会按照你声明的配置去把所有的容器启动起来,只需docker-compose up即可启动所有的容器

  4. 但是Docker-Compose只能管理当前主机上的Docker,也就是说不能去启动其他主机上的Docker容器

  • Docker Swarm
  1. Docker Swarm 是一款用来管理多主机上的Docker容器的工具,可以负责帮你启动容器,监控容器状态

  2. 如果容器的状态不正常它会帮你重新帮你启动一个新的容器,来提供服务,同时也提供服务之间的负载均衡

  • Kubernetes
  1. Kubernetes它本身的角色定位是和Docker Swarm 是一样的,都是一个跨主机的容器管理平台

  2. k8s是谷歌公司根据自身的多年的运维经验研发的一款容器管理平台,而Docker Swarm则是由Docker 公司研发的。

核心作用:快速迭代、服务自愈

参考原址:不做大哥好多年 及 51CTO学院:阿良 Dcker

发布了91 篇原创文章 · 获赞 174 · 访问量 7万+

猜你喜欢

转载自blog.csdn.net/weixin_44685869/article/details/104686368