mysql缓存方案

1 解决问题

对于mysql而言,在体系结构中是有一个缓存的,但是在实际的项目中,读一般远远大于写,大概有10倍的样子,自己的公司项目是在17倍的样子,默认的mysql内部实现的缓冲不够用,无法满足高并发的需求;所以就产生了一些缓存中间件,主流的缓存中间件redis,memcached等

2 mysql主从复制

原理图:
在这里插入图片描述
具体流程:

1 主库更新事件(update,insert,delete)通过io-thread写入binlog
2 从库请求读取binlog,通过io-thread写入(write)从库本地relay log(中继日志)
3 从库通过sql-thread线程读取(read)relay log,并把更新事件在从库中执行(relay一遍)

binlog:它是在事务提交后产生,跟引擎无关;
redolog:在事务提交后,也会有刷盘操作

2 读写分离

1 组织图
在这里插入图片描述
对于这种框架来说,当从越多,主就越慢;当然也可以多个主。

3 缓存中间件介绍

读多写少,单个主节点能支撑项目数据量;数据的主要依据是mysql;
1 mysql缓存
mysql体系结构中是有缓冲层,它的作用也是用来缓冲热点数据,这些数据包括数据文件,索引文件等;它的缓冲层是从自身触发的,跟具体的业务无关;缓冲策略采用主要是LRU(当然是经过优化的LRU);
mysql数据主要存储在磁盘当中,适合大量重要数据的存储&

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

丰恒谷

你的鼓励是我最大创作动力!!!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值