Redis持久化机制 - Go语言中文社区

Redis持久化机制


Redis持久化机制

全量同步与增量同步的区别

全量同步:就是每天定时(避开高峰期)或者采用一个周期实现将数据拷贝到一个地方也就是Rdb存储。
增量同步:比如采用对行为的操作实现对数据的同步,也就是AOF。
全量与增量的比较:增量同步比全量同步更加消耗服务器的内存,但是能够更加的保证数据的同步。

RDB与AOF实现持久化的区别
Redis提供了两种持久化的机制,分别为RDB、AOF实现,RDB采用定时(全量)持久化机制,但是服务器因为某种原因宕机后可能数据会丢失,AOF是基于数据日志操作实现的持久化,所以AOF采用增量同步的方案。

Redis已经帮助我默认开启了rdb存储。

Redis的RDB与AOF同步配置

RDB
Redis默认采用rdb方式实现数据的持久化,以快照的形式将数据持久化到磁盘的是一个二进制的文件dump.rdb, 在redis.conf文件中搜索“dump.rdb “。

在这里插入图片描述

Redis会将数据集的快照dump到dump.rdb文件中。此外,我们也可以通过配置文件来修改Redis服务器dump快照的频率,在打开6379.conf文件之后,我们搜索save,可以看到下面的配置信息:
save 900 1 #在900秒(15分钟)之后,如果至少有1个key发生变化,则dump内存快照。
save 300 10 #在300秒(5分钟)之后,如果至少有10个key发生变化,则dump内存快照。
save 60 10000 #在60秒(1分钟)之后,如果至少有10000个key发生变化,则dump内存快照。
Set(包含增加和覆盖)、del
Set name yushengjun
Set name mayikt
Del name

在这里插入图片描述

Aof
在Redis的配置文件中存在三种同步方式,它们分别是:
appendfsync always #每次有数据修改发生时都会写入AOF文件,能够保证数据不丢失,但是效率非常低。
appendfsync everysec #每秒钟同步一次,可能会丢失1s内的数据,但是效率非常高。
appendfsync no #从不同步。高效但是数据不会被持久化。
直接修改redis.conf中 appendonly yes
建议最好还是使用everysec 既能够保证数据的同步、效率也还可以。
Aof是以执行命令的形式实现同步
MySQL与Redis一致性解决同步问题
SpringBoot整合Redis的注解版本

@RestController
public class MemberController {
    @Autowired
    private UserMapper userMapper;

    @RequestMapping("/findMemberAll")
    @Cacheable(cacheNames = "member", key = "'findMemberAll'")
    public List<MemberEntity> findMemberAll() {
        return userMapper.findMemberAll();
    }
}
public interface UserMapper {
    @Select("select * from users")
    List<MemberEntity> findMemberAll();
}
spring:
  redis:
    host: 192.168.212.155
    password: 123456
    port: 6379
    database: 1
  #数据库连接配置
  datasource:
    driver-class-name:
    url: 
    username: 
    password: 
<!--mysql数据库驱动-->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

<!--mybatis-->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.0</version>
</dependency>

开启我们的@EnableCaching

可以参考别人的博客使用方法
https://blog.csdn.net/micro_hz/article/details/76599632

MySQL与Redis一致性解决同步问题
方式1:直接清除Redis的缓存,重新读取数据库即可
方式2:使用mq异步订阅mysql binlog实现增量同步
方式3:使用alibaba的canal

**MySQL与Redis的数据同步的问题如何解决?

方式1 直接清理Redis的缓存,重新查询数据库即可~~
方式2 直接采用mq订阅mysql binlog日志文件增量同步到Redis中,整个过程采用最终一致性方案。
**
3.

使用alibaba的canal

**Redis的持久化机制:
Redis因为某种原因的情况下宕机之后,数据是不会丢失的。
原理就是持久化
EHCACHE
大部分的缓存框架都会基本功能淘汰策略、持久机制
Redis的持久化的机制有两种:aof、rdb(默认)

全量同步与增量同步区别:
1.就是每天定时(避开高放弃)或者是采用一种周期的实现将数据拷贝另外一个地方。
频率不是很大,但是可能会造成数据的丢失。
2.增量同步采用行为操作对数据的实现同步
频率非常高、对服务器同步的压力也是非常大的、保证数据不丢失。
**

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/qq_44499717/article/details/115696746
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2023-01-03 12:32:06
  • 阅读 ( 224 )
  • 分类:Redis

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