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 dll:http://windows.php.net/downloads/pecl/snaps/redis/2.2.5/ 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 进入redis目录后 开启服务  (注意加上redis.conf)
  1. redis-server.exe redis.conf
这个窗口要保持开启  关闭时redis服务会自动关闭 redis会自动保存数据到硬盘 所以图中是我第二次开启时 多了一个 DB loaded from disk 3.测试使用 另外开启一个命令行窗口 进入redis目录下 (注意修改自己的ip)
  1. redis-cli.exe -h 192.168.10.61 -p 6379
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. 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会定时 保存数据到硬盘上

分类: web

标签: