jedis池的介绍及使用(转)

1、jedis池的介绍

       相信你们都用过线程池或者是jdbc的链接池,使用池能够减小系统在使用所需对象时建立对象的开销,从而提升系统性能和效率。jedis池也是如此,那么咱们该如何使用jedis池呢?java

2、jedis池的使用redis

1.所需jar服务器

   commons-pool.jar、jedis-2.1.0.jar
2.编写Redis配置文件(redis.properties 
ide

本例中代码以下:性能

#*****************jedis链接参数设置*********************#测试

#redis服务器ip #   spa

redis.ip=192.168.8.167线程

#redis服务器端口号#  对象

redis.port=6379blog

#************************jedis池参数设置*******************#  

#jedis的最大分配对象#  

jedis.pool.maxActive=3000

#jedis最大保存idel状态对象数 #  

jedis.pool.maxIdle=1000

#jedis池没有对象返回时,最大等待时间 #  

jedis.pool.maxWait=1500

#jedis调用borrowObject方法时,是否进行有效检查#  

jedis.pool.testOnBorrow=true

#jedis调用returnObject方法时,是否进行有效检查 #  

jedis.pool.testOnReturn=true

3.编写Java实现代码:

package com.zhongying.customer.utils;

import java.io.IOException;

import java.util.Properties;

import redis.clients.jedis.Jedis;

import redis.clients.jedis.JedisPool;

import redis.clients.jedis.JedisPoolConfig;

public class MyJedisPool {

    private static JedisPool pool;    

    //静态代码初始化池配置  

    static {    

      try{

      Properties props = new Properties();

     props.load(MyJedisPool.class.getClassLoader().getResourceAsStream("redis.properties"));

             //建立jedis池配置实例  

             JedisPoolConfig config = new JedisPoolConfig();   

             //设置池配置项值  

             config.setMaxActive(Integer.valueOf(props.getProperty("jedis.pool.maxActive")));    

             config.setMaxIdle(Integer.valueOf(props.getProperty("jedis.pool.maxIdle")));    

             config.setMaxWait(Long.valueOf(props.getProperty("jedis.pool.maxWait")));    

             config.setTestOnBorrow(Boolean.valueOf(props.getProperty("jedis.pool.testOnBorrow")));    

             config.setTestOnReturn(Boolean.valueOf(props.getProperty("jedis.pool.testOnReturn")));    

             //根据配置实例化jedis池  

             pool = new JedisPool(config, props.getProperty("redis.ip"), Integer.valueOf(props.getProperty("redis.port"))); 

      }catch (IOException e) {

e.printStackTrace();

}

    }  

    

    /**得到jedis对象*/

    public static Jedis getJedisObject(){

     return pool.getResource();

    }

    

    /**归还jedis对象*/

    public static void recycleJedisOjbect(Jedis jedis){

     pool.returnResource(jedis);  

    }

      

    /** 

     * 测试jedis池方法 

     */  

    public static void main(String[] args) {

        Jedis jedis = getJedisObject();//得到jedis实例                  

        //获取jedis实例后能够对redis服务进行一系列的操做  

        jedis.set("name""zhuxun");  

        System.out.println(jedis.get("name"));  

        jedis.del("name");  

        System.out.println(jedis.exists("name"));  

        recycleJedisOjbect(jedis); //将 获取的jedis实例对象还回迟中

    }  

}

4.测试执行结果以下:

    zhuxun    false 

相关文章
相关标签/搜索