Windows下Redis的安装使用

Redis是一个key-value存储系统。Redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。本文中,作者分享了在Windows下进行安装和使用Redis的技巧。

作者:蛙牛来源:oschina|2014-03-04 09:53

推广 | 令人窒息的奖品等你—2016最权威的全球开发者调研

Redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave。

前言

因为是初次使用,所以是在windows下进行安装和使用,参考了几篇博客,下面整理一下:

安装Redis

官方网站:http://redis.io/

官方下载:http://redis.io/download可以根据需要下载不同版本

windows版:https://github.com/mythz/redis-windows

Windows下Redis的安装使用

Windows下Redis的安装使用

github的资源可以ZIP直接下载的(这个是给不知道的同学友情提示下)。

下载完成后 可以右键解压到 某个硬盘下 比如D:\Redis\redis-2.6。

在D:\Redis\redis-2.6\bin\release下 有两个zip包 一个32位一个64位。

根据自己windows的位数 解压到D:\Redis\redis-2.6 根目录下。

2.启动Redis

Windows下Redis的安装使用

进入redis目录后 开启服务 (注意加上redis.conf)


  1. redis-server.exeredis.conf

这个窗口要保持开启 关闭时redis服务会自动关闭

redis会自动保存数据到硬盘 所以图中是我第二次开启时 多了一个 DB loaded from disk

3.测试使用

Windows下Redis的安装使用

另外开启一个命令行窗口 进入redis目录****意修改自己的ip)


  1. redis-cli.exe-h192.168.10.61-p6379

4.Java开发包Jedis

Jedis :http://www.oschina.net/p/jedis(Redis的官方首选Java开发包)


  1. 1<!--Redis-->
  2. 2<dependency>
  3. 3<groupId>redis.clients</groupId>
  4. 4<artifactId>jedis</artifactId>
  5. 5<version>2.0.0</version>
  6. 6<type>jar</type>
  7. 7<scope>compile</scope>
  8. 8</dependency>

