Redis 客户端Jedis使用---连接池

2024-09-08 07:48

本文主要是介绍Redis 客户端Jedis使用---连接池,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Jedis 是Redis 的Java客户端,通过一段时间的使用,jedis基本实现redis的所有功能,并且jedis在客户端实现redis数据分片功能,Redis本身是没有数据分布功能。

一、下载jedis 代码

jedis 代码地址:https://github.com/xetorthio/jedis

再次感受到开源的强大。呵呵,大家有时间可以看看源码。

二、项目中如何使用Jedis使用

现在大家都喜欢用maven作为项目管理利器,那我只说明一下Maven如何使用jedis,只需要添加以下依赖就可以。

<dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>2.1.0</version></dependency>

OK, 用maven管理jar包依赖真的很方便。建议大家都采用maven管理项目。

三、建立一个简单的连接

 

public class JedisUtil {public static Jedis createJedis() {Jedis jedis = new Jedis("127.0.0.1");return jedis;}public static Jedis createJedis(String host, int port) {Jedis jedis = new Jedis(host, port);return jedis;}public static Jedis createJedis(String host, int port, String passwrod) {Jedis jedis = new Jedis(host, port);if (!StringUtils.isNotBlank(passwrod))jedis.auth(passwrod);return jedis;}
}
 
创建一个简单Jedis对象就是这样,告诉它的IP地址和端口号就可以,如果redis有密码,那需要在建立连接时,需要调用auth方法设置密码。
当然,简单连接不适合真实的环境使用,需要有连接池支持 。
 

四、建立Jedis连接池

 

创建连接jedis 连接池,jedis 提供JedisPool对象,使用比较方便。jedis pool 是基于apache common pool 实现。

package cn.opensv.example.redis;import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;public class JedisPoolUtils {private static JedisPool pool;/**
 * 建立连接池 真实环境,一般把配置参数缺抽取出来。
 * 
 */private static void createJedisPool() {// 建立连接池配置参数JedisPoolConfig config = new JedisPoolConfig();// 设置最大连接数config.setMaxActive(100);// 设置最大阻塞时间,记住是毫秒数millisecondsconfig.setMaxWait(1000);// 设置空间连接config.setMaxIdle(10);// 创建连接池pool = new JedisPool(config, "127.0.0.1", 6379);}/**
 * 在多线程环境同步初始化
 */private static synchronized void poolInit() {if (pool == null)createJedisPool();}/**
 * 获取一个jedis 对象
 * 
 * @return
 */public static Jedis getJedis() {if (pool == null)poolInit();return pool.getResource();}/**
 * 归还一个连接
 * 
 * @param jedis
 */public static void returnRes(Jedis jedis) {pool.returnResource(jedis);}}

五、Jedis 实现分片

Jedis分片采用Hash算法和基于的Key模式匹配。Jedis定义一个Hash接口,如果觉得自带的不爽,可以自己实现一个Hash算法。Jedis自带的Hash的算法是MurmurHash 2.0 。

MurmurHash算法:高运算性能,低碰撞率,由Austin Appleby创建于2008年,现已应用到Hadoop、libstdc++、nginx、libmemcached等开源系统。2011年Appleby被Google雇佣,随后Google推出其变种的CityHash算法。

官方网站:https://sites.google.com/site/murmurhash/

MurmurHash算法,自称超级快的hash算法,是FNV的4-5倍。

 

/**
 * 创建分片对象
 * @return
 */public static ShardedJedis createShardJedis() {//建立服务器列表List<JedisShardInfo> shards = new ArrayList<JedisShardInfo>();//添加第一台服务器信息JedisShardInfo si = new JedisShardInfo("localhost", 6379);si.setPassword("123");shards.add(si);//添加第二台服务器信息si = new JedisShardInfo("localhost", 6399);si.setPassword("123");shards.add(si);//建立分片连接对象ShardedJedis jedis = new ShardedJedis(shards);        //建立分片连接对象,并指定Hash算法//ShardedJedis jedis = new ShardedJedis(shards,selfHash);return jedis;}

分片也可以支持连接池,具体如下:

private static void createPool() {List<JedisShardInfo> shards = new ArrayList<JedisShardInfo>();JedisShardInfo si = new JedisShardInfo("localhost", 6379);si.setPassword("123");shards.add(si);si = new JedisShardInfo("localhost", 6399);si.setPassword("123");shards.add(si);pool = new ShardedJedisPool(new JedisPoolConfig(), shards);}

其它与普通的连接池没有区别。

除Jedis是redis的Java客户端实现,还有其他的一些开源库,如:Spring Redis Data ,不过功能还不够强大。


参考资料:http://blog.csdn.net/songylwq/article/details/26008327

    http://my.oschina.net/lilw/blog/169635





这篇关于Redis 客户端Jedis使用---连接池的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147530

相关文章

springboot security使用jwt认证方式

《springbootsecurity使用jwt认证方式》:本文主要介绍springbootsecurity使用jwt认证方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录前言代码示例依赖定义mapper定义用户信息的实体beansecurity相关的类提供登录接口测试提供一

go中空接口的具体使用

《go中空接口的具体使用》空接口是一种特殊的接口类型,它不包含任何方法,本文主要介绍了go中空接口的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录接口-空接口1. 什么是空接口?2. 如何使用空接口?第一,第二,第三,3. 空接口几个要注意的坑坑1:坑2:坑3:接口-空接口1. 什么是空接

springboot security快速使用示例详解

《springbootsecurity快速使用示例详解》:本文主要介绍springbootsecurity快速使用示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录创www.chinasem.cn建spring boot项目生成脚手架配置依赖接口示例代码项目结构启用s

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

Spring Boot3虚拟线程的使用步骤详解

《SpringBoot3虚拟线程的使用步骤详解》虚拟线程是Java19中引入的一个新特性,旨在通过简化线程管理来提升应用程序的并发性能,:本文主要介绍SpringBoot3虚拟线程的使用步骤,... 目录问题根源分析解决方案验证验证实验实验1:未启用keep-alive实验2:启用keep-alive扩展建

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

GORM中Model和Table的区别及使用

《GORM中Model和Table的区别及使用》Model和Table是两种与数据库表交互的核心方法,但它们的用途和行为存在著差异,本文主要介绍了GORM中Model和Table的区别及使用,具有一... 目录1. Model 的作用与特点1.1 核心用途1.2 行为特点1.3 示例China编程代码2. Tab

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S