• docker 生产环境基础应用


    项目背景

    此项目是在已有项目基础上,开发的一套相对独立的系统。项目总体分为三部分,前端、中间应用服务、流媒体服务。前端技术选型为vue+elementui,中间应用服务为.net core webapi+mysql+redis,流媒体服务为第三方成熟应用。在项目开发完毕之后,起初部署方式为在虚机上统一部署,倒也方便直观。但是对个人而言,一直关注着docker,但是一直没有应用到生产环境,于是就借此机会更新下部署模式,采用docker。关于docker的简介就不必多说了,网上的介绍很多,但是想要详细了解,建议参考官方文档

    docker架构

    docker 包括三个基本概念,如下所示(采摘于菜鸟教程):
    之所以有此介绍,是因为了解这几个基本概念,在应用上会方便许多。

    1. 镜像(Image):
      • Docker 镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04 就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。
    2. 容器(Container):
      • 镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和实例一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
    3. 仓库(Repository):
      • 仓库可看着一个代码控制中心,用来保存镜像。

    基础架构图

    详细信息自行百度

    应用实战

    1. 安装docker

    博主所用主机为centos 7+,关于docker的部署,可参考官方文档

    1. 卸载旧版本
    sudo yum remove docker 
                    docker-client 
                    docker-client-latest             
                    docker-common 
                    docker-latest 
                    docker-latest-logrotate 
                    docker-logrotate 
                    docker-engine
    
    2. 安装yum-utils软件包、设置仓库
    sudo yum install -y yum-utils
    
    sudo yum-config-manager 
        --add-repo 
        https://download.docker.com/linux/centos/docker-ce.repo
    
    3. 安装DOCKER引擎

    sudo yum install docker-ce docker-ce-cli containerd.io

    4. 启动docker

    sudo systemctl start docker

    5.通过运行hello-world映像来验证是否正确安装了Docker Engine 。

    sudo docker run hello-world

    6.登陆docker

    执行命令 sudo docker login 输入账号、密码登陆成功即可。

    2. 创建仓库

    仓库就是存放镜像的地方,博主所用仓库为docker-hub。当然还有很多厂商提供,如果考虑企业化建设,也可以私有化搭建。 docker-hub官方地址
    就像git一样,自由创建私有仓库。

    3. 制作镜像

    本篇以前端项目为例,制作镜像发布到仓库。

    前端项目采用的vue,进入打包好的dist文件中,创建Dockerfile文件,编写内容如下:

    FROM nginx
    WORKDIR /app
    COPY . /dist
    

    from nginx 指的是 依赖于nginx, workdir /app 指的是设置工作目录 copy . /dist 指的是 将dist文件夹中的内容 copy到外部 dist文件夹

    完毕之后,在dist文件夹,即dockerfile文件所在文件夹,执行命令如下: docker build -t zy/bg:vmp-web . 创建镜像。改命令意思是,制作一个隶属于bg仓库下的镜像,并且为改镜像打标签为:vmp-web。 完毕之后,通过 docker images 查看已有镜像

    按照我个人习惯,一个仓库包含web、server等多个项目的镜像。通过tag进行区分。

    镜像制作完毕后,可通过push命令将 镜像推送到远程仓库,便于后续使用。docker push zy/bg:vmp-web 推送完毕后,便可以在docker-hub中看到。

    镜像制作完毕之后,便可以运行了。docker run --name vmp-web -p 80:80 -d zy/bg:vmp-web -p 是进行端口映射,因为每一个容器就是一个沙盒,可以理解为一个精简版的虚机,80(外):80(容器) 就是把容器80端口,映射到外部的80端口。-d 是保持后台运行。--name 设置容器名称。 至此,访问地址就可以看到部署在容器内的应用了。
    既然容器就是一台精简版的虚机,我们当然也可以进入他的文件系统。
    进入docker容器有如下四种方式

    • docker attach
    • SSH
    • nsenter
    • exec
      在这里前三种不是特别推荐使用,不方便且不适用于生产环境,推荐用exec的方式。exec命令相对简单,操作方便适用生产。该命令必须适用于正在运行的容器,参数如下表所示:
    参数 描述
    --detach , -d 分离模式:在后台运行命令
    --detach-keys 覆盖分离容器的键序列
    --env , -e 设置环境变量
    --interactive , -i 即使没有附加也保持STDIN 打开
    --privileged 赋予命令扩展权限
    --tty , -t 分配伪TTY
    --user , -u 用户名或UID
    --workdir , -w 容器内的工作目录

    以我们刚才创建的vmp-web容器为例,我们想要修改容器内nginx的配置信息,我们可以通过命令 docker exec -it vmp-web /bin/bash 进入容器,进入容器之后,就和平常操作linux几乎一致了。通过vim nginx.conf修改时,会提示命令无法找到,也是正常现象。因为该容器内只包含了程序运行的必须条件,并不包含vim。此时我们想要修改容器nginx.conf,可以通过从外部copy文件的形式,也可以通过vim 直接修改。通过vim修改的时候,先在容器内安装vim,通过命令apt-get install vim进行安装,但是会提示如下信息:

    Reading package lists... Done
    Building dependency tree       
    Reading state information... Done
    E: Unable to locate package vim
    

    并不是命令有误,输入apt-get update命令,这条命令的作用就是同步 /etc/apt/sources.list/etc/apt/sources.list.d 中列出的源的索引。更新完毕后,再键入apt-get install vim即可。此时容器内已正常安装vim,可使用vim编辑nginx.conf文件了。
    但是很多时候我们想要直接从外部copy到容器内部,比如替换个文件,可以采用docker cp 命令,该命令使用方式如下:

    docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH|-
    docker cp [OPTIONS] SRC_PATH|- CONTAINER:DEST_PATH
    

    从容器内部copy文件到外部,从外部copy文件到容器内部。
    以刚才运行的vmp-web容器为例,想要将index.html copy到容器内部,docker cp index.html vmp-web:/ 改命令即是将index.html 文件复制到vmp-web容器内的根目录。如果想要将此文件从容器内复制到外部,可 通过 docker cp vmp-web:/index.html /index.html命令,即将容器内index.html文件复制到根目录中。想要退出docker容器,输入exit命令即可。
    至此,举一反三,想要将项目应用上docker已经差不多了,但是docker远不止这么简单,目前所介绍的也仅仅是应用基础。

    docker 常用命令介绍

    命令 使用方式 说明
    login docker login -p -u 登陆docker仓库
    logout docker logout 退出
    search docker search nginx 搜索nginx镜像
    build docker build -t zy/bg:vmp-web . 构建bg镜像,打标签为vmp-web,其中zy 为个人docker用户名
    pull docker pull nginx 拉取nginx镜像
    push docker push zy/bg:vmp-web 将本地生成的镜像推送到bg仓库,并且打标签为vmp-web
    images docker images 列出所有镜像
    tag docker tag zy/bg:vmp-web vmp-webOld 标记镜像
    rmi docker rmi vmp-webOld 删除镜像
    run docker run --name vmp-web -p 80:80 -d zy/bg:vmp-web 选择镜像启动容器
    ps docker ps 列出正在运行的容器,docker ps -a 列出所有容器,包括已经停止的容器
    start docker start vmp-web 启动容器
    stop docker stop vmp-web 停止容器
    kill docker kill vmp-web 杀掉容器
    rm docker rm vmp-web 删除容器
    exec docker exec -it vmp-web /bin/bash 进入容器内部
    cp docker cp index.html vmp-web:/ 将index.html文件复制到docker容器内部根目录

    更多命令请参考官方文档

    在本篇中,博主大都以name:tag 的形式删除、停止等操作镜像、容器,当然可以以image id和container id的形式操作。并且在以id操作的时候,并不需要完全键入id,以前几位形成唯一标识即可。

    docker知识点还有很多,需要继续探索。且描述有诸多不足,且请见谅。

  • 相关阅读:
    微信小程序错误码参考大全
    关于vagrant一个虚拟机搭建多个项目配置(总结)
    Vagrant安装完lnmp后,配置linux和windows共享文件并配置虚拟主机访问项目
    vagrant的centos镜像,怎么用root用户登录?
    Vagrant系列(二)----Vagrant的配置文件Vagrantfile详解
    过滤数组中的空数组array_filter()
    getMessage(),getFile,getLine获取异常用法
    测试工程师的福利!各远程移动测试平台对比分析
    学习这篇总结后,你也能做出天天快报一样的推荐系统
    别被官方文档迷惑了!这篇文章帮你详解yarn公平调度
  • 原文地址:https://www.cnblogs.com/ZyCoder/p/12832842.html
Copyright © 2020-2023  润新知