数据库大型应用解决方案_第1页
数据库大型应用解决方案_第2页
数据库大型应用解决方案_第3页
免费预览已结束,剩余5页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、随着互联网应用的广泛普及,海量数据的存储和访问成为了系统设计的瓶颈问题。对于一个大型的互联网应用,每天百万级甚至上亿的PV无疑对数据库造成了相当高的负载。对于系统的稳定性和扩展性造成了极大的问题。more一、负载均衡技术负载均衡集群是由一组相互独立的计算机系统构成,通过常规网络或专用网络进行连接,由路由器衔接在一起,各节点相互协作、共同负载、均衡压力,对客户端来说,整个群集可以视为 一台具有超高性能的独立服务器。1实现原理实现数据库的负载均衡技术,首先要有一个可以控制连接数据库的控制端。在这里,它截断了数据库和程序的直接连接,由所有的程序来访问这个中间层,然后再由中间层来访问数据库。这样,我们

2、就可以具体控制访问某个数据库了,然后还可以根据数据库的当前负载采取有效的均衡策略,来调整每次连接到哪个数据库。2、实现多据库数据同步对于负载均衡,最重要的就是所有服务器的数据都是实时同步的。这是一个集群所必需的,因为,如果数不据实时、不同步,那么用户从一台服务器读岀的数据,就有别于从另一台服务器读出的数据,这是不能允许的。所以必须实现数据库的数据同步。这样,在查询的时候就可以 有多个资源,实现均衡。比较常用的方法是Moebius for SQLServer集群,Moebius for SQLServer集群采用将核心程序驻留在每个机器的数据库中的办法,这个核心程序称为 Moebius forS

3、QL Server中间件,主要作用是监测数据库内数据的变化并将变化的数据同步到其他数据库中。数据同步完成后客户端才会得到响应,同步过程是并发完成的,所以同步到多个数据库和同步到一个数据库的时间基本相等;另外同步的过程是在事务的环境下完成的,保证了多份数据在任何时刻数据的一致性。正因为Moebius中间件宿主在数据库中的创新,让中间件不但能知道数据的变化,而且知道引起数据变化的SQL语句,根据SQL语句的类型智能的采取不同的数据同步的策略以保证数据同步成本的最小化。数据条数很少,数据内容也不大,则直接同步数据数据条数很少,但是里面包含大数据类型,比如文本, 然后再同步,从而减少网络带宽的占用和传

4、输所用的时间。二进制数据等,则先对数据进行压缩数据条数很多,此时中间件会拿到造成数据变化的SQL语句,然后对SQL语句进行解析,SQL语句到其他的数据库中。此种情况分析其执行计划和执行成本, 并选择是同步数据还是同步 应用在对表结构进行调整或者批量更改数据的时候非常有用。3、优缺点(1) 扩展性强:当系统要更高数据库处理速度时,只要简单地增加数据库服务器就可以得到扩展。(2) 可维护性:当某节点发生故障时,系统会自动检测故障并转移故障节点的应用,保证数据库的持续工作。(3) 安全性:因为数据会同步的多台服务器上,可以实现数据集的冗余,通过多份数据来保证安全性。另外它成功地将数据库放到了内网之中

5、,更好地保护了数据库的安全性。(4) 易用性:对应用来说完全透明,集群暴露岀来的就是一个IP(1) 不能够按照Web服务器的处理能力分配负载。(2) 负载均衡器(控制端)故障,会导致整个数据库系统瘫痪。、数据库的读写分离1,实现原理:读写分离简单的说是把对数据库读和写的操作分开对应不同的数据库服务器,这样能有效地减轻数据库压力,也能减轻io压力。主数据库提供写 操作,从数据库提供读操作,其实在很多系统中,主要是读的操作。当主数据库进行写操作时,数据要同步到从的数据库,样才能有效保证数据库完整性。Portal LayerApplication LayeWriteRadDatabase数据库BIG

