DBaaS体系及特性

2023-10-31

用户对云计算的交付能力已经不再满足于单纯的基础设施(IaaS)交付,他们希望数据中心中的更多传统IT 服务能以云服务模式进行交付,其中最为迫切的就是数据库。将数据库以云服务模式交付给用户,就是数据库即服务——DBaaS,也称云数据库。

传统数据库管理面临诸多挑战是DBaaS兴起的驱动力,概括起来有以下几个方面:

资源利用率低:与服务器虚拟化的情形相似,传统IT烟囱式部署架构,不仅导致应用服务器资源利用率低,大量的数据库服务器同样资源空闲严重,造成硬软件投资浪费。

使用成本高:数据库是业务数据的载体决定了数据库运维管理的重要性,需要具备专业数据库技能的管理员才能驾驭数据库的日常运维;昂贵的数据库软件license和维保成本令IT管理者头疼。

管理难度大:数据的高安全性和完整性要求决定了数据库架构的复杂性,服务器HA、容量管理、监控、容灾备份和恢复等都对管理员造成了极大了压力。

业务响应慢:传统的数据库部署都是被动响应客户的需求,从接收需求到完成交付通常都需要几周至几月的时间,严重制约业务部门的工作效率。

云数据库的诞生,使得困扰用户的上述问题得以迎刃而解。

一、数据库即服务的目标

云数据库将数据库资源池化,通过网络将服务交付给客户,如图1所示。传统各委办局都需要各自建设维护自己的数据库系统,在DBaaS模式下,他们只需通过一个WEB门户提交数据库需求申请,就可以快速获得所需要的数据库系统,省时省力。

数据库即服务的目标在于:

1)帮助业务部门减少数据库总体拥有成本(TCO)。通过平台的整合、标准化,充分利用硬件资源,合理的共享数据库软件,减少数据库软件使用量,从而从整体上降低数据库使用成本。

2)数据库资源的敏捷交付。业务部门不再需要经过漫长的无奈的等待去获取到数据库资源,他们可以通过自助服务的方式,选择所需的配置规格,几分钟后就可以生成数据库实例。而且,随着业务量的变化,可以在线申请资源扩容,享受到云弹性的优势。

3)降低管理员负担。将繁琐的、低效的手工部署和配置、监控工作程序化、自动化,大大解放数据库管理员的工作负荷,使得数据库管理员可以聚焦到更有价值的工作上。

DBAAS 云计算 数据库

图1数据库即服务实现数据库资源池化

二、数据库即服务的体系架构

云平台的标准体系架构由物理层、虚拟化层、云服务层、云运维管理、云服务管理、云安全管理6大部分构成。云数据库不同于云主机,云数据库一般基于物理服务器和物理存储部署,这是因为数据库服务器负载通常高于应用服务器,承载数据库的服务器本身不适合虚拟化。因此云数据库的体系架构与云计算平台的体系架构稍有不同,数据库即服务的体系架构如图2所示:

DBAAS 云计算 数据库

图2数据库即服务体系架构

物理层以高性能服务器、高性能存储和网络设备构成。数据库资源层负责将数据库资源池化,形成各种类型的数据库资源池,如Oracle资源池,MySQL资源池,PostgreSQL资源池和SQL Server资源池。数据库服务层通过门户向租户提供数据库资源自动化交付、数据库生命周期管理、账号管理、表空间管理、报警管理、备份恢复管理等功能。

云安全防护平台为物理层、数据库资源层、数据库服务层提供全方位的安全防护,包括漏洞扫描、主机防御、租户隔离、认证与审计、数据安全等模块。满足国家有关云安全标准的要求。云运行监控与维护管理平台为云平台运维管理员提供设备管理、配置管理、镜像管理、备份管理、日志管理、监控与报表等,满足云平台的日常运维的需求。云服务管理平台主要为云服务管理员提供服务交付的管理,包括组织架构管理、租户管理、云业务流程定义、计费策略定义等。

三、数据库即服务的特性

3.1 兼容主流数据库

数据库即服务给传统IT带来的价值需要体现在能够兼容现有的业务应用上。存量的业务系统如果不能迁移到云上,其价值将大打折扣,对客户的吸引力也会大大降低。

