Jedis连接池使用
构建redis连接池,返还到连接池
private static JedisPool jedisPool = null;
private static Jedis jedis; static {
jedis = getJedisPool().getResource();
} /**
* 构建redis连接池
*/
public static JedisPool getJedisPool() {
if (jedisPool == null) {
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(1024); // 可用连接实例的最大数目,如果赋值为-1,表示不限制.
config.setMaxIdle(5); // 控制一个Pool最多有多少个状态为idle(空闲的)jedis实例,默认值也是8
config.setMaxWaitMillis(1000 * 100); // 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时/如果超过等待时间,则直接抛出异常
config.setTestOnBorrow(true); // 在borrow一个jedis实例时,是否提前进行validate操作,如果为true,则得到的jedis实例均是可用的
jedisPool = new JedisPool(config, "127.0.0.1", 6379);
}
return jedisPool;
} /**
* 释放jedis资源
*/
public static void returnResource(Jedis jedis) {
if (jedis != null) {
jedis.close();
}
}
jedis使用
- 典型的jedis使用方法
public static String get(String key) {
String value = null;
Jedis jedis = null;
try {
JedisPool pool = getJedisPool();
jedis = pool.getResource();
value = jedis.get(key);
}
catch (Exception e) {
returnResource(jedis);
e.printStackTrace();
}
finally {
returnResource(jedis);
}
return value;
}
这种写法会经常忘记返回jedis到pool.参考Spting JdbcTemplate的实现方式,优化如下
- 优化jedis使用方法
public static String getByTemplate(final String key) {
RedisTemplate redisTemplate = new RedisTemplate(getJedisPool());
String value = redisTemplate.execute(new RedisCallback<String>() {
@Override
public String handle(Jedis jedis) {
return jedis.get(key);
}
});
return value;
}RedisTemplate封装了从JedisPool中取jedis以及返回池中
public class RedisTemplate { private JedisPool jedisPool; public RedisTemplate(JedisPool jedisPool) {
this.jedisPool = jedisPool;
} public <T> T execute(RedisCallback<T> callback) {
Jedis jedis = jedisPool.getResource();
try {
return callback.handle(jedis);
}
catch (Exception e) {
// throw your exception
throw e;
}
finally {
returnResource(jedis);
}
} private void returnResource(Jedis jedis) {
if (jedis != null) {
jedis.close();
}
}
}
public interface RedisCallback<T> {
public T handle(Jedis jedis);
}
- 常用的jedis方法
字符串
@Test
public void testString() {
jedis.set("name", "webb"); // 添加数据
System.out.println("name -> " + jedis.get("name")); jedis.append("name", " , javaer"); // 拼接
System.out.println("name -> " + jedis.get("name")); jedis.del("name"); // 删除数据
System.out.println("name -> " + jedis.get("name")); jedis.mset("name", "webb", "age", "24"); // 设置多个键值对
jedis.incr("age"); // 进行加1操作 System.out.println("name -> " + jedis.get("name") + ", age -> " + jedis.get("age"));
}
列表
@Test
public void testList() {
String key = "java framework"; jedis.lpush(key, "spring");
jedis.lpush(key, "spring mvc");
jedis.lpush(key, "mybatis"); System.out.println(jedis.lrange(key, 0 , -1)); // -1表示取得所有 jedis.del(key);
jedis.rpush(key, "spring");
jedis.rpush(key, "spring mvc");
jedis.rpush(key, "mybatis"); System.out.println(jedis.lrange(key, 0 , -1)); // -1表示取得所有 System.out.println(jedis.llen(key)); // 列表长度
System.out.println(jedis.lrange(key, 0, 3));
jedis.lset(key, 0 , "redis"); // 修改列表中单个值
System.out.println(jedis.lindex(key, 1)); // 获取列表指定下标的值
System.out.println(jedis.lpop(key)); // 列表出栈
System.out.println(jedis.lrange(key, 0 , -1)); // -1表示取得所有
}
散列
@Test
public void testMap() {
String key = "user"; Map<String, String> map = new HashMap<>();
map.put("name", "webb");
map.put("age", "24");
map.put("city", "hangzhou"); jedis.hmset(key, map); // 添加数据 List<String> rsmap = jedis.hmget(key, "name", "age", "city"); // 第一个参数存入的是redis中map对象的key,后面跟的是放入map中的对象的key
System.out.println(rsmap); jedis.hdel(key, "age"); // 删除map中的某个键值 System.out.println(jedis.hmget(key, "age"));
System.out.println(jedis.hlen(key)); // 返回key为user的键中存放的值的个数
System.out.println(jedis.exists(key)); // 是否存在key为user的记录
System.out.println(jedis.hkeys(key)); // 返回map对象中的所有key
System.out.println(jedis.hvals(key)); // 返回map对象中所有的value Iterator<String> iterator = jedis.hkeys("user").iterator(); while (iterator.hasNext()) {
String key2 = iterator.next();
System.out.print(key2 + " : " + jedis.hmget("user", key2) + "\n");
}
}
集合
@Test
public void testSet() {
String key = "userSet";
String key2 = "userSet2"; jedis.sadd(key, "webb");
jedis.sadd(key, "webb");
jedis.sadd(key, "lebo");
jedis.sadd(key, "lebo0425");
jedis.sadd(key, "who"); jedis.srem(key, "who"); // 删除 System.out.println(jedis.smembers(key)); // 获取所有加入的value
System.out.println(jedis.sismember(key, "who")); // 判断value是否在集合中
System.out.println(jedis.srandmember(key)); // 随机返回一个value
System.out.println(jedis.scard(key)); // 返回集合的元素个数 jedis.sadd(key2, "webb");
jedis.sadd(key2, "ssq"); System.out.println(jedis.sinter(key, key2)); // 交集
System.out.println(jedis.sunion(key, key2)); // 并集
System.out.println(jedis.sdiff(key, key2)); // 差集
}
有序集合
@Test
public void testSortedSet() {
String key = "sortedSet"; jedis.zadd(key, 1999, "one");
jedis.zadd(key, 1994, "two");
jedis.zadd(key, 1998, "three");
jedis.zadd(key, 2000, "four");
jedis.zadd(key, 2017, "five"); Set<String> setValues = jedis.zrange(key, 0 , -1); // score从小到大
System.out.println(setValues);
Set<String> setValues2 = jedis.zrevrange(key, 0, -1); // score从大到小
System.out.println(setValues2); System.out.println(jedis.zcard(key)); // 元素个数
System.out.println(jedis.zscore(key, "three")); // 元素下标
System.out.println(jedis.zrange(key, 0, -1)); // 集合子集
System.out.println(jedis.zrem(key, "five")); // 删除元素
System.out.println(jedis.zcount(key, 1000, 2000)); // score在1000-2000内的元素个数
}
参考文章:
1.https://my.oschina.net/u/866190/blog/389543
2.http://blog.csdn.net/edagarli/article/details/21887111
Jedis连接池使用的更多相关文章
- Java与redis交互、Jedis连接池JedisPool
Java与redis交互比较常用的是Jedis. 先导入jar包: commons-pool2-2.3.jar jedis-2.7.0.jar 基本使用: public class RedisTest ...
- Jedis连接池
jedis是官方首选的java客户端开发包 Redis不仅是使用命令来操作,现在基本上主流的语言都有客户端支持,比如java.C.C#.C++.php.Node.js.Go等. 在官方网站里列一些Ja ...
- 详解Jedis连接池报错处理
在使用Jedis连接池模式下,比较常见的报错如下: redis.clients.jedis.exceptions.JedisConnectionException:Could not get a re ...
- 为什么要用Jedis连接池+浅谈jedis连接池使用
为什么要使用Jedis连接池 Redis作为缓存数据库理论上和MySQL一样需要客户端和服务端建立起来连接进行相关操作,使用MySQL的时候相信大家都会使用一款开源的连接池,例如C3P0.因为直连会消 ...
- Jedis与Jedis连接池
1.Jedis简介 实际开发中,我们需要用Redis的连接工具连接Redis然后操作Redis, 对于主流语言,Redis都提供了对应的客户端: https://redis.io/clients 2. ...
- 三、redis学习(jedis连接池)
一.jedis连接池 二.jedis连接池+config配置文件 三.jedis连接池+config配置文件+util工具类 util类 public class JedisPoolUtils { / ...
- Java Redis系列3(Jedis的使用+jedis连接池技术)
Jedis的使用 什么是Jedis? 一款Java操作redis数据库的工具 使用步骤 1.下载redis所需的java包 2.使用步骤 import org.junit.Test; public c ...
- Jedis 连接池的基本使用
jedis直连 每次操作都会创建一个jedis对象,执行完毕后关闭连接后释放,对应的就是一次Tcp连接. jedis连接池 预先生成一批jedis连接对象放入连接池中,当需要对redis进行操作时从连 ...
- jedis连接池详解(Redis)
转自:http://tianxingzhe.blog.51cto.com/3390077/1684306 原子性(atomicity): 一个事务是一个不可分割的最小工作单位,事务中包括的诸操作要么都 ...
随机推荐
- 效率神器 Workflow 实例分享
WorkflowShare Workflow实例分享,Github链接:WorkflowShare logo.jpg 苹果公司收购 Workflow 并将其完全免费,作为一款效率类 APP,Workf ...
- 什么是https
我们都知道HTTPS能够加密信息,以免敏感信息被第三方获取.所以很多银行网站或电子邮箱等等安全级别较高的服务都会采用HTTPS协议. HTTPS简介 HTTPS其实是有两部分组成:HTTP + SSL ...
- 用js实现图片的无缝滚动效果
实现图片的无缝滚动就是要让你的图片集在一定时间里自动切换,那就需要js里的定时器来控制时间. js中关于定时器的方法有两种:setTimeout和setInterval.它们接收的参数是一样的,第一个 ...
- 自己开发图表插件,脱离echart
前言 由于公司业务需要做一些图标来展示一些数据,之前都是用百度的echart.js.这次放弃使用它转而自己开发是有几个原因1.echart文件太大,有些功能用不到2.echart样式不易扩展3.需求简 ...
- 浅谈对java中传参问题的理解
之前用的c/c++比较多,在c/c++中对于传参类型,无外乎就是传值.传引用.传指针这几种.但在java中,由于没有指针类型,其传参的方式也发生了相应的变化.在网上找了找,按我之前的理解,java中传 ...
- input 点击链接事件
- 老李分享:Uber究竟是用什么开发语言? 1
老李分享:Uber究竟是用什么开发语言? poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:9 ...
- 转接口IC GM7122:BT656转CVBS芯片 视频编码电路
1 概述 视频编码电路主要实现接收8位CCIR656格式的YUV数据,(例如MPEG解码数据),并编码成CVBS信号,经过D/A转换后输出.基本的编码功能包括副载波产生,色差信号调制,同步信号内 ...
- 极化SAR图像基础知识(1)
从今天开始学习极化SAR图像,记录于此. 极化散射矩阵S是用来表示单个像素散射特性的一种简便办法,它包含了目标的全部极化信息.
- [Python]再学 socket 之非阻塞 Server
再学 socket 之非阻塞 Server 本文是基于 python2.7 实现,运行于 Mac 系统下 本篇文章是上一篇初探 socket 的续集, 上一篇文章介绍了:如何建立起一个基本的 sock ...