数据库的这些性能优化,你做了吗

转载自   数据库的这些性能优化,你做了吗

在互联网项目中,当业务规模越来越大,数据也越来越多,随之而来的就是数据库压力会越来越大。

我们可能会采取各种方式去优化,比如之前文章提到的缓存方案,SQL优化等等,除了这些方式以外,这里再分享几个针对数据库优化的常规手段:「数据读写分离」与「数据库Sharding」。这两点基本上是大中型互联网项目中应用的非常普遍的方案了。

下面我们来详细看一看,

一、从读写分离到CQRS

 

(图片来源阿里云)

由于互联网业务场景,大多数是读多写少,因此进行数据库的读写分离是一件非常简单且有效率的方案。
读写分离简单点来说就是把对数据的读操作和写操作进行分开来,让这两种操作去访问不同的数据库,这样的话,就可以减轻数据库的压力了。

例如上图中,数据库会有一个「主实例」,这个主要用来提供写操作的(偶尔也会承担一点读操作),除了「主实例」以外,还会有多个「从实例」(在图中显示的是 只读实例),「从实例」的功能只是用来承担读操作的。

那上面就出现了多个数据库了,在多个数据库之间的数据是怎么保证一致性的呢?

其实,我们常用的数据库就自带这类同步功能,比如 Mysql,它自己有一个master-slave功能,可以实现主库与从库数据的自动同步,是基于二进制日志复制来实现的。在主库进行的写操作,会形成二进制日志,然后Mysql会把这个日志异步的同步到从库上,从库再自动执行一遍这个二进制日志,那么数据就跟主库一致了。

除了Mysql以外,像Oracle等商业数据库都有类似的功能,甚至是网络上还有很多开源的第三方数据同步工具,也有很多成熟好用的。

好了,「主实例」与「从实例」之间的数据同步问题解决了,那现在还有一个问题就是,项目中是怎样让 写请求 去访问「主实例」,让 读请求 去访问「从实例」的,这个路由规则是怎么实现的呢?

常规的有2种方式:

使用编码方式
这个方式主要是靠开发同学在编码的时候,根据读写不同的操作需求,去调用不同的数据源。例如在数据操作层(DAO层)将读数据与写数据分开为两个方法(函数),然后为这两个方法分别指定不同的数据库即可。
但是这种方式有点硬编码的味道了,而且对开发同学而言还得额外关注这个事情,多了一个编码成本且容易不小心忽略掉。

使用中间件
这种方式就是在后端数据库的前面,前置一个 数据库代理服务,如下图的:MySQL-Proxy 是Mysql提供的一个中间件,用于实现读写分离请求,但这个组件实际用的人不多,我们可以选择其它的一些开源的组件替代,例如:MyCat、ProxySQL 等等,但大致的原理比较类似,通过这个图很容易理解这个模式。

 

好了,基础的读写分离就讲完了,但感觉这个方式虽然实用是实用,就是不怎么有逼格。

OK,想要有逼格是吧,满足你,那我们就来聊一聊另一个有逼格的读写分离概念: 「 CQRS 」

CQRS:Command Query Responsibility Segregation
命令(增删改)和查询的责任分离

 

我们还是先看图,通过上图可以简单的理解一下CQRS

CQRS 重点强调的就是 Query(读) 和 Command(写)的分离,在业务上将职责分离清晰,Command 主要做业务逻辑的执行,Query来负责数据查询和展示。同时 这两种操作是基于不同的数据源,甚至是一个是数据库,另外一个是NoSQL都可以,Query去查询的数据源可以直接按照领域模型进行存储,而并不是按照数据模型去存储,这样查询出来就立即可以展示,而不用转换,且查询效率高。

其实CQRS是由鼎鼎大名的 Martin Fowler 提出,搞计算机的应该都认识。想要更深入的去学习CQRS,可以翻看Martin Fowler公开的资料。

二、Sharding(分库分表)

上面讲完了数据库的读写分离,现在我们来聊一下数据库的Sharding。

随着数据库里的数据越来越大,单表查询的性能已经不能满足业务要求了,这个时候就需要进行分表处理了,将大表拆分为若干个小表,不同的分表中数据也不一样,这样可以分散查询压力,提高处理效率。

