Redis缓存 ava-Jedis操作Redis,基本操作以及 实现对象保存
源代码下载: http://download.csdn.net/detail/jiangtao_st/7623113
1、Maven配置
- <dependency>
- <groupId>redis.clients</groupId>
- <artifactId>jedis</artifactId>
- <version>2.5.0</version>
- </dependency>
- <dependency>
- <groupId>com.alibaba</groupId>
- <artifactId>fastjson</artifactId>
- <version>1.1.41</version>
- </dependency></span>
2、Properties 配置文件
redis.pool.maxActive=100
redis.pool.maxIdle=20
redis.pool.maxWait=3000
redis.ip=localhost
redis.port=6379
3、代码具体实现的Client
- /**
- *
- * <p>
- * Redis客户端访问
- * </p>
- *
- * @author 卓轩
- * @创建时间:2014年7月11日
- * @version: V1.0
- */
- public class RedisClient {
- public static JedisPool jedisPool; // 池化管理jedis链接池
- static {
- //读取相关的配置
- ResourceBundle resourceBundle = ResourceBundle.getBundle("redis");
- int maxActive = Integer.parseInt(resourceBundle.getString("redis.pool.maxActive"));
- int maxIdle = Integer.parseInt(resourceBundle.getString("redis.pool.maxIdle"));
- int maxWait = Integer.parseInt(resourceBundle.getString("redis.pool.maxWait"));
- String ip = resourceBundle.getString("redis.ip");
- int port = Integer.parseInt(resourceBundle.getString("redis.port"));
- JedisPoolConfig config = new JedisPoolConfig();
- //设置最大连接数
- config.setMaxTotal(maxActive);
- //设置最大空闲数
- config.setMaxIdle(maxIdle);
- //设置超时时间
- config.setMaxWaitMillis(maxWait);
- //初始化连接池
- jedisPool = new JedisPool(config, ip, port);
- }
- /**
- * 向缓存中设置字符串内容
- * @param key key
- * @param value value
- * @return
- * @throws Exception
- */
- public static boolean set(String key,String value) throws Exception{
- Jedis jedis = null;
- try {
- jedis = jedisPool.getResource();
- jedis.set(key, value);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- jedisPool.returnResource(jedis);
- }
- }
- /**
- * 向缓存中设置对象
- * @param key
- * @param value
- * @return
- */
- public static boolean set(String key,Object value){
- Jedis jedis = null;
- try {
- String objectJson = JSON.toJSONString(value);
- jedis = jedisPool.getResource();
- jedis.set(key, objectJson);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- jedisPool.returnResource(jedis);
- }
- }
- /**
- * 删除缓存中得对象,根据key
- * @param key
- * @return
- */
- public static boolean del(String key){
- Jedis jedis = null;
- try {
- jedis = jedisPool.getResource();
- jedis.del(key);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- jedisPool.returnResource(jedis);
- }
- }
- /**
- * 根据key 获取内容
- * @param key
- * @return
- */
- public static Object get(String key){
- Jedis jedis = null;
- try {
- jedis = jedisPool.getResource();
- Object value = jedis.get(key);
- return value;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- jedisPool.returnResource(jedis);
- }
- }
- /**
- * 根据key 获取对象
- * @param key
- * @return
- */
- public static <T> T get(String key,Class<T> clazz){
- Jedis jedis = null;
- try {
- jedis = jedisPool.getResource();
- String value = jedis.get(key);
- return JSON.parseObject(value, clazz);
- } catch (Exception e) {
- e.printStackTrace();
- return null;
- }finally{
- jedisPool.returnResource(jedis);
- }
- }
- }
4、Sharding 分片管理
- /**
- *
- * <p>
- * Sharding Redis Client 工具类
- * </p>
- *
- * @author 卓轩
- * @创建时间:2014年7月11日
- * @version: V1.0
- */
- public class ShardingRedisClient {
- private static ShardedJedisPool shardedJedisPool;
- static {
- // 读取相关的配置
- ResourceBundle resourceBundle = ResourceBundle.getBundle("redis");
- int maxActive = Integer.parseInt(resourceBundle.getString("redis.pool.maxActive"));
- int maxIdle = Integer.parseInt(resourceBundle.getString("redis.pool.maxIdle"));
- int maxWait = Integer.parseInt(resourceBundle.getString("redis.pool.maxWait"));
- String ip = resourceBundle.getString("redis.ip");
- int port = Integer.parseInt(resourceBundle.getString("redis.port"));
- //设置配置
- JedisPoolConfig config = new JedisPoolConfig();
- config.setMaxTotal(maxActive);
- config.setMaxIdle(maxIdle);
- config.setMaxWaitMillis(maxWait);
- //设置分片元素信息
- JedisShardInfo shardInfo1 = new JedisShardInfo(ip,port);
- JedisShardInfo shardInfo2 = new JedisShardInfo(ip,port);
- List<JedisShardInfo> list = new ArrayList<JedisShardInfo>();
- list.add(shardInfo1);
- list.add(shardInfo2);
- shardedJedisPool = new ShardedJedisPool(config, list);
- }
- /**
- * 向缓存中设置字符串内容
- * @param key key
- * @param value value
- * @return
- * @throws Exception
- */
- public static boolean set(String key,String value) throws Exception{
- ShardedJedis jedis = null;
- try {
- jedis = shardedJedisPool.getResource();
- jedis.set(key, value);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- shardedJedisPool.returnResource(jedis);
- }
- }
- /**
- * 向缓存中设置对象
- * @param key
- * @param value
- * @return
- */
- public static boolean set(String key,Object value){
- ShardedJedis jedis = null;
- try {
- String objectJson = JSON.toJSONString(value);
- jedis = shardedJedisPool.getResource();
- jedis.set(key, objectJson);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- shardedJedisPool.returnResource(jedis);
- }
- }
- /**
- * 删除缓存中得对象,根据key
- * @param key
- * @return
- */
- public static boolean del(String key){
- ShardedJedis jedis = null;
- try {
- jedis = shardedJedisPool.getResource();
- jedis.del(key);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- shardedJedisPool.returnResource(jedis);
- }
- }
- /**
- * 根据key 获取内容
- * @param key
- * @return
- */
- public static Object get(String key){
- ShardedJedis jedis = null;
- try {
- jedis = shardedJedisPool.getResource();
- Object value = jedis.get(key);
- return value;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- shardedJedisPool.returnResource(jedis);
- }
- }
- /**
- * 根据key 获取对象
- * @param key
- * @return
- */
- public static <T> T get(String key,Class<T> clazz){
- ShardedJedis jedis = null;
- try {
- jedis = shardedJedisPool.getResource();
- String value = jedis.get(key);
- return JSON.parseObject(value, clazz);
- } catch (Exception e) {
- e.printStackTrace();
- return null;
- }finally{
- shardedJedisPool.returnResource(jedis);
- }
- }
- }
5、 单元测试、保存对象、写入对象
- /**
- *
- * <p>
- * 测试独立redis 客户端
- * </p>
- *
- * @author 卓轩
- * @创建时间:2014年7月11日
- * @version: V1.0
- */
- public class SimpleClient {
- @Test
- public void userCache(){
- //向缓存中保存对象
- UserDO zhuoxuan = new UserDO();
- zhuoxuan.setUserId(113445);
- zhuoxuan.setSex(1);
- zhuoxuan.setUname("卓轩");
- zhuoxuan.setUnick("zhuoxuan");
- zhuoxuan.setEmail("zhuoxuan@mogujie.com");
- //调用方法处理
- boolean reusltCache = RedisClient.set("zhuoxuan", zhuoxuan);
- if (reusltCache) {
- System.out.println("向缓存中保存对象成功。");
- }else{
- System.out.println("向缓存中保存对象失败。");
- }
- }
- @Test
- public void getUserInfo(){
- UserDO zhuoxuan = RedisClient.get("zhuoxuan",UserDO.class);
- if(zhuoxuan != null){
- System.out.println("从缓存中获取的对象," + zhuoxuan.getUname() + "@" + zhuoxuan.getEmail());
- }
- }
- }
Redis缓存 ava-Jedis操作Redis,基本操作以及 实现对象保存的更多相关文章
- 【Redis】使用Jedis操作Redis
Jedis介绍 jedis就是集成了redis的一些命令操作,封装了redis的java客户端. Jedis使用 使用jedis需要引入jedis的jar包,下面提供了maven依赖 jedis.ja ...
- <Redis> 入门四 Jedis操作Redis
pom依赖 <dependencies> <!-- https://mvnrepository.com/artifact/redis.clients/jedis --> < ...
- Jedis操作Redis
Jedis操作Redis的常用封装方法 @Resource(name="jedispool") private JedisPool pool=null; /** * 设置缓存对象过 ...
- jedis操作redis的几种常见方式总结
Redis是一个著名的key-value存储系统,也是nosql中的最常见的一种,这篇文章主要给大家总结了关于在java中jedis操作redis的几种常见方式,文中给出了详细的示例代码供大家参考学习 ...
- Java中Jedis操作Redis与Spring的整合
Redis是一个key-value存储系统.它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有序集合).这些数据类型都支持push/pop. ...
- Redis入门和Java利用jedis操作redis
Redis入门和Java利用jedis操作redis Redis介绍 Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库. Redis 与其他 key - val ...
- Jedis操作Redis数据库
添加Maven依赖: <dependencies> <!-- 单元测试 --> <dependency> <groupId>junit</grou ...
- 四、Jedis操作Redis
前言: 原来我们操作mysql需要用的jdbc,现在操作redis则需要jedis,jedis是客户端,而redis是服务器,使用jedis客户端来操作redis. 在这里要使用jedis操作red ...
- JAVA中通过Jedis操作Redis连接与插入简单库
一.简述 JAVA中通过Jedis操作Redis连接与插入简单库 二.依赖 <!-- https://mvnrepository.com/artifact/redis.clients/jedis ...
- 第三百节,python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型
python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型 delete(*names)根据删除redis中的任意数据类型 #!/usr/bin/env pyt ...
随机推荐
- java RuntimeException
总结了一下JAVA中常见的几种RuntimeException,大约有如下几种: NullPointerException - 空指针引用异常 ClassCastException - 类型强制转换异 ...
- ichartjs
ichartjs-基于html5的图表组件 不适合桌面端
- 陈正冲老师对于c语言野指针的解释
那到底什么是野指针呢?怎么去理解这个“野”呢?我们先看别的两个关于“野”的词: 野孩子:没人要,没人管的孩子:行为动作不守规矩,调皮捣蛋的孩子.野狗:没有主人的狗,没有链子锁着的狗,喜欢四处咬人. 对 ...
- (2015年郑州轻工业学院ACM校赛题) J 堆
判断是否是一个堆,把树构造好遍历一遍就OK了 #include<stdio.h> #include<iostream> #include<stack> #inclu ...
- Spring基础知识及bean的配置
IOC与DI: IOC(inversion of control):其思想是反转资源获取的方向.传统的资源查找方式要求组件向容器发起请求查找资源.作为回应,容器适时的返回资源.而应用了IOC之后,则是 ...
- SharePoint 2010 master page 控件介绍(5):其他
转:http://blog.csdn.net/lgm97/article/details/6409227 <!-- 处理搜索按下"enter"键和点击后退按钮 --> ...
- 我的WCF之旅(1):创建一个简单的WCF程序
为了使读者对基于WCF的编程模型有一个直观的映像,我将带领读者一步一步地创建一个完整的WCF应用.本应用功能虽然简单,但它涵盖了一个完整WCF应用的基本结构.对那些对WCF不是很了解的读者来说,这个例 ...
- Swift不可变数组
Objective-C编写了2个不同的类来区分不可变数组(NSArray)和可变数组(NSMutableArray): Swift通过使用常量和变量来区分不可变数组和可变数组. 只要将数组定义为常量, ...
- extjs分组查询
<script type="text/jscript"> var grid; Ext.onReady(function () { Ext.QuickTips.init( ...
- Base-Android快速开发框架(四)--网络操作之FastJson以及AsyncHttpClient
Android的展示数据,除了上章所讲的本地存储外,大部分数据都来自于网络.首先介绍一下Android APP开发常见的网络操作方式.从网络层面上有底层的tcp/ip,也就是我们常见的socket套接 ...