目前在多数行业,基于Oracle开发的业务系统占据大部分比例。图3所示的是某省级政府各厅局委办业务系统所使用数据库的占比图。从图中可以看到,商业数据库软件在业务系统中占据绝对优势。因此,DBaaS服务能兼容的数据库类型就成了衡量DBaaS产品的关键指标。

DBAAS 云计算 数据库

图3政务业务使用数据库类型统计

典型的DBaaS服务应能提供对目前主流数据库的支持:Oracle、SQL Server和MySQL。广泛的兼容性保证了客户的应用能够平滑的、以较小的代价迁移到云上。

3.2 高安全

DBaaS是一个多租户共享使用的环境,租户数据安全除了基本的数据库安全管理以外,还需要针对云环境进行安全加强。DBaaS安全体系架构如图4所示。

DBAAS 云计算 数据库

图4DBaaS安全体系架构

DBaaS应支持以下增强的安全特性:

租户网络隔离:云的基本安全原则就是租户网络隔离,云数据库须满足不同的租户网络严格隔离的要求。

资源隔离:数据库实例对硬件资源的需求如CPU、内存资源可以得到隔离保护,IO资源最大使用量可以得到限制,避免租户数据库之间的资源争用和相互干扰,确保数据库服务SLA的达成。

数据库软件级隔离:不同租户的数据库实例使用不同的数据库软件代码,使得租户数据库升级或者打补丁不会对其他租户造成影响;而且可将数据库的最高管理权限交还给租户,保证仅云租户拥有其数据库的最高管理权限——此为公安部信息系统安全等级保护标准的要求。

数据库审计:在云环境下,数据库审计应采用基于流量旁路的审计方案且只有租户能看到属于他们数据库的审计信息。

自定义备份:支持租户按库灵活定义备份策略。如备份方式,全备份或者增量备份;备份周期是日备份、周备份还是月备份等。

访问安全:支持租户配置访问控制列表,基于IP白名单授权访问。

3.3 高可用

DBaaS高可用预防单点故障,其实现原理如下:将多台服务器(大于2台)组建成集群,让它们都提供数据库服务,再配置1台或多台服务器作为整个集群的热备服务器,有点类似于硬盘Raid组hotspare盘,集群中的任何生产节点都可以共享备份节点。这样就既实现了HA,同时又将资源闲置率降到了最低。其架构示意图如图5所示。

DBAAS 云计算 数据库

图5 DBaaS高可用实现

3.4 灵活性

DBaaS的灵活性体现在以下一些方面:

弹性,同其他云服务一样,DBaaS的弹性是基本要求。用户能对数据库实例自助增加CPU、内存、数据盘和IO资源,以满足业务增长的需要。

配置灵活性,用户能针对数据库实例的属性进行自配置,如修改IP、实例名或者端口;能对备份恢复策略进行修改;对数据库监控要素和报警阀值进行自定义。

数据库迁移,提供数据库迁移功能,以便自动实现实例在物理服务器间的迁移。

数据交换,支持数据库导入导出,实现与外部数据的交换。

四、数据库即服务的自动化交付流程

数据库即服务的自动化交付流程如图6所示:

DBAAS 云计算 数据库

图6 DBaaS自动化交付流程

由管理员在物理机上安装好操作系统,并安装好数据库模板。管理员将物理机加入物理资源池管理,配置集群和相应参数。

租户通过门户填写数据库请求,提交数据库类型、CPU核数、内存、连接数、网段、字符集等数据库参数;

由租户管理员审核申请并审批通过;

系统下发租户的数据库参数;

DBaaS平台根据租户请求在物理机资源池中挑选最合适的一台服务器,并在其上自动创建所需的数据库实例;

DBaaS平台将数据库信息及账号发送给租户,租户使用数据库。

五、数据库即服务的适用场景

数据库即服务实现了数据库的整合、服务的敏捷交付以及系统的自动化部署功能,因此,数据库即服务具备广泛的适用场景。

在传统IT环境,各种数据库分散部署,资源割裂不能共享,维护困难,软硬件成本高昂。使用DBaaS能有效提高资源利用率,合法共享昂贵的数据库软件,减轻维护人员的工作负荷。下面对传统部署模式与DBaaS部署模式的直接成本进行一个简单对比,以5台Oracle数据库服务器为例(需支持热备),传统模式下需要部署在10台服务器上(两两组成集群),DBaaS模式下只需要3台服务器(2主1备),假设传统每台5万,共10台;DBaaS每台7万,共3台; 假设每台服务器购买4CPU license,5万/CPU。综合数据库软件成本(不计维保费用),对比如下表:

成本构成          服务器   CPU            总计

传统模式(万元)      50       200              250

DBaaS模式(万元)     21         60                 81

表1传统模式与DBaaS模式成本对比

很显然,采用DBaaS模式可以将软硬件成本大幅降低。

在私有云环境下,DBaaS将数据库打包成云资源,与计算、存储资源一样以云服务方式交付给业务部门,使得业务部门享受到快捷、弹性的数据库服务。在专有云环境下,云服务商通过DBaaS服务丰富云服务目录,拉近与业务的距离,增强用户粘性。建立客户和云服务商双赢、持久共存的云生态环境。

结束语

数据库即服务随着云服务模式的流行正在被广泛关注和认可。它不仅让用户不再关心底层的物理硬件和操作系统,甚至连数据库的部署和管理都不用关心。让用户能够将精力聚焦到他们的核心业务上去,或者极大的提升传统IT部门和业务部门的生产力。数据库即服务产品在传统IT、私有云和专有云领域都有它的用武之地。在用户需求和云计算技术的双重推动下,数据库即服务必将得到越来越多用户的青睐。

本文来自:http://www.chinaz.com/news/2016/0104/491690.shtml

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

DBaaS体系及特性 的相关文章

  • python如何调用参数配置文件_如何使用Python3实现json作为配置文件?

    当脚本重复使用时候 我们需要不断的去更新一些参数 这样使得时间浪费很多 效率也不高 这该怎么办呢 小编在遇到同样问题时 发现了一个可以解决的方式 那就是利用json 大家有需求的可以来看下哦 相信大部分人遇到这个问题 最先尝试的是 py文件
  • Alist简单使用指南

    一 Alist 简介 一款支持多种存储的目录文件列表程序 支持 web 浏览与 webdav 后端基于gin 前端使用react 下面使用 docker和caddy 主要用来支持https 来部署 效果 二 docker部署 配置docke
  • Nginx转发超简单实现

    使用场景 用Nginx做转发 实现更好的服务器管理 此处实现多域名转发 假设服务器分配 客户访问机器IP 192 168 137 70 Nginx接收访问请求 并转发到49服务器 真实服务机器IP 192 168 137 49 IIS或者A
  • push c语言什么作用,“c语言”中,“pop函数”和“push函数”的作用分别是什么?...

    这个算是数据结构的内容讲解的是一个叫做栈类型的数据结构 这个数据结构的特点就是后进先出 最后放进去的数据最先拿出来 pop函数就是拿出数据的操作 push是放入是数据的操作 内容拓展 pop函数呵push函数的使用 include incl
  • 利用fgets实现行数读取

    首先在shell下man fgets include
  • opencv实现图片裁剪和缩放

    1 格式转换 yuv2rgb include
  • 5.揭秘angular2学习 ------- 管道

    管道简介 管道是什么 Angular的管道可以看作成是一个数据格式化展示的工具 管道可以将数据格式化显示 而不改变源数据 比如关于日期的展示 对于源数据使用管道1可以以yyyy MM dd来展示 也可以使用管道2展示成Feb 28 2017
  • 在HM和VTM上实现无损压缩

    1 HM 方法一 在命令行输入增加 TransquantBypassEnableFlag 1 CUTransquantBypassFlagForce 1 HM16 9中对应的命令行 方法二 直接在cfg里面修改 把TransquantByp
  • C代码创建多通道WAV音频文件

    C代码创建多通道WAV音频文件 算法调试经常需要在PC端进行仿真输出 涉及到多通道 或者每一级算法的输出对比 这时需要多通道的WAV文件生成 代码 这里给出的是默认16bit单点数据位长 可以自己修改下 改成自己想要的位长 file wav
  • Socket长连接与短连接

    长连接与短连接 所谓长连接 指在一个TCP连接上可以连续发送多个数据包 在TCP连接保持期间 如果没有数据包发送 需要双方发检测包以维持此连接 一般需要自己做在线维持 短连接是指通信双方有数据交互时 就建立一个TCP连接 数据发送完成后 则
  • MBA-day13 逻辑学 模态推理(可能与必然的推理)

    1 基本概念 模态判断 是反应事物的可能性或必然性的判断 根据判断所反应的事物的可能性还是必然性 可以把模态判断分为可能判断与必然判断 模态命题 可能命题 必然命题 可能肯定命题 可能否定命题 必然肯定命题 必然否定命题 2 模态判断的负判
  • 第63讲:Python编程案例之猴子吃桃

    文章目录 1 需求描述以及分析 2 递推方式实该该程序 3 递归方式实现该程序 1 需求描述以及分析 需求描述 猴子第一天摘了若干个桃子 第一天吃了若干个桃子中的一半 觉得不过瘾 又多吃了一个 第二天早上又将第一天剩下的桃子吃了一半 并且也
  • IDEA中修改workspace.xml内容,保存后自动被删除

    最近在做一个SpringBoot的分布式项目 由于项目里面有多个启动器 每次查找启动类文件来启动服务效率就很低 于是想到用Run Dashboard来管理启动类 由于是新的电脑装的IDEA没有自动开启这个工具 因此需要手动开启一下 开启方式
  • 【Docker】安装Presto连接Hive、mysql、oracle、postgresql、SQL server等7种类型数据库

    目录 1 简介 2 下载安装 1 下载镜像 2 下载presto客户端jar文件 3 将hadoop配置拷贝到容器 4 新增hive properties配置文件 5 重启容器 在linux命令行下 3 测试连接 4 其他类型数据库配置连接
  • Java 两点经纬度计算距离和角度

    角度 计算两点对于正北方向的朝向角度 0 360 param start format latitude 30 longitude 120 param end private static double bearing List
  • UEFI入门必读的12本书

    作者简介 罗冰 系统安全 特别是物理隔离领域 专家 主导开发网络隔离卡 双网隔离机 国产隔离系统 单向光传输等各类安全产品 拥有十几项发明和实用新型专利 致力于UEFI技术的研究 实践和推广 在CSDN和知乎上设有 UEFI开发探索 专栏
  • UE4(unreal engine4)蒙太奇动画删除不想要的帧数

    UE4系列文章目录 文章目录 UE4系列文章目录 前言 一 问题原因 二 具体操作步骤 前言 UE4 unreal engine4 蒙太奇动画删除不想要的帧数 当我们在UE4中导入一个fbx骨骼动画 当我们想要截取动画中某些不想用的帧时 点
  • 软件版本号命名规范_产品版本命名的规范与规则

    上一篇文章我们对产品的版本迭代的方法进行了一些总结 本篇文章我会针对产品的版本命名 验收 发布这三个层面 来总结一下我自己的想法 希望能对大家有所帮助 01 产品版本命名的规范与规则 1 1 版本命名规范 软件版本号由主版本号 次版本号 修
  • springboot后台获取不到前台Vue日期问题解决

    一 实体类字段写法如下 JsonFormat pattern yyyy MM dd timezone GMT 8 private Date sendTime Vue使用element ui写法

