前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >产品能力|云原生技术的知识体系构建-DOCKER学习笔记part1

产品能力|云原生技术的知识体系构建-DOCKER学习笔记part1

作者头像
破晓之翼
发布2022-12-02 16:28:55
1990
发布2022-12-02 16:28:55
举报
文章被收录于专栏:产品能力产品能力

云原生技术的知识体系构建

第一部分:docker学习笔记。 后续不断补充。


文章目录


前言

云计算时代应需求而产生和大规模运用的Docker。 目前的技术水平已经真正的进入了云计算时代,各大基础设施纷纷上云。很多大企业将所有业务都迁移到了云上。而云的基础设施就是 Docker,准确的说是容器,而 Docker 正是当下最主流的容器技术。 Docker 是基础设施,是因为 Docker 的资源限制和隔离性是云上必不可少的特性。相比于之前每个部门的应用申请一堆物理机来部署自己的应用进程,使用云计算的方式来统一管理公司所有的应用使得资源的使用率更加的高。 那么这么多的应用部署到一起就需要解决三个主要问题:应用隔离、应用部署和资源限制。


一、Docker 是什么?

在这里插入图片描述
在这里插入图片描述

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。 一个完整的Docker有以下几个部分组成:

Docker 包括三个基本概念:

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

在这里插入图片描述
在这里插入图片描述

我们通过客户端写命令,然后客户端将命令发送给守护进程,守护进程再将命令执行的结果返回给客户端,这就使我们能通过命令查看执行结果,镜像就是容器的源代码,容器通过镜像启动,使用仓库来保存用户构建的镜像,仓库分为共有和私有。

二、Docker用来干什么

2.1应用隔离

很容易理解,比如不同的应用依赖了冲突的基础软件包,如果都直接部署在操作系统环境下,必然会引起冲突。这个时候就需要应用之间互相隔离。Docker 使用操作系统底层的 Namespace 技术来做隔离是一种主流的技术方案。

2.2 应用部署

在容器技术诞生之前,所有的应用都是直接部署在操作系统上面的,彼此之间共享底层的操作系统资源,比如内存、CPU、磁盘等。 打个比方,如果我们要将应用 A 和应用 B 部署到同一台机器上,那么这两个应用需要的环境信息,我们都需要满足。如果应用 A 和 B 的环境依赖之间存在冲突,或者说不兼容,那么管理起来就会非常的困难。 而这个问题,我们通过容器的镜像技术却可以非常简单地解决掉。除此之后,Docker 技术还有很多相比于传统技术更加优势的地方,这也 Docker 技术能够迅猛发展起来的根本原因。

2.3资源限制

不同的应用共享集群不可避免的涉及到资源使用限制的问题。比如一个公司同时有多个业务部门使用一个统一的集群,在统计研发成本时,需要统计各个部门的资源使用情况然后做划分。这样我们就可以根据资源使用限制来划分,当某些应用资源使用超限就杀掉应用。Docker 使用内核提供的 Cgroup 技术来做资源限制正好可以应用到这个场景。

2.4 项目中的实际用途

a. Web 应用的自动化打包和发布。 b. 自动化测试和持续集成、发布。 c. 在服务型环境中部署和调整数据库或其他的后台应用。 d. 从头编译或者扩展现有的OpenShift或Cloud Foundry平台来搭建自己的PaaS环境


三、Docker的优点

3.1简化程序:

Docker 让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,便可以实现虚拟化。Docker改变了虚拟化的方式,使开发者可以直接将自己的成果放入Docker中进行管理。方便快捷已经是 Docker的最大优势,过去需要用数天乃至数周的 任务,在Docker容器的处理下,只需要数秒就能完成。

3.2 避免选择恐惧症:

如果你有选择恐惧症,还是资深患者。Docker 帮你 打包你的纠结!比如 Docker 镜像;Docker 镜像中包含了运行环境和配置,所以 Docker 可以简化部署多种应用实例工作。比如 Web 应用、后台应用、数据库应用、大数据应用比如 Hadoop 集群、消息队列等等都可以打包成一个镜像部署。

3.3 节省开支:

一方面,云计算时代到来,使开发者不必为了追求效果而配置高额的硬件,Docker 改变了高性能必然高价格的思维定势。Docker 与云的结合,让云空间得到更充分的利用。不仅解决了硬件管理的问题,也改变了虚拟化的方式。 tips: 预算什么时候都是宝贵的,钱要花到刀刃上去。

3.4一致性:

容器非常适合持续集成和持续交付(CI / CD)工作流程,请考虑以下示例方案: 您的开发人员在本地编写代码,并使用 Docker 容器与同事共享他们的工作。 他们使用 Docker 将其应用程序推送到测试环境中,并执行自动或手动测试。 当开发人员发现错误时,他们可以在开发环境中对其进行修复,然后将其重新部署到测试环境中,以进行测试和验证。 测试完成后,将修补程序推送给生产环境,就像将更新的镜像推送到生产环境一样简单。 Docker 允许开发人员使用您提供的应用程序或服务的本地容器在标准化环境中工作,从而简化了开发的生命周期。 tips: 对于工程化管理非常重要。

下一篇:Docker 在 Centeros上的安装。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-10-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 云原生技术的知识体系构建
    • 文章目录
    • 前言
    • 一、Docker 是什么?
    • 二、Docker用来干什么
      • 2.1应用隔离
        • 2.2 应用部署
          • 2.3资源限制
            • 2.4 项目中的实际用途
            • 三、Docker的优点
              • 3.1简化程序:
                • 3.2 避免选择恐惧症:
                  • 3.3 节省开支:
                    • 3.4一致性:
                    相关产品与服务
                    容器镜像服务
                    容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
                    领券
                    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档