package com.jianfeitech.utils;
import java.util.Set;
import org.apache.log4j.Logger;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
import com.jianfeitech.constants.AdConstants;
/**
*
* Redis 工具类。
*
* @author wjxie
*
*/
public class RedisUtil {
private static Logger logger = Logger.getLogger(RedisUtil.class);
private static JedisPool pool;
static {
pool = new JedisPool(new JedisPoolConfig(), AdConstants.REDIS_URL);
}
public static String get(String key) {
Jedis jedis = getJedis();
try {
String result = jedis.get(key);
pool.returnResource(jedis);
return result;
} catch (Exception e) {
logger.error("", e);
pool.returnBrokenResource(jedis);
return null;
}
}
public static void set(String key, String value) {
Jedis jedis = getJedis();
try {
jedis.set(key, value);
pool.returnResource(jedis);
} catch (Exception e) {
logger.error("", e);
pool.returnBrokenResource(jedis);
}
}
public static Long incr(String key) {
Jedis jedis = getJedis();
try {
Long result = jedis.incr(key);
pool.returnResource(jedis);
return result;
} catch (Exception e) {
logger.error("", e);
pool.returnBrokenResource(jedis);
return null;
}
}
public static void deleteBatch(String pattern) {
Jedis jedis = getJedis();
try {
Set<String> keys = jedis.keys(pattern);
if (keys != null && keys.size() > 0) {
for (String key : keys) {
jedis.del(key);
}
}
pool.returnResource(jedis);
} catch (Exception e) {
logger.error("", e);
pool.returnBrokenResource(jedis);
}
}
public static Long getLong(String key) {
try {
String result = get(key);
return Long.valueOf(result);
} catch (NumberFormatException e) {
logger.debug("", e);
return 0L;
}
}
public static void setLong(String key, Long value) {
String result = String.valueOf(value);
set(key, result);
}
public static Jedis getJedis() {
Jedis jedis = null;
int count = 0;
do {
try {
jedis = pool.getResource();
} catch (Exception e) {
logger.debug("", e);
pool.returnBrokenResource(jedis);
}
count++;
} while (jedis == null && count < 10000);
if (jedis == null) {
throw new RuntimeException("Fucking jedis config.");
}
return jedis;
}
}
分享到:
相关推荐
`RedisUtil`通常是一个封装了Jedis操作的工具类,简化了开发人员与Redis交互的流程。下面将详细阐述Redis的基本类型以及`RedisUtil`中可能包含的常用操作方法。 1. **字符串(Strings)** Redis中的字符串是最基础的...
在Java开发中,我们经常会用到一个名为`RedisUtil`的工具类来简化与Redis服务器的交互。这个`redisUtil.zip`可能包含了实现这种交互所需的Java代码。 首先,`RedisUtil`通常包含了一系列静态方法,用于执行基本的...
RedisUtil:Redis工具类 指定缓存失效时间,根据key 获取过期时间,判断key是否存在,删除缓存,普通缓存获取,普通缓存放入,普通缓存放入并设置时间等
RedisUtil 实现了对redis的保存, 修改, 删除, 获取, 判断是否存在和 获取Redis 信息
该工具类是包含:redis String,map,set,list 4种数据类型的常用操作方法。
RedisUtil工具类是Java开发中常见的一种封装,用于简化Redis操作。Redis是一种高性能的键值对数据存储系统,常被用作缓存和数据库。在Java应用中,通过RedisUtil可以方便地进行数据的增删改查,提高代码的可读性和可...
狂神的Redis工具类,有时候所需积分会莫名其妙变成非0值,我发现了会改回0 - =
这里我们主要讨论的是`RedisUtil`方法封装类和`RedisConfig`配置类,以及`application.yml`配置文件在集成Redis时的作用。 1. **RedisUtil方法封装类**: `RedisUtil`是为简化Redis操作而设计的一个工具类,它通常...
redis工具类,初始化Redis连接池,获取Jedis实例,释放jedis资源
Springboot+redisUtil+websocket,可以测试正常连接websocket和redis.
RedisUtil.java,JAVA Redis工具类
Springboot+redisUtil+websocket上个版本不能在websocket里调用Redis,现在添加了SpringUitls实现了这个功能
RedisUtil 是一个针对 Redis 数据库的 Java 工具类,它简化了与 Redis 的交互,提供了方便的方法来执行常见的 Redis 操作。Redis 是一个高性能的键值存储系统,广泛用于缓存、分布式锁、计数器等多个场景。下面将...