Redis 使用工具类:

package com.qlwb.business.common.redis;

import org.apache.log4j.Logger;

import redis.clients.jedis.Jedis;

import redis.clients.jedis.JedisPool;

import redis.clients.jedis.JedisPoolConfig;

import com.aspire.boc.util.ResourceManager;

public class RedisPool {

// Redis服务器IP
private static String ADDR = ""; // Redis的端口号
private static int PORT = 6379; // 可用连接实例的最大数目,默认值为8;
// 如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。
private static int MAX_ACTIVE = 2000; // 控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
private static int MAX_IDLE = 200; // 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;
private static int MAX_WAIT = 10000; private static int TIMEOUT = 10000;// 0是关闭此设置 // 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
private static boolean TEST_ON_BORROW = true; private static JedisPool jedisPool = null; /**
* 初始化Redis连接池
*/
static {
try {
ResourceManager rm = ResourceManager.getInstance();
ADDR = rm.getValue("redis_addr");
JedisPoolConfig config = new JedisPoolConfig();
**config.setMaxTotal(MAX_ACTIVE);**
config.setMaxIdle(MAX_IDLE);
**config.setMaxWaitMillis(MAX_WAIT);**
config.setTestOnBorrow(TEST_ON_BORROW);
config.setTestOnReturn(TEST_ON_BORROW);
jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT); } catch (Exception e) {
e.printStackTrace();
}
} /**
* 获取Jedis实例
*
* @return
*/
public static Jedis getJedis()
{
try {
if (jedisPool != null) {
Jedis jedis = jedisPool.getResource();
//jedisPool.returnBrokenResource(jedis);
return jedis;
} else {
return null;
}
} catch (Exception e) {
e.printStackTrace();
return null;
}
} /**
* 返还到连接池
*
* @param jedis
*/
public static void returnResource(final Jedis jedis) {
if (jedis != null && jedisPool !=null) {

// jedisPool.returnResource(jedis);

jedis.close();

}

}

/**

* 释放jedis资源

*

* @param jedis

*/

public static void returnBrokenResource(final Jedis jedis) {

if (jedis != null && jedisPool !=null) {

jedisPool.close();

}

}

/**

*

* @方法名称:get

* @内容摘要: <直接从从库中获得信息>

* @param key

* @return

* String

* @exception

* @author:鹿伟伟

* @创建日期:2016年3月16日-上午10:52:22

*/

public static String get(String key){

String value = null;

Jedis jedis = null;

try {

jedis =getJedis();

value = jedis.get(key);

} catch (Exception e) {

//释放redis对象

returnBrokenResource(jedis);

Logger.getLogger(RedisPool.class).error(“get error”, e);

}finally{

returnResource(jedis);

}

return value;

}

/**

*

* @方法名称:set

* @内容摘要: <设置数据>

* @param key

* @param value

* void

* @exception

* @author:鹿伟伟

* @创建日期:2016年3月3日-上午10:34:50

*/

public static void set(String key,String value){

Jedis jedis = null;

try {

jedis =getJedis();

jedis.set(key,value);

} catch (Exception e) {

//释放redis对象

returnResource(jedis);

Logger.getLogger(RedisPool.class).error(“set error”, e);

}finally{

returnResource(jedis);

}

}

/**

*

* @方法名称:expire

* @内容摘要: <设置数据有限时间>

* @param key

* @param time

* void

* @exception

* @author:鹿伟伟

* @创建日期:2016年3月3日-上午10:37:51

*/

public static void expire(String key,int time){

Jedis jedis = null;

try {

jedis =getJedis();

jedis.expire(key, time);

} catch (Exception e) {

//释放redis对象

returnResource(jedis);

Logger.getLogger(RedisPool.class).error(“expire error”, e);

}finally{

returnResource(jedis);

}

}

public static boolean exists(String key){

Jedis jedis = null;

try {

jedis =getJedis();

return jedis.exists(key);

} catch (Exception e) {

//释放redis对象

returnResource(jedis);

Logger.getLogger(RedisPool.class).error(“exists error”, e);

}finally{

returnResource(jedis);

}

return false;

}

/**

* @param args

*/

