1.1 Docker Compose
1、什么是docker compose
1. Compose是一個定義和管理多容器的工具,使用Python語言編寫。
2. 使用Compose配置文件描述多個容器應用的架構,比如使用什么鏡像、數據卷、網絡、映射端口等;
3. 然后一條命令管理所有服務,比如啟動、停止、重啟等。
2、docker compose作用
1. 現在我們要部署django項目,需要 django+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 配置常用字段
6、常用命令
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: '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:

[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

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;"]

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; } } }

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 phpinfo();?>
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: '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: # 創建一個網絡
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 公司研發的。
核心作用:快速迭代、服務自愈