Redis连接池
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Redis连接池,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2523字,纯文字阅读大概需要4分钟。
内容图文
![Redis连接池](/upload/InfoBanner/zyjiaocheng/917/a9a2dfe3faca4aff874f3eaae440c135.jpg)
package com.lee.utils; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; public final class RedisPool { //Redis服务器IP private static String ADDR = "127.0.0.1"; //Redis的端口号 private static Integer PORT = 6379; //访问密码 private static String AUTH = "12345"; //可用连接实例的最大数目,默认为8; //如果赋值为-1,则表示不限制,如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽) private static Integer MAX_TOTAL = 1024; //控制一个pool最多有多少个状态为idle(空闲)的jedis实例,默认值是8 private static Integer MAX_IDLE = 200; //等待可用连接的最大时间,单位是毫秒,默认值为-1,表示永不超时。 //如果超过等待时间,则直接抛出JedisConnectionException private static Integer MAX_WAIT_MILLIS = 10000; private static Integer TIMEOUT = 10000; //在borrow(用)一个jedis实例时,是否提前进行validate(验证)操作; //如果为true,则得到的jedis实例均是可用的 private static Boolean TEST_ON_BORROW = true; private static JedisPool jedisPool = null; /** * 静态块,初始化Redis连接池 */ static { try { JedisPoolConfig config = new JedisPoolConfig(); /*注意: 在高版本的jedis jar包,比如本版本2.9.0,JedisPoolConfig没有setMaxActive和setMaxWait属性了 这是因为高版本中官方废弃了此方法,用以下两个属性替换。 maxActive ==> maxTotal maxWait==> maxWaitMillis */ config.setMaxTotal(MAX_TOTAL); config.setMaxIdle(MAX_IDLE); config.setMaxWaitMillis(MAX_WAIT_MILLIS); config.setTestOnBorrow(TEST_ON_BORROW); jedisPool = new JedisPool(config,ADDR,PORT,TIMEOUT,AUTH); } catch (Exception e) { e.printStackTrace(); } } /** * 获取Jedis实例 * @return */ public synchronized static Jedis getJedis(){ try { if(jedisPool != null){ Jedis jedis = jedisPool.getResource(); return jedis; }else{ return null; } } catch (Exception e) { e.printStackTrace(); return null; } } public static void returnResource(final Jedis jedis){ //方法参数被声明为final,表示它是只读的。 if(jedis!=null){ // jedisPool.returnResource(jedis); //jedis.close()取代jedisPool.returnResource(jedis)方法将3.0版本开始 jedis.close(); } } }
main
public static void main(String[] args) { RedisPool.getJedis().set("name","lee"); // RedisPool.getJedis().del("name"); System.out.println("show:"+RedisPool.getJedis().get("name")); }
非连接池连接
public static void main(String[] args) { //连接本地的 Redis 服务 Jedis jedis = new Jedis("127.0.0.1", 6379); //权限认证 jedis.auth("12345"); System.out.println("连接成功"); //设置 redis 字符串数据 // jedis.set("test", "redis-test"); // 获取存储的数据并输出 System.out.println("redis 存储的字符串为: "+ jedis.get("test")); }
内容总结
以上是互联网集市为您收集整理的Redis连接池全部内容,希望文章能够帮你解决Redis连接池所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。