public static void main(String[] args) {

// System.out.println(get(“productcount_1605”));

for (int i = 0; i < 1000; i++) {

System.out.println(i+”—-“+get(“productcount_1605”));

// try {

// Thread.sleep(1000);

// } catch (InterruptedException e) {

// // TODO Auto-generated catch block

// e.printStackTrace();

// }

}

}

}

Jedis使用工具类的更多相关文章

  1. Redis+Jedis封装工具类

    package com.liying.monkey.core.util; import java.io.IOException; import java.util.ArrayList; import ...

  2. java JedisUtils工具类

    package com.sh.xrsite.common.utils; import java.util.List; import java.util.Map; import java.util.Se ...

  3. Redis工具类

    /** * Copyright © 2012-2016 * <a href="https://github.com/thinkgem/smkj">smkj</a& ...

  4. java中的redis工具类

    1.redis基础类 package com.qlchat.component.redis.template; import javax.annotation.PostConstruct; impor ...

  5. 动态代理模式_应用(Redis工具类)

    本次使用动态代理的初衷是学习Redis,使用Java操作Redis时用到Jedis的JedisPool,而后对Jedis的方法进一步封装完善成为一个工具类.因为直接使用Jedis对象时,为了保证性能, ...

  6. Jedis 操作 Redis 工具类

    配置类 pom.xml pom.xml 里配置依赖 <dependency> <groupId>redis.clients</groupId> <artifa ...

  7. Jedis工具类代码

    安装Redis可以参考 https://www.cnblogs.com/dddyyy/p/9763098.html Redis的学习可以参考https://www.cnblogs.com/dddyyy ...

  8. Jedis工具类(含分布式锁的调用和释放)

    个人把工具类分为两部分: 一.连接池部分 import org.slf4j.Logger; import org.slf4j.LoggerFactory; import redis.clients.j ...

  9. redis集群使用Java工具类(Java jedis集群工具类)

    package com.xiaomi.weather.vote.webservices.util.redisCache; import com.google.common.base.Strings; ...

随机推荐

  1. java 中Int和Integer区别以及相关示例

    Java是一个近乎纯洁的面向对象编程语言,但是为了编程的方便还是引入不是对象的基本数据类型,但是为了能够将这些基本数据类型当成对象操作,Java为每一个基本数据类型都引入了对应的包装类型(wrappe ...

  2. 在Action获取Scope对象

    引言:在前面的Action操作中,关键就是Action中的exectue方法,但是此方法并没有request.session.application等对象作为参数,自然就不能利用这些对象来操作.下面我 ...

  3. Asp.net 微信企业号网页开发流程

    一.在pageload方法中获取code var code = GetCode(); private string GetCode() { return HttpContext.Current.Req ...

  4. datatables的使用

    在开发web项目中,界面就是一个以丰富友好的样式来展现数据的窗口,同样的数据不用的展现形式给人不同的体验,数据列表是数据是一种常见展现形式,对于数据列表的一个最基本的要求就是能够实现分页以及检索功能. ...

  5. jquery 选择器的总结

    元素选择 $("input") id选择 $('#id') class选择 $('.id') 属性选择 $('[prop]')或者$('[prop=“value1”]')或者$(' ...

  6. 2018杭电多校第六场1009(DFS,思维)

    #include<bits/stdc++.h>using namespace std;int a[100010];char s[20];int zhiren[100010];vector& ...

  7. [poj 1276] Cash Machine 多重背包及优化

    Description A Bank plans to install a machine for cash withdrawal. The machine is able to deliver ap ...

  8. python 数组学习

    2 NumPy-快速处理数据 标准安装的Python中用列表(list)保存一组值,可以用来当作数组使用,不过由于列表的元素可以是任何对象,因此列表中所保存的是对象的指针.这样为了保存一个简单的[1, ...

  9. puppet批量管理500多台服务器

    前言 puppet使用了有一段时间了,之前写的手顺书一直未发布到blog上来,今天正好有空,写下一点笔记.公司在用的服务器有500多台,基本都为CentOS,版本有5和6两种,管理起来很不方便,尤其是 ...

  10. Kotlin VS Java:基本语法差异

    Kotlin比Java更年轻,但它是一个非常有前途的编程语言,它的社区不断增长. 每个人都在谈论它,并说它很酷. 但为什么这么特别? 我们准备了一系列文章,分享我们在Kotlin开发Android应用 ...