云原生

第2章 云原生基础设施之容器技术

2.1 容器发展背景

企业 IT 业务云化路径 - 传统业务云化

方式一:物理机部署,统一管理

  • 特征: 业务无法云化部署,物理资源搬迁或纳管到云平台资源池。
  • 资源管理: 按峰值需求静态分配,资源占用率高,缺乏统一管理。

方式二:云化后虚拟化部署

  • 特征: 应用使用 P2V/V2V 方式迁移到 IaaS 平台
  • 资源管理: 按应用组件分类打标签,集群化管理。

企业 IT 业务云化路径 - 业务云化创新

方式一:云化后容器部署

  • 特征: 应用容器化,快速发布和弹性伸缩(应用不改或少改)。
  • 资源管理: 混合编排虚机进程和容器应用。

方式二:云原生

  • 特征: 引用微服务化实现 Cloud-Native 架构(应用架构改造),业务敏捷。
  • 资源管理: 应用层集中、动态管理和调度。

容器是什么?

  • 容器是一种轻量级、可移植、自包含的软件打包技术,使应用程序可以在几乎任何地方以相同的方式运行。
  • 开发人员在自己开发环境创建并测试好的容器,无需任何修改就能够在生产系统的虚拟机、物理服务器或公有云主机上运行。

为什么使用容器?

容器核心思想

容器与虚拟机

  • 容器和虚拟机之间的主要区别在于虚拟化层的位置和操作系统资源的使用方式。

容器 VS 虚拟机

Docker 项目介绍

  • 2013 年,dotCloud 公司将 Docker 项目开源。

  • Docker 项目:

    • GitHub 上开发的 Moby 开源项目的一部分
    • 遵循 Apache License 2.0 许可证协议
    • Go 语言编写
  • Docker 是一个开源的引擎,可以轻松的为任何应用创建一个轻量级的、可移植的、自给自足的容器。

  • Docker 公司目前推出两个版本:

    • Docker CE(社区版)
    • Docker EE(企业版)

2.2 容器关键技术介绍

容器规范

  • 容器不光是 Docker,还有其他容器,比如 CoreOS 的 rkt 。为了保证容器生态的健康发展,保证不同容器之间能够兼容,包含 Docker 、CoreOS 、Google 在内的若干公司共同成立了一个叫 Open Container Initiative(OCI) 的组织,其目的是制定开放的容器规范。

容器 runtime

  • runtime 与操作系统 kernel 紧密协作,为容器提供运行环境。
  • 常见的容器 rumtime:
    • runC 是 Docker 公司 2015 年发布的容器 runtime 工具,符合 OCI 规范。

      • runC 由 Libcontainer 演变而来。
    • rkt ,是 CoreOS 公司开发的 Docker/runc 的一个流行替代方案,符合 OCI 规范。
    • Kata ,2017 年整合 Clear Container 和 runV 项目,基于虚拟化技术的容器实现,符合 OCI 规范。
    • gVisor ,2018 年 Google 公司发布 gVisor 的项目,基于虚拟化技术的容器实现,符合 OCI 规范。

Docker Engine 介绍

Docker 架构

Docker 内部构建

  • Docker 镜像(Image)

    • Docker 镜像就是一个只读模板,镜像可以用来创建 Docker 容器。另外 Dccker 提供了一个很简单的机制来创建镜像活着更新现有的镜像,用户甚至可以直接从其他人那里下载一个已经做好的镜像来直接使用。
  • Dcoker 容器(Container)
    • Docker 利用容器来运行应用。容器是从镜像创建的运行实例,它可以被启动、开始、停止、删除、每个容器都是相互隔离的、保证安全的平台。
  • Docker 仓库(Repository)
    • 仓库是集中存放镜像文件的场所。仓库注册服务器上往往存放着很多仓库,每个仓库中又包含了多个镜像,每个镜像有不同的标签。

Docker 容器实现原理

  • Docker 容器通过 namespace 技术实现进程隔离,通过 cgroup 技术实现容器进程可用资源的限制。Docker 启动一个容器时,实际是创建了包含多个 namespace 参数的进程。

Namespace

  • Namespace:命名空间

    • 作用:资源隔离。
    • 原理:namespace 将内核的全局资源进行封装,使得每个 namespace 都有一份独立的资源。因此不同进程在各自 namespace 内对同一资源的使用不会相互干扰。

PID namespace 隔离示例

  • 以交互模式启动一个 centos 容器,并在其中运行 /bin/bash 程序。执行 ps 命令查看到 “/bin/bash” 是 PID=1 的进程,即 Docker 将其隔离与宿主机中的其他进程之外。

  • 打开另一个终端,使用 docker inspect 查看容器进程在宿主机上的真实 PID 。实际上,该容器上运行的 “/bin/bash” 在宿主机上的 PID=96745 的进程。

