设为首页 收藏本站
查看: 734|回复: 0

[经验分享] Java Redis实战之Redis + Jedis

[复制链接]

尚未签到

发表于 2016-12-17 11:00:07 | 显示全部楼层 |阅读模式
目前Redis大概有3中基于Java语言的Client:

  • Jredis
  • Jedis
  • Redis4J
一、简单使用Jedis
需要Jedis就从Maven获取吧!
Maven Pom.xml

 
Xml代码   DSC0000.gif


  • <dependency>  
  •     <groupId>redis.clients</groupId>  
  •     <artifactId>jedis</artifactId>  
  •     <version>2.1.0</version>  
  •     <type>jar</type>  
  •     <scope>compile</scope>  
  • </dependency>  

[xml] view plaincopy 



  • <dependency>  
  •     <groupId>redis.clients</groupId>  
  •     <artifactId>jedis</artifactId>  
  •     <version>2.1.0</version>  
  •     <type>jar</type>  
  •     <scope>compile</scope>  
  • </dependency>  

 
 
 
如果只是简单使用Jedis,以下这么几行代码足够:
 
Java代码  


  • Jedis jedis = new Jedis("10.11.20.140");  
  • String keys = "name";  
  •   
  • // 删数据  
  • jedis.del(keys);  
  • // 存数据  
  • jedis.set(keys, "snowolf");  
  • // 取数据  
  • String value = jedis.get(keys);  
  •   
  • System.out.println(value);  

[java] view plaincopy 



  • Jedis jedis = new Jedis("10.11.20.140");  
  • String keys = "name";  
  •   
  • // 删数据  
  • jedis.del(keys);  
  • // 存数据  
  • jedis.set(keys, "snowolf");  
  • // 取数据  
  • String value = jedis.get(keys);  
  •   
  • System.out.println(value);  

 
 
二、池化使用Jedis
Jedis使用commons-pool完成池化实现。
先做个配置文件:
Properties代码  


  • #最大分配的对象数  
  • redis.pool.maxActive=1024  
  • #最大能够保持idel状态的对象数  
  • redis.pool.maxIdle=200  
  • #当池内没有返回对象时,最大等待时间  
  • redis.pool.maxWait=1000  
  • #当调用borrow Object方法时,是否进行有效性检查  
  • redis.pool.testOnBorrow=true  
  • #当调用return Object方法时,是否进行有效性检查  
  • redis.pool.testOnReturn=true  
  • #IP  
  • redis.ip=10.11.20.140  
  • #Port  
  • redis.port=6379  

 
 
 在静态代码段中完成初始化:
 
Java代码  


  • private static JedisPool pool;  
  • static {  
  •     ResourceBundle bundle = ResourceBundle.getBundle("redis");  
  •     if (bundle == null) {  
  •         throw new IllegalArgumentException(  
  •                 "[redis.properties] is not found!");  
  •     }  
  •     JedisPoolConfig config = new JedisPoolConfig();  
  •     config.setMaxActive(Integer.valueOf(bundle  
  •             .getString("redis.pool.maxActive")));  
  •     config.setMaxIdle(Integer.valueOf(bundle  
  •             .getString("redis.pool.maxIdle")));  
  •     config.setMaxWait(Long.valueOf(bundle.getString("redis.pool.maxWait")));  
  •     config.setTestOnBorrow(Boolean.valueOf(bundle  
  •             .getString("redis.pool.testOnBorrow")));  
  •     config.setTestOnReturn(Boolean.valueOf(bundle  
  •             .getString("redis.pool.testOnReturn")));  
  •     pool = new JedisPool(config, bundle.getString("redis.ip"),  
  •             Integer.valueOf(bundle.getString("redis.port")));  
  • }  

[java] view plaincopy 



  • private static JedisPool pool;  
  • static {  
  •     ResourceBundle bundle = ResourceBundle.getBundle("redis");  
  •     if (bundle == null) {  
  •         throw new IllegalArgumentException(  
  •                 "[redis.properties] is not found!");  
  •     }  
  •     JedisPoolConfig config = new JedisPoolConfig();  
  •     config.setMaxActive(Integer.valueOf(bundle  
  •             .getString("redis.pool.maxActive")));  
  •     config.setMaxIdle(Integer.valueOf(bundle  
  •             .getString("redis.pool.maxIdle")));  
  •     config.setMaxWait(Long.valueOf(bundle.getString("redis.pool.maxWait")));  
  •     config.setTestOnBorrow(Boolean.valueOf(bundle  
  •             .getString("redis.pool.testOnBorrow")));  
  •     config.setTestOnReturn(Boolean.valueOf(bundle  
  •             .getString("redis.pool.testOnReturn")));  
  •     pool = new JedisPool(config, bundle.getString("redis.ip"),  
  •             Integer.valueOf(bundle.getString("redis.port")));  
  • }  

 
 然后,修改前面那段jedis操作Redis
