redis的使用

来源:互联网 发布:埃兹拉米勒 知乎 编辑:程序博客网 时间:2024/06/05 21:52

这两天活不多,今天改完bug后学习一下redis。

概念什么的在此就不再阐述了,我们只讲工作中要用到的最基础,最实用和特别要注意的地方。

一、Redis 数据类型

Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

String(字符串)

string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。

string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。

string类型是Redis最基本的数据类型,一个键最大能存储512MB。

实例

redis 127.0.0.1:6379> SET name "runoob"OKredis 127.0.0.1:6379> GET name"runoob"

在以上实例中我们使用了 Redis 的 SET 和 GET 命令。键为 name,对应的值为 runoob

注意:一个键最大能存储512MB。

Hash(哈希)

Redis hash 是一个键名对集合。

Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。

实例

127.0.0.1:6379> HMSET user:1 username runoob password runoob points 200OK127.0.0.1:6379> HGETALL user:11) "username"2) "runoob"3) "password"4) "runoob"5) "points"6) "200"

以上实例中 hash 数据类型存储了包含用户脚本信息的用户对象。 实例中我们使用了 Redis HMSET, HGETALL 命令,user:1为键值。

每个 hash 可以存储 232 -1 键值对(40多亿)。


List(列表)

Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。

实例

redis 127.0.0.1:6379> lpush runoob redis(integer) 1redis 127.0.0.1:6379> lpush runoob mongodb(integer) 2redis 127.0.0.1:6379> lpush runoob rabitmq(integer) 3redis 127.0.0.1:6379> lrange runoob 0 101) "rabitmq"2) "mongodb"3) "redis"redis 127.0.0.1:6379>

列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。


Set(集合)

Redis的Set是string类型的无序集合。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。

sadd 命令

添加一个string元素到,key对应的set集合中,成功返回1,如果元素已经在集合中返回0,key对应的set不存在返回错误。

sadd key member

实例

redis 127.0.0.1:6379> sadd runoob redis(integer) 1redis 127.0.0.1:6379> sadd runoob mongodb(integer) 1redis 127.0.0.1:6379> sadd runoob rabitmq(integer) 1redis 127.0.0.1:6379> sadd runoob rabitmq(integer) 0redis 127.0.0.1:6379> smembers runoob1) "rabitmq"2) "mongodb"3) "redis"

注意:以上实例中 rabitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。

集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。


zset(sorted set:有序集合)

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

zset的成员是唯一的,但分数(score)却可以重复。

zadd 命令

添加元素到集合,元素在集合中存在则更新对应score

zadd key score member 

实例

redis 127.0.0.1:6379> zadd runoob 0 redis(integer) 1redis 127.0.0.1:6379> zadd runoob 0 mongodb(integer) 1redis 127.0.0.1:6379> zadd runoob 0 rabitmq(integer) 1redis 127.0.0.1:6379> zadd runoob 0 rabitmq(integer) 0redis 127.0.0.1:6379> ZRANGEBYSCORE runoob 0 10001) "redis"2) "mongodb"3) "rabitmq"

二、Java 使用 Redis

在我们的普通javaweb中使用redis非常简单
1.加入所需的jar包
//用于连接redis的数据库连接池
 //java的redis jar包
2.在配置文件中加入(appcationContext.xml)
<!--导入redis.xml--><import resource="classpath:config/spring/Jedis.xml" />


Jedis.xml:

<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:dwr="http://www.directwebremoting.org/schema/spring-dwr"xmlns:amq="http://activemq.apache.org/schema/core" xmlns:jms="http://www.springframework.org/schema/jms"xmlns:util="http://www.springframework.org/schema/util" xmlns:p="http://www.springframework.org/schema/p"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd        http://www.directwebremoting.org/schema/spring-dwr http://www.directwebremoting.org/schema/spring-dwr-2.0.xsd        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.0.xsd        http://activemq.apache.org/schema/core http://activemq.apache.org/schema/core/activemq-core.xsd        http://www.springframework.org/schema/jms http://www.springframework.org/schema/jms/spring-jms-2.5.xsd"><bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">      <property name="maxActive"  value="50" />      <property name="maxIdle" value="10" />      <property name="maxWait" value="1000" />      <property name="testOnBorrow"  value="true"/>  </bean> <bean id="shardInfo" class="redis.clients.jedis.JedisShardInfo">     <constructor-arg index="0" value="${redis.address}" />      <constructor-arg index="1" value="${redis.port}" type="int"/>  </bean>    <bean id="shardedJedisPool" class="redis.clients.jedis.ShardedJedisPool">      <constructor-arg index="0" ref="jedisPoolConfig" />      <constructor-arg index="1">          <list>              <ref bean="shardInfo" />          </list>      </constructor-arg>  </bean>  <bean id="redisUtil" class="framelib.redis.impl.RedisUtilImpl">    <property name="shardedJedisPool" ref="shardedJedisPool"></property><property name="shardedJedisPoolMap">   <map>      <!-- 以后扩展redis服务,一次往后累加 -->      <entry key="1">     <ref bean="shardedJedisPool" />      </entry>   </map>  </property></bean>  </beans>

java里面我这里封装了一下,目录结构如下:



IRedisCacheConfirm.java
package framelib.redis;import javax.servlet.http.HttpServletRequest;/** * redis cache数据取得确保器 *    该接口用于取得缓存数据时用,如果缓存中没有对应的数据, * @author kong.fanqing * */public interface IRedisCacheConfirmer {/** * 取得redis key * @return */public String getRedisKey();/** * 当缓存中没有数据时调用 * @return */public Object getObject();/** * 取得缓存数据 * @return */public Object getCacheObject(HttpServletRequest request);}

