Redis的util類,求指導

來源:互聯網
上載者:User

標籤:

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;


public class RedisUtils {
    
    private static final Log log = LogFactory.getLog(RedisUtils.class);
    
    private static JedisPool rPool = null;
    
    private static JedisPool wPool = null;
    
    static{
        JedisPoolConfig config = new JedisPoolConfig();
        config.setMaxTotal(BaseConstants.REDIS_MAX_TOTAL);
        config.setMaxIdle(BaseConstants.REDIS_MAX_IDLE);
        config.setMaxWaitMillis(BaseConstants.REDIS_TIME_OUT);
        config.setTestOnBorrow(BaseConstants.REDIS_TESTONBORROW);
        rPool = new JedisPool(config, Config.INSTANCE.getConfigValue("redis.r.host"),
                Integer.parseInt(Config.INSTANCE.getConfigValue("redis.r.port")));
        wPool = new JedisPool(config, Config.INSTANCE.getConfigValue("redis.w.host"),
                Integer.parseInt(Config.INSTANCE.getConfigValue("redis.w.port")));
    }
    
    /**
     * Get A New Redis Connection From Read Redis Pool To Read Data!
     * @return
     */
    public static Jedis getReadJedis(){
        Jedis jedis = rPool.getResource();
        if(StringUtils.notEmpty(Config.INSTANCE.getConfigValue("redis.r.pwd"))){
            jedis.auth(Config.INSTANCE.getConfigValue("redis.r.pwd"));
        }
        log.info("Get A New Redis Connection From Read Redis Pool To Read Data!");
        return jedis;
    }
    
    /**
     * Get A New Redis Connection From Write Redis Pool To Output Data!
     * @return
     */
    public static Jedis getWriteJedis(){
        Jedis jedis = wPool.getResource();
        if(StringUtils.notEmpty(Config.INSTANCE.getConfigValue("redis.w.pwd"))){
            jedis.auth(Config.INSTANCE.getConfigValue("redis.w.pwd"));
        }
        log.info("Get A New Redis Connection From Write Redis Pool To Output Data!");
        return jedis;
    }
    
    /**
     * Get A New Redis Connection appointing the db index From Write Redis Pool To Output Data!
     * @param Index
     * @return
     */
    public static Jedis getWriteJedis(int Index){
        Jedis jedis = getWriteJedis();
        jedis.select(Index);
        return jedis;
    }  
    
    /**
     * Realeas Read Redis Connection!
     * @param jedis the redis to be realeas
     */
    public static void releasReadJedis(Jedis rJedis){
        try {
            if(rJedis!=null){
                rJedis.disconnect();   
                rPool.returnResource(rJedis);
                log.info("Realeas Read Redis Connection!");
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
   
    /**
     * Realeas Write Redis Connection!
     * @param jedis the redis to be realeas
     */
    public static void releasWriteJedis(Jedis wJedis){
        try {
            if(wJedis!=null){
                wJedis.disconnect();   
                wPool.returnResource(wJedis);
                log.info("Realeas Write Redis Connection!");
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
   
    /**
     * destory read redis pool
     */
    public static void destoryReadPool(){
        if(rPool != null){
            rPool.destroy();
            log.info("Destory Read Redis Pool!");
        }
    }
    
    /**
     * destory write redis pool
     */
    public static void destoryWritePool(){
        if(wPool != null){
            wPool.destroy();
            log.info("Destory Write Redis Pool!");
        }
    }
   
    /**
     * destory all redis pool
     */
    public static void destoryAllPool(){
        destoryReadPool();
        destoryWritePool();
    }
}

Redis的util類,求指導

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.