云数据库知识学习——概述

一、云计算是云数据库兴起的基础

        云计算是分布式计算、并行计算、效用计算、网络存储、虚拟化、负载均衡等计算机和网络技术发展融合的产物。云计算是由一系列可以动态升级和被虚拟化的资源组成的,用户无需掌握云计算的技术,只要通过网络就可以访问这些资源。

        云计算主要包括 3 种类型,即 IaaS(Infrastructure as a Service)、PaaS(Platform as a Service)和 SaaS(Software as a Service)。以 SaaS 为例,它极大地改变了用户使用软件的方式,用户不再需要购买软件安装到本地计算机上,只要通过网络就可以使用各种软件。SaaS 厂商将应用软件统一部署在自己的服务器上,用户可以在线购买、在线使用、按需付费。成立于 1999 年的 Salesforce公司,是 SaaS 厂商的先驱,提供 SaaS 云服务,并提出了“终结软件”的口号。在该公司的带动下,其他 SaaS 厂商如雨后春笋般的大量涌现。

        与传统的软件使用方式相比,云计算这种模式具有明显的优势,见表 6-1。

二、云数据库的概念

        云数据库是部署和虚拟化在云计算环境中的数据库。云数据库是在云计算的大背景下发展起来的一种新兴的共享基础架构的方法,它极大地增强了数据库的存储能力,消除了人员、硬件、软件的重复配置,让软、硬件升级变得更加容易,同时也虚拟化了许多后端功能。云数据库具有高可扩展性、高可用性、采用多租形式和支持资源有效分发等特点。

        在云数据库中,所有数据库功能都是在云端提供的,客户端可以通过网络远程使用云数据库提供的服务,如图 6-1 所示。客户端不需要了解云数据库的底层细节,所有的底层硬件都已经被虚拟化,对客户端而言是透明的,就像在使用一个运行在单一服务器上的数据库一样,非常方便容易,同时又可以获得理论上近乎无限的存储和处理能力。

        需要指出的是,有人认为数据库属于应用基础设施(即中间件),因此把云数据库列入 PaaS的范畴,也有人认为数据库本身也是一种应用软件,因此把云数据库划入 SaaS。对于这个问题,本文把云数据库划入 SaaS,但同时也认为,云数据库到底应该被划入 PaaS 还是 SaaS,这并不是最重要的。实际上,云计算 IaaS、PaaS 和 SaaS 这 3 个层次之间的界限有些时候也不是非常明晰。对于云数据库而言,最重要的方面就是它允许用户以服务的方式通过网络获得云端的数据库功能。

三、云数据库的特性

3.1.动态可扩展

        理论上,云数据库具有无限可扩展性,可以满足不断增加的数据存储需求。在面对不断变化的条件时,云数据库可以表现出很好的弹性。例如,对于一个从事产品零售的电子商务公司,会存在季节性或突发性的产品需求变化,或者对于类似 Animoto 的网络社区站点,可能会经历一个指数级的用户增长阶段,这时,就可以分配额外的数据库存储资源来处理增加的需求,这个过程只需要几分钟。一旦需求过去以后,就可以立即释放这些资源。

3.2.高可用性

        不存在单点失效问题。如果一个节点失效了,剩余的节点就会接管未完成的事务。而且,在云数据库中,数据通常是冗余存储的,在地理上也是分布的。诸如 Google、Amazon 和 IBM 等大型云计算供应商,具有分布在世界范围内的数据中心,通过在不同地理区间内进行数据复制,可以提供高水平的容错能力。例如,Amazon SimpleDB 会在不同的区域内进行数据复制,因此,即使某个区域内的云设施发生失效,也可以保证数据继续可用。

3.3.较低的使用代价

        通常采用多租户(Multi-tenancy)的形式,同时为多个用户提供服务,这种共享资源的形式对于用户而言可以节省开销,而且用户采用“按需付费”的方式使用云计算环境中的各种软、硬件资源,不会产生不必要的资源浪费。另外,云数据库底层存储通常采用大量廉价的商业服务器,这也大大降低了用户开销。腾讯云数据库官方公布的资料显示,当实现类似的数据库性能时,如果采用自己投资自建 MySQL 的方式,则单价为每台每天 50.6 元,实现双机容灾需要 2 台,即 101.2元/天,平均存储成本是 0.25 元每 GB 每天,平均 1 元可获得的 QPS(Query Per Second)为 24 次/秒;而如果采用腾讯云数据库产品,企业不需要投入任何初期建设成本,成本仅为 72 元/天,平均存储成本为 0.18 元每 GB 每天,平均 1 元可获得的 QPS 为 83 次/秒,相对于自建,云数据库平均 1 元获得的 QPS 提高为原来的 346%,具有极高的性价比。

