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. QTP使用outlook发送邮件

    '发邮件 Dim objOutlook  Dim objOutlookMsg Dim olMailItem  ' Create the Outlook object and the new mail ...

  2. C++模板特化编程

    在C++中,模板特化是除了类之外的一种封装变化的方法.模板特化可以通过编译器来对不同的模板参数生成不同的代码. 模板特化通常以模板结构体作为载体.常用技法包括:类型定义.静态成员常量定义和静态成员函数 ...

  3. Qt 按顺序保存多个文件

    void MainWindow::on_pushButtonSnap_clicked() { ]; sprintf(image_name, "%s%d%s", "C:/i ...

  4. mysql查询语句in和exists二者的区别和性能影响

    mysql中的in语句是把外表和内表作hash 连接,而exists语句是对外表作loop循环,每次loop循环再对内表进行查询.一直大家都认为exists比in语句的效率要高,这种说法其实是不准确的 ...

  5. Servlet编程实例 续2

    -----------------siwuxie095 Servlet 跳转之请求的重定向 继续完善登录实例,如下: login.jsp 不变,修改 LoginServlet,新建两个 JSP 文件 ...

  6. mongodb 操作数据库

    1.使用和创建数据库: use mydb //没有就创建 2.显示数据库 show dbs 3.显示数据库状态 db.stats() 4.检查当前所用的数据库 db 5.删除数据库(先用然后删除) u ...

  7. Shrio00 Shiro角色授权、Shiro权限授权、开启Shiro缓存

    1 需求01 用户进行过认证登录后,某些接口是有权限限制的:如何实现只有相应权限的用户才可以调用相应接口 2 修改shiro配置类  ShiroConfiguration package cn.xia ...

  8. Jmeter JDBC Request的sql语句不支持;号

    Jmeter JDBC Request的sql语句不支持:号,如果要批量插入数据,则需要使用以下方式 INSERT INTO bank_info( `id`, `bank_code`, `bank_n ...

  9. 6.wireshark使用全解

    开始之前先推荐一个wireshark视频: http://www.shiyanbar.com/course-video/watchVideo/cid/419/vid/2001 页面功能简介 1.主界面 ...

  10. Postman使用-1

    文章来源:http://www.cnplugins.com/tool/specify-postman-methods.html https://www.cnblogs.com/Skyyj/p/6856 ...