云原生介绍与容器的基本概念

云原生介绍

1、云原生的定义

云原生为用户指定了一条低心智负担的、敏捷的、能够以可扩展、可复制的方式最大化地利用云的能力、发挥云的价值的最佳路径。

2、云原生思想两个理论

第一个理论基础是:不可变基础设施。

第二个理论基础是:云应用编排理论。

3、基础设施向云演进

(1) 过程:

传统的应用基础设施是可变的:需要发布或者更新一个软件,流程大致是这样的,先通过 SSH 连到服务器,然后手动升级或者降级软件包,逐个调整服务器上的配置文件,并且将新代码直接都部署到现有服务器上。因此,这套基础设施会不断地被调整和修改。

在云上,应用基础设施是不可变的。一旦应用部署完成之后,那么这套应用基础设施就不会再修改了。如果需要更新,那么需要现更改公共镜像来构建新服务直接替换旧服务。

(2) 意义:

基础设施保持一致性和可靠性;

镜像本身是自包含的,其包含了应用运行所需要的所有依赖;

云原生的基础设施还提供了简单、可预测的部署和运维能力;

应用本身也可以更好地扩容。

容器的基本概念

一、容器与镜像:

1、容器

(1) 操作系统中进程的特点:

第一,这些进程可以相互看到、相互通信;

第二,它们使用的是同一个文件系统,可以对同一个文件进行读写操作;

第三,这些进程会使用相同的系统资源。

这三个特点带来的问题:

具有高级权限的进程可能会将其他进程的数据进行增删改查;进程与进程之间的依赖可能会存在冲突;这些进程使用的是同一个宿主机的资源,存在资源抢占的问题。

(2) 什么是容器:

容器就是一个视图隔离、资源可限制、独立文件系统的进程集合。

视图隔离:就是能够看到部分进程以及具有独立的主机名等;

控制资源使用率:对于内存大小以及 CPU 使用个数等进行限制;

③ 独立文件系统:容器将系统的其他资源隔离开来,具有自己独立的资源视图。

2、镜像

(1) 什么是镜像

容器运行时所需要的所有的文件集合称之为容器镜像。

通常采用 Dockerfile 来构建镜像。描述构建的每个步骤,每个构建步骤都会对已有的文件系统进行操作,带来文件系统内容的变化,这些变化称之为 changeset。当我们把构建步骤所产生的变化依次作用到一个空文件夹上,就能够得到一个完整的镜像。

changeset 的分层以及复用特点带来的优势:

提高分发效率:对于大的镜像而言,将其拆分成各个小块能够并行下载这些数据,提高镜像的分发效率;

具有了复用能力之后,可以节约大量的磁盘空间。

(2) 如何构建镜像

① FROM 行表示以下的构建步骤基于什么镜像进行构建;

② WORKDIR 行表示会把接下来的构建步骤都在哪一个相应的具体目录下进行,类似于 Shell 里面的 cd;

③ COPY 行表示的是可以将宿主机上的文件拷贝到容器镜像内;

④ RUN 行表示在具体的文件系统内执行相应的动作,运行完毕后就得到一个应用了;

⑤ CMD 行表示使用镜像时的默认程序名字。

当有了 Dockerfile 之后,就可以通过 docker build 命令构建出所需要的应用。

docker registry 镜像仓库,负责存储所有产生的镜像数据。只需要通过 docker push 就能够将本地镜像推动到镜像仓库中,就能够在生产环境上或者测试环境上将相应的数据下载下来并运行了。

(3) 如何运行容器:

从镜像仓库中将相应的镜像下载下来;

通过 docker images 来查看本地镜像,在列表中选中想要的镜像;

当选中镜像之后,通过 docker run 来运行这个镜像得到想要的容器,可以通过多次运行得到多个容器。

一个镜像就相当于是一个模板,一个容器就像是一个具体的运行实例,因此镜像就具有了一次构建、到处运行的特点。

二、容器生命周期:

1、容器运行时的生命周期

在使用 docker run 的时候会选择一个镜像来提供独立的文件系统并指定相应的运行程序。这里指定的运行程序称之为 initial 进程。这个 initial 进程启动的时候,容器也会随之启动,当 initial 进程退出的时候,容器也会随之退出。可以认为容器的生命周期和 initial 进程的生命周期是一致的。

容器内不只有这样的一个 initial 进程,initial 进程本身也可以产生其他的子进程或者通过 docker exec 产生出来的操作,也属于 initial 进程管理的范围内。当 initial 进程退出的时候,所有的子进程也会随之退出。

2、数据卷

当一个容器退出被删除之后,数据也就会丢失了。所以需要将容器所产生出来的重要数据持久化到指定的目录上,这个目录就称之为数据卷。

(1) 数据卷特点:

数据卷的生命周期是独立于容器的生命周期的,也就是说容器的创建、运行、停止、删除等操作都和数据卷没有任何关系。将数据卷挂载到容器内,容器就能够将数据写入到相应的目录里面了,而且容器的退出并不会导致数据的丢失。

(2) 数据卷管理的方式:

通过 bind 的方式,直接将宿主机的目录直接挂载到容器内。

将目录管理交给运行引擎。

三、容器和 VM 之间的差异

