本文作者:kris

MySQL优化之缓存优化(续)-mysql 缓存优化

kris 2025-01-31 11:48:04 2
MySQL优化之缓存优化(续)-mysql 缓存优化摘要: 怎么把mysql的数据缓存进redis?1,redis是一种内存性的数据存储服务,所以它的速度要比mysql快。2,redis只支持String,hashmap,set,sorte...

怎么把mysql的数据缓存进redis?

1,redis是一种内存性的数据存储服务,所以它的速度要比mysql快。

2,redis只支持String,hashmap,set,sortedset等基本数据类型,但是不支持联合查询,所以它适合做缓存。

3,有时候缓存的数据量非常大,如果这个时候服务宕机了,且开启了redis的持久化功能,重新启动服务,数据基本上不会丢。

4,redis可以做内存共享,因为它可以被多个不同的客户端连接。

5,做为mysql等数据库的缓存,是把部分热点数据先存储到redis中,或第一次用的时候加载到redis中,下次再用的时候,直接从redis中取。

MySQL优化之缓存优化(续)-mysql 缓存优化

图片来源:网络

6,redis中的数据可以设置过期时间expire,如果这个数据在一定时间内没有被延长这个时间,那个一定时间之后这个数据就会从redis清除。所以,redis只是用来缓存数据库中经常被访问的数据,可以增加访问速度和并发量。而mysql只是提供一种数据备份和数据源的作用。

mysql查询缓存是基于什么粒度?

mysql数据库查询缓存原理是:

1、缓存SELECT操作的结果集和SQL语句,key为sql,value为查询结果集;

2、如果新的SELECT语句到了,以这个sql为key去缓存中查询,如果匹配,就把缓存的结果集返回。

匹配标准:与缓存的SQL语句是否完全一样,sql中字母区分大小写以及中间的空格,简单理解为存储了一个key-value结构,key为sql,value为sql查询结果,匹配时使用Java的String的equals(),例如:

select age from user 与 select AGE from user不会匹配,因为大小写不同;

select age from use 与 select age from user不会匹配,因为空格不同;

php redis做mysql的缓存,怎么异步redis同步到mysql数据库?

此时一位IT码农路过,并留下个人见解。

要想redis异步去同步Mysql的数据,大部分时候使用的都是队列的形式。例如php使用resque包进行部署,实现自动化队列的形式,开一些额外的线程监听,将一些操作push到队列上,然后被监听之后就执行相关的操作(某个控制器和方法)同步到Mysql表里面。

或者是采用swoole扩展,里面有封装redis的异步操作,可以很容易的实现redis的异步,然后再把数据同步到mysql上。

最后,喜欢的小伙伴可以给我点赞或者关注我哦。

文章版权及转载声明

作者:kris本文地址:https://www.damoyx.com/p/29156.html发布于 2025-01-31 11:48:04
文章转载或复制请以超链接形式并注明出处大漠游侠网

阅读
分享