Java 使用 Redis
安装
开始在 Java 中使用 Redis 前, 我们需要确保已经安装了 redis 服务及 Java redis 驱动,且你的机器上能正常使用 Java。 Java的安装配置可以参考我们的 Java开发环境配置 接下来让我们安装 Java redis 驱动:
- 首先你需要下载驱动包,下载 jedis.jar,确保下载最新驱动包。
- 在你的classpath中包含该驱动包。
连接到 redis 服务
import redis.clients.jedis.Jedis; public class RedisJava { public static void main(String[] args) { //连接本地的 Redis 服务 Jedis jedis = new Jedis("localhost"); System.out.println("Connection to server sucessfully"); //查看服务是否运行 System.out.println("Server is running: "+jedis.ping()); } }
编译以上 Java 程序,确保驱动包的路径是正确的。
$javac RedisJava.java $java RedisJava Connection to server sucessfully Server is running: PONG Redis Java String Example
Redis Java String(字符串) 实例
import redis.clients.jedis.Jedis; public class RedisStringJava { public static void main(String[] args) { //连接本地的 Redis 服务 Jedis jedis = new Jedis("localhost"); System.out.println("Connection to server sucessfully"); //设置 redis 字符串数据 jedis.set("runoobkey", "Redis tutorial"); // 获取存储的数据并输出 System.out.println("Stored string in redis:: "+ jedis.get("runoobkey")); } }
编译以上程序。
$javac RedisStringJava.java $java RedisStringJava Connection to server sucessfully Stored string in redis:: Redis tutorial
Redis Java List(列表) 实例
import redis.clients.jedis.Jedis; public class RedisListJava { public static void main(String[] args) { //连接本地的 Redis 服务 Jedis jedis = new Jedis("localhost"); System.out.println("Connection to server sucessfully"); //存储数据到列表中 jedis.lpush("tutorial-list", "Redis"); jedis.lpush("tutorial-list", "Mongodb"); jedis.lpush("tutorial-list", "Mysql"); // 获取存储的数据并输出 List<String> list = jedis.lrange("tutorial-list", 0 ,5); for(int i=0; i<list.size(); i++) { System.out.println("Stored string in redis:: "+list.get(i)); } } }
编译以上程序。
$javac RedisListJava.java $java RedisListJava Connection to server sucessfully Stored string in redis:: Redis Stored string in redis:: Mongodb Stored string in redis:: Mysql
Redis Java Keys 实例
import redis.clients.jedis.Jedis; public class RedisKeyJava { public static void main(String[] args) { //连接本地的 Redis 服务 Jedis jedis = new Jedis("localhost"); System.out.println("Connection to server sucessfully"); // 获取数据并输出 List<String> list = jedis.keys("*"); for(int i=0; i<list.size(); i++) { System.out.println("List of stored keys:: "+list.get(i)); } } }
编译以上程序。
$javac RedisKeyJava.java $java RedisKeyJava Connection to server sucessfully List of stored keys:: tutorial-name List of stored keys:: tutorial-list
附项目使用的Jedis工具类package com.me.backstage.commons.cache; import java.util.Arrays; import java.util.List; import java.util.Map; import java.util.Set; import payment.tools.util.StringUtil; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; import redis.clients.jedis.SortingParams; import redis.clients.util.SafeEncoder; import com.me.backstage.commons.PropertiesLoader; public class JedisUtil { /** * 缓存生存时间 */ private static final int expire = 60000; private static JedisPool jedisPool = null; public JedisUtil(){ PropertiesLoader PropertiesLoader = new PropertiesLoader("sys_config.properties"); JedisPoolConfig config = new JedisPoolConfig(); //控制一个pool可分配多少个jedis实例,通过pool.getResource()来获取; //如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。 config.setMaxActive(Integer.valueOf(PropertiesLoader.getProperty("redis.MaxActive"))); //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例。 config.setMaxIdle(Integer.valueOf(PropertiesLoader.getProperty("redis.MaxIdle"))); //表示当borrow(引入)一个jedis实例时,最大的等待时间,如果超过等待时间,则直接抛出JedisConnectionException; config.setMaxWait(Integer.valueOf(PropertiesLoader.getProperty("redis.MaxWait"))); //在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的; config.setTestOnBorrow(true); //redis如果设置了密码: // jedisPool = new JedisPool(config, JRedisPoolConfig.REDIS_IP, // JRedisPoolConfig.REDIS_PORT, // 10000,JRedisPoolConfig.REDIS_PASSWORD); //redis未设置了密码: jedisPool = new JedisPool(config, PropertiesLoader.getProperty("redis.host"), Integer.parseInt(PropertiesLoader.getProperty("redis.port")), 10000); } public JedisPool getPool() { return jedisPool; } /** * 从jedis连接池中获取获取jedis对象 */ private Jedis getJedis() { return jedisPool.getResource(); } private static final JedisUtil jedisUtil = new JedisUtil(); /** * 获取JedisUtil实例 */ public static JedisUtil getInstance() { return jedisUtil; } /** * 回收jedis */ public void returnJedis(Jedis jedis) { jedisPool.returnResource(jedis); } /** * 设置过期时间 */ public void expire(String key, int seconds) { if (seconds <= 0) { return; } Jedis jedis = getJedis(); jedis.expire(key, seconds); returnJedis(jedis); } /** * 设置默认过期时间 */ public void expire(String key) { expire(key, expire); } //*******************************************Keys*******************************************// public class Keys { /** * 清空所有key */ public String flushAll() { Jedis jedis = getJedis(); String stata = jedis.flushAll(); returnJedis(jedis); return stata; } /** * 更改key */ public String rename(String oldkey, String newkey) { return rename(SafeEncoder.encode(oldkey), SafeEncoder.encode(newkey)); } /** * 更改key,仅当新key不存在时才执行 * * @return 状态码 */ public long renamenx(String oldkey, String newkey) { Jedis jedis = getJedis(); long status = jedis.renamenx(oldkey, newkey); returnJedis(jedis); return status; } /** * 更改key */ public String rename(byte[] oldkey, byte[] newkey) { Jedis jedis = getJedis(); String status = jedis.rename(oldkey, newkey); returnJedis(jedis); return status; } /** * 设置key的过期时间,以秒为单位 */ public long expired(String key, int seconds) { Jedis jedis = getJedis(); long count = jedis.expire(key, seconds); returnJedis(jedis); return count; } /** * 设置key的过期时间,它是距历元(即格林威治标准时间 1970 年 1 月 1 日的 00:00:00,格里高利历)的偏移量。 */ public long expireAt(String key, long timestamp) { Jedis jedis = getJedis(); long count = jedis.expireAt(key, timestamp); returnJedis(jedis); return count; } /** * 查询key的过期时间 */ public long ttl(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); long len = sjedis.ttl(key); returnJedis(sjedis); return len; } /** * 取消对key过期时间的设置 */ public long persist(String key) { Jedis jedis = getJedis(); long count = jedis.persist(key); returnJedis(jedis); return count; } /** * 删除keys对应的记录,可以是多个key */ public long del(String... keys) { Jedis jedis = getJedis(); long count = jedis.del(keys); returnJedis(jedis); return count; } /** * 删除keys对应的记录,可以是多个key */ public long del(byte[]... keys) { Jedis jedis = getJedis(); long count = jedis.del(keys); returnJedis(jedis); return count; } /** * 判断key是否存在 */ public boolean exists(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); boolean exis = sjedis.exists(key); returnJedis(sjedis); return exis; } /** * 对List,Set,SortSet进行排序,如果集合数据较大应避免使用这个方法 **/ public List sort(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); List list = sjedis.sort(key); returnJedis(sjedis); return list; } /** * 对List,Set,SortSet进行排序或limit **/ public List sort(String key, SortingParams parame) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); List list = sjedis.sort(key, parame); returnJedis(sjedis); return list; } /** * 返回指定key存储的类型 **/ public String type(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); String type = sjedis.type(key); returnJedis(sjedis); return type; } /** * 查找所有匹配给定的模式的键 */ public Set keys(String pattern) { Jedis jedis = getJedis(); Set set = jedis.keys(pattern); returnJedis(jedis); return set; } } //*******************************************Sets*******************************************// public class Sets { /** * 向Set添加一条记录,如果member已存在返回0,否则返回1 */ public long sadd(String key, String member) { Jedis jedis = getJedis(); long s = jedis.sadd(key, member); returnJedis(jedis); return s; } public long sadd(byte[] key, byte[] member) { Jedis jedis = getJedis(); long s = jedis.sadd(key, member); returnJedis(jedis); return s; } /** * 获取给定key中元素个数 */ public long scard(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); long len = sjedis.scard(key); returnJedis(sjedis); return len; } /** * 返回从第一组和所有的给定集合之间的差异的成员 */ public Set sdiff(String... keys) { Jedis jedis = getJedis(); Set set = jedis.sdiff(keys); returnJedis(jedis); return set; } /** * 这个命令等于sdiff,但返回的不是结果集,而是将结果集存储在新的集合中,如果目标已存在,则覆盖。 **/ public long sdiffstore(String newkey, String... keys) { Jedis jedis = getJedis(); long s = jedis.sdiffstore(newkey, keys); returnJedis(jedis); return s; } /** * 返回给定集合交集的成员,如果其中一个集合为不存在或为空,则返回空Set **/ public Set sinter(String... keys) { Jedis jedis = getJedis(); Set set = jedis.sinter(keys); returnJedis(jedis); return set; } /** * 这个命令等于sinter,但返回的不是结果集,而是将结果集存储在新的集合中,如果目标已存在,则覆盖。 **/ public long sinterstore(String newkey, String... keys) { Jedis jedis = getJedis(); long s = jedis.sinterstore(newkey, keys); returnJedis(jedis); return s; } /** * 确定一个给定的值是否存在 **/ public boolean sismember(String key, String member) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); boolean s = sjedis.sismember(key, member); returnJedis(sjedis); return s; } /** * 返回集合中的所有成员 */ public Set smembers(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); Set set = sjedis.smembers(key); returnJedis(sjedis); return set; } public Set smembers(byte[] key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); Set set = sjedis.smembers(key); returnJedis(sjedis); return set; } /** * 将成员从源集合移出放入目标集合
* 如果源集合不存在或不包哈指定成员,不进行任何操作,返回0
* 否则该成员从源集合上删除,并添加到目标集合,如果目标集合中成员已存在,则只在源集合进行删除 */ public long smove(String srckey, String dstkey, String member) { Jedis jedis = getJedis(); long s = jedis.smove(srckey, dstkey, member); returnJedis(jedis); return s; } /** * 从集合中删除成员 */ public String spop(String key) { Jedis jedis = getJedis(); String s = jedis.spop(key); returnJedis(jedis); return s; } /** * 从集合中删除指定成员 */ public long srem(String key, String member) { Jedis jedis = getJedis(); long s = jedis.srem(key, member); returnJedis(jedis); return s; } /** * 合并多个集合并返回合并后的结果,合并后的结果集合并不保存
*/ public Set sunion(String... keys) { Jedis jedis = getJedis(); Set set = jedis.sunion(keys); returnJedis(jedis); return set; } /** * 合并多个集合并将合并后的结果集保存在指定的新集合中,如果新集合已经存在则覆盖 **/ public long sunionstore(String newkey, String... keys) { Jedis jedis = getJedis(); long s = jedis.sunionstore(newkey, keys); returnJedis(jedis); return s; } } //*******************************************SortSet*******************************************// public class SortSet { /** * 向集合中增加一条记录,如果这个值已存在,这个值对应的权重将被置为新的权重 */ public long zadd(String key, double score, String member) { Jedis jedis = getJedis(); long s = jedis.zadd(key, score, member); returnJedis(jedis); return s; } public long zadd(String key, Map scoreMembers) { Jedis jedis = getJedis(); long s = jedis.zadd(key, scoreMembers); returnJedis(jedis); return s; } /** * 获取集合中元素的数量 */ public long zcard(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); long len = sjedis.zcard(key); returnJedis(sjedis); return len; } /** * 获取指定权重区间内集合的数量 */ public long zcount(String key, double min, double max) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); long len = sjedis.zcount(key, min, max); returnJedis(sjedis); return len; } /** * 获得set的长度 */ public long zlength(String key) { long len = 0; Set set = zrange(key, 0, -1); len = set.size(); return len; } /** * 权重增加给定值,如果给定的member已存在 */ public double zincrby(String key, double score, String member) { Jedis jedis = getJedis(); double s = jedis.zincrby(key, score, member); returnJedis(jedis); return s; } /** * 返回指定位置的集合元素,0为第一个元素,-1为最后一个元素 */ public Set zrange(String key, int start, int end) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); Set set = sjedis.zrange(key, start, end); returnJedis(sjedis); return set; } /** * 返回指定权重区间的元素集合 */ public Set zrangeByScore(String key, double min, double max) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); Set set = sjedis.zrangeByScore(key, min, max); returnJedis(sjedis); return set; } /** * 获取指定值在集合中的位置,集合排序从低到高 */ public long zrank(String key, String member) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); long index = sjedis.zrank(key, member); returnJedis(sjedis); return index; } /** * 获取指定值在集合中的位置,集合排序从高到低 */ public long zrevrank(String key, String member) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); long index = sjedis.zrevrank(key, member); returnJedis(sjedis); return index; } /** * 从集合中删除成员 */ public long zrem(String key, String member) { Jedis jedis = getJedis(); long s = jedis.zrem(key, member); returnJedis(jedis); return s; } /** * 删除 */ public long zrem(String key) { Jedis jedis = getJedis(); long s = jedis.del(key); returnJedis(jedis); return s; } /** * 删除给定位置区间的元素 */ public long zremrangeByRank(String key, int start, int end) { Jedis jedis = getJedis(); long s = jedis.zremrangeByRank(key, start, end); returnJedis(jedis); return s; } /** * 删除给定权重区间的元素 */ public long zremrangeByScore(String key, double min, double max) { Jedis jedis = getJedis(); long s = jedis.zremrangeByScore(key, min, max); returnJedis(jedis); return s; } /** * 获取给定区间的元素,原始按照权重由高到低排序 */ public Set zrevrange(String key, int start, int end) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); Set set = sjedis.zrevrange(key, start, end); returnJedis(sjedis); return set; } /** * 获取给定值在集合中的权重 */ public double zscore(String key, String memebr) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); Double score = sjedis.zscore(key, memebr); returnJedis(sjedis); if (score != null){ return score; } return 0; } } //*******************************************Hash*******************************************// public class Hash { /** * 从hash中删除指定的存储 */ public long hdel(String key, String fieid) { Jedis jedis = getJedis(); long s = jedis.hdel(key, fieid); returnJedis(jedis); return s; } public long hdel(String key) { Jedis jedis = getJedis(); long s = jedis.del(key); returnJedis(jedis); return s; } /** * 测试hash中指定的存储是否存在 */ public boolean hexists(String key, String fieid) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); boolean s = sjedis.hexists(key, fieid); returnJedis(sjedis); return s; } /** * 返回hash中指定存储位置的值 */ public String hget(String key, String fieid) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); String s = sjedis.hget(key, fieid); returnJedis(sjedis); return s; } public byte[] hget(byte[] key, byte[] fieid) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); byte[] s = sjedis.hget(key, fieid); returnJedis(sjedis); return s; } /** * 以Map的形式返回hash中的存储和值 */ public Map hgetAll(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); Map map = sjedis.hgetAll(key); returnJedis(sjedis); //添加用户黑名单 TODO 临时添加,处理完错误数据后去掉 if(key.length() == 45){ PropertiesLoader propertiesLoader = new PropertiesLoader("sys_config.properties"); String phoneList = propertiesLoader.getProperty("black_phone_list"); if(!StringUtil.isEmpty(phoneList)){ List list = Arrays.asList(phoneList.split(",")); String phoneNum = map.get("loginTel"); if(list.contains(phoneNum)){ throw new RuntimeException("该用户无法操作!手机号:"+phoneNum); } } } return map; } /** * 添加一个对应关系 **/ public long hset(String key, String fieid, String value) { Jedis jedis = getJedis(); long s = jedis.hset(key, fieid, value); returnJedis(jedis); return s; } public long hset(String key, String fieid, byte[] value) { Jedis jedis = getJedis(); long s = jedis.hset(key.getBytes(), fieid.getBytes(), value); returnJedis(jedis); return s; } /** * 添加对应关系,只有在fieid不存在时才执行 **/ public long hsetnx(String key, String fieid, String value) { Jedis jedis = getJedis(); long s = jedis.hsetnx(key, fieid, value); returnJedis(jedis); return s; } /** * 获取hash中value的集合 */ public List hvals(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); List list = sjedis.hvals(key); returnJedis(sjedis); return list; } /** * 在指定的存储位置加上指定的数字,存储位置的值必须可转为数字类型 */ public long hincrby(String key, String fieid, long value) { Jedis jedis = getJedis(); long s = jedis.hincrBy(key, fieid, value); returnJedis(jedis); return s; } /** * 返回指定hash中的所有存储名字,类似Map中的keySet方法 */ public Set hkeys(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); Set set = sjedis.hkeys(key); returnJedis(sjedis); return set; } /** * 获取hash中存储的个数,类似Map中size方法 */ public long hlen(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); long len = sjedis.hlen(key); returnJedis(sjedis); return len; } /** * 根据多个key,获取对应的value,返回List,如果指定的key不存在,List对应位置为null */ public List hmget(String key, String... fieids) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); List list = sjedis.hmget(key, fieids); returnJedis(sjedis); return list; } public List hmget(byte[] key, byte[]... fieids) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); List list = sjedis.hmget(key, fieids); returnJedis(sjedis); return list; } /** * 添加对应关系,如果对应关系已存在,则覆盖 */ public String hmset(String key, Map map) { Jedis jedis = getJedis(); String s = jedis.hmset(key, map); returnJedis(jedis); return s; } /** * 添加有过期时间的记录 */ public String hmsetEx(String key, int second, Map map) { Jedis jedis = getJedis(); String str = jedis.hmset(key, map); jedis.expire(key, second); returnJedis(jedis); return str; } /** * 添加对应关系,如果对应关系已存在,则覆盖 */ public String hmset(byte[] key, Map map) { Jedis jedis = getJedis(); String s = jedis.hmset(key, map); returnJedis(jedis); return s; } } //*******************************************Strings*******************************************// public class Strings { /** * 根据key获取记录 */ public String get(String key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); String value = sjedis.get(key); returnJedis(sjedis); return value; } /** * 根据key获取记录 */ public byte[] get(byte[] key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); byte[] value = sjedis.get(key); returnJedis(sjedis); return value; } /** * 添加有过期时间的记录 */ public String setEx(String key, int seconds, String value) { Jedis jedis = getJedis(); String str = jedis.setex(key, seconds, value); returnJedis(jedis); return str; } /** * 添加有过期时间的记录 */ public String setEx(byte[] key, int seconds, byte[] value) { Jedis jedis = getJedis(); String str = jedis.setex(key, seconds, value); returnJedis(jedis); return str; } /** * 添加一条记录,仅当给定的key不存在时才插入 */ public long setnx(String key, String value) { Jedis jedis = getJedis(); long str = jedis.setnx(key, value); returnJedis(jedis); return str; } /** * 添加记录,如果记录已存在将覆盖原有的value */ public String set(String key, String value) { return set(SafeEncoder.encode(key), SafeEncoder.encode(value)); } /** * 添加记录,如果记录已存在将覆盖原有的value */ public String set(String key, byte[] value) { return set(SafeEncoder.encode(key), value); } /** * 添加记录,如果记录已存在将覆盖原有的value */ public String set(byte[] key, byte[] value) { Jedis jedis = getJedis(); String status = jedis.set(key, value); returnJedis(jedis); return status; } /** * 从指定位置开始插入数据,插入的数据会覆盖指定位置以后的数据
* 例:String str1="123456789";
* 对str1操作后setRange(key,4,0000),str1="123400009"; */ public long setRange(String key, long offset, String value) { Jedis jedis = getJedis(); long len = jedis.setrange(key, offset, value); returnJedis(jedis); return len; } /** * 在指定的key中追加value **/ public long append(String key, String value) { Jedis jedis = getJedis(); long len = jedis.append(key, value); returnJedis(jedis); return len; } /** * 将key对应的value减去指定的值,只有value可以转为数字时该方法才可用 */ public long decrBy(String key, long number) { Jedis jedis = getJedis(); long len = jedis.decrBy(key, number); returnJedis(jedis); return len; } /** * 可以作为获取唯一id的方法
* 将key对应的value加上指定的值,只有value可以转为数字时该方法才可用 */ public long incrBy(String key, long number) { Jedis jedis = getJedis(); long len = jedis.incrBy(key, number); returnJedis(jedis); return len; } /** * 对指定key对应的value进行截取 */ public String getrange(String key, long startOffset, long endOffset) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); String value = sjedis.getrange(key, startOffset, endOffset); returnJedis(sjedis); return value; } /** * 获取并设置指定key对应的value
* 如果key存在返回之前的value,否则返回null */ public String getSet(String key, String value) { Jedis jedis = getJedis(); String str = jedis.getSet(key, value); returnJedis(jedis); return str; } /** * 批量获取记录,如果指定的key不存在返回List的对应位置将是null */ public List mget(String... keys) { Jedis jedis = getJedis(); List str = jedis.mget(keys); returnJedis(jedis); return str; } /** * 批量存储记录 */ public String mset(String... keysvalues) { Jedis jedis = getJedis(); String str = jedis.mset(keysvalues); returnJedis(jedis); return str; } /** * 获取key对应的值的长度 */ public long strlen(String key) { Jedis jedis = getJedis(); long len = jedis.strlen(key); returnJedis(jedis); return len; } public long del(String key) { Jedis jedis = getJedis(); long len = jedis.del(key); returnJedis(jedis); return len; } } //*******************************************Lists*******************************************// public class Lists { /** * List长度 */ public long llen(String key) { return llen(SafeEncoder.encode(key)); } /** * List长度 */ public long llen(byte[] key) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); long count = sjedis.llen(key); returnJedis(sjedis); return count; } /** * 覆盖操作,将覆盖List中指定位置的值 */ public String lset(byte[] key, int index, byte[] value) { Jedis jedis = getJedis(); String status = jedis.lset(key, index, value); returnJedis(jedis); return status; } /** * 覆盖操作,将覆盖List中指定位置的值 */ public String lset(String key, int index, String value) { return lset(SafeEncoder.encode(key), index, SafeEncoder.encode(value)); } // /** // * 在value的相对位置插入记录 // * // * @param key // * @return 记录总数 // */ // public long linsert(String key, LIST_POSITION where, String pivot, // String value) { // return linsert(SafeEncoder.encode(key), where, // SafeEncoder.encode(pivot), SafeEncoder.encode(value)); // } /** * 在指定位置插入记录 * */ // public long linsert(byte[] key, LIST_POSITION where, byte[] pivot, // byte[] value) { // Jedis jedis = getJedis(); // long count = jedis.linsert(key, where, pivot, value); // returnJedis(jedis); // return count; // } /** * 获取List中指定位置的值 **/ public String lindex(String key, int index) { return SafeEncoder.encode(lindex(SafeEncoder.encode(key), index)); } /** * 获取List中指定位置的值 **/ public byte[] lindex(byte[] key, int index) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); byte[] value = sjedis.lindex(key, index); returnJedis(sjedis); return value; } /** * 将List中的第一条记录移出List */ public String lpop(String key) { return SafeEncoder.encode(lpop(SafeEncoder.encode(key))); } /** * 将List中的第一条记录移出List */ public byte[] lpop(byte[] key) { Jedis jedis = getJedis(); byte[] value = jedis.lpop(key); returnJedis(jedis); return value; } /** * 将List中最后第一条记录移出List */ public String rpop(String key) { Jedis jedis = getJedis(); String value = jedis.rpop(key); returnJedis(jedis); return value; } /** * 向List尾部追加记录 */ public long lpush(String key, String value) { return lpush(SafeEncoder.encode(key), SafeEncoder.encode(value)); } /** * 向List头部追加记录 */ public long rpush(String key, String value) { Jedis jedis = getJedis(); long count = jedis.rpush(key, value); returnJedis(jedis); return count; } /** * 向List头部追加记录 */ public long rpush(byte[] key, byte[] value) { Jedis jedis = getJedis(); long count = jedis.rpush(key, value); returnJedis(jedis); return count; } /** * 向List中追加记录 */ public long lpush(byte[] key, byte[] value) { Jedis jedis = getJedis(); long count = jedis.lpush(key, value); returnJedis(jedis); return count; } /** * 获取指定范围的记录,可以做为分页使用 */ public List lrange(String key, long start, long end) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); List list = sjedis.lrange(key, start, end); returnJedis(sjedis); return list; } /** * 获取指定范围的记录,可以做为分页使用 */ public List lrange(byte[] key, int start, int end) { //ShardedJedis sjedis = getShardedJedis(); Jedis sjedis = getJedis(); List list = sjedis.lrange(key, start, end); returnJedis(sjedis); return list; } /** * 删除List中c条记录,被删除的记录值为value */ public long lrem(byte[] key, int c, byte[] value) { Jedis jedis = getJedis(); long count = jedis.lrem(key, c, value); returnJedis(jedis); return count; } /** * 删除List中c条记录,被删除的记录值为value */ public long lrem(String key, int c, String value) { return lrem(SafeEncoder.encode(key), c, SafeEncoder.encode(value)); } /** * 算是删除吧,只保留start与end之间的记录 */ public String ltrim(byte[] key, int start, int end) { Jedis jedis = getJedis(); String str = jedis.ltrim(key, start, end); returnJedis(jedis); return str; } /** * 算是删除吧,只保留start与end之间的记录 */ public String ltrim(String key, int start, int end) { return ltrim(SafeEncoder.encode(key), start, end); } } public static void main(String[] args) { JedisUtil jedisUtil = JedisUtil.getInstance(); JedisUtil.Strings strings = jedisUtil.new Strings(); strings.setEx("val", 10, "123154"); // strings.set("nnn", "nnnn"); System.out.println("-----" + strings.get("val")); // Jedis jedis = JedisUtil.getInstance().getJedis(); // for (int i = 0; i < 10; i++) { // jedis.set("test", "test"); // System.out.println(i + "==" + jedis.get("test")); // // } // JedisUtil.getInstance().returnJedis(jedis); } }