首页 > 运维 > Docker > 什么是docker 容器编排

什么是docker 容器编排

青灯夜游
发布: 2021-12-30 16:24:57
原创
4957 人浏览过

在docker中,通过执行一个YAML文件,将文件中所定义的多个容器依次启动,这就是容器编排;实现容器编排的工具是“docker-compose”。YAML文件会定义一系列的容器以及容器运行时的属性,Compose会根据这些配置来管理容器。

什么是docker 容器编排

本教程操作环境:linux5.9.8系统、docker-1.13.1版、Dell G3电脑。

Docker容器编排

什么是容器编排
  • 通过执行一个文件,将文件中所定义的多个容器依次启动,这就是容器编排
  • 这个文件就是yaml文件

用来实现容器编排的工具

  • docker-compose

    可以通过安装Docker Compose工具来实现基于YAML文件的容器编排,YAML文件会定义一系列的容器以及容器运行时的属性,Docker Compose会根据这些配置来管理容器。

安装docker-compose

  • docker-compose在epel源中
[root@worker1 ~]# yum install epel-release -y
[root@worker1 ~]# yum install docker-compose -y
登录后复制

docker-compose命令的使用

  • 格式:docker-compose [选项]

  • 选项

    • up:启动定义在yaml文件中的容器
    • down:关闭定义在yaml文件中的容器
    • -f x.yaml:指定docker-compose所要读取的yaml文件
    • -d:在后台执行操作
    • ps:查看基于docker-compose所启动的容器的状态
    • logs:查收启动容器过程中的日志信息,用于排除错误
案例:

编写docker-compose.yaml文件来启动两个容器:nginx,php

1)准备环境

  • 安装epel
  • 安装docker-compose
  • 重启docker
  • 重启防火墙
[root@master ~]# yum install docker -y
[root@master ~]# yum install epel-release -y
[root@master ~]# yum install docker-compose -y
[root@master ~]# systemctl restart docker
[root@master ~]# systemctl restart firewalld
登录后复制

2)创建yaml文件

# 编写yam文件,在文件实现自动启动nginx容器
[root@worker1 ~]# vim docker-compose.yaml
登录后复制
version: '2'
services:
  web:
    image: nginx:1.17.10
    ports:
      - 80:80
    volumes:
      - /opt/html:/web
      - /opt/conf/nginx.conf:/etc/nginx/nginx.conf
登录后复制
  • version:指定版本号,2
  • services:设置要启动服务,一个服务就是一个docker容器

2)nginx 启动容器

[root@worker1 ~]# docker-compose up -d
登录后复制

查看基于yaml文件启动的容器的状态

[root@master ~]# docker-compose ps
   Name            Command          State         Ports       
--------------------------------------------------------------
root_web_1   nginx -g daemon off;   Up      0.0.0.0:80->80/tcp
登录后复制
  • 状态主要是是state:如果是UP,表示正常

查看启动容器过程中的日志信息

[root@worker1 ~]# docker-compose logs
登录后复制

关闭基于yaml文件所启动的容器

[root@worker1 ~]# docker-compose down
登录后复制

3)在第二步的基础上编辑yaml文件,启动php服务

第一步:修改yaml文件

version: '2'services:
  web:
    image: nginx
    ports:
      - 80:80
    volumes:
      - /opt/html:/web
      - /opt/conf/nginx.conf:/etc/nginx/nginx.conf
    links:               # 指定php容器的名称
      - php
  php:                   # 此处需要和links中的值保持一致
    image: php:5.6-fpm
    container_name: php   # 此处需要和links中的值保持一致
    volumes:
      - /opt/php:/php
登录后复制

第二步:修改nginx的配置文件

[root@master ~]# vi /opt/conf/nginx.conf 
        location ~ \.php$ {
            root           /php;
            fastcgi_pass   php:9000;    # 指定php容器名称,docker会自动将名称转换成ip
            fastcgi_index  index.php;     
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            include        fastcgi_params;
        }
登录后复制

第三步:启动服务

[root@master ~]# docker-compose up -d
[root@master ~]# docker-compose ps
Name         Command                        State         Ports       
-----------------------------------------------------------------------
php          docker-php-entrypoint php-fpm   Up           9000/tcp          
root_web_1   nginx -g daemon off;            Up           0.0.0.0:80->80/tcp
登录后复制

容器编排应用题1

1 准备一台Centos7的服务器,检测网络正常

2 检查服务器docker运行是否正常,如没有请安装

3 请编写wordpress.yml模板文件,格式正确

4 请新建服务mysql和wordpress,wordpress的启动依赖于mysql服务

5 将/opt/wordpress/data目录挂载到到mysql容器的/var/lib/mysql目录下,做持久存储!

6 MySQL初始信息包括:root密码,创建的数据库,普通用户,普通用户的密码

7 wordpress数据库配置正确

8 wordpress做端口映射,将wordprss的80端口映射在宿主机的8000端口上

# 这个yaml文件要启动两个容器
version: '2'
services:
  # 第一个容器:wordpress容器
  wordpress:
    # 指定镜像名称
    image: wordpress
    # 将容器的80端口映射到宿主机的8000
    ports:
      - 8000:80
    # 设置将mysql容器的名称解析程序mysql容器的IP
    links:
      - mysql
    # 设置容器之间依赖关系,设置成必须先启动mysql容器才启动wordpress容器
    depends_on:
      - mysql
  # 第二个容器:MySQL容器
  mysql:
    # 指定镜像名名称是mysql
    image: mysql:5.6
    # 设置容器的名称的是mysql
    container_name: mysql
    # 设置逻辑卷挂载
    volumes: 
      - /opt/wordpress/data:/var/lib/mysql 
    # 设置mysql容器的环境变量
    environment:
      # 设置mysql容器中mysql的root密码为123
      MYSQL_ROOT_PASSWORD: 123
      # 为wordpress创建一个数据库,库名是wordpress
      MYSQL_DATABASE: wp   
      # 创建一个普通用户wp
      MYSQL_USER: wp
      # 为上面的普通用户设置密码是wp
      MYSQL_PASSWORD: wp
登录后复制

9 docker-compose成功启动各个容器,成功访问到wordpress页面

[root@master ~]# docker-compose up -d
[root@master ~]# docker ps
登录后复制
  • 浏览器访问:http://ip:8000

推荐学习:《docker视频教程

以上是什么是docker 容器编排的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板