java使用jeids实现redis2.6的key管理(2)

Wesley13
• 阅读 488

代码:

    https://github.com/viakiba/redis

主要是:

    MIGRATE,MOVE,OBJECT,PERSIST/PEXPIRE/PEXPIREAT,PTTL/TTL

import org.junit.Test;

import redis.clients.jedis.Jedis;

/**
 * @description: 
 *             关于key的相关操作(2)
 *             MIGRATE,MOVE,OBJECT,PERSIST/PEXPIRE/PEXPIREAT,PTTL/TTL
 *             
 *             参考:http://redisdoc.com/index.html
 * @author viakiba
 * @date 2017年8月17日
 */
public class App3 {
    static interface RedisConfig {
        public final static String HOST = "127.0.0.1";
        public final static int PORT = 6379;
    }
    
    /**
     * @description: 测试连接是否通过
     * @author: viakiba
     * @throws Exception
     */
    @Test
    public void test1() throws Exception {
        //连接测试是否通过
        Jedis jedis = new Jedis(RedisConfig.HOST,RedisConfig.PORT);
        System.out.println(jedis.ping());//pong则通过
    }
    
    /**
     * @description: MIGRATE
     *                  将 key 原子性地从当前实例传送到目标实例的指定数据库上,一旦传送成功, 
     *                  key 保证会出现在目标实例上,而当前实例上的 key 会被删除。
     *                 注意:
     *                 这个命令是一个原子操作,它在执行的时候会阻塞进行迁移的两个实例,
     *                 直到以下任意结果发生:迁移成功,迁移失败,等待超时。
     * 参考:
     *                 http://redisdoc.com/key/migrate.html
     * @author: viakiba
     * @throws Exception
     */
    @Test
    public void test2() throws Exception {
        //jedis不存在该命令
        Jedis jedis = new Jedis(RedisConfig.HOST,RedisConfig.PORT);
        jedis.flushAll();
    }
    
    /**
     * @description: MOVE
     *                     将当前数据库的 key 移动到给定的数据库 db 当中。
     *                  注意:
     *                     如果当前数据库(源数据库)和给定数据库(目标数据库)有相同名字的给定 key ,
     *                     或者 key 不存在于当前数据库,那么 MOVE 没有任何效果。
     *                      因此,也可以利用这一特性,将 MOVE 当作锁(locking)原语(primitive)。
     * @author: viakiba
     * @throws Exception
     */
    @Test
    public void test3() throws Exception {
        Jedis jedis = new Jedis(RedisConfig.HOST,RedisConfig.PORT);
        jedis.flushAll();//清空所有数据
        System.out.println("=====准备数据=========");
        jedis.set("k1", "v1");//默认选择index为0的数据库
        System.out.println("index0===>"+jedis.get("k1"));
        jedis.select(1);
        System.out.println("index1===>"+jedis.get("k1"));
        System.out.println("======执行move======");
        jedis.select(0);
        jedis.move("k1", 1);
        System.out.println("======查看结果======");
        System.out.println("index0===>"+jedis.get("k1"));
        jedis.select(1);
        System.out.println("index1===>"+jedis.get("k1"));
    }
    
    /**
     * @description: OBJECT
     *                      OBJECT 命令允许从内部察看给定 key 的 Redis 对象。
     * @author: viakiba
     * @throws Exception
     */
    @Test
    public void test4() throws Exception {
        Jedis jedis = new Jedis(RedisConfig.HOST,RedisConfig.PORT);
//        jedis.flushAll();//清空所有数据
//        System.out.println("=====准备数据=========");
//        jedis.set("k1", "v1");//默认选择index为0的数据库
        
        //OBJECT REFCOUNT <key> 返回给定 key 引用所储存的值的次数。此命令主要用于除错
//        Long objectRefcount = jedis.objectRefcount("k1");
//        System.out.println(objectRefcount);
        //OBJECT ENCODING <key> 返回给定 key 锁储存的值所使用的内部表示(representation)。
        //个人理解 编码方式 embstr  这与value有关 编码有多种
        /*
             字符串可以被编码为 raw (一般字符串)或 int (为了节约内存,Redis 会将字符串表示的 64 位有符号整数编码为整数来进行储存)。
            列表可以被编码为 ziplist 或 linkedlist 。 ziplist 是为节约大小较小的列表空间而作的特殊表示。
            集合可以被编码为 intset 或者 hashtable 。 intset 是只储存数字的小集合的特殊表示。
            哈希表可以编码为 zipmap 或者 hashtable 。 zipmap 是小哈希表的特殊表示。
            有序集合可以被编码为 ziplist 或者 skiplist 格式。 ziplist 用于表示小的有序集合,而 skiplist 则用于表示任何大小的有序集合。
         */
//        String objectEncoding = jedis.objectEncoding("k1");
//        System.out.println(objectEncoding);
        //OBJECT IDLETIME <key> 返回给定 key 自储存以来的空闲时间(idle, 没有被读取也没有被写入),以秒为单位。
        Long objectIdletime = jedis.objectIdletime("k1");
        System.out.println(objectIdletime);//单位是秒
    }
    