接口IRedisUtil:
package framelib.redis;import java.io.Serializable;import java.util.List;import java.util.Map;import java.util.Set;/** * 操作redis接口 * @author kong.fanqing * */public interface IRedisUtil {/**存对象**/public String setObject(String key, Object obj);public String setObject(String key, Serializable value);public String setObject(String key, List<? extends Serializable> value);public String setObject(String key,Map<?, ?extends Serializable> value);public String setObject(String key,Set<?extends Serializable> value);/**取对象**/public Object getObject(String key);/**List集合**/public Object lindex(String key,int index);public Long llen(String key);public Object lpop(String key);public Object lrpop(String key);public Long lpush(String key,Serializable value);public void lpush(String key,List<? extends Serializable> value);public Long rpush(String key,Serializable value);public void rpush(String key,List<? extends Serializable> value);public Long lpushx(String key,Serializable value);public void lpushx(String key,List<? extends Serializable> value);public Long rpushx(String key,Serializable value);public void rpushx(String key,List<? extends Serializable> value);public List lrange(String key,int start,int end);public Long lrem(String key,int count,Serializable value);public String lset(String key,int index,Serializable value);public String ltrim(String key,int start,int end);/*忽略*/public String rpoplpush(String srcKey,String detKey);/**Set集合**/public Long sadd(String key,Serializable value);public void sadd(String key,Set<?extends Serializable> values);public Long scard(String key);public boolean sismember(String key,Serializable value);public Set<? extends Serializable> smembers(String key);public Object spop(String key);public Object srandmember(String key);public Long srem(String key,Serializable value);/*******Sorted set************/public Long zadd(String key,double score,Serializable value);public Long zcard(String key);public Long zcount(String key,double min,double max);public double zincrby(String key,double incrementscore,Serializable value);public Set<? extends Serializable> zrange(String key,int start,int end);public Set<? extends Serializable> zrangeByScore(String key,double min,double max);public Set<? extends Serializable> zrangeByScore(String key,double min,double max, int offset, int count);public Long zrem(String key,Serializable value);public Long zremrangeByRank(String key,int start ,int end);public Long zremrangeByScore(String key,double start,double end);public Set<? extends Serializable> zrevrange(String key,int start,int end);public Long zrank(String key,Serializable value);public Long zrevrank(String key,Serializable value);public double zscore(String key,Serializable value);/**********hash 表***********/public Long hset(String key,String field,Serializable value);//public void hset(String key,Map<String, ?extends Serializable> value);public boolean hexists(String key,String field);public Long hsetnx(String key,String field,Serializable value);public String hmset(String key,Map<String, ? extends Serializable> values);public Object hget(String key,String field);public List hmget(String key,List<String> fields);public Map<String,? extends Serializable> hgetAll(String key);public Long hdel(String key,String field);public Long hlen(String key);public Set<String> hkeys(String key);public List hvals(String key);/********************String***************************/public String set(String key,String value);public Long setnx(String key,String value);public String setex(String key,int seconds,String value);public Long append(String key,String value);public String get(String key);public String getSet(String key,String value);//public Long strlen(String key);public Long decr(String key);public Long decrBy(String key,long integer);public Long incr(String key);public Long incrBy(String key,long integer);/********************通用**************************///public Pipeline pipeline(String key);public Long ttl(String key);//public Long move(String key,int dbindex);public String type(String key);public Long expire(String key,int seconds);public Long expireAt(String key,long timestamp);//public Long persist(String key);//public Map<String, Object> mget(List<String> keys);public boolean exists(String key);public Long del(String key);//public Long del(List<String> keys);public Set<String> keys(Integer idKey,String pattern);//public String flushAll();//public long delKeys(String pattern);}

RedisFactory.java
package framelib.redis;import javax.servlet.http.HttpServletRequest;import framelib.utils.SpringUtil;/** *  * @author kong.fanqing * */public class RedisFactory {/** * 返回redisService,如果redis没有启用,则返回null * @return */public static IRedisUtil getIRedisService(HttpServletRequest request){return (IRedisUtil)SpringUtil.getWebApplicationContext(request.getSession().getServletContext()).getBean("redisUtil");}}
RedisCacheAstractConfirmer.java
package framelib.redis.impl;import javax.servlet.http.HttpServletRequest;import framelib.redis.IRedisCacheConfirmer;import framelib.redis.IRedisUtil;import framelib.redis.RedisFactory;/** * 缓存确保类---模板类 * @author kong.fanqing * */public abstract class RedisCacheAbstractConfirmer implements IRedisCacheConfirmer {public Object getCacheObject(HttpServletRequest request) {IRedisUtil redisService = RedisFactory.getIRedisService(request);Object obj = null;if(redisService == null) {//不启用缓存,则直接调用getObject的返回对象obj = this.getObject();} else {//取得缓存keyString redisKey = this.getRedisKey();//从缓存中取得对象obj = redisService.getObject(redisKey);//如果没有取得对象if(obj == null) {//调用getObject的返回对象obj = this.getObject();if(obj != null) {//将对象返回缓存中redisService.setObject(redisKey, obj);}}}return obj;}}


接口实现类,用来操作redis的工具类
package framelib.redis.impl;import java.io.ByteArrayInputStream;import java.io.ByteArrayOutputStream;import java.io.IOException;import java.io.ObjectInputStream;import java.io.ObjectOutputStream;import java.io.Serializable;import java.util.ArrayList;import java.util.HashMap;import java.util.HashSet;import java.util.Iterator;import java.util.LinkedHashSet;import java.util.List;import java.util.Map;import java.util.Set;import java.util.Map.Entry;import framelib.common.Common;import redis.clients.jedis.Jedis;import redis.clients.jedis.JedisShardInfo;import redis.clients.jedis.ShardedJedis;import redis.clients.jedis.ShardedJedisPool;import redis.clients.jedis.Tuple;import framelib.redis.IRedisUtil;/** * 操作redis实现类 * @author zhang.yuwei * */public class RedisUtilImpl implements IRedisUtil{/** * 存放key不是企业ID的数据,目前暂且不提供 */private ShardedJedisPool shardedJedisPool;/** * 为提高扩展性,以后会有多个redis服务,此Map中key为redis服务个数分别为1,2,3,4.....;value为对应的redis池 * 目前假设每10万个企业占用一台redis服务,在redis中key为每个企业ID */private Map<Integer,ShardedJedisPool> shardedJedisPoolMap;      /*public void setShardedJedisPool(ShardedJedisPool shardedJedisPool) {this.shardedJedisPool = shardedJedisPool;}*/    /** * 获取Jedis连接 * @return */private  ShardedJedis  getShardedJedis(String key) {ShardedJedisPool pool=null;try{int id = Integer.parseInt(key);int redisKey = id/Common.REDIS_DATA_NUM+1;pool = shardedJedisPoolMap.get(redisKey);}catch(Exception e){return shardedJedisPool.getResource();    //对于存储id以外的key,有shardedJedisPool提供}if(pool!=null){return pool.getResource();}else{return shardedJedisPool.getResource();   //如果某一台存放企业ID的redis服务宕机,有shardedJedisPool提供临时提供服务}    }public void setShardedJedisPoolMap(Map<Integer, ShardedJedisPool> shardedJedisPoolMap) {this.shardedJedisPoolMap = shardedJedisPoolMap;}    public void setShardedJedisPool(ShardedJedisPool shardedJedisPool) {this.shardedJedisPool = shardedJedisPool;}/** * 释放资源 * @param key * @param redis */private void returnResource(String key,ShardedJedis shardedJedis){shardedJedisPool.returnResource(shardedJedis);/*ShardedJedisPool pool=null;try{int id = Integer.parseInt(key);int redisKey = id/Common.REDIS_DATA_NUM+1;pool = shardedJedisPoolMap.get(redisKey);}catch(Exception e){shardedJedisPool.returnResource(shardedJedis);    //对于存储id以外的key,有shardedJedisPool提供}if(pool!=null){pool.returnResource(shardedJedis);}else{shardedJedisPool.returnResource(shardedJedis);  //如果某一台存放企业ID的redis服务宕机,有shardedJedisPool提供临时提供服务}*/}/** * 释放不可用的资源 * @param key * @param redis *  */private void returnBrokenResource(ShardedJedis shardedJedis){shardedJedisPool.returnBrokenResource(shardedJedis);}private byte[] objectToByte(Object obj) {byte[] bs=null;try {ByteArrayOutputStream bos = new ByteArrayOutputStream();ObjectOutputStream oos = new ObjectOutputStream(bos);oos.writeObject(obj); bs =  bos.toByteArray();oos.close();bos.close();return bs;} catch (IOException e) {e.printStackTrace();}return bs;}private Object byteToObject(byte[]  bs){Object obj = null;try{if(bs != null){ByteArrayInputStream bis = new ByteArrayInputStream(bs);ObjectInputStream inputStream = new ObjectInputStream(bis);obj = inputStream.readObject();//inputStream.close();//bis.close();}return obj;}catch (IOException e) {e.printStackTrace();}catch (ClassNotFoundException e1) {e1.printStackTrace();} return obj;}/** * 删除给定的key * 当key存在 返回1 * 当key不存在 返回0 */public Long del(String key) {ShardedJedis shardedJedis = getShardedJedis(key);long count = shardedJedis.del(key);returnResource(key,shardedJedis);return count;}/*************************存对象***********************************//** * 存一个对象 * 如果key已经存在 覆盖原值 * 成功返回 OK * 失败返回 null */public String setObject(String key, Serializable value) {return setObjectImpl(key, value);}/** * 存一个对象 * 如果key已经存在 覆盖原值 * 成功返回 OK * 失败返回 null */public String setObject(String key, Object value) {return setObjectImpl(key, value);}/** * 存一个List 对象 * 如果key已经存在 覆盖原值 * 成功返回 OK * 失败返回 null */public String setObject(String key, List<? extends Serializable> value) {return setObjectImpl(key, value);}private String setObjectImpl(String key, Object value){ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);String setObjectRet = shardedJedis.set(key.getBytes(), byteArray);return setObjectRet;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * 存一个Map对象 * 如果key已经存在 覆盖原值 * 成功返回 OK * 失败返回 null */public String setObject(String key, Map<?, ? extends Serializable> value) {return setObjectImpl(key, value);}/** * 存一个Set集合 * 如果key已经存在 覆盖原值 * 成功返回 OK * 失败返回 null */public String setObject(String key, Set<? extends Serializable> value) {return setObjectImpl(key, value);}/*************取对象****************/public Object getObject(String key) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] bs = shardedJedis.get(key.getBytes());Object obj = byteToObject(bs);return obj;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/*****对List集合的操作*****//** * String lindex(String key,int index); * 取出key对应的list集合中取出下标为index的值 * 相当与list.get(index); * 如果key存在且对应的不是List集合 抛出异常: ERR Operation against a key holding the wrong kind of value */public Object lindex(String key, int index) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] bs = shardedJedis.lindex(key.getBytes(),index);Object obj = byteToObject(bs);return obj;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** *  * 查询 key所对应的list集合的size * long llen(String key); * key --> list对应的key * return key对应list的size() * 如果key不存在  返回0 * 如果key对应的不是List集合 抛出异常: ERR Operation against a key holding the wrong kind of value */public Long llen(String key) {ShardedJedis shardedJedis = getShardedJedis(key);long size = 0;try{size = shardedJedis.llen(key.getBytes());return size;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return size;}/** * 删除key对应的list中下标为0的元素 * 返回被删除的value * String loop(String key); * key --> list对应的key * return value 当key不存在  返回null * 如果key对应的不是List集合 抛出异常: ERR Operation against a key holding the wrong kind of value * 例: key对应List-->[1,2,3,4,5] * lpop(key);-->1 */public Object lpop(String key) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] bs = shardedJedis.lpop(key.getBytes());Object obj = byteToObject(bs);return obj;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * 删除key对应的list的最后一个元素 * String roop(String key); * key --> list对应的key * return 被删除的元素 当key不存在  返回null * 如果key对应的不是List集合 抛出异常: ERR Operation against a key holding the wrong kind of value * 例: key对应List-->[1,2,3,4,5] * rpop(key);-->5 */public Object lrpop(String key) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] bs = shardedJedis.rpop(key.getBytes());Object obj = byteToObject(bs);return obj;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * 向list里添加数据 加入list头部 * long lpush(String key,String value); * key-->要添加的list的key * value-->要添加的值 * return 当前list的size * 当key不存在时,会创建一个List并执行添加操作 * 当key对应的不是List集合时 抛出异常:ERR Operation against a key holding the wrong kind of value * 例: key对应List-->[1,2,3,4,5] * lpush(key,0);//6 * key对应List变为-->[0,1,2,3,4,5] */public Long lpush(String key, Serializable value) {ShardedJedis shardedJedis  = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);long size = shardedJedis.lpush(key.getBytes(), byteArray);return size;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * 向list里添加数据 加入list尾部 * long rpush(String key,String value); * key-->要添加的list的key * value-->要添加的值 * return 当前list的size * 当key不存在时,会创建一个List并执行添加操作 * 当key对应的不是List集合时 抛出异常:ERR Operation against a key holding the wrong kind of value * 例: key对应List-->[1,2,3,4,5] * lpush(key,0);//6 * key对应List变为-->[1,2,3,4,5,0] */public Long rpush(String key, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);long size = shardedJedis.rpush(key.getBytes(), byteArray);return size;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * 向list里添加数据 仅当list已经存在时才能执行 加入list头部 * long lpushx(String key,String value); * key-->要添加的list的key * value-->要添加的值 * return 当前list的size * 当key对应的不是List集合时 抛出异常:ERR Operation against a key holding the wrong kind of value */public Long lpushx(String key, Serializable value) {if(exists(key)){return lpush(key, value);}return (long)0;}/** * 利用管道pipeline * 向list里添加数据 仅当list已经存在时才能执行 加入list头部 * void lpushx(String key,list value); * key-->要添加的list的key * value-->要添加的值 * 当key对应的不是List集合时 抛出异常:ERR Operation against a key holding the wrong kind of value */public void lpushx(String key, List<? extends Serializable> values) {if(exists(key)){lpush(key, values);}}/** * 向list里添加数据 仅当list已经存在时才能执行 加入list尾部 * long rpushx(String key,String value); * key-->要添加的list的key * value-->要添加的值 * return 当前list的size * 当key对应的不是List集合时 抛出异常:ERR Operation against a key holding the wrong kind of value */public Long rpushx(String key, Serializable value) {if(exists(key)){return rpush(key, value);}return (long)0;}/** * 利用管道pipeline * 向list里添加数据 仅当list已经存在时才能执行 加入list尾部 * void lpushx(String key,list value); * key-->要添加的list的key * value-->要添加的值 * 当key对应的不是List集合时 抛出异常:ERR Operation against a key holding the wrong kind of value */public void rpushx(String key, List<? extends Serializable> values) {if(exists(key)){rpush(key, values);}}/** * 取出key对应的list集合 start为起始位 最小为0,end为结束位置  当end=-1表示到最后一位(包含) -2为倒数第二位... * List lrange(String key,int start,int end); * key-->要获取的list的key * start-->开始位置 * end--> 结束位置 * 如:一个list集合["1","2","3","4","5","6"] * jedis.lrange("list", 0, 3); ==>["1","2","3","4"] * jedis.lrange("list", 0, -1);==>["1","2","3","4","5","6"] * 当key对应的不是List集合时 抛出异常:ERR Operation against a key holding the wrong kind of value */public List lrange(String key, int start, int end) {ShardedJedis shardedJedis = getShardedJedis(key);List list = new ArrayList();try {List<byte[]> bs = shardedJedis.lrange(key.getBytes(),start,end);for (int i = 0; i < bs.size(); i++) {list.add(byteToObject(bs.get(i)));}return list;}  catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * 从list中删除count个值为value的元素 count为正数是从首位往后删  count为负数是从末位往前删 * long lrem(String key,int count,String value); * key-->key * count--> 数量 * value-->值 * return 删除的数量 * 如:一个list集合["1","2","1","2","3","1"] * jedis.lrem("testList",1, "1")==>["2","1","2","3","1"] 返回1 * jedis.lrem("testList",-1, "1")==>["1","2","1","2","3"]返回1 * jedis.lrem("testList",5, "1")==>["2","2","3"] 返回3 * 当key对应的不是List集合时 抛出异常:ERR Operation against a key holding the wrong kind of value */public Long lrem(String key, int count, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);long result = shardedJedis.lrem(key.getBytes(),count, byteArray);return result; } catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * 把key对应的list集合中下标为index的元素改为value 下标错误的话抛出 ERR index out of range * String lset(String key,int index,String value); * key key * index 元素下标 * value 值 * return  OK * 当key对应的不是List集合时 抛出异常:ERR Operation against a key holding the wrong kind of value * 如:一个list集合["1","2","3","4"] * lset(list,3,"5");==>["1","2","5","4"]返回OK */public String lset(String key, int index, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);String result = shardedJedis.lset(key.getBytes(),index, byteArray);return result;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * 删除key对应的list集合中下标范围不在start-->end 范围内的所有元素 * String ltrim(String key,int start,int end); * key  key * start 开始下标 * end 结束下标(包含) * return  OK * 当key对应的不是List集合时 抛出异常:ERR Operation against a key holding the wrong kind of value *  * 如:一个list集合["1","2","3","4","5","6","7"] * ltrim(list,3,5);==>["4","5","6"]返回OK */public String ltrim(String key, int start, int end) {ShardedJedis shardedJedis = getShardedJedis(key);try{String result = shardedJedis.ltrim(key.getBytes(),start,end);return result;} catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}public String rpoplpush(String srcKey, String detKey) {return null;}/*********Set集合************//** * 向set里添加数据 加入list尾部 * long sadd(String key,String value); * key-->要添加的set的key * value-->要添加的值 * return 成功返回1失败返回0 * 当key不存在时,会创建一个set并执行添加操作 * 当key对应的不是set集合时 抛出异常:ERR Operation against a key holding the wrong kind of value */public Long sadd(String key, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);Long sum = shardedJedis.sadd(key.getBytes(), byteArray);return sum;} catch (Exception e) {returnBrokenResource( shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long) 0;}/** * 返回key对应的set集合中元素的数量==>set.size() * 如果key不存在  返回0 * 如果key对应的不是set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Long scard(String key) {ShardedJedis shardedJedis = getShardedJedis(key);try{long size = shardedJedis.scard(key.getBytes());return size;} catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * SISMEMBER * public Boolean sismember(String key, Serializable member) * 描述:判断member元素是否是key对应的集合的成员。 * 返回值:如果member元素是key对应的集合的成员,则返回true * 如果member元素不是key对应的集合的成员,或者key不存在,则返回false * 如果key对应的不是set集合  抛出 ERR Operation against a key holding the wrong kind of value */public boolean sismember(String key, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);boolean flag = shardedJedis.sismember(key.getBytes(), byteArray);return flag;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return false;}/** * SMEMBER * public Set smember(String key) * 描述:返回key对应的集合的所有成员。不存在key视为空。 * 返回值: key对应的集合的所有成员集合。 * 如果key对应的不是set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Set<? extends Serializable> smembers(String key) {ShardedJedis shardedJedis = getShardedJedis(key);Set set = new HashSet();try {Set<byte[]> bs = shardedJedis.smembers(key.getBytes());for (Iterator<byte[]> iterator = bs.iterator(); iterator.hasNext();) {set.add(byteToObject(iterator.next()));}return set;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * SPOP * public String spop(String key) * 描述:随即移除key对应的集合中的一个元素,并将该元素返回。 * 返回值:key对应的集合中被随即移除的元素。 * 当key不存在时 返回null *  如果key对应的不是set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Object spop(String key) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] bs = shardedJedis.spop(key.getBytes());Object obj = byteToObject(bs);return obj;} catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * SRANDMEMBER * public String srandmember(String key) * 描述:随即获取key对应的集合中的一个元素。 * 返回值:随即获取key对应的集合中的一个元素。如果key不存在,则返回null。 * 如果key对应的不是set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Object srandmember(String key) {ShardedJedis shardedJedis= getShardedJedis(key);try {byte[] bs = shardedJedis.srandmember(key.getBytes());Object obj = byteToObject(bs);return obj;}  catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * srem * public String srem(String key ,Serializable value) * 删除key对应set集合中值为value的元素 * 删除成功返回1 * 如果key不存在 或者 value 不在set集合中 返回0 * 如果key对应的不是set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Long srem(String key, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);long count = shardedJedis.srem(key.getBytes(), byteArray);return count;} catch (Exception e) {returnBrokenResource( shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/*******************Sorted set*****************************//** * ZADD * public Long zadd(String key, double score, String member) * 描述:将一个元素member及其score值加入key对应的有序集中。如果某个member已经是有序集的成员,那么更新这个member的score值,并通过重新插入这个member元素 *          来保证member在正确的位置上。score值可以是整数值或双精度浮点数。有序集中member的排序是根据其score升序排列的。如果key不存在,则创建一个空的有序集并执行 *    zadd操作。当key存在但不是有序集类型时,返回一个错误。 * 返回值:被成功添加的心成员的数量,不包含安歇被更新的,已经存在的成员。 * 如果key对应的不是zset集合  抛出 ERR Operation against a key holding the wrong kind of value */public Long zadd(String key, double score, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);long count = shardedJedis.zadd(key.getBytes(),score, byteArray);return count;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * ZCARD * public Long zcard(String key) * 描述:返回key对应的有序集的基数。 * 返回值:当key存在且是有序集类型时,返回有序集的基数。 *              当key不存在时,返回0。 *  当key对应的不是有序集类型时  抛出 ERR Operation against a key holding the wrong kind of value */public Long zcard(String key) {ShardedJedis shardedJedis = getShardedJedis(key);long size = 0;try{size = shardedJedis.zcard(key.getBytes());return size;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return size;}/** * ZCOUNT * public Long zcount(String key) * 描述:返回key对应的有序集 中, score 值在 min 和 max 之间(默认包括 score 值等于 min 或 max )的成员的数量。 * 返回值:返回key对应的有序集 中, score 值在 min 和 max 之间(默认包括 score 值等于 min 或 max )的成员的数量。 * 例: jedis.zcount("testzcard", 8, 9)==》testzcard对应的有序集中8<=score<=9的个数 * 当key对应的不是有序集类型时  抛出 ERR Operation against a key holding the wrong kind of value */public Long zcount(String key, double min, double max) {ShardedJedis shardedJedis = getShardedJedis(key);long size = 0;try{size = shardedJedis.zcount(key.getBytes(),min,max);return size;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return size;}/** * ZINCRBY * public Double zincrby(String key, double incrementscore, Serializable member) * 描述:为key对应的有序集中member的score值加上增量incrementscore。当key对应的不是有序集是返回一个错误。 * 返回值:member的新的score值。 * 例:jedis.zincrby("testzincrby", 10, "google")==>testzincrby对应的有序集中google的score + 10 * 当key对应的不是有序集类型时  抛出 ERR Operation against a key holding the wrong kind of value */public double zincrby(String key, double incrementscore, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);double score = shardedJedis.zincrby(key.getBytes(),incrementscore, byteArray);return score;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return 0;}/** * zrange * public Set zrange(String key,int start,int end) * 描述:返回key对应的有序set集合的所有成员。不存在key视为空。 * 返回值: key对应的有序set集合的所有成员集合。 * 如果key对应的不是有序set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Set<? extends Serializable> zrange(String key, int start, int end) {ShardedJedis shardedJedis = getShardedJedis(key);Set set = new LinkedHashSet();try {Set<byte[]> bs = shardedJedis.zrange(key.getBytes(),start,end);ByteArrayInputStream bis = null;ObjectInputStream inputStream = null;for (Iterator<byte[]> iterator = bs.iterator(); iterator.hasNext();) {set.add(byteToObject(iterator.next()));}return set;}  catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * ZRANGEBYSCORE * public Set<String> zrangeByScore(String key, double min, double max) * 描述:返回key对应有序集 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从小到大)次序排列。  * 返回值:指定区间内的有序集成员集合。 、 * 如果key对应的不是有序set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Set<? extends Serializable> zrangeByScore(String key, double min,double max) {ShardedJedis shardedJedis = getShardedJedis(key);Set set = new LinkedHashSet();try {Set<byte[]> bs = shardedJedis.zrangeByScore(key.getBytes(),min,max);for (Iterator<byte[]> iterator = bs.iterator(); iterator.hasNext();) {set.add(byteToObject(iterator.next()));}return set;}  catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * ZREM * public Long zrem(String key, Serializable members) * 描述:移除key对应的有序集中的member(s)元素,不存在的将被忽略。 * 返回值:删除成功 返回1 * 否则 返回0 *  * 如果key对应的不是有序set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Long zrem(String key, Serializable value) {ShardedJedis shardedJedis= getShardedJedis(key);try {byte[] byteArray = objectToByte(value);long count = shardedJedis.zrem(key.getBytes(), byteArray);return count;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * ZREMRANGEBYRANK * public  Long zremrangeByRank(String key, int start, int end) * 描述:移除key对应的有序集中指定区间【start,end】内的所有成员。 *     下标参数 start 和 stop 都以 0 为底,也就是说,以 0 表示有序集第一个成员,以 1 表示有序集第二个成员,以此类推。 *     你也可以使用负数下标,以 -1 表示最后一个成员, -2 表示倒数第二个成员,以此类推。 * 返回值:被移除的成员的数量。 * 如果key对应的不是有序set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Long zremrangeByRank(String key, int start, int end) {ShardedJedis shardedJedis = getShardedJedis(key);long count = 0;try{count = shardedJedis.zremrangeByRank(key.getBytes(),start,end);return count;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return count;}/** * ZREMRANGEBYSCORE * public  Long zremrangeByScore(String key, double start, double end) * 描述:移除key对应的有序集中score在区间【start,end】内的所有成员。 *     下标参数 start 和 stop 都以 0 为底,也就是说,以 0 表示有序集第一个成员,以 1 表示有序集第二个成员,以此类推。 *     你也可以使用负数下标,以 -1 表示最后一个成员, -2 表示倒数第二个成员,以此类推。 * 返回值:被移除的成员的数量。 * 例:jedis.zremrangeByScore("testZinterstore", 150, 200);==》testZinterstore删除元素150<=score<=160 * 如果key对应的不是有序set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Long zremrangeByScore(String key, double start, double end) {ShardedJedis shardedJedis = getShardedJedis(key);long count = 0;try{count = shardedJedis.zremrangeByScore(key.getBytes(),start,end);return count;} catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return count;}/** * ZREVRANGE  * public Set<String> zrevrange(String key, long start, long end) * 描述:返回key对应的有序集中指定区间内的成员。其中成员的的位置是按照score值得降序来排序的。 *     下标参数 start 和 stop 都以 0 为底,也就是说,以 0 表示有序集第一个成员,以 1 表示有序集第二个成员,以此类推。     *     你也可以使用负数下标,以 -1 表示最后一个成员, -2 表示倒数第二个成员,以此类推。     * 返回值:指定区间内的有序集成员集合。     *      * 如果key对应的不是有序set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Set<? extends Serializable> zrevrange(String key, int start, int end) {ShardedJedis shardedJedis = getShardedJedis(key);Set set = new LinkedHashSet();try {Set<byte[]> bs = shardedJedis.zrevrange(key.getBytes(),start,end);for (Iterator<byte[]> iterator = bs.iterator(); iterator.hasNext();) {set.add(byteToObject(iterator.next()));}return set;} catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * ZRANK * public Long zrank(String key, Serializable member) * 描述:返回key对应的有序集 中成员 member 的排名。其中有序集成员按 score 值递增排序。 *     排名以 0 为底,也就是说, score 值最大的成员排名为 0 。 * 返回值:如果 member 是key对应的有序集 中成员 ,返回 member 的排名。 * 如果 member 不是key对应的有序集 中成员 ,返回 null  * 如果key对应的不是有序set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Long zrank(String key, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);long rank = shardedJedis.zrank(key.getBytes(), byteArray);return rank;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * ZREVRANK * public  Long zrevrank(String key, Serializable member) * 描述:返回key对应的有序集 中成员 member 的排名。其中有序集成员按 score 值递减(从大到小)排序。 *     排名以 0 为底,也就是说, score 值最大的成员排名为 0 。 * 返回值:如果 member 是key对应的有序集 中成员 ,返回 member 的排名。 * 如果 member 不是key对应的有序集 中成员 ,返回 null  * 如果key对应的不是有序set集合  抛出 ERR Operation against a key holding the wrong kind of value */public Long zrevrank(String key, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);long rank = shardedJedis.zrevrank(key.getBytes(), byteArray);return rank;} catch (Exception e) {returnBrokenResource( shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * ZSCORE * public Double zscore(String key, Serializable member) * 描述:返回key对应的有序集中member对应的score值。 * 返回值:member成员的score值。 * 如果key对应的不是有序set集合  抛出 ERR Operation against a key holding the wrong kind of value */public double zscore(String key, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);double score = shardedJedis.zscore(key.getBytes(), byteArray);return score;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return 0;}/********************************Hash 表**********************************************//** * String hset(String key,Map<String,String>) * 同时将多个field-value以Map集合设置到key对应的哈希表中 * 此命令会覆盖哈希表中已存在的域 * 如果key不存在  会创建一个空哈希表 并执行此方法 * 返回  成功返回OK * 如果key对应的不是哈希表  返回 ERR Operation against a key holding the wrong kind of value *  */public Long hset(String key, String field, Serializable value) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] byteArray = objectToByte(value);Long result = shardedJedis.hset(key.getBytes(),field.getBytes(), byteArray);return result;} catch (Exception e) {returnBrokenResource( shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * Boolean hexists(String key,String field); * 查看key对应的哈希表中,是不是存在给定的域field * 如果存在 返回true * 如果不含有指定域 或者key不存在 返回false * 如果key对应的不是哈希表 抛出ERR Operation against a key holding the wrong kind of value */public boolean hexists(String key, String field) {ShardedJedis shardedJedis = getShardedJedis(key);try{boolean flag = shardedJedis.hexists(key.getBytes(),field.getBytes());returnResource(key,shardedJedis);return flag;} catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}return false;}/** * Long hsetnx(String key,String field,String value); * 在key对应的哈希表中,当且仅当域field不存在时,新建域field设置值为value * 如果域field已经存在 不执行操作 * 如果key不存在  新建一个哈希表然后进行hsetnx操作 * 如果key存在且对应的不是哈希表 ERR Operation against a key holding the wrong kind of value * 返回: * 设置成功 返回1 * 如果给定的域已经存在且没有操作被执行 返回0 *  */public Long hsetnx(String key, String field, Serializable value) {ShardedJedis shardedJedis= getShardedJedis(key);try {byte[] byteArray = objectToByte(value);Long result = shardedJedis.hsetnx(key.getBytes(),field.getBytes(), byteArray);return result;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * String hmset(String key,Map<String,String>) * 同时将多个field-value以Map集合设置到key对应的哈希表中 * 此命令会覆盖哈希表中已存在的域 * 如果key不存在  会创建一个空哈希表 并执行此方法 * 返回  成功返回OK * 如果key对应的不是哈希表  返回 ERR Operation against a key holding the wrong kind of value *  */public String hmset(String key, Map<String, ? extends Serializable> values) {Map<byte[], byte[]> hash = new HashMap<byte[], byte[]>();ShardedJedis shardedJedis = getShardedJedis(key);try {for (Entry<String, ? extends Serializable> e : values.entrySet()) {String skey = e.getKey();Serializable value = e.getValue();byte[] byteArray = objectToByte(value);hash.put(skey.getBytes(),byteArray);}String result = shardedJedis.hmset(key.getBytes(),hash);return result;} catch (Exception e) {returnBrokenResource(shardedJedis);e.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * Object hget(String key,String field); * 返回key对应哈系表中给定的域field的值 * 当给定域不存在或者key不存在时 返回null * 如果key对应的不是哈希表 抛出ERR Operation against a key holding the wrong kind of value */public Object hget(String key, String field) {ShardedJedis shardedJedis = getShardedJedis(key);try {byte[] bs = shardedJedis.hget(key.getBytes(),field.getBytes());Object obj = byteToObject(bs);return obj;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}/** * List hmget(String key,String ...fields); * 返回哈希表 key 中,一个或多个给定域的值。 * 当给定域不存在或者key不存在时 返回空的List * 如果key对应的不是哈希表 抛出ERR Operation against a key holding the wrong kind of value */public List hmget(String key, List<String> fields) {ShardedJedis shardedJedis = getShardedJedis(key);byte[][] bytes = new byte[fields.size()][];for (int i = 0; i < fields.size(); i++) {bytes[i] = fields.get(i).getBytes();}List list = new ArrayList();try {List<byte[]> bs = shardedJedis.hmget(key.getBytes(),bytes);Object obj = null;for (int i = 0; i < bs.size(); i++) {list.add(byteToObject(bs.get(i)));}return list;}  catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return list;}/** * Map<String,String> hgetAll(String key); * 以Map集合的形式返回key对应的哈希表中所有的域和值 * 如果key不存在 返回一个空Map * 如果key对应的不是哈希表 抛出ERR Operation against a key holding the wrong kind of value */public Map<String, ? extends Serializable> hgetAll(String key) {Map map = new HashMap();ShardedJedis shardedJedis = getShardedJedis(key);try {Map<byte[], byte[]> bbs = shardedJedis.hgetAll(key.getBytes());Object obj = null;for (Entry<byte[], byte[]> e:bbs.entrySet()) {byte[] bkey = e.getKey();byte[] bs = e.getValue();obj = byteToObject(bs);map.put(new String(bkey), obj);}return map;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();} finally{returnResource(key,shardedJedis);}return map;}/** * Long hdel(String key,String field); * 删除key对应的哈希表中一个指定域 * 不存在的域被忽略 * 返回 删除成功 1 * 如果key不存在时 返回0 * 当key对应的不是哈希表 抛出 ERR Operation against a key holding the wrong kind of value */public Long hdel(String key, String field) {ShardedJedis shardedJedis = getShardedJedis(key);try{long result = shardedJedis.hdel(key.getBytes(),field.getBytes());return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * Long hlen(String key); * 返回 key对应哈希表中域的数量 * 当key不存在时 返回0 * 如果key对应的不是哈希表 抛出ERR Operation against a key holding the wrong kind of value */public Long hlen(String key) {ShardedJedis shardedJedis = getShardedJedis(key);try{long result = shardedJedis.hlen(key.getBytes());return result;} catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return (long)0;}/** * Set<String> hkeys(String key); * 以Set集合的形式返回key对应哈希表中所有域 * 如果key不存在 返回一个空Set集合 * 如果key对应的不是哈希表 抛出ERR Operation against a key holding the wrong kind of value */public Set<String> hkeys(String key) {Set<String> set = new HashSet<String>();ShardedJedis shardedJedis = getShardedJedis(key);try {Set<byte[]> bs = shardedJedis.hkeys(key.getBytes());for (Iterator<byte[]> iterator = bs.iterator(); iterator.hasNext();) {set.add(new String(iterator.next()));}return set;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return set;}/** * List<String> hvals(String key); * 以List集合的形式返回key对应的哈希表中所有域的值 * 当key不存在时,返回一个空List集合 * key存在且对应的不是哈希表 ERR Operation against a key holding the wrong kind of value * 返回值: * 一个包含哈希表中所有值的表 */public List hvals(String key) {List list = new ArrayList();ShardedJedis shardedJedis = getShardedJedis(key);try {List<byte[]> bbs = (List<byte[]>) shardedJedis.hvals(key.getBytes());Object obj = null;for (byte[] bs : bbs) {list.add(byteToObject(bs));}return list;}  catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return list;}/*********************String*****************************//** * String set(String key,String value); * 将字符串值value 存到key中 * 如果 key 已经持有其他值, 就覆写旧值,无视类型。 * 返回值:OK *  */public String set(String key, String value) {ShardedJedis shardedJedis = getShardedJedis(key);String result = null;try { result = shardedJedis.set(key,value);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * String setnx(String key,String value); * 当且仅当key不存在 将字符串值value 存到key中 * 如果 key 已经存在 不做任何操作 返回0 * 成功 返回1 *  */public Long setnx(String key, String value) {ShardedJedis shardedJedis = getShardedJedis(key);long result = 0;try { result = shardedJedis.setnx(key,value);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * SETEX * public String setex(String key, int seconds, String value) * 描述: 将值value关联到key,并将key的生存时间设置为seconds(以秒为单位)。如果key已关联在其他值,SETEX将复写旧值。 * 参数:key  seconds  value * 返回值:设置成功时返回OK。 * 当seconds参数不合法时,返回 ERR invalid expire time in SETEX  *  */ public String setex(String key, int seconds, String value) {ShardedJedis shardedJedis = getShardedJedis(key);String result = null;try { result = shardedJedis.setex(key, seconds, value);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * Long append(String key,String value); * 如果key存在并且是一个字符串 将value追加到key原来的值的末尾 * 如果key不存在  就添加一个key 对应value 就像执行SET key value一样 * 如果key对应的不是一个字符串时,抛出 ERR Operation against a key holding the wrong kind of value * return 追加value之后,key中字符串的长度 */public Long append(String key, String value) {ShardedJedis shardedJedis = getShardedJedis(key);long result = 0;try { result = shardedJedis.append(key, value);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * String get(String key); * 返回key对应的字符串值 * 如果key不存在 返回null * 如果key储存的值不时字符串类型,抛出ERR Operation against a key holding the wrong kind of value */public String get(String key) {ShardedJedis shardedJedis = getShardedJedis(key);String result = null;try { result = shardedJedis.get(key);return result;} catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * String getSet(String key,String value); * 将给定key对应的值设为value 并返回 旧值 * 当 key对应的值不是字符串类型时 抛出ERR Operation against a key holding the wrong kind of value * 当 key不存在时 新建一个空key并将value存入  返回null * 当新值=旧值时,覆盖  */public String getSet(String key, String value) {ShardedJedis shardedJedis = getShardedJedis(key);String result = null;try { result = shardedJedis.getSet(key, value);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * Long decr(String key); * 将key中所储存的数字值减1  注:key中存的必须是64位(long)整数,可以是负数 * 然后把这个修改后的数字值返回 * 如果key不存在 key的值会被初始化为0然后执行decr() 也就是-1 * 如果key对应的value不是数值 抛出 ERR value is not an integer or out of range */public Long decr(String key) {ShardedJedis shardedJedis = getShardedJedis(key);long result = 0;try { result = shardedJedis.decr(key);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * Long decrBy(String key,long integer); * 将key所储存的值减去integer * 如果key不存在,那么key的值会先被初始化为0,然后执行decrBy操作 * 然后把这个修改后的数字值返回 * 如果key对应的value不是数值 抛出 ERR value is not an integer or out of range */public Long decrBy(String key, long integer) {ShardedJedis shardedJedis = getShardedJedis(key);long result = 0;try { result = shardedJedis.decrBy(key,integer);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * Long incr(String key); * 将key中所储存的数字值加1  注:key中存的必须是64位(long)整数,可以是负数 * 然后把这个修改后的数字值返回 * 如果key不存在 key的值会被初始化为0然后执行incr() 也就是-1 * 如果key对应的value不是数值 抛出 ERR value is not an integer or out of range */public Long incr(String key) {ShardedJedis shardedJedis = getShardedJedis(key);long result = 0;try { result = shardedJedis.incr(key);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * Long incrBy(String key,long integer); * 将key所储存的值加上integer * 如果key不存在,那么key的值会先被初始化为0,然后执行incrBy操作 * 然后把这个修改后的数字值返回 * 如果key对应的value不是数值 抛出 ERR value is not an integer or out of range */public Long incrBy(String key, long integer) {ShardedJedis shardedJedis = getShardedJedis(key);long result = 0;try { result = shardedJedis.incrBy(key, integer);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * Long ttl(String key); * 以秒为单位,返回给定 key 的剩余生存时间。 * 当 key 不存在或没有设置生存时间时,返回 -1 。 * 否则,返回 key 的剩余生存时间(以秒为单位)。 */public Long ttl(String key) {ShardedJedis shardedJedis = getShardedJedis(key);long result = 0;try { result = shardedJedis.ttl(key.getBytes());return result;} catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * 判断key是不是已经存在 * @param key * 存在 返回true * 否则 返回false */public boolean exists(String key) {ShardedJedis shardedJedis = getShardedJedis(key);boolean result = false;try { result = shardedJedis.exists(key.getBytes());return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * TYPE * public String type(String key) * 描述:返回key所对应的value的类型。 * 返回值:none - key不存在 * string - 字符串 * list - 列表 * set - 集合 * zset - 有序集 * hash - 哈希表 */public String type(String key) {ShardedJedis shardedJedis = getShardedJedis(key);String result = null;try { result = shardedJedis.type(key.getBytes());return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * Long expire(String key,int seconds); * 给指定的key设置生存时间 以秒为单位 当key过期时,会被自动删除 * 如果key不存在 返回0 * 设置成功返回1 * 过期时间的延迟在1秒钟之内,也就是,就算key已经过期,但它还是可能在1秒之内被访问到 */public Long expire(String key, int seconds) {ShardedJedis shardedJedis = getShardedJedis(key);long result = 0;try { result = shardedJedis.expire(key.getBytes(), seconds);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}/** * long expireAt(String key,long timestamp); * expireAt作用和expire类似,都用于为key设置生存时间、 * 但是expireAt接受的时间参数是时间戳 即毫秒(ms) * 如果设置生存时间成功,返回1 * 当key不存在或没办法设置生存时间  返回0 */public Long expireAt(String key, long timestamp) {ShardedJedis shardedJedis = getShardedJedis(key);long result = 0;try {result = shardedJedis.expireAt(key.getBytes(), timestamp);return result;} catch (Exception e2) {returnBrokenResource(shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return result;}public void lpush(String key, List<? extends Serializable> value) {// TODO Auto-generated method stub}public void rpush(String key, List<? extends Serializable> value) {// TODO Auto-generated method stub}public void sadd(String key, Set<? extends Serializable> values) {// TODO Auto-generated method stub}    public Set<String> keys(Integer idKey, String pattern) {        String key = new String(idKey+"");        ShardedJedis shardedJedis = getShardedJedis(key);        Set<String> keys = null;        try{        Jedis shard = shardedJedis.getShard(key);        keys = shard.keys(pattern);        if(keys==null){            return new HashSet<String>();        }        }catch (Exception e2) {        returnResource(key,shardedJedis);        e2.printStackTrace();}finally{returnResource(key,shardedJedis);}        return keys;    }    /**     * 范围查找 + 分页      * 2013-11-13, 下午04:15:20     * 方法描述:     * @param key     * @param min     * @param max     * @param offset     * @param count     * @return     */    public Set<? extends Serializable> zrangeByScore(String key,double min, double max, int offset, int count) {ShardedJedis shardedJedis = getShardedJedis(key);Set set = new LinkedHashSet();try {Set<byte[]> bs = shardedJedis.zrangeByScore(key.getBytes(),min,max,offset,count);for (Iterator<byte[]> iterator = bs.iterator(); iterator.hasNext();) {set.add(byteToObject(iterator.next()));}return set;}  catch (Exception e2) {returnBrokenResource( shardedJedis);e2.printStackTrace();}finally{returnResource(key,shardedJedis);}return null;}}

redis的配置问题:

daemonize    如果需要在后台运行,把该项改为yes  

pidfile      配置多个pid的地址 默认在/var/run/redis.pid

bind 绑定ip,设置后只接受来自该ip的请求

port 监听端口,默认为6379

timeout      设置客户端连接时的超时时间,单位为秒

loglevel     分为4级,debug、verbose、notice、warning

logfile      配置log文件地址

databases    设置数据库的个数,默认使用的数据库为0

save         设置redis进行数据库镜像的频率

rdbcompression    在进行镜像备份时,是否进行压缩

Dbfilename        镜像备份文件的文件名

Dir   数据库镜像备份的文件放置路径

Slaveof     设置数据库为其他数据库的从数据库

Masterauth 主数据库连接需要的密码验证

Requirepass     设置登录时需要使用的密码

Maxclients 限制同时连接的客户数量

Maxmemory 设置redis能够使用的最大内存

Appendonly 开启append only模式

以下了解即可:

Appendfsync 设置对appendonly.aof文件同步的频率

vm-enabled 是否开启虚拟内存支持

vm-swap-file 设置虚拟内存的交换文件路径

vm-max-memory 设置redis使用的最大物理内存大小

vm-page-size 设置虚拟内存的页大小

vm-pages 设置交换文件的总的page数量

vm-max-threads 设置VM IO同时使用的线程数量

Glueoutputbuf 把小的输出缓存存放在一起

hash-max-zipmap-entries 设置hash的临界值

Activerehashing 重新hash




补充(20170828):

再次回到redis,在工作中会碰到这样一个问题,究竟在何种场景使用redis?如何使用效率最高?

下面为大家一一解答:

1.何种场景?

一个充分的例子是 用来存储比如一个新闻网页最新的10条信息,一般我们都是 select * from news order by update_time  desc  limit 10;(找到最新的10条信息)

但是这样的效率是很低的,所以,我们放入redis中:

LPUSH latest.comments <ID> 

放入一个List中或者其他的存储结构,就可以快速查询了

2.如何使效率最高

string:用来存储基本的key-value类型的数据(理论上所有的数据都可以通过这种方式存储,但是为了效率以及操作的便利性,这里只存储最基本的k-v数据,比方说一个user信息,里面有user_id,user_name,user_sex等等,这里如果用key-value来存储,那么,就会出现很多的键(userId:1,userId:2等等),这样多了就会造成内存的大面积浪费,所以应当采取其他的存储结构)

hash:他的value是hashmap类型的,数据量少的时候是另外一种类型,如果多的话就会变成hashmap类型,利用hashmap类型可以很方便的解决上面例子中的问题

List: 主要用于队列和栈的储存结构,存储一系列的数据,比如说分页查询的10条数据

set: 和上面的一样,但是有一点不同,set可以除重,这是更高级的用法

zset:有序的set,在存储进redis的时候就会被存储为有序的,效率自然是杠杠滴~

另外还有Pub/sub(订阅/发布)的模式,可以用来做多人聊天,一个人发布信息,让这个群组的所有人接受。





以上就是redis的基本使用,在工作中目前够用了,至于更加深入的研究,需要读者去查阅其他资料以及实践中的应用。


如果你觉得本文好,可以留言或者是收藏哦,有不对的地方也欢迎大家指出,谢谢支持~


原创粉丝点击