网络舆情网站,外贸代运营,wordpress数据库导入,餐饮众筹模板网站建设一、云计算是云数据库兴起的基础 云计算是分布式计算、并行计算、效用计算、网络存储、虚拟化、负载均衡等计算机和网络技术发展融合的产物。云计算是由一系列可以动态升级和被虚拟化的资源组成的#xff0c;用户无需掌握云计算的技术#xff0c;只要通过网络就可以访问这些资…一、云计算是云数据库兴起的基础 云计算是分布式计算、并行计算、效用计算、网络存储、虚拟化、负载均衡等计算机和网络技术发展融合的产物。云计算是由一系列可以动态升级和被虚拟化的资源组成的用户无需掌握云计算的技术只要通过网络就可以访问这些资源。 云计算主要包括 3 种类型即 IaaSInfrastructure as a Service、PaaSPlatform as a Service和 SaaSSoftware 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 元可获得的 QPSQuery 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 基础设施和配置数据库成本相对而言比较昂贵而且需要自己进行机房维护和数据库故障处理。