    /**
     * @description: PTTL/TTL
     *                 TTL:以秒为单位,返回给定 key 的剩余生存时间(TTL, time to live)。
     *                 PTTL:这个命令类似于 TTL 命令,但它以毫秒为单位返回 key 的剩余生存时间,而不是像 TTL 命令那样,以秒为单位。
     * @author: viakiba
     * @throws Exception
     */
    @Test
    public void test5() throws Exception {
        Jedis jedis = new Jedis(RedisConfig.HOST,RedisConfig.PORT);
        jedis.flushAll();//清空所有数据
        System.out.println("=====准备数据=========");
        jedis.set("k0", "v0");//默认选择index为0的数据库
        jedis.setex("k1", 5, "v1");//默认选择index为0的数据库
        Thread.sleep(3000);
        /**
             当 key 不存在时,返回 -2 。
            当 key 存在但没有设置剩余生存时间时,返回 -1 。
            否则,以秒为单位,返回 key 的剩余生存时间。
         */
        System.out.println(jedis.ttl("k2"));//秒级,另外pttl()jedis没有提供
        System.out.println(jedis.ttl("k0"));//秒级,另外pttl()jedis没有提供
        System.out.println(jedis.ttl("k1"));//秒级,另外pttl()jedis没有提供
    }
    
    /**
     * @description: PEXPIRE/PEXPIREAT/PERSIST
     *                 PERSIST:移除给定 key 的生存时间,将这个 key 从『易失的』(带生存时间 key )转换成『持久的』(一个不带生存时间、永不过期的 key )。
     *                 PEXPIREAT:这个命令和 EXPIREAT 命令类似,但它以毫秒为单位设置 key 的过期 unix 时间戳,而不是像 EXPIREAT 那样,以秒为单位。
     *                 PEXPIRE:这个命令和 EXPIRE 命令的作用类似,但是它以毫秒为单位设置 key 的生存时间,而不像 EXPIRE 命令那样,以秒为单位。
     * @author: viakiba
     * @throws Exception
     */
    @Test
    public void test6() throws Exception {
//        Jedis jedis = new Jedis(RedisConfig.HOST,RedisConfig.PORT);
//        jedis.flushAll();//清空所有数据
//        System.out.println("=====准备数据=========");
//        jedis.setex("k0", 10, "v0");//默认选择index为0的数据库
//        System.out.println(jedis.ttl("k0"));
//        jedis.persist("k0");
//        System.out.println("===========");
//        System.out.println(jedis.ttl("k0"));
        
        
    }
}
点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
2年前
Java爬虫之JSoup使用教程
title:Java爬虫之JSoup使用教程date:201812248:00:000800update:201812248:00:000800author:mecover:https://imgblog.csdnimg.cn/20181224144920712(https://www.oschin
Stella981 Stella981
2年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
2年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Docker 部署SpringBoot项目不香吗?
  公众号改版后文章乱序推荐,希望你可以点击上方“Java进阶架构师”,点击右上角,将我们设为★“星标”!这样才不会错过每日进阶架构文章呀。  !(http://dingyue.ws.126.net/2020/0920/b00fbfc7j00qgy5xy002kd200qo00hsg00it00cj.jpg)  2
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
4个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这