Cgroups

  • Cgroups:Linux Control Groups
  • 作用:限制一个进程组对系统资源的使用上限,包括 CPU 、内存、Block I/O 等。
  • Cgroups 还可以设置进程优先级,对进程进行挂起和恢复等操作。
  • 原理:将一组进程放在一个 Cgroup 中,通过给这个 Cgroup 分配指定的可用资源,达到控制这一组进程可用资源的目的。
  • 实现:在 Linux 中,Cgroups 以文件和目录的方式组织在操作系统的 /sys/fs/cgroup 路径下。该路径中所有的资源种类均可被 Cgroup 限制。

容器镜像

  • 容器镜像是容器的模板,容器时镜像的运行实例,runtime 根据容器镜像创建容器。

  • 容器镜像挂载在容器根目录下,为容器中的应用提供执行环境的文件系统。

    • 容器镜像打包了整个操作系统的文件和目录,也包括应用本身,即应用及其运行所需的所有依赖都被封装在容器镜像中。
  • 容器镜像采用分层结构:

    • 所有容器共享宿主机 Kernel ,并且不能修改宿主机 Kernel 。即容器运行过程中使用容器镜像中的文件,使用宿主机 OS 上的 Kernel 。

UnionFS 联合文件系统

  • UnionFS 主要的功能是将多个不同位置的目录联合挂载到同一个目录下。

    • 每一个镜像层都是 Linux 操作系统文件与目录的一部分。在使用镜像时,docker 会将所有的镜像层联合挂载到一个统一的挂载点上,表现为一个完整的 Linux 操作系统提供容器使用。

容器数据卷

  • 卷就是目录或文件,存在于一个或多个容器中,由 docker 挂载到容器,但不属于联合文件系统,因此能够绕过 Union File System 提供一些用于持续存储或共享数据的特性。卷的设计目的就是数据的持久化,完全独立与容器的生存周期,因此 Docker 不会在容器删除时删除其挂载的数据卷。

    • 启动容器的时候直接使用 -v 命令就可以进行数据卷的挂载。
    • 还可以在 Dockerfile 中使用 VOLUME 指令来个镜像添加一个或多个数据卷。

容器 copy-on-write 特性

对容器的增删改查操作:

Registry

  • Registry 是存放容器镜像的仓库,用户可以进行镜像下载和访问,分为公有和私有两类。

    • 公有镜像仓库

      • Docker Hub 是 Docker 公司为公众提供的托管 Registry 。
      • Quay.io 现为 Red Hat 下的公共托管 Registy 。

    • 私有镜像仓库

      • 企业可以用 Docker Registry 构建私有的 Registry 。

Docker Hub

  • Docker Hub 是目前世界上最大的容器镜像仓库,由 Docker 公司维护,并提供官方镜像及大量用户上传的镜像。

2.3 如何使用 Dockerfile 构建镜像

如何构建镜像

  • Dockerfile 是一个文本文件,其内包含了一条条的指令,每一条指令构建一层,因此每一条指令的内容,就是描述该层应当如何构建。

Dockerfile

  • Dockerfile :文件指令集,描述如何自动创建 Docker 镜像。

    • Dockerfile 是包含若干指令的文本文件,可以通过这些指令创建出 docker image 。
    • Dockerfile 文件中的指令执行后,会创建一个个新的镜像层。
    • Dockerfile 文件中的注释以"#"开始。
    • Dockerfile 一般由 4 部分组成“
      • 基础镜像信息
      • 维护者信息
      • 镜像操作指令
      • 容器启动指令
  • build context :为镜像构建提供所需的文件或目录。

Dockerfile 常用指令

一个简单的 Dockerfile

#基于centos镜像
FROM centos
#维护人的信息
MAINTAINER docker_user docker_user@email.com
#安装httpd软件包
RUN yum -y update
RUN yum -y install httpd
#开启80端口
EXPOSE 80
#复制该脚本至镜像中,并修改其权限
ADD run.sh /run.sh
RUN chmod 755 /run.sh
#当启动容器时执行的脚本文件
CMD ["/run.sh"]

Dockerfile 示例 (1)

  • 编辑一个 Dockerfile 文件,并命名为 Dockerfile1 ,存放于 /root/df 目录下。
FROM httpd
COPY index.html /
RUN /bin/bash -c "echo Huawei"
  • 使用 dcoker build 命令用文件 Dockerfile1 构建一个镜像,并将镜像命名为 test2 。

Dockerfile 示例 (2)

