Windows下Redis的安装使用

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


作者:蛙牛


​51CTO 网+ 第十二期沙龙:大话数据之美_如何用数据驱动用户体验​

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的安装使用(带Java示例)_java

Windows下Redis的安装使用(带Java示例)_redis_02

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的安装使用(带Java示例)_redis_03

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



  1. redis-server.exe redis.conf



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

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

3.测试使用

Windows下Redis的安装使用(带Java示例)_jar_04

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



  1. redis-cli.exe -h 192.168.10.61 -p 6379



4.Java开发包Jedis

Jedis :​​javascript:void(0)​​ (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. package com.lujianing.utils;
  2. import org.junit.Before;
  3. import org.junit.Test;
  4. import redis.clients.jedis.Jedis;
  5. import redis.clients.jedis.JedisPool;
  6. import redis.clients.jedis.JedisPoolConfig;
  7. import java.util.HashMap;
  8. import java.util.Iterator;
  9. import java.util.List;
  10. import java.util.Map;
  11. /**
  12. * Created by lujianing on 14-2-28.
  13. */
  14. public class JedisUtilTest {
  15. JedisPool pool;
  16. Jedis jedis;
  17. @Before
  18. public void setUp() {
  19. pool = new JedisPool(new JedisPoolConfig(), "192.168.10.61");
  20. jedis = pool.getResource();
  21. //   jedis.auth("password");
  22. }
  23. @Test
  24. public void testGet(){
  25. System.out.println(jedis.get("lu"));
  26. }
  27. /**
  28. * Redis存储初级的字符串
  29. * CRUD
  30. */
  31. @Test
  32. public void testBasicString(){
  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 将jarorwar append到已经有的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. public void testMap(){
  59. Map<String,String> user=new HashMap<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. String key = iter.next();                System.out.println(key+":"+jedis.hmget("user",key));
  77. }
  78. }
  79. /**
  80. * jedis操作List
  81. */
  82. @Test
  83. public void testList(){
  84. //开始前,先移除所有的内容
  85. jedis.del("java framework");
  86. System.out.println(jedis.lrange("java framework",0,-1));
  87. //先向key java framework中存放三条数据
  88. jedis.lpush("java framework","spring");
  89. jedis.lpush("java framework","struts");
  90. jedis.lpush("java framework","hibernate");
  91. //再取出所有数据jedis.lrange是按范围取出,
  92. // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有
  93. System.out.println(jedis.lrange("java framework",0,-1));
  94. }
  95. /**
  96. * jedis操作Set
  97. */
  98. @Test
  99. public void testSet(){
  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. public void test() throws InterruptedException {
  114. //keys中传入的可以用通配符
  115. System.out.println(jedis.keys("*")); //返回当前库中所有的key  [sose, sanme, name, jarorwar, foo, sname, java framework, 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的安装使用(带Java示例)_java_05