然而,当表越来越多,所有的数据都在一个数据库上时,网络IO以及文件IO也都会集中在一个数据库上,可能会超过单台服务器的容量, CPU、内存、文件IO、网络IO 都会成为系统的瓶颈,QPS/TPS也会超过单数据库实例的处理极限。那么这个时候就需要对数据库进行分片处理。

因为分表和分库的思路类似,因此下面统一来聊技术方案。
其实分库分表只是我们通俗的便于理解的说话,正确的描述应该是:数据分片

数据的分片主要有2种模式:

  • 垂直拆分

  • 水平拆分

两种拆分应用的场景是不同的:

垂直拆分,是指按照业务模块进行拆分。简单来讲,就是把业务紧密的模块的字段/表放在一起,放在同一个数据库或者服务器上。将不同业务的字段/表进行独立,拆到不同的数据库或者服务器上。比如一个游戏系统中,可以将玩家基本信息与道具公会等信息进行拆分。
如图示例:


(图片来源网络)

水平拆分,是指纯粹的按照某种数据规则/格式进行拆分。例如 按照数据唯一ID的哈希散列拆分、按照数据的日期拆分、按照某种范围拆分等等。水平拆分需要注意的是,随着数据动态的变化,分片数量可能需要随之动态调整,另外就是水平分片是没有考虑业务特征的,因此在进行业务汇总查询或者分片中事物处理的时候就比较麻烦一些。
如图示例:

另外,在实际应用中,两种拆分模式一般会结合在一起使用,效果更佳。

以上就是数据库性能优化之「数据读写分离」与「数据库Sharding」方法,欢迎大家一起交流。

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

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

相关文章

java知识点总结(二)

 复杂选择结构: 一、Switch的结构语法: switch(变量){ case 1: //代码 break; case 2: //代码 break; default : //代码 break; } 2.switch:相当于一个开关,后面的括号里面可以是int short byte char 枚举类型 Strin…

flume的配置和开启

配置文件: 编辑 flume-conf.properties agent1表示代理名称 agent1.sourcessource1 agent1.sinkssink1 agent1.channelschannel1 配置source1 agent1.sources.source1.typespooldir agent1.sources.source1.spoolDir/usr/local/flume_logs agent1.sources…

青客宝团队Consul内部分享ppt

Consul 是一个支持多数据中心,分布式,高可用的服务发现和配置共享系统。由 HashiCorp 公司使用 Go 语言开发,基于Raft协议。部署起来非常容易,只需要极少的可执行程序和配置文件,具有绿色、轻量级的特点。 Consul是支持…

2018蓝桥杯省赛---java---C---9(小朋友崇拜圈)

题目描述 思路分析 数组来储存小朋友们的崇拜对象,然后下标1就是对应的小朋友座号,写一个方法找出每一个小朋友的崇拜圈大小,然后找出最大的崇拜圈即可 代码实现 package lanqiao;import java.util.*;public class Main {public static vo…

漫画:什么是时间复杂度

转载自 漫画:什么是时间复杂度 时间复杂度的意义 究竟什么是时间复杂度呢?让我们来想象一个场景: 某一天,小灰和大黄同时加入了一个公司...... 一天过后,小灰和大黄各自交付了代码,两端代码实现的功能…

Office基础和计算机操作基础的知识点(一)

 运指如飞: 一、鼠标的基本操作 1.单击 2.双击 3.移动 4.拖拽 二、键盘的分布 1.功能键区 2.打字键盘区 3.数字键盘区 4.指示灯 5.编辑键区 三、输入法 1.切换输入法:ctrlshift 2.选中的方法: 1)鼠标选中 2)按shift键移动左右键 四、记事…

Flume整合SparkStreaming出现UnsupportedClassVersionError: org/apache/spark/streaming/flume/sink/SparkFlum

Flume整合SparkStreaming使用Poll方式拉取数据出现 UnsupportedClassVersionError: org/apache/spark/streaming/flume/sink/SparkFlumeProtocol : Unsupported major.minor version 52.0 问题: INFO node.Application: Starting Source source1 18/06/12 03:34…

Visual Studio 和 Team Foundation Server 产品维护及周期策略

1 适用于 Visual Studio 和 Team Foundation Server 2012 - 2017 这些产品遵循 Microsoft 10 年支持生命周期策略(5 年主流支持和 5 年扩展支持),起始日期为主要产品版本向全球 (RTW) 发布的日期。 例如,Visual Studio 2017 于 20…

28. 实现 strStr()---LeetCode---JAVA(今天又是一行超人)

class Solution {public int strStr(String haystack, String needle) {return haystack.indexOf(needle);} }

DevOps通用及版本控制面试题

转载自 DevOps通用及版本控制面试题 通用DevOps面试问题 此类别将包含与任何特定DevOps阶段无关的问题。这里的问题旨在测试您对DevOps的理解,而不是关注特定工具或阶段。 问题一: DevOps和Agile之间的根本区别是什么? 两者之间的差异…

Office基础知识点总结(二)

 PowerPoint幻灯片制作: 一、PPT2010的界面: 1.功能选项卡 2.大纲区 3.标题栏 4.备注页 5.状态栏 6.工作区 二、创建PPT演示文稿 1.开始–》PPT2010 2.在PPT里面新建–》文件–》新建–》样本模板–》选择模板。 三、PPT2010中的视图: 1.普…

zookeeper出现Error contacting service. It is probably not running.

在两个节点 的zookeeper搭建启动的时候出现如下报错 JMX enabled by default Using config: /root/app/zookeeper/bin/../conf/zoo.cfg Error contacting service. It is probably not running. 查看zookeeper.out 日志报错如下 2018-06-13 03:13:18,573 [myid:0] - INFO …

微信和支付宝支付模式详解及实现(.Net标准库)

支付基本上是很多产品都必须的一个模块,大家最熟悉的应该就是微信和支付宝支付了,不过更多的可能还是停留在直接sdk的调用上,甚至和业务系统高度耦合,网上也存在各种解决方案,但大多形式各异,东拼西凑而成。…

DFS

//深度优先算法//i第一次就是0public void dfs(boolean[]isVisited,int i){//首先我们访问该节点System.out.println(getValueByIndex(i));isVisited[i]true;int wgetFirstNeighbor(i);while (w!-1){if(!isVisited[w]){dfs(isVisited,w);}//如果w节点已经被访问过wgetNextNeigh…

这些Spring面试题,你都会了吗?

转载自 这些Spring面试题,你都会了吗? 问题一: 什么是Spring? Spring是Enterprise Java的开源开发框架。Spring Framework的核心功能可用于开发任何Java应用程序,但有一些扩展用于在Java EE平台之上构建Web应用程…

计算机操作基础知识点总结

 计算机组装: 一、计算机硬件组成: 1.CPU 2.主板 3.内存 4.硬盘 5.光驱 6.显卡 7.网卡 8.声卡 9.电源 10.操作系统 二、CPU型号: 1.INTEL 1)主频:2.8-3.7GHZ 2)核心:双核、四核、八核、十核 3)高速总缓冲&#xff1a…

Kafka启动出现Error: Could not create the Java Virtual Machine. Error: A fatal exception has occurred. Pr

kafka启动时,出现报错! [rootSpark1 bin]# cat nohup.out Unrecognized VM option ‘UseCompressedOops’ Error: Could not create the Java Virtual Machine. Error: A fatal exception has occurred. Program will exit. 原因: 开始…

BFS

public void bfs(boolean[]isVisited,int i){int u;//表示队列的头结点对应的下标int w;//表示邻接节点w//队列LinkedList queue new LinkedList();//访问节点,输出节点信息System.out.println(getValueByIndex(i)">");isVisited[i]true;queue.addLas…

.NET遇上Docker - 使用Docker Compose组织Ngnix和.NETCore运行

本文工具准备: Docker for WindowsVisual Studio 2015 与 Visual Studio Tools for Docker或 Visual Studio 2017 需要在安装时选择“容器开发支持”,如图: Docker的思想是将不同的应用放在不同的容器中分开运行,如运行.NetCore …

平面设计基础(PS)知识点总结

 PS基础知识: 一、ps全称:Adobe Photoshop ,Adobe Photoshop是由Adobe Systems 开发和发行的专门用于图形图像处理的软件。 二、PS的应用领域: 1.在平面设计中的应用 2.在插画设计中的应用 3.在网页设计中的应用 4.在界面设计中…