随机推荐

  • 4.2、Flink任务怎样读取文件中的数据

    目录 1 前言 2 readTextFile 已过时 不推荐使用 3 readFile 已过时 不推荐使用 4 fromSource FileSource 推荐使用 1 前言 思考 读取文件时可以设置哪些规则呢 1 文件的格式 txt cs
  • (二)程序语言设计基础

    目录 1 程序设计语言概述 1 1 基本概念 1 1 1 低级语言和高级语言 1 1 2 编译程序和解释程序 1 1 3 程序设计语言的定义 1 1 4 程序设计语言的分类 1 2 程序设计语言的基本成分 1 2 1 数据成分 1 2 2
  • 2022最新android设备uuid、udid使用教程​

    前言 udid UDID是Unique Device Identifier的缩写 中文意思是设备唯一标识 uuid UUID是Universally Unique Identifier的缩写 中文意思是通用唯一识别码 简言之 udid对应某
  • elasticsearch 中text与keyword的区别

    创建索引 PUT ellis mappings properties name type text fields keyword type keyword ignore above 256 age type long 我们可以看到name类
  • VBA常用语法

    最近接触了一下VBA编程 才知道Excel还能编程 而且还如此强大 真的是惊呆了 话不多说 先了解一下VBA常用的语法吧 1 基础语法 高级for循环 Function deleteArrayByIndex list As String D
  • oracle获取随机记录

    oracle获取随机记录 select from select from ford car order by dbms random value where rownum lt 1001
  • 【vision transformer】DETR原理及代码详解(三)

    transformer 端到端目标检测DETR项目实践及代码详解 Paddle Detr git PaddleViT object detection DETR at develop BR IDL PaddleViT GitHub 数据集及
  • Redis SDS简单动态字符串

    结构体定义 本质上说就是用C语言来实现基本的面向对象 来对底层的字符串进行表示 方便上层使用 为调用者减少负担 typedef char sds struct sdshdr int len int free char buf 举例常用操作
  • 搭建JMeter分布式测试环境

    分布式测试概述 现在我们来了解如何使用多台机器来执行压力测试 也就是所谓的分布式测试 当我们模拟大量的并发虚拟用户时 比如我们要起10万 100万甚至更多的并发用户时 一台负载机器可能就满足不了我们需要的用户量 此时 就需要使用多台主机搭建
  • Git入门--自定义标签

    忽略特殊文件 忽略某些文件时 需要编写 gitignore gitignore文件本身要放到版本库里 并且可以对 gitignore做版本管理 配置别名 git config global alias co checkout 用co来代替c
  • FFmpeg源码分析:av_register_all()注册封装器与解封装器

    FFmpeg中av register all 函数用于注册所有muxers demuxers与protocols FFmpeg4 0以前是用链表存储muxer demuxer FFmpeg4 0以后改为数组存储 并且av register
  • SPP原理和代码

    空间金字塔池化 Spatial Pyramid Pooling SPP 原理和代码实现 Pytorch 一 为什么需要SPP 首先需要知道为什么需要SPP 我们都知道卷积神经网络 CNN 由卷积层和全连接层组成 其中卷积层对于输入数据的大小
  • 众享比特董事长严挺:数字藏品在国内有三大发展趋势

    2022年11月2日 巴比特主办的温州元宇宙月系列活动之 数字藏品 虚拟人 元宇宙营销新策略 论坛在温州召开 众享比特董事长严挺 众享链网发起人严挺出席论坛并进行主题为 元宇宙在国内落地的一些实践分享 的演讲 温州元宇宙主题月秉承 拥抱数字
  • Hyperledger fabric2.4 搭建自己的网络

    1 使用cryptogen工具生成证书 1 1 将fabric samples bin目录下的二进制文件复制到 usr local bin目录 以便全局使用这些命令 cd fabric samples bin cp usr local bi
  • 那些你可能遇到的 Linux 命令?什么,你还不知道?赶紧收藏?完善中!

    文章目录 一 Linux 进程 1 通过进程名查找进程号 1 1 ps aux ps ef diff 1 2 ps aux ps aux 什么 它们不一样 1 3 grep awk 取出进程号 取出进程号并 Kill 2 通过进程号查看进程
  • LINUX应用和驱动交互的四种方式

    Linux开发中 应用读取数据时往往会遇到驱动尚未获得有效数据的情况 所以需要采用适合的同步方式 1 非阻塞方式 非阻塞方式 顾名思义就是不管数据是否准备好 驱动都会返回结果 采用这种方式就需要应用不停地重复查询 查询硬件的线程就会一直都占
  • Centos7 升级openssl-1.1.1s及openssh-9.1p1(附脚本)

    主要是上个月openssl出现了漏洞 因此要对服务器的进行升级 建议如果没问题还是尽量别升级 主要步骤是2 脚本内容也只包含升级 1和3是开启和关闭telnet 不建议使用telnet 1 安装和启动telnet 实际中我没使用telnet
  • 数据结构前言

    一 什么是数据结构 数据结构是计算机存储 组织数据的方式 数据结构是指相互之间存在一种或多种特定关系的数据元素的集合 上面是百度百科的定义 通俗的来讲数据结构就是数据元素集合与数据元素集合或者数据元素与数据元素之间的组成形式 举个简单明了的
  • Web Worker 用法

    一 概述 JavaScript 语言采用的是单线程模型 也就是说 所有任务只能在一个线程上完成 一次只能做一件事 前面的任务没做完 后面的任务只能等着 随着电脑计算能力的增强 尤其是多核 CPU 的出现 单线程带来很大的不便 无法充分发挥计
  • DBaaS体系及特性

    用户对云计算的交付能力已经不再满足于单纯的基础设施 IaaS 交付 他们希望数据中心中的更多传统IT 服务能以云服务模式进行交付 其中最为迫切的就是数据库 将数据库以云服务模式交付给用户 就是数据库即服务 DBaaS 也称云数据库 传统数据