(2.3.2)JAVA使用高速缓存redis

大型项目中一般都会用到缓存,如果项目使用集群部署的话,每台机器如何共享缓存内容呢? 

使用Redis可以做到让多台机器甚至多个应用之间共享缓存


安装

首先要有一台服务器安装功能Redis服务,下载地址:http://redis.io/

下载到服务器后解压redis-2.6.14.tar.gz

tar -zxvf  redis-2.6.14.tar.gz

然后进入redis-2.6.14目录 ,先通过make命令编译 ,再cd 进入src目录

sudo ./redis-server 开启服务

如果看到输出: 15 Aug 13:38:05.698 * The server is now ready to accept connections on port 6379  就表示服务开启成功了,默认端口是6379


如果要打开客户端可以在src目录下面 sudo ./redis-cli 就打开了客户端。


 数据结构

存入普通键值对
put keyname value



操作List
RPUSH listname value 将新的值加入到List的结尾
LPUSH listname value 将新的值加入到List的开头
LRANGE listname startIndex endIndex 截取List,包含endIndex
LLEN listname 获取制定list的长度
LPOP listname 移除List的第一个元素
RPOP listname 移除List的最后一个元素


操作Set
SADD setname value 添加元素
SREM setname value 移除元素
SISMEMBER setname value 判断元素是否在set内
SMEMBERS setname 获取set内所有元素
SUNION 用来合并俩功能个Set,并将两个Set内的重复元素合并,得到一个新的Set 用法为: SUNION setname1 setname2

操作带有排序功能的Set,会根据score来排序
ZADD setname score value
使用ZRANGE 0 - 1 能够获取set里面的所有元素


