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);</

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
Redis缓存中存入MySQL数据的方案有两种: 方案1:通过MySQL自动同步刷新Redis 这种方案使用MySQL的触发器和UDF函数来实现。当MySQL中的数据发生变化时,触发器会将变化的数据通过UDF函数写入到Redis中,从而实现数据的同步。 方案2:解析MySQL的binlog实现 这种方案通过解析MySQL的binlog来获取数据库中的数据变化,并将解析出来的数据写入到Redis中。当MySQL中有数据写入时,我们可以解析binlog文件,提取出数据变化的信息,然后将这些信息写入到Redis中,从而实现数据的同步。 以下是方案2的示例代码: ```python import pymysql import redis from pymysqlreplication import BinLogStreamReader # MySQL连接配置 mysql_config = { 'host': 'localhost', 'port': 3306, 'user': 'root', 'password': 'password', 'db': 'mydatabase' } # Redis连接配置 redis_config = { 'host': 'localhost', 'port': 6379, 'db': 0 } # 创建MySQL连接 mysql_conn = pymysql.connect(**mysql_config) # 创建Redis连接 redis_conn = redis.Redis(**redis_config) # 创建binlog解析器 stream = BinLogStreamReader(connection_settings=mysql_config, server_id=100) # 监听binlog事件 for binlog_event in stream: if binlog_event.event_type == 'write_rows': for row in binlog_event.rows: # 将数据写入Redis redis_conn.set(row['values']['key'], row['values']['value']) elif binlog_event.event_type == 'delete_rows': for row in binlog_event.rows: # 从Redis中删除数据 redis_conn.delete(row['values']['key']) # 关闭连接 stream.close() mysql_conn.close() redis_conn.close() ``` 请注意,以上代码仅为示例,实际使用时需要根据具体情况进行配置和修改。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

丰恒谷

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

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

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

打赏作者

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

抵扣说明:

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

余额充值