文档章节

redis连接池

开源中国首席撸管冠军
 开源中国首席撸管冠军
发布于 2015/03/25 15:25
字数 301
阅读 891
收藏 11

public final class RedisUtil {

   

    //Redis服务器IP

    private static String ADDR = "192.168.0.100";

   

    //Redis的端口号

    private static int PORT = 6379;

   

    //访问密码

    private static String AUTH = "admin";

   

    //可用连接实例的最大数目,默认值为8;

    //如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。

    private static int MAX_ACTIVE = 1024;

   

    //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。

    private static int MAX_IDLE = 200;

   

    //等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;

    private static int MAX_WAIT = 10000;

   

    private static int 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.setMaxActive(MAX_ACTIVE);

            config.setMaxIdle(MAX_IDLE);

            config.setMaxWait(MAX_WAIT);

            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 resource = jedisPool.getResource();

                return resource;

            } else {

                return null;

            }

        } catch (Exception e) {

            e.printStackTrace();

            return null;

        }

    }

   

    /**

     * 释放jedis资源

     * @param jedis

     */

    public static void returnResource(final Jedis jedis) {

        if (jedis != null) {

            jedisPool.returnResource(jedis);

        }

    }

}

© 著作权归作者所有

开源中国首席撸管冠军
粉丝 47
博文 53
码字总数 32844
作品 0
深圳
其他
私信 提问
关于nodejs下redis/mysql需不需要连接池的问题

连接池的作用主要是较少每次临时建立连接所带来的开销。初步一看,nodejs运行单线程上,它不能同时使用多个连接,乍一看是不需要连接池的。但是这只是我们初步下意识的感觉,下面我们详细分析...

吾爱
2016/03/04
407
0
python连接redis

一、安装服务 下载、编译安装 wget http://download.redis.io/releases/redis-3.0.1.tar.gztar -zxvf redis-3.0.1.tar.gzcd redis-3.0.1make 二进制文件是编译完成后在src目录下,通过下面的...

huangzp168
2017/11/24
0
0
redis:Could not get a resource from the pool

redis作为缓存服务器,从连接池中获取不到可用连接,一般排查手段:1.首先判断redis连接参数是否配置正确?很有可能,之前一直能取,但现在突然出现异常,很有可能是redis的服务器down掉了,...

moreThink
2016/08/03
18
0
Nginx+Lua+Redis连接池

上篇介绍了如果使用Lua访问Redis,但是每次都是重新创建一个连接到Redis,其实更好的方法是使用Redis连接池。 如果创建Redis连接池呢?原理是用Nginx的Upstream来实现,在Nginx启动时就可以创...

醉人的笑容你有没有
2016/04/19
3.1K
2
使用acl网络通信库的 redis c++ 模块开发 redis 应用

一、概述 (可以直接略过此段)redis 最近做为 nosql 数据服务应用越来越广泛,其相对于 memcached 的最大优点是提供了更加丰富的数据结构,所以应用场景就更为广泛。redis 的出现可谓是广大...

郑树新
2015/02/12
0
0

没有更多内容

加载失败,请刷新页面

加载更多

JAVA 8 中新增 lambda 表达式的一些基本应用

import java.util.Arrays;import java.util.List;import java.util.function.Function;import java.util.stream.Collectors;public class TestLambda { public static void......

这是一只小小鸟
16分钟前
1
0
Java向word中插入Excel文件对象

前言: 在word文件中,虽然也有表格。但是有时我们想要将Excel中表格的大量数据直接插入到word文档中,这就需要用到word的插入对象的功能,也就是直接将Excel文件当做对象插入到word中。 本地的...

qianxi
18分钟前
2
0
海量数据下的注册中心 - SOFARegistry 架构介绍

SOFAStack Scalable Open Financial Architecture Stack 是蚂蚁金服自主研发的金融级分布式架构,包含了构建金融级云原生架构所需的各个组件,是在金融场景里锤炼出来的最佳实践。 SOFARegi...

SOFAStack
21分钟前
11
0
python操作excel表格

python 对excel的操作 提示:如果需要写多个表,需要把多个表写完在保存,否则会出现表格覆盖问题 此程序 采取一边请求,一边存取,做个异常处理,即可保存已存在的数据 """# sheet的名称,...

鹏灬
23分钟前
1
0
好程序员web前端分享如何理解JS的单线程

好程序员web前端分享如何理解JS单线程,JS本质是单线程的。也就是说,它并不能像JAVA语言那样,两个线程并发执行。 但我们平时看到的JS,分明是可以同时运作很多任务的,这又是怎么回事呢? ...

好程序员IT
27分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部