java - 使用 JedisPool 的 Redis 连接池变得过于冗长

标签 java redis connection-pooling jedis

这是我的JedisFactory

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

class JedisFactory {
    private static JedisPool jedisPool;
    private static JedisFactory instance;

    public JedisFactory() {
        jedisPool = new JedisPool(getPoolConfig(), "localhost");
    }

    private JedisPoolConfig getPoolConfig() {
        JedisPoolConfig poolConfig = new JedisPoolConfig();
        //poolConfig.setTestOnBorrow(true);
        //poolConfig.setTestOnReturn(true);
        poolConfig.setMaxIdle(2);
// Tests whether connections are dead during idle periods
        //poolConfig.setTestWhileIdle(true);
        poolConfig.setMaxTotal(2);
        //poolConfig.setMaxWaitMillis(120000);
        return poolConfig;
    }

    public JedisPool getJedisPool() {
        System.out.println("get pool");
        return jedisPool;
    }

    public static JedisFactory getInstance() {
        if (instance == null) {
            instance = new JedisFactory();
        }
        return instance;
    }
}

这里是用法:

public static void del(String key) {
        Jedis jedis = JedisFactory.getInstance().getJedisPool().getResource();
        try {
            jedis.del(key);
        } finally {
            JedisFactory.getInstance().getJedisPool().returnResource(jedis);
        }
    }


    public static String ping() {
        Jedis jedis = JedisFactory.getInstance().getJedisPool().getResource();
        try {
            return jedis.ping();
        } finally {
            JedisFactory.getInstance().getJedisPool().returnResource(jedis);
        }
    }
    public static void clear() {
        Jedis jedis = JedisFactory.getInstance().getJedisPool().getResource();
        try {
            jedis.flushAll();
        } finally {
            JedisFactory.getInstance().getJedisPool().returnResource(jedis);
        }
    }

因此,对于每个操作,我都必须输入大量样板代码。如何避免?

最佳答案

  1. 您的 JedisFactory.getInstance() 工厂方法不是线程安全的。您可以同时拥有多个 JedisFactory 实例。

  2. 如果您使用 JDK 7 和最近的 Jedis 版本,您可以只使用 try-with-resource。

    尝试(Jedis jedis = JedisFactory.getInstance().getJedisPool().getResource()) { jedis.flushAll();

上面的代码可以工作。

  1. 由于 JedisPool 是线程安全的,您可以只初始化 JedisPool 并传递到任何地方。如果你想继续使用 JedisFactory,你可以通过添加像 JedisFactory.getResource() 这样的 util 方法来最小化你的代码,让 getResource() 为调用者做所有的工作。由于您创建了 JedisFactory,因此无需向公众公开内部 JedisPool 字段。

关于java - 使用 JedisPool 的 Redis 连接池变得过于冗长,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41697363/

相关文章:

java - Lwjgl GUI 库

java - 为什么这个 while 在接收值之前终止? (java)

java - Maven - "files was unexpected at this time"

azure - 在 Azure 上使用 Redis PubSub 作为通知引擎

python - SQLAlchemy,如何将 ORM 和 session 与连接池一起使用?

java - 线程 "main"java.util.UnknownFormatConversionException : Conversion = ' ' 中的异常

python - redis 获取函数返回无

database - Redis//Benchmark工具//如何开启异步测试

java - 连接池泄漏原因

java - 如何修复c3p0连接池初始化异常?