`

数据库集群简单概念

 
阅读更多

1.集群定义:
集群是指用一组服务器运行一到多个应用程序。

集群可以简单到只有两台服务器,在他们之间配置故障切换,如果一台服务器失效,由另一台服务器接管应用程序的处理。集群也可以用来运行复杂的分布式系统:应用程序将数据分割成多个可管理的部分,每个部分都可以独立进行处理。如果一台服务器失效,其他服务器不会受影响,失效节点的进程被重新分配到集群中的其他节点。

 

2.集群的分类

故障切换集群、分布式数据库系统
故障切换集群又可以分为两类:(主动/被动集群、主动/主动集群)

主动/被动集群:任何时候都只有一台服务器拥有负载,辅助服务器以被动模式运行,时刻等待着主动服务器停机进而接管主服务器,它一直与主动服务器保持同步。缺点:只有一个服务器拥有负载,资源浪费,效率低。

 主动/主动集群:两台服务器同时都执行实际的任务。每台服务器都同一个实例,同时又可以作为其他服务器上运行的实例的故障切换数据库。

 

3.为什么要用数据库集群
使用读写分离,提高数据库的系统性能。
让主数据库处理事务性操作,从数据库处理SELECT查询。数据库复制被用来把事务性查询导致的变更同步到集群中的从数据库,从而使从数据库和主数据库的数据保持一致。 主服务器也可以提供查询服务。

 

4.为什么读写分离能提高数据库的性能?
1).物理服务器增加,负荷增加
2).主从只负责各自的写和读,极大程度的缓解X锁和S锁争用
3).从库可配置myisam引擎,提升查询性能以及节约系统开销
4).从库同步主库的数据和主库直接写还是有区别的,通过主库发送来的binlog恢复数据,但是,最重要区别在于主库向从库发送binlog是异步的,从库恢复数据也是异步的。
5).读写分离适用与读远大于写的场景,如果只有一台服务器,当select很多时,update和delete会被这些select访问中的数据堵塞,等待select结束,并发性能不高。对于写和读比例相近的应用,应该部署双主相互复制。
6).分摊读取。假如我们有1主3从,假设现在1分钟内有10条写入,150条读取。那么,1主3从相当于共计40条写入,而读取总数没变,因此平均下来每台服务器承担了10条写入和50条读取。因此,虽然写入没变,但是读取大大分摊了,提高了系统性能。另外,当读取被分摊后,又间接提高了写入的性能。
7).MySQL复制另外一大功能是增加冗余,提高可用性,当一台数据库服务器宕机后能通过调整另外一台从库来以最快的速度恢复服务。

 

5.数据库集群和分布式数据库有什么区别?
1).分布式是并联工作的,集群是串联工作的。
2).分布式是指将不同的业务分布在不同的地方。集群指的是将几台服务器集中在一起,实现同一业务。分布式中的每一个节点,都可以做集群。 而集群并不一定就是分布式的。分布式的每一个节点,都完成不同的业务,一个节点垮了,哪这个业务就不可访问了。
举例:比如新浪网,访问的人多了,他可以做一个群集,前面放一个响应服务器,后面几台服务器完成同一业务,如果有业务访问的时候,响应服务器看哪台服务器的
负载不是很重,就将给哪一台去完成。而分布式,跟集群差不多, 但是它的组织比较松散,不像集群,有一个组织性,一台服务器垮了,其它的服务器可以顶上来。
3).分布式是以缩短单个任务的执行时间来提升效率的,而集群则是通过提高单位时间内执行的任务数来提升效率。

分享到:
评论

相关推荐

    数据库集群系统实现方案详解数据库集群系统实现方案详解

    【数据库集群系统实现方案详解】 数据库集群是一种高可用性和高可靠性的解决方案,它通过将多台服务器联结成一个整体,对外展现为一个单一的系统,以提供不间断的服务。集群技术的关键在于,当集群中的一台服务器...

    MS SQL SERVER 数据库集群知多少

    1. **集群概念**:数据库集群是一种硬件和软件的组合,其中多个物理服务器(节点)协同工作,共同管理一个单一的逻辑数据库实例。当一个节点发生故障时,其他节点能够接管服务,确保业务连续性。 2. **SQL Server ...

    mysql数据库各集群优缺点

    #### 一、MySQL数据库集群概念 MySQL数据库集群是指通过一组相互连接的数据库服务器组成的系统,这些服务器共同提供数据服务,旨在提高数据的可用性、可扩展性和性能。集群通常包括多种不同的配置模式,如Master-...

    Oracle 12c RAC数据库集群运维宝典.pdf

    "Oracle 12c RAC 数据库集群运维宝典" ...本书籍为读者提供了 Oracle 12c RAC 数据库集群的运维知识点,涵盖了基本概念、架构特性、日常运维命令等方面,旨在帮助初学者快速掌握 RAC 环境运维技能。

    Oracle RAC集群的简单介绍

    **一、Oracle RAC的基本概念** 1. **实例(Instance)**:每个Oracle RAC节点上运行的数据库软件组件,包括内存结构(如SGA)和后台进程。每个实例都有自己的PGA(Program Global Area)内存,但共享SGA中的数据。 ...

    Oracle数据库高可用集群实现方案.pdf

    下面将详细讲解这两种架构的概念、体系结构和实现的功能,同时比较它们的稳定性、容错性、资源利用率、可扩展性和可维护性,并结合实践案例,说明湖北省电力公司如何采用Oracle RAC集群方案搭建数据库集群。...

    Oracle 12c database-concepts 数据库的概念全解析 英文版

    Oracle 12c Database Concepts 是 Oracle 官方发布的一份关于 Oracle 12c 数据库概念的详细解析文档,该文档涵盖了 Oracle 12c 数据库的基本概念、架构、管理、安全、性能优化、 Troubleshooting 等方面的知识点。...

    人大金仓_KingbaseES_数据库入门指南for+linux

    接下来,理解数据库的基本概念至关重要。数据库是存储和管理数据的系统,金仓数据库作为关系型数据库,遵循ACID(原子性、一致性、隔离性和持久性)原则,支持SQL语言进行数据查询和操作。在KingbaseES中,你可以...

    数据库考试模拟试题(3份带答案)

    10. **数据库集群与复制**:数据库集群可以提高可用性和性能,复制技术可以实现数据的冗余和灾难恢复。理解主从复制、多源复制的原理和应用场景。 以上只是数据库考试可能涵盖的一些基础知识点,具体考试可能还会...

    数据库高级应用所有课堂实例

    此外,还会涉及到数据库集群的概念,如MySQL的InnoDB Cluster。 9. **性能监控与调优**:通过学习监控工具(如MySQL Performance Schema或Oracle AWR报告),了解如何分析数据库性能,找出性能瓶颈,优化SQL语句、...

    数据库应用与设计-大型数据库系统架构设计方法.pdf

    此外,还涉及了数据库的基础概念,如ACID特性和关系数据库的基本原理。 首先,文档介绍了大型数据库系统的可扩展性设计方法。在大型系统中,用户数量和行为难以预测,可扩展性指的是系统应对用户增长和处理请求增多...

    MySQL数据库MySQL数据库.ppt

    【数据库基本概念】 1. **数据(Data)**:数据是数据库中存储的基本单元,可以是文字、数字、图像等各种形式。数据与其语义是不可分割的,比如学生记录“李明,男,1972年,江苏,计算机系,1990年入学”,其中...

    数据库分库技巧

    4. **集群**:指一组相互协作的数据库实例共同提供服务,可以通过集群来实现更高的可用性和性能。 5. **负载均衡**:通过负载均衡器将请求合理地分发到不同的数据库实例中,确保每个实例都能得到合理的利用,避免...

    mysql集群-中文版

    描述:“高可用的mysql集群的讲解,简单明了,通俗易懂,希望大家喜欢。” 知识点: 1. MySQL集群的定义和重要性:MySQL集群是一种高性能、高可用性的数据库解决方案,它允许多个MySQL服务器协同工作,提供数据的冗余...

    keycloak集群部署配置

    ### Keycloak集群部署配置...通过本篇文章的学习,读者应该能够理解Keycloak集群的基本概念、部署模式、环境需求以及具体的配置步骤。在实际部署过程中,还需要关注网络环境的兼容性和安全性,以确保集群的正常运行。

    Oracle数据库使用指南

    1.1.4 Oracle数据库基本概念 Oracle数据库由多个组件组成,如数据库实例(Instance)、数据库文件(Data Files)、控制文件(Control Files)、重做日志文件(Redo Log Files)等。实例是运行在操作系统上的内存结构...

    Oracle数据库实用教程(第二版)

    此外,还讨论了数据库的高可用性解决方案,如RAC(实时应用集群)和Data Guard,为关键业务提供持续服务。 在数据库开发方面,书中涵盖PL/SQL编程,这是一种专为Oracle设计的结构化查询语言扩展,用于编写存储过程...

    在kingbase下运行的数据库课件

    1. 数据库概念:数据库是存储和管理数据的系统,Kingbase提供了一种组织和存储数据的方式,便于高效检索和管理。 2. Kingbase特点:高可用性、高并发性、线性扩展、强大的安全性、良好的兼容性与移植性,使其成为...

Global site tag (gtag.js) - Google Analytics