测试例子原帖:http://flychao88.iteye.com/blog/1527163


  1. packagecom.lujianing.utils;
  2. importorg.junit.Before;
  3. importorg.junit.Test;
  4. importredis.clients.jedis.Jedis;
  5. importredis.clients.jedis.JedisPool;
  6. importredis.clients.jedis.JedisPoolConfig;
  7. importjava.util.HashMap;
  8. importjava.util.Iterator;
  9. importjava.util.List;
  10. importjava.util.Map;
  11. /**
  12. *Createdbylujianingon14-2-28.
  13. */
  14. publicclassJedisUtilTest{
  15. JedisPoolpool;
  16. Jedisjedis;
  17. @Before
  18. publicvoidsetUp(){
  19. pool=newJedisPool(newJedisPoolConfig(),"192.168.10.61");
  20. jedis=pool.getResource();
  21. //jedis.auth("password");
  22. }
  23. @Test
  24. publicvoidtestGet(){
  25. System.out.println(jedis.get("lu"));
  26. }
  27. /**
  28. *Redis存储初级的字符串
  29. *CRUD
  30. */
  31. @Test
  32. publicvoidtestBasicString(){
  33. //-----添加数据----------
  34. jedis.set("name","minxr");//向key-->name中放入了value-->minxr
  35. System.out.println(jedis.get("name"));//执行结果:minxr
  36. //-----修改数据-----------
  37. //1、在原来基础上修改
  38. jedis.append("name","jarorwar");//很直观,类似map将jarorwarappend到已经有的value之后
  39. System.out.println(jedis.get("name"));//执行结果:minxrjarorwar
  40. //2、直接覆盖原来的数据
  41. jedis.set("name","闵晓荣");
  42. System.out.println(jedis.get("name"));//执行结果:闵晓荣
  43. //删除key对应的记录
  44. jedis.del("name");
  45. System.out.println(jedis.get("name"));//执行结果:null
  46. /**
  47. *mset相当于
  48. *jedis.set("name","minxr");
  49. *jedis.set("jarorwar","闵晓荣");
  50. */
  51. jedis.mset("name","minxr","jarorwar","闵晓荣");
  52. System.out.println(jedis.mget("name","jarorwar"));
  53. }
  54. /**
  55. *jedis操作Map
  56. */
  57. @Test
  58. publicvoidtestMap(){
  59. Map<String,String>user=newHashMap<String,String>();
  60. user.put("name","minxr");
  61. user.put("pwd","password");
  62. jedis.hmset("user",user);
  63. //取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List
  64. //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数
  65. List<String>rsmap=jedis.hmget("user","name");
  66. System.out.println(rsmap);
  67. //删除map中的某个键值
  68. //jedis.hdel("user","pwd");
  69. System.out.println(jedis.hmget("user","pwd"));//因为删除了,所以返回的是null
  70. System.out.println(jedis.hlen("user"));//返回key为user的键中存放的值的个数1
  71. System.out.println(jedis.exists("user"));//是否存在key为user的记录返回true
  72. System.out.println(jedis.hkeys("user"));//返回map对象中的所有key[pwd,name]
  73. System.out.println(jedis.hvals("user"));//返回map对象中的所有value[minxr,password]
  74. Iterator<String>iter=jedis.hkeys("user").iterator();
  75. while(iter.hasNext()){
  76. Stringkey=iter.next();System.out.println(key+":"+jedis.hmget("user",key));
  77. }
  78. }
  79. /**
  80. *jedis操作List
  81. */
  82. @Test
  83. publicvoidtestList(){
  84. //开始前,先移除所有的内容
  85. jedis.del("javaframework");
  86. System.out.println(jedis.lrange("javaframework",0,-1));
  87. //先向keyjavaframework中存放三条数据
  88. jedis.lpush("javaframework","spring");
  89. jedis.lpush("javaframework","struts");
  90. jedis.lpush("javaframework","hibernate");
  91. //再取出所有数据jedis.lrange是按范围取出,
  92. //第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度-1表示取得所有
  93. System.out.println(jedis.lrange("javaframework",0,-1));
  94. }
  95. /**
  96. *jedis操作Set
  97. */
  98. @Test
  99. publicvoidtestSet(){
  100. //添加
  101. jedis.sadd("sname","minxr");
  102. jedis.sadd("sname","jarorwar");
  103. jedis.sadd("sname","闵晓荣");
  104. jedis.sadd("sanme","noname");
  105. //移除noname
  106. jedis.srem("sname","noname");
  107. System.out.println(jedis.smembers("sname"));//获取所有加入的value
  108. System.out.println(jedis.sismember("sname","minxr"));//判断minxr是否是sname集合的元素
  109. System.out.println(jedis.srandmember("sname"));
  110. System.out.println(jedis.scard("sname"));//返回集合的元素个数
  111. }
  112. @Test
  113. publicvoidtest()throwsInterruptedException{
  114. //keys中传入的可以用通配符
  115. System.out.println(jedis.keys("*"));//返回当前库中所有的key[sose,sanme,name,jarorwar,foo,sname,javaframework,user,braand]
  116. System.out.println(jedis.keys("*name"));//返回的sname[sname,name]
  117. System.out.println(jedis.del("sanmdde"));//删除key为sanmdde的对象删除成功返回1删除失败(或者不存在)返回0
  118. System.out.println(jedis.ttl("sname"));//返回给定key的有效时间,如果是-1则表示永远有效
  119. jedis.setex("timekey",10,"min");//通过此方法,可以指定key的存活(有效时间)时间为秒
  120. Thread.sleep(5000);//睡眠5秒后,剩余时间将为<=5
  121. System.out.println(jedis.ttl("timekey"));//输出结果为5
  122. jedis.setex("timekey",1,"min");//设为1后,下面再看剩余时间就是1了
  123. System.out.println(jedis.ttl("timekey"));//输出结果为1
  124. System.out.println(jedis.exists("key"));//检查key是否存在System.out.println(jedis.rename("timekey","time"));
  125. System.out.println(jedis.get("timekey"));//因为移除,返回为null
  126. System.out.println(jedis.get("time"));//因为将timekey重命名为time所以可以取得值min
  127. //jedis排序
  128. //注意,此处的rpush和lpush是List的操作。是一个双向链表(但从表现来看的)
  129. jedis.del("a");//先清除数据,再加入数据进行测试
  130. jedis.rpush("a","1");
  131. jedis.lpush("a","6");
  132. jedis.lpush("a","3");
  133. jedis.lpush("a","9");
  134. System.out.println(jedis.lrange("a",0,-1));//[9,3,6,1]
  135. System.out.println(jedis.sort("a"));//[1,3,6,9]//输入排序后结果
  136. System.out.println(jedis.lrange("a",0,-1));
  137. }
  138. }

Redis会定时 保存数据到硬盘上

Windows下Redis的安装使用

【编辑推荐】