Java代码  


  • // 从池中获取一个Jedis对象  
  • Jedis jedis = pool.getResource();  
  • String keys = "name";  
  •   
  • // 删数据  
  • jedis.del(keys);  
  • // 存数据  
  • jedis.set(keys, "snowolf");  
  • // 取数据  
  • String value = jedis.get(keys);  
  •   
  • System.out.println(value);  
  •   
  • // 释放对象池  
  • pool.returnResource(jedis);  

[java] view plaincopy 



  • // 从池中获取一个Jedis对象  
  • Jedis jedis = pool.getResource();  
  • String keys = "name";  
  •   
  • // 删数据  
  • jedis.del(keys);  
  • // 存数据  
  • jedis.set(keys, "snowolf");  
  • // 取数据  
  • String value = jedis.get(keys);  
  •   
  • System.out.println(value);  
  •   
  • // 释放对象池  
  • pool.returnResource(jedis);  

 
 改为从对象池中,获取Jedis实例:
 
Java代码  


  • // 从池中获取一个Jedis对象  
  • Jedis jedis = pool.getResource();  

[java] view plaincopy 



  • // 从池中获取一个Jedis对象  
  • Jedis jedis = pool.getResource();  

 
 
 
 切记,最后使用后,释放Jedis对象:
 
Java代码  


  • // 释放对象池  
  • pool.returnResource(jedis);  

[java] view plaincopy 



  • // 释放对象池  
  • pool.returnResource(jedis);  

 
 
 
三、一致性哈希
 
Memcached完全基于分布式集群,而RedisMaster-Slave,如果想把Reids,做成集群模式,无外乎多做几套Master-Slave,每套Master-Slave完成各自的容灾处理,通过Client工具,完成一致性哈希。
PS:Memcached是在Server端完成ShardingRedis只能依靠各个ClientSharding。可能会在Redis 3.0系列支持ServerSharding
 
保留前面的JedisPoolConfig,新增两个Redis的IP(redis1.ip,redis2.ip),完成两个JedisShardInfo实例,并将其丢进List中:
 
Java代码  


  • JedisShardInfo jedisShardInfo1 = new JedisShardInfo(  
  •                 bundle.getString("redis1.ip"), Integer.valueOf(bundle                       .getString("redis.port")));  
  • JedisShardInfo jedisShardInfo2 = new JedisShardInfo(  
  •                 bundle.getString("redis2.ip"), Integer.valueOf(bundle                       .getString("redis.port")));  
  •   
  • List<JedisShardInfo> list = new LinkedList<JedisShardInfo>();  
  • list.add(jedisShardInfo1);  
  • list.add(jedisShardInfo2);  

[java] view plaincopy 



  • JedisShardInfo jedisShardInfo1 = new JedisShardInfo(  
  •                 bundle.getString("redis1.ip"), Integer.valueOf(bundle                       .getString("redis.port")));  
  • JedisShardInfo jedisShardInfo2 = new JedisShardInfo(  
  •                 bundle.getString("redis2.ip"), Integer.valueOf(bundle                       .getString("redis.port")));  
  •   
  • List<JedisShardInfo> list = new LinkedList<JedisShardInfo>();  
  • list.add(jedisShardInfo1);  
  • list.add(jedisShardInfo2);  

 
 初始化ShardedJedisPool代替JedisPool:
 
Java代码  


  • ShardedJedisPool pool = new ShardedJedisPool(config, list);  

[java] view plaincopy 



  • ShardedJedisPool pool = new ShardedJedisPool(config, list);  

 
 改由ShardedJedis,获取Jedis对象:
 
Java代码  


  • // 从池中获取一个Jedis对象  
  • ShardedJedis jedis = pool.getResource();  
  • String keys = "name";  
  • String value = "snowolf";  
  • // 删数据  
  • jedis.del(keys);  
  • // 存数据  
  • jedis.set(keys, value);  
  • // 取数据  
  • String v = jedis.get(keys);  
  •   
  • System.out.println(v);  
  •   
  • // 释放对象池  
  • pool.returnResource(jedis);  

