简易教程 http://www.runoob.com/redis/redis-install.html
http://os.51cto.com/art/201403/431103.htm
http://www.cnblogs.com/edisonfeng/p/3571870.html
1安装 https://github.com/ServiceStack/redis-windows 下载
启动命令行 cd /d D:developTools edis
启动服务 redis-server.exe redis.windows.conf (redis.windows.conf 455行增加参数:maxheap 1024000000)
启动redis服务的doc窗口,不用关闭,因为服务需要一直执行,关闭服务,直接关闭窗口就行。
新打开一个doc窗口,用自带的客户端工具进行测试 命令【redis-cli.exe】,详细操作如下。。事例展示了一个基本的读写操作,设置set key->age,value->21,get age 得到key的值。^_^
2 开发
<dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.6.1</version> </dependency>
http://flychao88.iteye.com/blog/1527163
http://www.cnblogs.com/edisonfeng/p/3571870.html
http://www.redis.cn/commands.html#sorted_set 中文官网
package com.testLib.redis; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; import org.apache.log4j.Logger; import org.junit.Before; import org.junit.Test; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; public class JedisUtilTest { private static Logger log = Logger.getLogger(JedisUtilTest.class); JedisPool pool; Jedis jedis; /** * 初始化非切片池 */ private void initialPool() { // 池基本配置 JedisPoolConfig config = new JedisPoolConfig(); config.setMaxWaitMillis(1000); config.setMaxIdle(5); config.setTestOnBorrow(false); pool = new JedisPool(config,"127.0.0.1",6379); } @Before public void setUp() { initialPool(); jedis = pool.getResource(); } /** * Redis存储初级的字符串 * CRUD */ @Test public void testBasicString(){ setUp(); //-----添加数据---------- jedis.set("name","minxr");//向key-->name中放入了value-->minxr log.info(jedis.get("name"));//执行结果:minxr //-----修改数据----------- //1、在原来基础上修改 jedis.append("name","jarorwar"); //很直观,类似map 将jarorwar append到已经有的value之后 log.info(jedis.get("name"));//执行结果:minxrjarorwar //2、直接覆盖原来的数据 jedis.set("name","闵晓荣"); log.info(jedis.get("name"));//执行结果:闵晓荣 //删除key对应的记录 jedis.del("name"); log.info(jedis.get("name"));//执行结果:null /** * mset相当于 * jedis.set("name","minxr"); * jedis.set("jarorwar","闵晓荣"); */ jedis.mset("name","minxr","jarorwar","闵晓荣"); log.info(jedis.mget("name","jarorwar")); } /** * jedis操作Map */ @Test public void testMap(){ Map<String,String> user=new HashMap<String,String>(); user.put("name","minxr"); user.put("pwd","password"); jedis.hmset("user",user); //取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数 List<String> rsmap = jedis.hmget("user", "name"); log.info(rsmap); //删除map中的某个键值 // jedis.hdel("user","pwd"); log.info(jedis.hmget("user", "pwd")); //因为删除了,所以返回的是null log.info(jedis.hlen("user")); //返回key为user的键中存放的值的个数1 log.info(jedis.exists("user"));//是否存在key为user的记录 返回true log.info(jedis.hkeys("user"));//返回map对象中的所有key [pwd, name] log.info(jedis.hvals("user"));//返回map对象中的所有value [minxr, password] Iterator<String> iter=jedis.hkeys("user").iterator(); while (iter.hasNext()){ String key = iter.next(); log.info(key+":"+jedis.hmget("user",key)); } } /** * jedis操作List */ @Test public void testList(){ //开始前,先移除所有的内容 jedis.del("java framework"); log.info(jedis.lrange("java framework",0,-1)); //先向key java framework中存放三条数据 jedis.lpush("java framework","spring"); jedis.lpush("java framework","struts"); jedis.lpush("java framework","hibernate"); //再取出所有数据jedis.lrange是按范围取出, // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有 log.info(jedis.lrange("java framework",0,-1)); } /** * jedis操作Set */ @Test public void testSet(){ //添加 jedis.sadd("sname","minxr"); jedis.sadd("sname","jarorwar"); jedis.sadd("sname","闵晓荣"); jedis.sadd("sanme","noname"); //移除noname jedis.srem("sname","noname"); log.info("jedis操作集合 set begin----------------"); log.info("smembers" +jedis.smembers("sname"));//获取所有加入的value log.info(jedis.sismember("sname", "minxr"));//判断 minxr 是否是sname集合的元素 log.info(jedis.srandmember("sname")); log.info(jedis.scard("sname"));//返回集合的元素个数 log.info("jedis操作集合 set end----------------"); } /** * jedis操作有序集合sorted set */ @Test public void testZSet(){ //添加 String key = "zhumlSortSet"; jedis.zadd(key, 10, "a"); jedis.zadd(key, 8, "c"); jedis.zadd(key, 9, "b"); jedis.zadd(key, 7, "d"); log.info("jedis操作有序集合sorted set begin----------------"); log.info("zcard" + jedis.zcard(key)); log.info("zrevrange" + jedis.zrevrange(key, 0, 3)); log.info("zrevrange" + jedis.zrevrange(key, 0, 3)); log.info("" + jedis.zscore(key, "a")); log.info("ZRANGE" + jedis.zrangeByScore(key, 8, 10)); log.info("jedis操作有序集合sorted set end------------------"); } @Test public void test() throws InterruptedException { //keys中传入的可以用通配符 log.info(jedis.keys("*")); //返回当前库中所有的key [sose, sanme, name, jarorwar, foo, sname, java framework, user, braand] log.info(jedis.keys("*name"));//返回的sname [sname, name] log.info(jedis.del("sanmdde"));//删除key为sanmdde的对象 删除成功返回1 删除失败(或者不存在)返回 0 log.info(jedis.ttl("sname"));//返回给定key的有效时间,如果是-1则表示永远有效 jedis.setex("timekey", 10, "min");//通过此方法,可以指定key的存活(有效时间) 时间为秒 Thread.sleep(5000);//睡眠5秒后,剩余时间将为<=5 log.info(jedis.ttl("timekey")); //输出结果为5 jedis.setex("timekey", 1, "min"); //设为1后,下面再看剩余时间就是1了 log.info(jedis.ttl("timekey")); //输出结果为1 log.info(jedis.exists("key"));//检查key是否存在 log.info(jedis.rename("timekey","time")); log.info(jedis.get("timekey"));//因为移除,返回为null log.info(jedis.get("time")); //因为将timekey 重命名为time 所以可以取得值 min //jedis 排序 //注意,此处的rpush和lpush是List的操作。是一个双向链表(但从表现来看的) jedis.del("a");//先清除数据,再加入数据进行测试 jedis.rpush("a", "1"); jedis.lpush("a","6"); jedis.lpush("a","3"); jedis.lpush("a","9"); log.info(jedis.lrange("a",0,-1));// [9, 3, 6, 1] log.info(jedis.sort("a")); //[1, 3, 6, 9] //输入排序后结果 log.info(jedis.lrange("a",0,-1)); } }