3.4.易用性

        使用云数据库的用户不用控制运行原始数据库的机器,也不必了解它身在何处。用户只需要一个有效的连接字符串(URL)就可以开始使用云数据库,而且就像使用本地数据库一样。许多基于MySQL 的云数据库产品(如腾讯云数据库、阿里云 RDS 等),完全兼容 MySQL 协议,用户可通过基于 MySQL 协议的客户端或者 API 访问实例。用户可无缝地将原有 MySQL 应用迁移到云存储平台,无需进行任何代码改造。

3.5.高性能

        采用大型分布式存储服务集群,支撑海量数据访问,多机房自动冗余备份,自动读写分离。

3.6.免维护

        用户不需要关注后端机器及数据库的稳定性、网络问题、机房灾难、单库压力等各种风险,云数据库服务商提供 7×24h 的专业服务,扩容和迁移对用户透明且不影响服务,并且可以提供全方位、全天候立体式监控,用户无需半夜去处理数据库故障。

3.7.安全

        提供数据隔离,不同应用的数据会存在于不同的数据库中而不会相互影响;提供安全性检查,可以及时发现并拒绝恶意攻击性访问;数据提供多点备份,确保不会发生数据丢失。

        以腾讯云数据库为例,开发者可快速在腾讯云中申请云服务器实例资源,通过 IP/PORT 直接访问 MySQL 实例,完全无需再安装 MySQL 实例,可以一键迁移原有 SQL 应用到腾讯云平台,大大节省了人力成本;同时,该云数据库完全兼容 MySQL 协议,可通过基于 MySQL 协议的客户端或 API 便捷地访问实例。此外,还采用了大型分布式存储服务集群,支撑海量数据访问,7×24h的专业存储服务,可以提供高达 99.99%服务可用性的 MySQL 集群服务,并且数据可靠性超过99.999%。腾讯云数据库和自建数据库的比较见表 6-2。

四、云数据库是个性化数据存储需求的理想选择

        在大数据时代,每个企业几乎每天都在不断产生大量的数据。企业类型不同,对于存储的需求也千差万别,而云数据库可以很好地满足不同企业的个性化存储需求。

        首先,云数据库可以满足大企业的海量数据存储需求。云数据库在当前数据爆炸的大数据时代具有广阔的应用前景。根据 IDC 的研究报告,企业对结构化数据的存储需求每年会增加 20%左右,而对非结构化数据的存储需求将会每年增加 60%左右。传统的关系数据库难以水平扩展,根本无法存储如此海量的数据。因此,具有高可扩展性的云数据库就成为企业海量数据存储管理的很好选择。

        其次,云数据库可以满足中小企业的低成本数据存储需求。中小企业在 IT 基础设施方面的投入比较有限,非常渴望从第三方方便、快捷、廉价地获得数据库服务。云数据库采用多租户方式同时为多个用户提供服务,降低了单个用户的使用成本,而且用户使用云数据库服务通常按需付费,不会浪费资源造成额外支出。因此,云数据库使用成本很低,对于中小企业而言可以大大降低企业的信息化门槛,让企业在付出较低成本的同时,获得优质的专业级数据库服务,从而有效提升企业信息化水平。

        另外,云数据库可以满足企业动态变化的数据存储需求。企业在不同时期需要存储的数据量是不断变化的,有时增加,有时减少。在小规模应用的情况下,系统负载的变化可以由系统空闲的多余资源来处理,但是在大规模应用的情况下,传统的关系数据库由于其伸缩性较差,不仅无法满足应用需求,而且会给企业带来高昂的存储成本和管理开销。而云数据库的良好伸缩性,可以让企业在需求增加时立即获得数据库能力的提升,在需求减少时立即释放多余的数据库能力,较好地满足企业的动态数据存储需求。

        当然,并不是说云数据库可以满足不同类型的个性化存储需求,就意味着企业一定要把数据存放到云数据库中。到底选择自建数据库还是选择云数据库,取决于企业自身的具体需求。对于一些大型企业,目前通常采用自建数据库,一方面是由于企业财力比较雄厚,有内部的 IT 团队负责数据库维护,另一方面数据是现代企业的核心资产,涉及很多高级商业机密,企业出于数据安全考虑,不愿意把内部数据保存在公有云的云数据库中,尽管云数据库供应商也会一直强调数据的安全性,但是这依然不能打消企业的顾虑。对于一些财力有限的中小企业而言,IT 预算比较有限,不可能投入大量资金建设和维护数据库,企业数据并非特别敏感,因此云数据库这种前期零投入、后期免维护的数据库服务,可以很好地满足他们的需求。