[java] view plaincopy 



  • // 从池中获取一个Jedis对象  
  • ShardedJedis jedis = pool.getResource();  
  • String keys = "name";  
  • String value = "snowolf";  
  • // 删数据  
  • jedis.del(keys);  
  • // 存数据  
  • jedis.set(keys, value);  
  • // 取数据  
  • String v = jedis.get(keys);  
  •   
  • System.out.println(v);  
  •   
  • // 释放对象池  
  • pool.returnResource(jedis);  

 
 
 使用commons-pool连接池
[java] view plaincopyprint? 



  • /* 
  •  * JedisPoolTest.java 
  •  */  
  • package com.x.java2000_wl;  
  •   
  • import java.util.ResourceBundle;  
  •   
  • import org.junit.Assert;  
  • import org.junit.BeforeClass;  
  • import org.junit.Test;  
  •   
  • import redis.clients.jedis.Jedis;  
  • import redis.clients.jedis.JedisPool;  
  • import redis.clients.jedis.JedisPoolConfig;  
  •   
  • /** 
  •  * jedis Pool 操作 
  •  * @author http://blog.csdn.net/java2000_wl 
  •  * @version <b>1.0</b> 
  •  */  
  • public class JedisPoolTest {  
  •   
  •     private static JedisPool jedisPool;  
  •       
  •     /** 
  •      * initPoolConfig 
  •      * <br>------------------------------<br> 
  •      * @return 
  •      */  
  •     private static JedisPoolConfig initPoolConfig() {  
  •         JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();  
  •         // 控制一个pool最多有多少个状态为idle的jedis实例  
  •         jedisPoolConfig.setMaxActive(1000);   
  •         // 最大能够保持空闲状态的对象数  
  •         jedisPoolConfig.setMaxIdle(300);  
  •         // 超时时间  
  •         jedisPoolConfig.setMaxWait(1000);  
  •         // 在borrow一个jedis实例时,是否提前进行alidate操作;如果为true,则得到的jedis实例均是可用的;  
  •         jedisPoolConfig.setTestOnBorrow(true);   
  •         // 在还会给pool时,是否提前进行validate操作  
  •         jedisPoolConfig.setTestOnReturn(true);  
  •         return jedisPoolConfig;  
  •     }  
  •       
  •     /** 
  •      * 初始化jedis连接池 
  •      * <br>------------------------------<br> 
  •      */  
  •     @BeforeClass  
  •     public static void before() {  
  •         JedisPoolConfig jedisPoolConfig = initPoolConfig();    
  •         // 属性文件读取参数信息  
  •         ResourceBundle bundle = ResourceBundle.getBundle("redis_config");  
  •         String host = bundle.getString("redis.host");  
  •         int port = Integer.valueOf(bundle.getString("redis.port"));  
  •         int timeout = Integer.valueOf(bundle.getString("redis.timeout"));  
  •         String password = bundle.getString("redis.password");  
  •         // 构造连接池  
  •         jedisPool = new JedisPool(jedisPoolConfig, host, port, timeout, password);  
  •     }  
  •   
  •     @Test  
  •     public void testSet() {  
  •         Jedis jedis = null;   
  •         // 从池中获取一个jedis实例  
  •         try {  
  •             jedis = jedisPool.getResource();  
  •             jedis.set("blog_pool""java2000_wl");  
  •         } catch (Exception e) {  
  •             // 销毁对象  
  •             jedisPool.returnBrokenResource(jedis);  
  •             Assert.fail(e.getMessage());  
  •         } finally {  
  •             // 还会到连接池  
  •             jedisPool.returnResource(jedis);  
  •         }  
  •     }         
  •       
  •     @Test  
  •     public void testGet() {  
  •         Jedis jedis = null;   
  •         try {  
  •             // 从池中获取一个jedis实例  
  •             jedis = jedisPool.getResource();  
  •             System.out.println(jedis.get("blog_pool"));  
  •         } catch (Exception e) {  
  •             // 销毁对象  
  •             jedisPool.returnBrokenResource(jedis);  
  •             Assert.fail(e.getMessage());  
  •         } finally {  
  •             // 还会到连接池  
  •             jedisPool.returnResource(jedis);  
  •         }  
  •     }  
  • }  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-315510-1-1.html 上篇帖子: 备份和恢复Redis 下篇帖子: CentOS7安装redis
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表