写一篇关于redis链接池的平常记录,最近在学习,因此学到的都将记录下来,首先是写一个redis链接池:java
package com.charRobot.util; 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; // Redis访问密码 private static String AUTH = "password"; //可用链接实例的最大数目,默认为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(); config.setMaxTotal(MAX_TOTAL); config.setMaxIdle(MAX_IDLE); config.setMaxWaitMillis(MAX_WAIT_MILLIS); 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) { if (jedis != null) { jedisPool.returnResource(jedis); } } }
写好后,咱们直接写一个main方法,用于测试:redis
public class RedisJava { public static void main(String[] args) { RedisPool.getJedis().set("name", "xlf"); System.out.println("name : " + RedisPool.getJedis().get("name")); } }
运行后获得结果:服务器
其实用法都差很少,咱们再试试list操做:学习
RedisPool.getJedis().lpush("info","xlf"); RedisPool.getJedis().lpush("info","100"); RedisPool.getJedis().lpush("info","200"); System.out.println("长度" + RedisPool.getJedis().llen("info")); // jedis.llen表示长度,-1表示全部 System.out.println("info:" + RedisPool.getJedis().lrange("info", 0, -1));
运行结果为:测试
大部分操做都差很少,只是逻辑有所不一样3d