五、云数据库与其他数据库的关系

        关系数据库采用关系数据模型,NoSQL 数据库采用非关系数据模型,二者都属于不同的数据库技术。从数据模型的角度来说,云数据库并非一种全新的数据库技术,而只是以服务的方式提供数据库功能。云数据库并没有专属于自己的数据模型,云数据库所采用的数据模型可以是关系数据库所使用的关系模型(如微软的 SQL Azure 云数据库、阿里云 RDS 都采用了关系模型),也可以是 NoSQL 数据库所使用的非关系模型(如 Amazon Dynamo 云数据库采用的是“键/值”存储)。同一个公司也可能提供采用不同数据模型的多种云数据库服务,例如百度云数据库提供了 3 种数据库服务,即分布式关系型数据库服务(基于关系数据库 MySQL)、分布式非关系型数据库服务(基于文档数据库 MongoDB)、键/值型非关系型数据库服务(基于键/值数据库 Redis)。实际上,许多公司在开发云数据库时,后端数据库都是直接使用现有的各种关系数据库或 NoSQL 数据库产品。比如,腾讯云数据库采用 MySQL 作为后端数据库,微软的 SQL Azure 云数据库采用 SQLServer 作为后端数据库。从市场的整体应用情况来看,由于 NoSQL 应用对开发者要求较高,而MySQL 拥有成熟的中间件、运维工具,已经形成一个良性的生态圈等,因此从现阶段来看,云数据库的后端数据库主要是以 MySQL 为主、NoSQL 为辅。

        在云数据库这种 IT 服务模式出现之前,企业要使用数据库,就需要自建关系数据库或 NoSQL数据库,它们被称为“自建数据库”。云数据库与这些“自建数据库”最本质的区别在于,云数据库是部署在云端的数据库,采用 SaaS 服务模式,用户可以通过网络租赁使用数据库服务,只要有网络的地方都可以使用,不需要前期投入和后期维护,使用价格也比较低廉,云数据库对用户而言是完全透明的,用户根本不知道自己的数据被保存在哪里。云数据库通常采用多租户模式,即多个租户共用一个实例,租户的数据既有隔离又有共享,从而解决了数据存储的问题,同时也降低了用户使用数据库的成本。而自建的关系数据库和 NoSQL 数据库本身都没有采用 SaaS 服务模式,需要用户自己搭建 IT 基础设施和配置数据库,成本相对而言比较昂贵,而且需要自己进行机房维护和数据库故障处理。

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

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

相关文章

Maven中导入jQuery,前端页面中引用jQuery

第一步pom文件中,配置maven坐标。 第二步,在前端页面中引用jQuery 注:该前端页面需要在web根目录即webapp目录下。可认为在maven中导入jQuery后,jquery.min.js文件放在目录webapp/webjars/jquery/3.3.1下。

java实现本地文件转文件流发送到前端

