- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章探寻云原生数据库由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
译者 | 李睿 。
审校 | 梁策 孙淑娟 。
如今,“云原生”这一概念已多用来表示应用逻辑和基础设施(包括数据库)的最佳实践集合。然而,早在云计算或云原生概念出现几十年前,许多支持应用程序运行的数据库就已存在,只是这些传统解决方案的数据引力限制了应用程序和工作负载的移动能力。随着企业将业务迁移到云端,数据存储方法该怎样发展?需不需要云原生数据库?云原生数据库又意味着什么?以下我们来一一解答.
要定义“云原生”,需要先来明白什么是“原生”(Native)。对于个人而言,原生二字可能会让你联想到母语、本国或本地之类的概念,亦或是自然界里野生动物的原生栖息地,包括各个物种如何适应所处环境等。因此,我们也从这里出发来理解云原生的含义.
以下是云原生计算基金会(CNCF)对该术语的定义: “云原生技术使企业能够在公共云、私有云和混合云等现代动态环境中构建和运行可扩展的应用程序,容器、服务网格、微服务、不可变基础设施以及声明性API都是典型例子。这些技术使松散耦合的系统具有弹性、可管理性和可观察性,辅以强大的自动化,工程师可以最少的工作量进行高频预测性更改。” 。
这一定义范围相当宽泛,但来定义云原生数据库还是有些吃力,就如CNCF景观图数据库部分所示:
仔细观察就会发现,这里包含各种各样的产品:如传统的关系数据库和NoSQL数据库,它们支持各种不同的数据模型,包括键/值、文档和图形。此外还包括现有数据库之上的分层聚类、查询或模式管理技术。这还不包括CNCF领域的其他有关类别,例如用于数据移动的流式传输和消息传递,或用于持久性的云原生存储.
这些数据库中哪些是云原生呢?除了专为云设计的数据库,是否也包括那些可以适应云中工作的数据库?在比尔·怀尔德 (Bill Wilder) 2012年出版的《云架构模式》(Cloud Architecture Patterns)一书中,他提出了一个有趣观点,把“云原生”定义为:“任何经过架构而能充分利用云平台的应用程序”.
根据这个定义,云原生数据库就是那些经过架构,能充分利用底层云基础设施的数据库。但是,这样定义也会有争议.
或者换个方式来问,云原生数据库有什么优势?其中,推动云计算普及的两个主要因素包括:成本和上市时间.
就像堆栈选择中的其他因素一样,这些目标也适用于数据库选择.
现在,我们可以重新审视CNCF的定义,以有助于成本和上市时间目标实现来归纳出云原生数据库的特征:
云原生数据库旨在落实这些要求,这让它们与那些可以通过一些调整部署到云中的数据库——“云就绪”数据库区分开来.
本文以Apache Cassandra™为例来审视云原生数据库的定义。虽然Cassandra在开发时“云原生”一词尚未普及,但由于受到了公共云基础设施的启发(例如亚马逊AWS的Dynamo论文和谷歌公司的BigTable),它在架构影响上有许多相似之处。因为这层关系,Cassandra体现了以下原则:
虽然Cassandra集群自动化的初始部署比较简单,但其他任务(例如扩展或升级)可能非常耗时且难以自动化。毕竟,即使是对单节点数据库操作也很有挑战,许多数据库管理员也都认同这点。幸运的是,K8ssandra项目为在Kubernetes上部署Cassandra提供了最佳实践,其中包括在交付运营(“Day 2”)后的自动化操作方面取得了重大进展.
有关Kubernetes,当人们谈论云中的数据库时,实际上是在说需要某种存储的有状态工作负载。但在云计算世界中,有状态是个麻烦事。数据引力相当棘手——由于法规和法律的限制,数据可能难以移动,而且成本可能会变得非常高昂.
由于最初不是为有状态工作负载而设计,在开始使用Kubernetes部署容器化应用程序时,其面临的挑战有增无减。目前出现了推动部署数据库在Kubernetes上运行的新趋势,以在单一平台上运行整个堆栈来最大限度地提升开发和运营效率。Kubernetes对云原生数据库有哪些额外要求呢?
首先,数据库必须在容器中运行。这听起来显而易见,但也需要做些工作。存储必须外部化,内存和其他计算资源必须适当调整,应用程序日志和指标必须可用于基础设施,以进行监控和日志聚合.
接下来,需要将数据库的存储需求映射到Kubernetes架构。每个数据库节点最起码要提出一个持久卷声明,Kubernetes可以使用它来分配具有适当容量和输入/输出(I/O)特征的存储卷。数据库通常使用Kubernetes状态集进行部署,这有助于管理存储卷到pod的映射,并保持一致、可预测的身份.
最后,需要工具来管理和自动化数据库操作,这当中包括安装和维护。通常这由Kubernetes操作员模式实现。操作员模式本身是一个控制回路,它观察Kubernetes资源的状态,并采取措施以助其实现。这样的话,它们就类似于Kubernetes的内置控制器,但关键区别在于它们了解特定域的状态,从而帮助Kubernetes做出更好决策.
例如,K8ssandra项目使用cass-operator,它定义了一个名为“Cassandra Datacenter”的Kubernetes自定义资源(CRD),由它来描述Cassandra集群每个顶级故障域的期望状态。这比处理有状态集或单个pod的抽象水平更高.
Kubernetes数据库操作员通常有助于解答以下问题:
云原生数据库是按可扩展性、弹性、韧性、可观察性和自动化等云原生原则设计的数据库。就如Cassandra所示,自动化通常是最终关卡,但在Kubernetes中运行数据库可以有效助力企业朝着这一目标迈进.
原文标题:The Search for a Cloud-Native Databaseby,作者:Pieter Humphrey 。
原文地址:https://www.51cto.com/article/703313.html 。
最后此篇关于探寻云原生数据库的文章就讲到这里了,如果你想了解更多关于探寻云原生数据库的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我计划使用 python 开发一个 Web/云应用程序,它执行以下操作, 1.上传Perl/Python抓取脚本并执行。 2. 上传脚本以按计划运行。 3. 使用不同的输入参数运行同一脚本的多个实例。
我正在开发一个应用程序,我想实现一个功能,可以在相同的用户设备之间共享,比方说,收藏夹、书签等。所以,我想实现类似 iCloud 的东西。 我想到了 2 个可能的想法:Backup Manager 和
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在尝试从一系列短语中使一个单词云成为一个词云,而不是从单个单词中重复很多短语。我的数据看起来像这样,数据框的一列是短语列表。 df$names <- c("John", "John", "Jose
对于配置AWS服务(EC2/R53/VPC/S3/..),Terraform等技术在执行回滚、错误处理等方面的方法不可靠。 AWS CloudFormation 模板解决了这些问题。 CloudFor
我无法使用我的 Azure 帐户执行任何操作,例如创建服务器或数据库或任何操作。看起来这一切都围绕着我无法创建的资源组>我收到此错误: 这特别困难,因为我什至无法使用云外壳,因为我得到了这个:请求 C
是否有在客户端使用 socket.io 的云/托管推送系统?据我所知,没有一个系统使用 socket.io AFAIK: http://beaconpush.com/ http://pusher.co
有没有办法在我的计算机上本地运行 RStudio,但使用运行 R 作为引擎的远程计算机而不是本地 R 安装? 需要明确的是,我知道可以将 RStudio 服务器与 Web GUI 一起使用,但我问的是
我正在寻找在这种情况下可以使用的合适服务: 在视频模式下打开相机并将其流式传输到 azure 云。 并从另一方聆听(也包括客户)。 我读到了有关 Azure 媒体服务的信息。 但根据this我知道客户
这个问题已经有答案了: 已关闭12 年前。 Possible Duplicate: Google App Engine, getting started 如何将 Java 应用程序部署到 Google
我有一个用 Java 7 编写的相当大的控制台应用程序,它管理大量的订单处理。 该应用程序使用大量订单 Web 服务、与数据库交互并将数据插入 ERP 系统。该应用程序的要求没有指定用户交互,因此在项
我已经阅读过有关 Windows Azure 的内容,但为了深入了解这项技术,我(显然)需要使用它。我有一个小型 ASP.NET 网站,流量很少,我认为在 Azure 上托管该网站会节省我的钱。除此之
我的 Activity 中有 3 个编辑文本(姓名、手机号码、职业)和一个按钮(保存)。每次用户单击按钮时,我都想将这三个数据保存到 Parse-cloud。然后新 Activity 在 imagev
我正在尝试通过node.js 将传感器数据发送到artik cloud。 (使用网络套接字和串行端口)。但它发送空。有人知道原因吗?我刚刚复制了教程中的代码,因此没有语法错误。 var webSock
我对 docker hub 和 docker cloud 有一点困惑。我有需要安装在客户端服务器中并运行容器的 docker 镜像。我相信这可以使用 docker hub 来完成,它允许在我的私有(p
晋城,华夏文化发祥地之一。两万年前留下高都遗址、塔水河、下川等人类遗址,女娲补天、愚公移山等神话传说,如今在云上有了崭新的魅力。 9月3日,阿里云数字中国行•晋城峰会期间,晋城市人民政府公布了
我刚开始使用 Airflow 插件,有点困惑。 我在 GCP (composer-1.13.4-airflow-1.10.12) 上使用 Cloud Composer 作为托管服务运行它 我按照文档编
据我所知,PHP 分析工具 XDebug 将其结果保存到文件中。然而,当应用程序运行在云分布式环境中时,处理此类文件是很困难的。处理这种情况的最佳做法是什么? XDebug 中是否有任何方法(最好是可
我们正在将 PHP 网站迁移到 Azure 云 Web 服务(Web 角色)。 目前,该网站通过驱动器盘符访问将用户提交的图像文件保存到文件系统。然后通过 URL 提供这些图像,例如content.e
我是一名优秀的程序员,十分优秀!