存入对象(使用Hashes数据结构
使用方法为:
添加元素  HMSET student:01 username zhoufeng age 20 sex 男
获取元素  HGETALL student:01 就能获取这个对象了


使用java客户端调用

Redis是支持绝大部分开发语言的客户端的 。

使用java客户端的示例如下:

首先下载jedis.x.x.x.jar 和 commons-pool-x.x.x.jar ,下载地址https://github.com/xetorthio/jedis

或者使用maven。加入下面的配置就可以了

[html]  view plain copy
  1.     
  2.    <dependency>  
  3.     <groupId>redis.clients</groupId>  
  4.     <artifactId>jedis</artifactId>  
  5.     <version>2.0.0</version>  
  6.     <type>jar</type>  
  7.     <scope>compile</scope>  
  8. </dependency>  
  9.      



然后就可以开发客户端测试了。

[java]  view plain copy
  1. package com.zf.redis;  
  2.   
  3. import java.util.HashMap;  
  4. import java.util.Iterator;  
  5. import java.util.List;  
  6. import java.util.Map;  
  7. import java.util.Map.Entry;  
  8. import java.util.Set;  
  9.   
  10. import org.junit.Before;  
  11. import org.junit.Test;  
  12.   
  13. import redis.clients.jedis.Jedis;  
  14.   
  15. public class TestRedis {  
  16.   
  17.     private static final String SERVER_ADDRESS = "127.0.0.1";   //服务器地址  
  18.     private static final Integer SERVER_PORT = 6379 ;   //端口  
  19.       
  20.     private Jedis jedis ;  
  21.       
  22.     @Before  
  23.     public void init(){  
  24.         jedis = new Jedis(SERVER_ADDRESS, SERVER_PORT);   
  25.     }  
  26.       
  27.       
  28.       
  29.     /** 
  30.      * 操作普通键值对 
  31.      */  
  32.     @Test  
  33.     public void test01(){  
  34.         jedis.set("name""zhoufeng");//存入1个key=name value=zhoufeng的键值对  
  35.         String value = jedis.get("name");   //获取key=name的值  
  36.         System.out.println(value);  
  37.     }  
  38.       
  39.     /** 
  40.      * 操作List 
  41.      */  
  42.     @Test  
  43.     public void test02(){  
  44.           
  45.         //将zhoufeng 加入students数组的结尾,如果该元素是第一个元素,那么会自动创建students数组  
  46.         jedis.rpush("students""zhoufeng");      
  47.           
  48.         //将zhangsan加入到students的末尾  
  49.         jedis.lpush("students""zhangsan");  
  50.           
  51.         //移除students的第一个元素  
  52.         jedis.lpop("students");  
  53.           
  54.         //移除students的最后一个元素  
  55.         jedis.rpop("students");  
  56.           
  57.         //移除制定的元素,第二个参数表示要移除的个数,因为list中是允许出现重复元素的  
  58.         jedis.lrem("student"1"zhangsan") ;  
  59.         //获取students数组的所有元素  
  60.         List <String> students = jedis.lrange("students"0, -1) ;  
  61.           
  62.         System.out.println(students);  
  63.     }  
  64.       
  65.     /** 
  66.      * 操作Set 
  67.      */  
  68.     @Test  
  69.     public void test03(){  
  70.         //添加元素  
  71.         jedis.sadd("teachers""zhangsan");  
  72.         jedis.sadd("teachers""lisi");  
  73.         jedis.sadd("teachers""wangwu");  
  74.           
  75.         //判断Set是否包含制定元素  
  76.         Boolean b1 = jedis.sismember("teachers""wangwu");  
  77.         Boolean b2 = jedis.sismember("teachers""xxxxx");  
  78.         System.out.println(b1 + "   " + b2);    
  79.           
  80.         //获取Set内所有的元素  
  81.         Set<String> members =  jedis.smembers("teachers");  
  82.         Iterator<String> it = members.iterator() ;  
  83.         while(it.hasNext()){  
  84.             System.out.println(it.next());  
  85.         }  
  86.           
  87.     //  jedis.sunion(keys...) 可以将多个Set合并成1个并返回合并后的Set  
  88.           
  89.     }  
  90.       
  91.     /** 
  92.      * 操作带排序功能的Set 
  93.      */  
  94.     @Test  
  95.     public void test04(){  
  96.         //添加元素,会根据第二个参数排序  
  97.         jedis.zadd("emps"5 , "aaa") ;  
  98.         jedis.zadd("emps"1 , "bbbb") ;  
  99.         jedis.zadd("emps"3 , "ccc") ;  
  100.         jedis.zadd("emps"2 , "ddd") ;  
  101.           
  102.         //获取所有元素  
  103.         Set<String> emps = jedis.zrange("emps"0, -1) ;  
  104.         Iterator<String> it = emps.iterator() ;  
  105.         while(it.hasNext()){  
  106.             System.out.println(it.next());  
  107.         }  
  108.     }  
  109.       
  110.     /** 
  111.      * 存入对象,使用Map作为对象 
  112.      */  
  113.     @Test  
  114.     public void test05(){  
  115.         Map<String , String > car = new HashMap<String , String >() ;  
  116.         car.put("COLOR""red") ;  
  117.         car.put("SIZE""2T");  
  118.         car.put("NO""京8888");  
  119.         //存入对象,使用car:01当作key,是为了方便和其他car区分。比如car:02  
  120.         jedis.hmset("car:01", car);  
  121.           
  122.         //获取整个对象  
  123.         Map<String, String> result = jedis.hgetAll("car:01");   
  124.         Iterator<Entry<String, String>>  it = result.entrySet().iterator();  
  125.         while(it.hasNext()){  
  126.             Entry<String, String> entry = it.next() ;    
  127.             System.out.println("key:" + entry.getKey() + " value:" + entry.getValue());  
  128.         }  
  129.           
  130.         //也可以获取制定的属性  
  131.         String no = jedis.hget("car:01""NO") ;  
  132.         System.out.println("NO:" + no);  
  133.     }  
  134.       
  135. }  

你可能感兴趣的:((2.3.2)JAVA使用高速缓存redis)