在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
怎样解决数据库高并发的问题?解决数据库高并发使用缓存式的Web应用程序架构、增加Redis缓存数据库、增加数据库索引、页面静态化、使用存储过程、MySQL主从读写分离、分表分库、负载均衡集群。
解决数据库高并发的常见方案:
1)缓存式的Web应用程序架构:在Web层和DB(数据库)层之间加一层cache层,主要目:减少数据库读取负担,提高数据读取速度。cache存取的媒介内存,可以考虑采用分布式的cache层,这样更容易破除内存量的限制,同时增加了灵活性。
2)增加Redis缓存数据库
3)增加数据库索引
4)页面静态化:效率最高、消耗最小的就是纯静态化的html页面,所以们尽可能使我们的网站上的页面采用静态页面来实现,这个最简的方法其实也是最有效的方法。用户可以直接获取页面,不用像VC结构走那么多流程,比较适用于页面信息大量被前台程序调86传智播客旗下高端IT在线教育平台·博学谷,但是更新频率很小的情况。
5)使用存储过程:处理一次请求需要多次访问数据库的操作,可以把操作整到储存过程,这样只要一次数据库访问就可以了。
6)MySQL主从读写分离:当数据库的写压力增加,cache层(如Memcached)只能缓解数库的读取压力。读写集中在一个数据库上让数据库不堪重负。使用从复制技术(master-slave模式)来达到读写分离,以提高读写性和读库的可扩展性。读写分离就是只在主服务器上写,只在从服务上读,基本原理是让主数据库处理事务性查询,而从数据库处理ect查询,数据库复制被用于把事务性查询(增删改)导致的改变新同步到集群中的从数据库。MySQL读写分离提升系统性能:
1、主从只负责各自的读和写,极大程度缓解X锁和S锁争用。
2、slave可以配置MyISAM引擎,提升查询性能以及节约系统开。
3、master直接写是并发的,slave通过主库发送来的binlog恢复据是异步的。
4、slave可以单独设置一些参数来提升其读的性能。
5、增加冗余,提高可用性。实现主从分离可以使用MySQL中间件如:Atlas
7)分表分库:在cache层的高速缓存,MySQL的主从复制,读写分离的基础上,时MySQL主库的写压力开始出现瓶颈,而数据量的持续猛增,由MyISAM使用表锁,在高并发下会出现严重的锁问题,大量的高并MySQL应用开始使用InnoDB引擎代替MyISAM。采用Master-Slave制模式的MySQL架构,只能对数据库的读进行扩展,而对数据的操作还是集中在Master上。这时需要对数据库的吞吐能力进一步扩展,以满足高并发访问与海量数据存储的需求。对于访问极为频繁且数据量巨大的单表来说,首先要做的是减少表的记录条数,以便减少数据查询所需的时间,提高数据库的吞吐,就是所谓的分表【水平拆分】。
在分表之前,首先需要选择适当的表策略(尽量避免分出来的多表关联查询),使得数据能够较为均地分布到多张表中,并且不影响正常的查询。分表能够解决单表数据量过大带来的查询效率下降的问题,但是无法给数据库的并发处理能力带来质的提升。面对高并发的读写访,当数据库master服务器无法承载写操作压力时,不管如何扩展ve服务器都是没有意义的,对数据库进行拆分,从而提高数据库入能力,即分库垂直拆分。
8)负载均衡集群:将大量的并发请求分担到多个处理节点。由于单个处理节点的故不影响整个服务,负载均衡集群同时也实现了高可用性。负载均衡将是大型网站解决高负荷访问和大量并发请求采用的极解决办法。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
python为什么这么火?python会一直火下去吗?
今天,我们来聊一聊最近火的一塌糊涂的编程语言——Python。众所周知,Python已不是一种年轻的编程语言,它突然火爆的背后到底有那些深层原因呢?
9802
2019-06-25 18:53:31
Python面试题 Tornado的核心是什么?
Tornado 的核心是 ioloop 和 iostream 这两个模块,前者提供了 一个高效的 I/O 事件循环,后者则封装了 一个无阻塞的 socket 。 通过向 ioloop 中添加网络 I/O 事件,利用无阻塞的 socket ,再搭配相应的回调函数,便可达到梦寐以求的高效异步执行。
11170
2019-07-02 17:43:40
2020年哪些热门IT岗位好找工作?
2020年热门IT岗位,由于疫情严重,导致临床医学、公共卫生、集成电路、人工智能、预防医学、应急管理、养老服务管理、电子商务专业人才紧缺,每个人都需要重新规划,了解当下热门iIT技术,提升自身的能力。
5607
2020-03-10 10:17:32
Python数据分析可以用来做什么?
随着大数据时代的来临和Python编程语言的火爆,Python数据分析早已成为现在职场人的必备核心技能。Python的功能强大,在工作中的很多领域都可以用到。Python数据分析可以用来做些什么呢?
5126
2020-05-26 10:23:38
8月份的编程薪酬排名出来啦,看看是谁突出了重围!
提起编程语言首先第一个不得不说python,作为最流行的初学者编程语言,无论从什么榜单来看,python都一直排在了前10位,为什么python被列为了初学者最受欢迎的编程语言。虽然不像rust语言发展的迅速,但不像js那样老是老一套。根据开发者的经验编写。它的通用性,易用性使其成为最受初学者欢迎的编程语言。
4558
2021-08-25 18:47:39
热门文章
- 前端是什么
- 前端开发的工作职责
- 前端开发需要会什么?先掌握这三大核心关键技术
- 前端开发的工作方向有哪些?
- 简历加分-4步写出HR想要的简历
- 程序员如何突击面试?两大招带你拿下面试官
- 程序员面试技巧
- 架构师的厉害之处竟然是这……
- 架构师书籍推荐
- 懂了这些,才能成为架构师 查看更多
扫描二维码,了解更多信息
