浅谈数据库集群(一)

  如今,随着上网人数的激增,一些大型的网站开始使用数据库集群来提升数据库的可靠性和数据库的性能。那么在介绍数据库集群以前首先须要弄清楚几个问题。mysql

1.为何要用数据库集群sql

        (1)经过使用数据库集群可使读写分离,提升数据库的系统性能。数据库

        你们都知道,mysql是支持分布式的。MySQL Proxy最强大的一项功能是实现“读写分离(Read/Write Splitting)”。基本的原理是让主数据库处理事务性查询,而从数据库处服务器

理SELECT查询。数据库复制被用来把事务性查询致使的变动同步到集群中的从数据库,从而使从数据库和主数据库的数据保持一致。 固然,主服务器也能够提供查询服务。网络

使用读写分离最大的做用无非是环境服务器压力。能够看下这张图:并发

 

 

——————————————————————————————————————————————————————————异步

 

   为何读写分离能提升数据库的性能?(摘自网络)分布式

        1.物理服务器增长,负荷增长
        2.主从只负责各自的写和读,极大程度的缓解X锁和S锁争用
        3.从库可配置myisam引擎,提高查询性能以及节约系统开销
        4.从库同步主库的数据和主库直接写仍是有区别的,经过主库发送来的binlog恢复数据,可是,最重要区别在于主库向从库发送binlog是异步的,从库恢复数据也是异步的
        5.读写分离适用与读远大于写的场景,若是只有一台服务器,当select不少时,update和delete会被这些select访问中的数据堵塞,等待select结束,并发性能不高。 对于写和读比例相近的应用,应该部署双主相互复制oop

        6.能够在从库启动是增长一些参数来提升其读的性能,例如--skip-innodb、--skip-bdb、--low-priority-updates以及--delay-key-write=ALL。固然这些设置也是须要根据具体业务需求来定得,不必定能用上性能

        7.分摊读取。假如咱们有1主3从,不考虑上述1中提到的从库单方面设置,假设如今1 分钟内有10条写入,150条读取。那么,1主3从至关于共计40条写入,而读取总数没变,所以平均下来每台服务器承担了10条写入和50条读取(主库不 承担读取操做)。所以,虽然写入没变,可是读取大大分摊了,提升了系统性能。另外,当读取被分摊后,又间接提升了写入的性能。因此,整体性能提升了,说白 了就是拿机器和带宽换性能。MySQL官方文档中有相关演算公式:官方文档 见6.9FAQ之“MySQL复制可以什么时候和多大程度提升系统性能”

        8.MySQL复制另一大功能是增长冗余,提升可用性,当一台数据库服务器宕机后能经过调整另一台从库来以最快的速度恢复服务,所以不能光看性能,也就是说1主1从也是能够的。

——————————————————————————————————————————————————————————

2.数据库集群和分布式数据库有什么区别?

        一句话:分布式是并联工做的,集群是串联工做的。

       1:分布式是指将不一样的业务分布在不一样的地方。 而集群指的是将几台服务器集中在一块儿,实现同一业务。分布式中的每个节点,均可以作集群。 而集群并不必定就是分

布式的。

        举例:就好比新浪网,访问的人多了,他能够作一个群集,前面放一个响应服务器,后面几台服务器完成同一业务,若是有业务访问的时候,响应服务器看哪台服务器的

负载不是很重,就将给哪一台去完成。而分布式,从窄意上理解,也跟集群差很少, 可是它的组织比较松散,不像集群,有一个组织性,一台服务器垮了,其它的服务器能够顶上来。

        分布式的每个节点,都完成不一样的业务,一个节点垮了,哪这个业务就不可访问了。

        2:简单说,分布式是以缩短单个任务的执行时间来提高效率的,而集群则是经过提升单位时间内执行的任务数来提高效率。

        举例:若是一个任务由10个子任务组成,每一个子任务单独执行需1小时,则在一台服务器上执行该任务需10小时。

采用分布式方案,提供10台服务器,每台服务器只负责处理一个子任务,不考虑子任务间的依赖关系,执行完这个任务只需一个小时。(这种工做模式的一个典型表明就是

Hadoop的Map/Reduce分布式计算模型)

        而采用集群方案,一样提供10台服务器,每台服务器都能独立处理这个任务。假设有10个任务同时到达,10个服务器将同时工做,1小时后,10个任务同时完成,这样,

整身来看,仍是1小时内完成一个任务!

          看下图:

转载自:http://blog.csdn.net/zhangzijiejiayou

相关文章
相关标签/搜索