java实现本地文件转文件流发送到前端 Controller public void export(HttpServletResponse response) {// 创建file对象response.setContentType("application/octet-stream");// 文件名为 sresponse.setHeader("Content-Disposition", "attachment;…

【C# Programming】编程入门:方法和参数

一、方法 1、方法的定义 由一系列以执行特定的操作或计算结果语句组成。方法总是和类关联,类型将相关的方法分为一组。 方法名称 形参和实参(parameter & argument)返回值 2、命名空间 一种分类机制,用于组合功能相关的所有类型。命名空间是分级…

架构师成长之路|Redis实现延迟队列的三种方式

延迟队列实现 基于监听key过期实现的延迟队列实现,这里需要继承KeyspaceEventMessageListener类来实现监听redis键过期 public class KeyExpirationEventMessageListener extends KeyspaceEventMessageListener implementsApplicationEventPublisherAware {private static f…

HarmonyOS开发:探索动态共享包的依赖与使用

前言 所谓共享包,和Android中的Library本质是一样的,目的是为了实现代码和资源的共享,在HarmonyOS中,给开发者提供了两种共享包,HAR(Harmony Archive)静态共享包,和HSP(H…

docker镜像配置mysql、redis

mysql 拉取mysql镜像 docker pull mysql:5.7创建并运行mysql容器 docker run -p 3306:3306 --name mysql\-v /mydata/mysql/log:/var/log/mysql\-v /mydata/mysql/data:/var/lib/mysql\-v /mydata/mysql/conf:/etc/mysql \-e MYSQL_ROOT_PASSWORD123456\-d mysql:5.7-e 设置…

Spring整合tomcat的WebSocket详细逻辑(图解)

主要解决存在的疑问 为什么存在2种spring整合websocket的方式,一种是使用ServerEndpoint注解的方式,一种是使用EnableWebSocket注解的方式,这2种有什么区别和联系?可以共存吗?它们实现的原理是什么?它们的各…

redis实战篇之导入黑马点评项目

1. 搭建黑马点评项目 链接:https://pan.baidu.com/s/1Q0AAlb4jM-5Fc0H_RYUX-A?pwd6666 提取码:6666 1.1 首先,导入SQL文件 其中的表有: tb_user:用户表 tb_user_info:用户详情表 tb_shop:商户…

windows11安装docker时,修改默认安装到C盘

1、修改默认安装到C盘 2、如果之前安装过docker,请删除如下目录:C:\Program Files\Docker 3、在D盘新建目录:D:\Program Files\Docker 4、winr,以管理员权限运行cmd 5、在cmd中执行如下命令,建立软联接: m…

【办公类-19-03】办公中的思考——Python批量制作word单元格照片和文字(小照片系列)

背景需求: 工会老师求助:如何在word里面插入4*8的框,我怎么也拉不到4*8大小(她用的是我WORD 文本框) 我一听,这又是要手动反复黏贴“文本框”“照片”“文字”的节奏哦 我问:你要做几个人&…

WEB APIs day6

一、正则表达式 RegExp是正则表达式的意思 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" co…

Ubuntu离线或在线安装Python解释器

这里以安装Python3.5.7为例。 首先进入官网&#xff0c;下载Python-3.5.7.tgz&#xff0c;或者使用以下命令下载&#xff08;需要联网&#xff09;&#xff1a; wget https://www.python.org/ftp/python/3.5.7/Python-3.5.7.tgz下载完成后&#xff0c;使用以下命令进行解压缩…

【教程】安防监控/视频存储/视频汇聚平台EasyCVR接入智能分析网关V4的操作步骤

TSINGSEE青犀AI边缘计算网关硬件 —— 智能分析网关目前有5个版本&#xff1a;V1、V2、V3、V4、V5&#xff0c;每个版本都能实现对监控视频的智能识别和分析&#xff0c;支持抓拍、记录、告警等&#xff0c;每个版本在算法模型及性能配置上略有不同。硬件可实现的AI检测包括&am…

Qt利用QTime实现sleep效果分时调用串口下发报文解决串口下发给下位机后产生的粘包问题

Qt利用QTime实现sleep效果分时调用串口下发报文解决串口下发给下位机后产生的粘包问题 文章目录 Qt利用QTime实现sleep效果分时调用串口下发报文解决串口下发给下位机后产生的粘包问题现象解决方法 现象 当有多包数据需要连续下发给下位机时&#xff0c;比如下载数据等&#x…

1987-2021年全国31省专利申请数和授权数

1987-2021年全国31省国内三种专利申请数和授权数 1、时间&#xff1a;1987-2021年 2、来源&#xff1a;整理自国家统计局、科技统计年鉴、各省年鉴 3、范围&#xff1a;31省市 4、指标&#xff1a;国内专利申请受理量、国内发明专利申请受理量、国内实用新型专利申请受理量…

Java“牵手”阿里巴巴商品详情数据,阿里巴巴商品详情API接口,阿里巴巴国际站API接口申请指南

阿里巴巴平台商品详情接口是开放平台提供的一种API接口&#xff0c;通过调用API接口&#xff0c;开发者可以获取阿里巴巴商品的标题、价格、库存、月销量、总销量、库存、详情描述、图片等详细信息 。 获取商品详情接口API是一种用于获取电商平台上商品详情数据的接口&#xf…

高频知识汇总 |【计算机网络】面试题汇总(万字长文通俗易懂)

我之前也已经在写了好几篇高频知识点汇总&#xff0c;简要介绍一下&#xff0c;有需要的同学可以点进去先收藏&#xff0c;之后用到时可以看一看。如果有帮助的话&#xff0c;希望大家给个赞&#xff0c;给个收藏&#xff01;有疑问的也可以在评论区留言讨论&#xff0c;能帮的…

WebStorm2023新版设置多个窗口,支持同时显示多个项目工程

调整设置 Appearance & Behavior -> System Settings> Project open project in New window&#xff1a;

数据结构之队列的实现(附源码)

目录 一、队列的概念及结构 二、队列的实现 拓展&#xff1a;循环队列 三、初学的队列以及栈和队列结合的练习题 一、队列的概念及结构 队列&#xff1a;只允许在一端进行插入数据操作&#xff0c;在另一端进行删除数据操作的特殊线性表&#xff0c;队列具有先进先出FIFO(Fi…

RabbitMQ:work结构

> 只需要在消费者端&#xff0c;添加Qos能力以及更改为手动ack即可让消费者&#xff0c;根据自己的能力去消费指定的消息&#xff0c;而不是默认情况下由RabbitMQ平均分配了&#xff0c;生产者不变&#xff0c;正常发布消息到默认的exchange > 消费者指定Qoa和手动ack …