实现将redis中的所有数据备份到数据库表中

实现将redis中的所有数据备份到数据库表中

bash 复制代码
/**
     * 将redis中的数据同步到mysql中
     */
    @Override
    public void  saveMysqlForRedis(){
        Jedis jedis = new Jedis("127.0.0.1", 6379);
        //System.out.println(jedis.ping());
        Set keys = jedis.keys("*");//列出所有的key
        Iterator t1 = keys.iterator();
        while (t1.hasNext()){
            Object obj1 = t1.next();
            saveRedisObject(jedis,obj1+"","127.0.0.1","6379");
        }

    }
    //存储单个对象
    public  void saveRedisObject(final Jedis jedis,final String rediskey,final String macIp,final String port ){
        String redisType = jedis.type(rediskey);//返回值的类型
        RedisTable redisTable = new RedisTable();
        redisTable.setRediskey(rediskey);
        redisTable.setRedistype(redisType+"/");
        //set集合
        if("set".equalsIgnoreCase(redisType)){
            Set<String> setStrings = jedis.smembers(rediskey);
            if(null!=setStrings && !setStrings.isEmpty()){
                Iterator setIterator = setStrings.iterator();
                while (setIterator.hasNext()){
                    Object obj1 = setIterator.next();
                    redisTable.setRedisvalue(obj1+"");
                    redisTableService.insert(redisTable);//save
                }
            }
        }
        //hash
        else if ("hash".equalsIgnoreCase(redisType)) {
            Set<String> hashSet = jedis.hkeys(rediskey);
            if(null != hashSet && !hashSet.isEmpty()){
                Iterator setIterator = hashSet.iterator();
                while (setIterator.hasNext()){
                    String objectName = setIterator.next()+"";
                    redisTable.setRedisvalue(jedis.hget(rediskey,objectName));
                    redisTableService.insert(redisTable);//save
                }
            }
        }else if("string".equalsIgnoreCase(redisType)){
            redisTable.setRedisvalue((jedis.get(rediskey)));
            redisTableService.insert(redisTable);//save
        }
    }
    ...同样的,还有redis的其他数据类型,如下图:

注意:

1.需要考虑redis和mysql数据的一致性;

2.考虑redis数据导入的数据的重复性问题。

相关推荐
kebeiovo3 小时前
Redis的五个基本类型(2)
数据库·redis·缓存
yh云想5 小时前
《深入解析缓存三大难题:穿透、雪崩、击穿及应对之道》
数据库·redis
会编程的林俊杰8 小时前
Redisson中的分布式锁
redis·分布式·redisson
野犬寒鸦8 小时前
Pipeline功能实现Redis批处理(项目批量查询点赞情况的应用)
java·服务器·数据库·redis·后端·缓存
程序员JerrySUN9 小时前
当前主流GPU全景讲解:架构、功能与应用方向
数据库·人工智能·驱动开发·redis·缓存·架构
小醉你真好9 小时前
12、Docker Compose 安装 Redis
redis·docker·容器
hzk的学习笔记11 小时前
Redis学习总结(持续更新)
数据库·redis·缓存
Pitayafruit15 小时前
【📕分布式锁通关指南 12】源码剖析redisson如何利用Redis数据结构实现Semaphore和CountDownLatch
redis·分布式·后端
超人也会哭️呀16 小时前
Redis(八):Redis高并发高可用(哨兵Sentinel)
redis·bootstrap·sentinel·哨兵·哨兵模式·高并发高可用
Code季风16 小时前
分布式系统中的幂等性设计:从理论到实现的全面指南
redis·分布式·微服务