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

[经验分享] Jedis(redis 客户端)

[复制链接]
发表于 2016-12-18 08:06:47 | 显示全部楼层 |阅读模式
Memcached,对于缓存对象大小有要求,单个对象不得大于1MB,且不支持复杂的数据类型,譬如SET
等。基于这些限制,有必要考虑Redis DSC0000.gif
  
言归正传,目前Redis大概有3中基于Java语言的Client:

  • Jredis
  • Jedis
  • Redis4J
这里只说Jedis,因为它是官方提供的唯一Redis Client For Java Provider!
 
一、简单使用Jedis
需要Jedis就从Maven获取吧!
Maven Pom.xml
 
Xml代码   DSC0001.png


  • <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);  

 
二、池化使用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")));  
  • }  

 然后,修改前面那段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);  

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


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

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


  • // 释放对象池  
  • 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);  

 初始化ShardedJedisPool代替JedisPool:
 
Java代码  


  • 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);  

 
 
 
四、Spring封装参考
 Ok,完成上述代码足够完成简单任务,如果有必要,可以用Spring封装初始化:
 
Xml代码  


  • <context:property-placeholder location="classpath:redis.properties" />  
  • <bean  
  •     id="jedisPoolConfig"  
  •     class="redis.clients.jedis.JedisPoolConfig"  
  • >  
  •     <property  
  •         name="maxActive"  
  •         value="${redis.pool.maxActive}" />  
  •     <property  
  •         name="maxIdle"  
  •         value="${redis.pool.maxIdle}" />  
  •     <property  
  •         name="maxWait"  
  •         value="${redis.pool.maxWait}" />  
  •     <property  
  •         name="testOnBorrow"  
  •         value="${redis.pool.testOnBorrow}" />  
  • </bean>  
  • <bean  
  •     id="shardedJedisPool"  
  •     class="redis.clients.jedis.ShardedJedisPool"  
  • >  
  •     <constructor-arg  
  •         index="0"  
  •         ref="jedisPoolConfig" />  
  •     <constructor-arg index="1">  
  •         <list>  
  •             <bean class="redis.clients.jedis.JedisShardInfo">  
  •                 <constructor-arg  
  •                     index="0"  
  •                     value="${redis1.ip}" />  
  •                 <constructor-arg  
  •                     index="1"  
  •                     value="${redis.port}"  
  •                     type="int" />  
  •             </bean>  
  •             <bean class="redis.clients.jedis.JedisShardInfo">  
  •                 <constructor-arg  
  •                     index="0"  
  •                     value="${redis2.ip}" />  
  •                 <constructor-arg  
  •                     index="1"  
  •                     value="${redis.port}"  
  •                     type="int" />  
  •             </bean>  
  •         </list>  
  •     </constructor-arg>  
  • </bean>  

 代码可以更简洁一些:
 
Java代码  


  • private ApplicationContext app;  
  • private ShardedJedisPool pool;  
  •   
  • @Before  
  • public void before() throws Exception {  
  •     app = new ClassPathXmlApplicationContext("applicationContext.xml");  
  •     pool = (ShardedJedisPool) app.getBean("shardedJedisPool");  
  • }  
  •   
  • @Test  
  • public void test() {  
  •   
  •     // 从池中获取一个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);  
  •   
  •     assertEquals(value, v);  
  • }  

 
当然,Spring提供了对于Redis的专门支持:spring-data-redis,以后有机会再深入研究。
  转载:
相关链接:
征服 Redis
征服 Redis + Jedis
征服 Redis + Jedis + Spring (一)—— 配置&常规操作(GET SET DEL)
征服 Redis + Jedis + Spring (二)—— 哈希表操作(HMGET HMSET)
征服 Redis + Jedis + Spring (三)—— 列表操作

运维网声明 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-315728-1-1.html 上篇帖子: php5.4添加redis扩展 下篇帖子: Centos6.5 安装 redis
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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