镜像命名

  • 镜像名称格式

    • image name = repository:tag
    • tag 一般用于描述镜像版本,若未指定 tag ,则默认为 “latest” 。

搭建私有 Registry 示例 (1)

  • 使用 “registry" 镜像构建本地镜像仓库。registry 是 docker hub 上维护的镜像,其服务端口是 5000 。-v 参数将宿主机的 /root/myregistry 目录映射到容器的 /var/lib/registry 目录,用于存放镜像数据。

  • 使用 docker tag 命令修改镜像名称,使其符合 registry 上的格式要求。若要将镜像上传到 registry ,镜像名称需要符合其命名格式要求:[Registry-host]:[port]/[username]/[repository:tag] 。

  • 上传容器镜像到私有 Registry 。

搭建私有 Registry 示例 (2)

  • 在 Linux 下,若使用如 “192.168.137.99:1000” 这样的内网地址作为私有仓库地址,则需要在 /etc/docker/daemon.json 中写入如下内容(如果文件不存在需新建该文件),然后重启 Docker 服务。

上传 SWR 镜像仓库

  • 连接容器镜像服务。登录容器镜像服务控制台,复制登陆指令,在安装容器引擎的机器中执行。

  • 在安装容器引擎的机器上执行以下命令,为 nginx 镜像打标签。

  • 上传镜像至镜像仓库。

  • 终端显示如下信息,表明上传镜像成功。

2.4 容器生命周期管理

查看 Docker 服务状态

  • 查看 Docker engine 状态

运行一个容器 (1)

  • 执行 docker run 命令运行一个容器。

    • “-d” 参数可在后台运行容器;“-p” 参数将宿主机 8080 端口映射到容器 80 端口。

运行一个容器 (2)

  • 使用 docker images 查看下载的镜像。

  • 使用 docker ps 命令查看容器运行状态,

  • 在浏览器上输入 “宿主机IP:端口” ,验证容器的可用性。

容器生命周期管理 (1)

  • 使用 docker stop 命令停止一个容器。

  • 使用 docker ps -a 查看所有状态的容器,状态是 Exited 。

  • 使用命令 docker start 命令启动一个容器。

  • 使用命令 docker start 命令启动一个容器,状态是 Up 。

容器生命周期管理 (2)

  • 使用 docker pause 命令暂停一个容器。

  • 使用命令 docker ps - a 查看所有状态的容器,状态是 Paused 。

  • 使用命令 docker unpause 恢复启动一个容器。

  • 使用命令 docker unpause 命令恢复一个容器,状态是 Up 。

容器生命周期管理 (3)

  • 使用 docker rm 命令删除一个容器。

  • 使用命令 docker ps -a 查看所有状态的容器,该容器已删除。

  • docker rm 一次可以指定多个容器,如果希望批量删除所有已经退出的容器,可以执行如下命令。

进入一个容器

  • 使用 docker attach 命令进入一个容器

  • 使用 docker exec 命令进入同一个容器

其他常见命令

  • 使用 docker inspect 获取容器/镜像元数据。

  • 使用 docker top 命令查看容器中运行的进程信息。

  • 使用 docker events 从服务器获取实时事件。

  • 使用 docker port 列出指定的容器的端口映射。

  • 使用 docker cp 与主机之间进行数据拷贝。

思考题

答案:ABCD

答案:A

本章总结

  • 介绍了容器的相关概念,发展,架构以及应用场景。
  • 介绍了容器和虚拟机的区别。
  • 介绍了 Docker 架构以及容器生命周期管理。
  • 介绍了容器相关基础操作。

缩略语

  • IaaS:Infrastructure as a Service ,即基础设施即服务,指把 IT 基础设施作为一种服务通过网络对外提供,并根据用户对资源的实际使用量或占用量进行计费的一种服务模式。
  • OCI:Open Container Initiative ,开放容器计划,定一套容器和镜像的标准和规范。
  • P2V:physical machine to virtual machine ,物理机转换成虚拟机。
  • PaaS:Platform as a Service ,即平台即服务,把服务器平台作为一种服务提供的商业模式。
  • UnionFS:Union File System ,联合文件系统,它是一种轻量级的高性能分层文件系统,实现 Docker 镜像的技术基础。
  • V2V:virtual machine to virtual machine ,不同虚拟化环境的虚拟机之间互相迁移、转换。