6、 IP 64如用那宜摆机(ebay的读写比率是 260:1,ebay 的读写分离)应用程序服务器(微软数据库分发)2,实现方法: 在MS Sql server 中可以使用发布定义的方式实现数据库复制,实现读写分离,复制是将一组数据从一个数据源拷贝到多个数据源的技术,是将一份数据发布到多个存储站点上的有效方式。使用复制技术,用户可以将一份数据发布到多台服务器上。复制技术可以确保分布在不同地点的数据自动同步更新,从而保证数据的一致性。SQL SERVER制技术类型有三种,分别是:快照复制、事务复制、合并复制。SQL SERVER主要采用岀版物、订阅的方式来处理复制。源数据所在的服务器是岀版服务器,

7、负责发表数据。岀版服务器把要发表的数据的所有改变情况的拷贝复制到分发服务 器,分发服务器包含有一个分发数据库,可接收数据的所有改变, 并保存这些改变,再把这些改变分发给订阅服务器。3,优缺点( 1)数据的实时性差:数据不是实时同步到自读服务器上的,当数据写入主服务器后,要 在下次同步后才能查询到。( 2)数据量大时同步效率差:单表数据量过大时插入和更新因索引,磁盘IO 等问题,性能会变的很差。( 3)同时连接多个(至少两个)数据库:至少要连接到两个数据数据库,实际的读写操作 是在程序代码中完成的,容易引起混乱( 4)读具有高性能高可靠性和可伸缩:只读服务器,因为没有写操作,会大大减轻磁盘IO等

8、性能问题, 大大提高效率; 只读服务器可以采用负载均衡, 主数据库发布到多个只读服务器上 实现读操作的可伸缩性。三、数据库拆分(分布式)通过某种特定的条件, 将存放在同一个数据库中的数据分散存放到多个数据库上, 实现分布 存储, 通过路由规则路由访问特定的数据库, 这样一来每次访问面对的就不是单台服务器了, 而 是 N 台服务器,这样就可以降低单台机器的负载压力。垂直(纵向)拆分:是指按功能模块拆分,比如分为订单库、商品库、用户库 . 这种方式 多个数据库之间的表结构不同。水平(横向)拆分:将同一个表的数据进行分块保存到不同的数据库中, 这些数据库中的表 结构完全相同。s 3 5订草库产船暉甲

9、广库(纵向拆分)(横向拆分)数据库1,实现原理:使 用垂直拆分,主要要看应用类型是否合适这种拆分方式,如系统可以分为,订 单系统,商品管理系统,用户管理系统业务系统比较明的,垂直拆分能很好的起到分散压力的作用。业务模块不明晰,耦合(表关联)度比较高的系统不适合使用这种拆分方式。但是垂直拆分方式并不能彻底解决所有压力问题,例如 有一个 5000w 的订单表,操作起来订单库的 压力仍然很大,如我们需要在这个表中增加( insert )一条新的数据, insert 完毕后,数据库 会针对这 张表重新建立索引, 5000w 行数据建立索引的系统开销还是不容忽视的,反过来,假 如我们将这个表分成 100

10、 个 table 呢,从 table_001 一直到 table_100 ,5000w 行数据平均下来, 每个子表里边就只有 50万行数据,这时候我们向一张只有50w行数据的table中insert数据后建立索引的时间就会呈数量级的下降,极大了提高了DB的运行时效率,提高了DB的并发量,这种拆分就是横向拆分2,实现方法: 垂直拆分,拆分方式实现起来比较简单,根据表名访问不同的数据库就可以 了。横向拆分的规则很多,这里总结前人的几点,(1) 顺序拆分:如可以按订单的日前按年份才分,2003年的放在db1中,2004年的db2,以此类推。当然也可以按主键标准拆分。优点:可部分迁移缺点:数据分布不均,可能 2003年的订单有 100W, 2008 年的有 500W。(2) hash取模分:对user_id进行hash(或者如果user_id是数值型的话直接使用user_id的值也可),然后用一个特定的数字,比如应用中需要将一个数据库切分成 4个数据库的话,我们就用 4 这个数字对 user_id 的 hash 值进行取模运算,也就是 user_id%4 ,这样的话每次运 算就有四种可能:结果为1的时候对应 DB1;结果为2的时候对应 DB2;结果为3的时候对应DB3;结果为0的时候对应 DB4,这样一来就非常均匀的将数据分配到4个DB中。优点:数据

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论