① VM 利用 Hypervisor 虚拟化技术来模拟 CPU、内存等硬件资源,这样就可以在宿主机上建立一个 Guest OS,每一个 Guest OS 都有一个独立的内核,比如 Ubuntu、CentOS 甚至是 Windows 等,在这样的 Guest OS 之下,每个应用都是相互独立的,VM 可以提供一个更好的隔离效果。但是需要把一部分的计算资源交给虚拟化,很难充分利用现有的计算资源,并且每个 Guest OS 都需要占用大量的磁盘空间。

容器是针对于进程而言的,因此无需 Guest OS,只需要一个独立的文件系统提供其所需要文件集合即可。所有的文件隔离都是进程级别的,因此启动时间快于 VM,并且所需的磁盘空间也小于 VM。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/467963.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OK-Robot机器人实现零样本算法 可在非结构化环境下完成拾取与放置任务

纽约大学的机器人专家团队与Meta人工智能学院研发人员共同合作开发了一种新型机器人,该机器人具备在非结构化环境下的认知能力,可在陌生房间利用视觉语言模型(VLMs),进行物品的抓取与放置。在论文当中,该团…

使用word2vec+tensorflow自然语言处理NLP

目录 介绍: 搭建上下文或预测目标词来学习词向量 建模1: 建模2: 预测: 介绍: Word2Vec是一种用于将文本转换为向量表示的技术。它是由谷歌团队于2013年提出的一种神经网络模型。Word2Vec可以将单词表示为高维空间…

片上网络NoC(4)——直连拓扑

目录 一、前言 二、直连拓扑 三、总结 一、前言 本文中,我们将继续介绍片上网络中拓扑相关的内容,主要介绍直连拓扑,在此之前,我们已经介绍过了拓扑的指标,这将是继续阅读本文的基础,还没有了解相关内容…

OCP的operator——(1)概述

文章目录 概述了解Operator什么是Operator为何使用OperatorOperator FrameworkOperator成熟度模型 Operator Framework 打包格式Bundle格式Manifest注解依赖关于opm CLI 基于文件的目录RukPak Operator Framework常用术语表常见Operator Framework术语BundleBundle imageCatalo…

《Java 简易速速上手小册》第8章:Java 性能优化(2024 最新版)

文章目录 8.1 性能评估工具 - 你的性能探测仪8.1.1 基础知识8.1.2 重点案例:使用 VisualVM 监控应用性能8.1.3 拓展案例 1:使用 JProfiler 分析内存泄漏8.1.4 拓展案例 2:使用 Gatling 进行 Web 应用压力测试 8.2 JVM 调优 - 魔法引擎的调校8…

MQTT的学习与应用

文章目录 一、什么是MQTT二、MQTT协议特点三、MQTT应用领域四、安装Mosquitto五、如何学习 MQTT 一、什么是MQTT MQTT(Message Queuing Telemetry Transport)是一种轻量级的消息传输协议,设计用于在低带宽、不稳定的网络环境中进行高效的通信…

MYSQL学习笔记:MYSQL存储引擎

MYSQL学习笔记:MYSQL存储引擎 MYSQL是插件式的存储引擎 存储引擎影响数据的存储方式 存储引擎是用来干什么的,innodb和myisam的主要区别–数据存储方式----索引 mysql> show engines; ----------------------------------------------------------…

宠物空气净化器适合养猫家庭吗?除猫毛好的猫用空气净化器推荐

宠物掉毛是一个普遍存在的问题,尤其在脱毛季节,毛发似乎无处不在。这给家中的小孩和老人带来了很多麻烦,他们容易流鼻涕、过敏等不适。此外,宠物有时还会不规矩地拉扯和撒尿,这股气味实在是难以忍受。家人们对宠物的存…

耳机壳UV树脂制作私模定制耳塞需要哪些工具和材料呢?

制作私模定制耳塞需要使用到一些工具和材料,包括但不限于以下内容: UV树脂:用于制作耳塞的主体部分,具有高硬度、耐磨、耐高温、环保等优点。耳模材料:用于获取用户的耳型,通常是一些快速固化的材料&#…

编码、理解和实现LLM中的自注意力、多头注意力、交叉注意力和因果注意力

原文链接:understanding-and-coding-self-attention 2024年1月14日 自注意力是 LLM 的一大核心组件。对大模型及相关应用开发者来说,理解自注意力非常重要。近日,Ahead of AI 杂志运营者、机器学习和 AI 研究者 Sebastian Raschka 发布了一篇…

【小赛1】蓝桥杯双周赛第5场(小白)思路回顾

我的成绩:小白(5/6) 完稿时间:2024-2-13 比赛地址:https://www.lanqiao.cn/oj-contest/newbie-5/ 相关资料: 1、出题人题解:“蓝桥杯双周赛第5次强者挑战赛/小白入门赛”出题人题解 - 知乎 (zhihu.com) 2、矩阵快速幂&…

vue三种路由守卫详解

在 Vue 中,可以通过路由守卫来实现路由鉴权。Vue 提供了三种路由守卫:全局前置守卫、全局解析守卫和组件内的守卫。 全局前置守卫 通过 router.beforeEach() 方法实现,可以在路由跳转之前进行权限判断。在这个守卫中,可以根据用…