在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

如何通过缓存+SQL修改优化慢查询

130次阅读
没有评论

共计 1079 个字符,预计需要花费 3 分钟才能阅读完成。

本篇内容介绍了“如何通过缓存 +SQL 修改优化慢查询”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让丸趣 TV 小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

问题描述

单例数据库模式中,后端高并发请求多(读多写少),导致数据库压力过大,关键接口响应变慢,严重影响体验。

需求

减少接口的响应时间。

寻找解决方案

由于问题主要处在数据库压力过大的情况,采用两种优化思路优化查询过程:

使用缓存分担数据库压力

对查询数据库过程做优化

缓存方案更新策略

使用 Redis,虽然可以很好地减少数据库的压力,但是同时在高并发的情况下,容易出现数据不一致的情况,尤其是在更新数据的时候。

最常见的导致不一致的原因是双写操作,即高并发情况下短时间内对数据库进行两次写操作。为了最小程度地出现这种情况,缓存在更新策略上采用先更新数据库后删除缓存的方式。

对于双写问题,在最坏情况下,写请求 A 在更新数据库后,被写请求 B 先一步更新数据库 + 删除缓存,然后 A 请求才删除缓存,也不会导致后续请求读取到错误的值。

对于先写后读,在最坏情况下,写请求 A 在更新数据库后,被读请求 C 先一步在缓存读取到旧值,然后 A 请求才删除缓存,也只会影响这段时间的读请求,删除后的读请求不影响。

对比其他方案(先更新缓存后更新数据库、先删除缓存后更新数据库、先更新数据库后更新缓存)在最坏情况下会导致的错误(更新数据库失败导致缓存是未知值、双写后数据库变成旧值、更新缓存失败导致缓存保存旧值)要好得多。

但是先更新数据库后删除缓存也不是完全安全的,除了上文提到的高并发下先写后读可能读到旧值外,若删除缓存失败,也有可能导致读到旧值。处理方法见下文。

缓存架构

添加缓存,势必要修改业务代码,如何配置架构才能把对代码的入侵性讲到最低,这里使用监听数据库 binlog 的方法,使用中间件监听 mysql 的日志,当出现操作时,通知专门的模块来修改缓存,做到修改缓存和业务逻辑解耦。

同时为了解决缓存删除失败的问题,当发生失败时,发送消息至消息队列传递给专门的模块进行重试删除。

中间件选择:

缓存使用 Redis

监听 binlog 使用 canal

消息队列使用 RocketMQ

架构如下所示:

SQL 优化

查询优化可以从两个方面进行:

根据高频的查询 case,遵循最左匹配原则,设置对应的索引或联合索引

通过了解业务场景,看看能否将一些小 SQL 合并成大 SQL

“如何通过缓存 +SQL 修改优化慢查询”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注丸趣 TV 网站,丸趣 TV 小编将为大家输出更多高质量的实用文章!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-13发表,共计1079字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 青青青国产成人久久111网站 | 男人在线天堂 | 中文国产成人精品久久无广告 | 99国产欧美久久精品 | 国产欧美一区二区三区免费视频 | 精品人妻va出轨中文字幕 | 在线一级黄色片 | 亚洲av永久无码精品一百度影院 | 日韩电影中文字幕在线网站 | 中文在线最新版天堂 | 两性色午夜免费视频 | 中老年熟妇激情啪啪大屁股 | 最近中文字幕完整版 | 美女福利视频国产免费观看 | 四虎色播| 97久久国产亚洲精品超碰热 | 亚洲自拍色图 | 国产精品揄拍一区二区久久 | 亚洲一区二区中文字幕 | 男人不识本网站 | 精品午夜一区二区三区在线观看 | 久久婷婷五月综合国产尤物app | 丰满人妻在公车被猛烈进入电影 | 中无码人妻丰满熟妇啪啪 | 97久久精品午夜一区二区 | 亚洲精品久久久久久无码色欲四季 | 亚洲成人在线视频观看 | 推川悠里在线 | 精品少妇人妻av免费久久久 | 日韩精品无码人成视频手机 | 日日噜噜夜夜狠狠视频免费 | 伊人久久综合成人网小说 | 少妇伦子伦精品无吗 | 七次郎在线视频对华免费一屋 | 国产不卡毛片 | 婷婷精品国产亚洲av麻豆不片 | 草草影 | 99热这里全部都是精品 | 亚洲是图你懂的 | 欧美精品国产日韩综合在线 | 国产av人人夜夜澡人人爽麻豆 |