【华为云原生入门级认证】第 2 章 云原生基础设施之容器技术相关推荐

  1. 《云原生入门级开发者认证》学习笔记之云原生基础设施之容器技术

    写在前面 嗯,报了考试,整理课堂笔记记忆 学习的原因: 虽然考了CKA,了解了一些K8s相关的知识 但是对云原生整个体系一直都很模糊 希望对云原生有一个基本的认识 通过学习实现云原生相关入门 博文主要 ...

  2. 阿里云APA云服务助理认证 第1章: 阿里云简介

    阿里云APA云助理考试认证 第1章: 阿里云简介 1.1 传统IT部署方式 - 自建机房 1.1.1 如果需要部署一个应用, 比如说网站, 管理员需要做哪些工作? 机房: 电力, 空调, 机柜 - 硬 ...

  3. 【华为云原生入门级认证】第 1 章 云原生架构总览

    云原生 第1章 云原生架构总览 1.1 云技术发展历程 1.2 云原生的定义 云原生出现的背景 如今企业大都处于下图中黄色和红色的板块,所以将软件迁移到云上就成为了极大的趋势. 云原生定义 - Piv ...

  4. 【重识云原生】第三章云存储3.5节——商用分布式云存储方案

    <重识云原生系列>专题索引: 第一章--不谋全局不足以谋一域 第二章计算第1节--计算虚拟化技术总述 第二章计算第2节--主流虚拟化技术之VMare ESXi 第二章计算第3节--主流虚拟 ...

  5. 【重识云原生】第四章云网络4.3.10.5节——VXlan组网架构

    <重识云原生系列>专题索引: 第一章--不谋全局不足以谋一域 第二章计算第1节--计算虚拟化技术总述 第三章云存储第1节--分布式云存储总述 第四章云网络第一节--云网络技术发展简述 第四 ...

  6. 【重识云原生】第四章云网络4.3.10.6节——VXLAN应用部署方案

    <重识云原生系列>专题索引: 第一章--不谋全局不足以谋一域 第二章计算第1节--计算虚拟化技术总述 第三章云存储第1节--分布式云存储总述 第四章云网络第一节--云网络技术发展简述 第四 ...

  7. 【重识云原生】第四章云网络4.3.10.2节——VXLAN Overlay网络方案设计

    <重识云原生系列>专题索引: 第一章--不谋全局不足以谋一域 第二章计算第1节--计算虚拟化技术总述 第三章云存储第1节--分布式云存储总述 第四章云网络第一节--云网络技术发展简述 第四 ...

  8. 【重识云原生】第二章计算第一节——计算虚拟化技术总述

    云平台计算领域知识地图: ​ 楔子:计算虚拟化技术算是云计算技术的擎天之柱,其前两代技术的演进一直引领着云计算的发展,即便到了云原生时代,其作用依然举足轻重. 一.计算虚拟化技术总述 1.1 虚拟化技 ...

  9. 【重识云原生】第四章云网络4.6节——Underlay 和 Overlay概念

    <重识云原生系列>专题索引: 第一章--不谋全局不足以谋一域 第二章计算第1节--计算虚拟化技术总述 第三章云存储第1节--分布式云存储总述 第四章云网络第一节--云网络技术发展简述 第四 ...

最新文章

  1. 下java7 64有什么用_Win 7 64位系统安装java 8,看完就明白了
  2. bootstrap的使用
  3. 基于XFS的NAS数据恢复可以做了
  4. Turbo C 2.0 集成调试器的使用方法
  5. 4.等待链表与调度链表
  6. /dev 设备文件属性解读
  7. 小程序基于mpvue开发坑一
  8. Tomcat 学习笔记(0)
  9. web api解决序列化后返回标准时间带T问题
  10. C# SOCKE通信
  11. axios http错误码处理
  12. java做一个鼠标连点_用C语言写一个鼠标连点器
  13. iOS:开放平台引用(二)--微信分享
  14. JPBC库应用之BLS签名
  15. 计算机视觉知识表征,计算机视觉基础 - 边缘和轮廓检测
  16. Node+Vue3.0+Mongodb实现完美解决高并发的购物平台管理系统
  17. 自动更新+淘客+电影网站PHP源码+手机版,可对接微信公众号带会员收费系统
  18. SpringBoot项目中ModelMapper配置以及使用
  19. 第十三章 使用动态SQL(五)
  20. Latex调整figure与下面正文之间的间距

热门文章

  1. Linux 输出重定向 命令 > file
  2. 【2021】03 C++
  3. c语言取整方法和四舍五入和 %d 和 %04d 和%-4d有什么区别
  4. 2019-5-8,给新班级的新生们学习禅道系统的部署与应用,并且让每个学员自己动手完成
  5. Matlab中十六进制和二进制值数转换
  6. python笔记手写照片_Python笔记-将图片转换为字符画
  7. python怎么画参数函数图像_python函数 图
  8. 小米家投影仪2和极米z6x 哪个好
  9. 【渝粤教育】国家开放大学2019年春季 0024-22T建筑工程管理与实务 参考试题
  10. kmeasns中的whiten介绍