package com.ztest.redis; import java.util.List; import redis.clients.jedis.Jedis; import com.sun.istack.internal.logging.Logger; import com.ztest.redis.util.JedisConnectionUtil; /** * * @author yafei.lv *redis异步??? */ public class JedisKeyTestTwo { private final static Logger logger = Logger.getLogger(JedisKeyTestOne.class); public static void keyTest(){ Jedis jedis = null; try{ jedis = JedisConnectionUtil.initJedis(); // 0.flushDb 和 flush all /* 一个端口一个库? * flush all : 清空整个 Redis 服务器的数据 (删除所有数据库的所有 key )。此命令从不失败。时间复杂度: 尚未明确.返回值: 总是返回 OK 。 * flush db : 清空当前数据库中的所有 key。此命令从不失败。时间复杂度: O(1)。返回值: 总是返回 OK 。 */ jedis.flushDB(); // 1.migrate 将key和value原子性地从当前实例,传送到目标实例的指定库上,一旦传送成功,key保证会出现在目示实例上,当前会被删除 //是原子操作、阻塞 /* * @Redis命令:migrate host port key destiontion-db timeout * * @例子:把6379的redis里面的key移到6378里面 * migrate 127.0.0.1 6378 lvyf 0(库名) 1000 */ // 2.move 将当前数据库key移动到指定数据库中,如果当前数据库 (源数据库) 和给定数据库 (目标数据库) 有相同名字的给定 key ,或者 key 不存在于当前 //数据库,那么 MOVE 没有任何效果 /* * @Redis命令: move key db * 时间复杂度: O(1) 返回值: 移动成功返回 1 ,失败则返回 0 @例子:move lvyf 0 */ jedis.set("lvyf1", "123"); jedis.move("lvyf1",1); jedis.flushAll(); // 3. object OBJECT 命令允许从内部察看给定 key 的 Redis 对象 jedis.set("lvyf","1q23"); jedis.objectEncoding("lvyf"); Long count = jedis.objectRefcount("lvyf"); logger.info("obj==" + jedis.get("lvyf")+",count=="+count); // 4. persist 移除key的存活时间 /* * @Redis命令 persist lvyf */ jedis.expire("lvyf", 5); jedis.persist("lvyf"); // 5. pexpire 给key设置存活时间,单位毫秒 /* @Redis命令 pexpire lvyf 1000 时间段 */ // 6. /* * PEXPIREAT key milliseconds-timestamp 这个命令和EXPIREAT 命令类似,但它以毫秒为单位设置 key 的过期 unix 时间戳,而不是像EXPIREAT 那样,以秒为单位 @Redis命 PEXPIREAT lvyf 140999887766655 ,某一时间点 */ // 7. pttl 它以毫秒为单位返回 key 的剩余生存时间 /* * @Redis命令 pttl lvyf */ // 8. randomkey 从当前数据库中随机返回 (不删除) 一个 key /* * @Redis命令 randomkey */ jedis.flushAll(); jedis.set("orange", "1"); jedis.set("apple", "2"); jedis.set("banana", "3"); logger.info("randomKey==" + jedis.randomKey()); // 9. rename 修改key /* * @Redis命令: rename key newkey * 当 key 和 newkey 相同,或者 key 不存在时,返回一个错误。 当 newkey 已经存在时,RENAME 命令将覆盖旧值。 * 从当前数据库中随机返回 (不删除) 一个 key */ jedis.flushAll(); jedis.set("1", "orange"); jedis.set("2","apple"); logger.info("修改前 key是2的value==" + jedis.get("2")); String result = jedis.rename("1", "2"); logger.info("修改结果==" + result + "修改后key是2的value==" + jedis.get("2")); // 10.renamenx 当且仅当newkey 不存在时,才会修改 /* * @Redis命令 renamenx lvyf lvyf1 * 时间复杂度: O(1) 返回值: 修改成功时,返回 1 。 如果 newkey 已经存在,返回 0 。 */ jedis.flushAll(); jedis.set("1", "orange"); jedis.set("2","apple"); logger.info("修改前 key是2的value==" + jedis.get("2")); Long result1 = jedis.renamenx("1", "3"); logger.info("修改结果==" + result1 + "修改后key是2的value==" + jedis.get("2") + ",3=="+jedis.get("3")+",1=="+jedis.get("1")); // 11.restore /* * @Redis命令 * RESTORE key ttl serialized-value * * 反序列化给定的序列化值,并将它和给定的 key 关联。 参数 ttl 以毫秒为单位为 key 设置生存时间;如果 ttl 为 0 ,那么不设置生存时间 返回值: 如果反序列化成功那么返回 OK ,否则返回一个错误。 DUMP greeting 再看看!!! x00x15hello, dumping world!x06x00Exa0Zx82xd8rxc1xde" # 将序列化数据 RESTORE 到另一个键上面 RESTORE greeting-again 0 "x00x15hello, dumping world!x06x00Exa0Zx82xd8rxc1xde" OK */ // 12. ttl 返回key的剩余生存时间 秒 jedis.flushAll(); jedis.set("lvyf", "123"); Long timeNoExpire = jedis.ttl("lvyf"); Long timeNotKeyExist = jedis.ttl("lvyafei1"); logger.info("timeNoExpire=="+timeNoExpire+",timeNotKeyExist=="+timeNotKeyExist); jedis.set("lv", "123"); jedis.expire("lv", 10); Thread.currentThread(); // Thread.sleep(1000*3); Long rightTTl = jedis.ttl("lv"); logger.info("rightTTl=="+rightTTl); /* * 13.type 返回key所存value类型 * TYPE key 返回 key 所储存的值的类型。 可用版本: >= 1.0.0 时间复杂度: O(1) 返回值: none (key 不存在) string (字符串) list (列表) set (集合) zset (有序集) hash (哈希表) */ jedis.flushAll(); jedis.set("lvyf", "123"); String type = jedis.type("lvyf"); logger.info("type=="+type+",not=="+jedis.type("123")); /* * 14. sort 对指定key的value排序 * * SORT key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern ...]] [ASC | DESC] [ALPHA] [STORE destination] 返回或保存给定列表、集合、有序集合 key 中经过排序的元素。 排序默认以数字作为对象,值被解释为双精度浮点数,然后进行比较。 时间复杂度: O(N+M*log(M)),N 为要排序的列表或集合内的元素数量,M 为要返回的元素数量。 如果只是使用SORT 命令的 GET 选项获取数据而没有进行排序,时间复杂度 O(N)。 返回值: 没有使用 STORE 参数,返回列表形式的排序结果。 使用 STORE 参数,返回排序结果的元素数量。 */ jedis.lpush("cost", "10","5","20","3"); List<String> sortResult = jedis.sort("cost"); for(String str : sortResult){ logger.info("str=="+ str); } /* * 15. SCAN * 命令是一个基于游标的迭代器( cursor based iterator):SCAN 命令每次被调用之后,都会向用户返 回一个新的游标,用户在下次迭代时需要使用这个新游标作为SCAN 命令的游标参数,以此来延续之前的 迭代过程。 当SCAN 命令的游标参数被设置为 0 时,服务器将开始一次新的迭代,而当服务器向用户返回值为 0 的游 标时,表示迭代已结束 */ // for(int i = 0 ; i < 20 ; i++){ // jedis.set(i+"", i+""); // } }catch(Exception e){ e.printStackTrace(); }finally{ if(jedis != null){ JedisConnectionUtil.returnJedis(jedis); //回收 } } } public static void main(String[] args) { keyTest(); } }