简单示例:Spring4 整合 单个Redis服务
1. 引入spring-data-redis.jar
2. spring配置文件添加如下配置
<!-- redis配置 -->
<context:property-placeholder location="classpath:redis.properties" />
<bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxIdle" value="${redis.maxIdle}" />
<property name="maxTotal" value="${redis.maxTotal}" />
<!--<property name="maxWaitMillis" value="${redis.maxWaitMillis}" />-->
<property name="testOnBorrow" value="${redis.testOnBorrow}" />
<!--<property name="testOnReturn" value="${redis.testOnReturn}" />-->
<!--<property name="blockWhenExhausted" value="${redis.blockWhenExhausted}" />-->
</bean> <!--<bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"-->
<!--p:hostName="${redis.host}" p:port="${redis.port}" p:password="${redis.pass}" p:poolConfig-ref="poolConfig"/>-->
<bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
p:hostName="${redis.host}" p:port="${redis.port}" p:poolConfig-ref="poolConfig"/> <!-- SDR默认采用的序列化策略有两种,一种是String的序列化策略,一种是JDK的序列化策略。 StringRedisTemplate默认采用的是String的序列化策略,保存的key和value都是采
用此策略序列化保存的。 RedisTemplate默认采用的是JDK的序列化策略,保存的key和value都是采用此策略序列化保存的。 就是因为序列化策略的不同,即使是同一个key用不同的
Template去序列化,结果是不同的。所以根据key去删除数据的时候就出现了删除失败的问题。 --> <!-- redis 序列化策略 ,通常情况下key值采用String序列化策略, --> <!-- 如果不指定序列化策略,StringRedisTemplate的key和value都将采用String序列化策略; -->
<!-- 但是RedisTemplate的key和value都将采用JDK序列化 这样就会出现采用不同template保存的数据不能用同一个template删除的问题 -->
<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
<property name="connectionFactory" ref="connectionFactory" />
<property name="keySerializer">
<bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
</property>
<property name="valueSerializer">
<bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer" />
</property>
<property name="enableTransactionSupport" value="true" />
</bean>
# Redis settings #redis的服务器地址
redis.host=localhost
#redis的服务端口
redis.port=6379
#密码
redis.pass=123 #最大空闲数
redis.maxIdle=300
#最大总数
redis.maxTotal=1000
#指明是否在从池中取出连接前进行检验,如果检验失败,则从池中去除连接并尝试取出另一个
redis.testOnBorrow=true
3. Redis工具类
package com.*; import org.apache.log4j.Logger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.*;
import org.springframework.stereotype.Component; import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.concurrent.TimeUnit; /**
* Created by Administrator on 2017/3/8.
*/
@Component
public class RedisManager<T> {
private Logger log = Logger.getLogger(RedisManager.class); @Autowired
private RedisTemplate redisTemplate; /** =================================== Hash ====================================================**/ /**
* 缓存Map
*
* @param key
* @param hashKey
* @param t
* @return
*/
public void setCacheMap(String key, String hashKey, T t) {
BoundHashOperations boundHashOperations = redisTemplate.boundHashOps(key);
boundHashOperations.put(hashKey, t);
// boundHashOperations.expire(BasConstant.MEMORY_TOKEN_EXPIRES, TimeUnit.DAYS);
// redisTemplate.opsForValue().set(realToken, studentVo, BasConstant.TOKEN_EXPIRES_HOUR, TimeUnit.DAYS);
//存储到redis并设置过期时间
// redisTemplate.boundValueOps(realToken).set(studentVo, BasConstant.TOKEN_EXPIRES_HOUR, TimeUnit.DAYS);
} /**
* 获得缓存的Map
*
* @param key //* @param hashOperation
* @return
*/
public <T> Map<String, T> getCacheMap(String key/*,HashOperations<String,String,T> hashOperation*/) {
Map<String, T> map = redisTemplate.opsForHash().entries(key);
/*Map<String, T> map = hashOperation.entries(key);*/
return map;
} /**
* 获取缓存的map大小
*
* @param key
* @return
*/
public long getCacheMapSize(String key) {
return redisTemplate.opsForHash().size(key);
} /**
* 获取map的value值
*
* @param key key
* @param hashKey field
* @return
*/
public Object getMapValue(String key, String hashKey) {
return redisTemplate.opsForHash().get(key, hashKey);
} /**
* 是否存在 key 及 field
*
* @param key key
* @param hashKey field
* @return
*/
public boolean hasHashKey(String key, String hashKey) {
return redisTemplate.opsForHash().hasKey(key, hashKey);
} /**
* 延期
*
* @param key
* @return
*/
public boolean expireHash(String key, long time) {
return redisTemplate.boundHashOps(key).expire(time, TimeUnit.DAYS);
} /**
* 从redis中删除key缓存
*
* @param key
*/
public void deleteHashKey(String key, Object... hashKeys) {
redisTemplate.opsForHash().delete(key, hashKeys);
} /** =================================== 通用 ====================================================**/ /**
* 从redis中删除key缓存
*
* @param key
*/
public void deleteKey(String key, Object... hashKeys) {
redisTemplate.delete(key);
} /**
* 是否存在key
*
* @param key
* @return 是否存在key
*/
public boolean hasKey(String key) {
return redisTemplate.hasKey(key);
} /**
* 延期
*
* @param key 键值
* @return
*/
public boolean expire(String key, long time, TimeUnit timeUnit) {
return redisTemplate.expire(key, time, timeUnit);
} /** =================================== List ====================================================**/ /**
* list缓存
*
* @param key
* @param value
* @return
*/
public boolean setCacheList(String key, String value) {
try {
ListOperations<String, String> listOps = redisTemplate.opsForList();
listOps.rightPush(key, value);
return true;
} catch (Throwable t) {
log.error("缓存[" + key + "]失败, value[" + value + "]", t);
}
return false;
} public void setValueForList(String key, long index, Object value){
BoundListOperations listOps = redisTemplate.boundListOps(key);
listOps.set(index, value);
} /**
* 缓存list
*
* @param key 键值
* @param list value
* @return
*/
public void setCacheList(String key, List list) {
BoundListOperations listOps = redisTemplate.boundListOps(key);
//只能以数组形式存放
listOps.rightPushAll(list.toArray());
} /**
* 获取list缓存 - 根据起始~终止位置
*
* @param key 键值
* @param start 起始位置
* @param end 截止位置
* @return
*/
public List getList(String key, long start, long end) {
List list = null;
try {
BoundListOperations listOperations = redisTemplate.boundListOps(key);
list = listOperations.range(start, end);
} catch (Throwable t) {
log.error("获取list缓存失败key[" + key + ", error[" + t + "]");
}
return list;
} /**
* 获取list缓存 - 根据索引位置
*
* @param key 键值
* @param i 索引位置
* @return
*/
public Object getCacheList(String key, int i) {
BoundListOperations listOps = redisTemplate.boundListOps(key);
return listOps.index(i);
} /**
* 获取总条数, 可用于分页
*
* @param key
* @return
*/
public long getCacheListSize(String key) {
BoundListOperations listOps = redisTemplate.boundListOps(key);
return listOps.size();
}
}
4. 在service中引入使用工具类操作redis
简单示例:Spring4 整合 单个Redis服务的更多相关文章
- 【Redis】三、Redis安装及简单示例
(四)Redis安装及使用 Redis的安装比较简单,仍然和大多数的Apache开源软件一样,只需要下载,解压,配置环境变量即可.具体安装过程参考:菜鸟教程Redis安装. 安装完成后,通过r ...
- Windows下安装Redis服务
说明:本文拷贝自https://jingyan.baidu.com/article/0f5fb099045b056d8334ea97.html Redis是有名的NoSql数据库,一般Linux都会默 ...
- Redis 安装与简单示例 01_转
一.Redis的安装 Redis下载地址如下:https://github.com/dmajkic/redis/downloads 解压后根据自己机器的实际情况选择32位或者64位.下载解压后图片如下 ...
- Redis 安装与简单示例 <第一篇>
一.Redis的安装 Redis下载地址如下:https://github.com/dmajkic/redis/downloads 解压后根据自己机器的实际情况选择32位或者64位.下载解压后图片如下 ...
- Redis 安装与简单示例(转)
本文转载自:http://www.cnblogs.com/kissdodog/p/3570984.html Redis的安装 Redis下载地址如下:https://github.com/dmajki ...
- Redis 安装与简单示例
Redis 安装与简单示例 一.Redis的安装 Redis下载地址如下:https://github.com/dmajkic/redis/downloads 解压后根据自己机器的实际情况选择32位或 ...
- 基于.NET CORE微服务框架 -surging的介绍和简单示例 (开源)
一.前言 至今为止编程开发已经11个年头,从 VB6.0,ASP时代到ASP.NET再到MVC, 从中见证了.NET技术发展,从无畏无知的懵懂少年,到现在的中年大叔,从中的酸甜苦辣也只有本人自知.随着 ...
- Redis 安装与简单示例 <第一篇>【转】
一.Redis的安装 Redis下载地址如下:https://github.com/dmajkic/redis/downloads 解压后根据自己机器的实际情况选择32位或者64位.下载解压后图片如下 ...
- Java操作redis简单示例
第一:安装Redis 首先我们要安装Redis,就像我们操作数据库一样,在操作之前肯定要先创建好数据库的环境. Redis的下载可以百度一下,或者打开下面的下载链接: https:/ ...
随机推荐
- jquery.cookie.js结合asp.net实现最近浏览记录
一.html代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://ww ...
- C++ 第四课:ASCII 码表
下面的 ASCII 码表包含数值在0-127之间的字符的十进制.八进制以及十六进制表示. 十进制 八进制 十六进制 字符 描述 0 0 00 NUL 1 1 01 SOH start of hea ...
- PSQL命令小结
经常使用psql查询数据,现在总结几个常用的命令参数,供以后参考 -h 数据库地址 -U 数据库用户名 -t 不打印字段等信息 -c 执行的SQL语句 -s 单步执行,就是执行的时 ...
- PASCAL知识
API Index http://docs.embarcadero.com/products/rad_studio/delphiAndcpp2009/HelpUpdate2/EN/html/delph ...
- shell 截取变量的字符串(转)
来自:http://blog.sina.com.cn/s/blog_7c95e5850100zpch.html 假设有变量 var=http://www.linuxidc.com/test.htm 一 ...
- Android 虚拟现实(virtual reality)入门指南
入门指南 本文档介绍怎样使用实验性的 Cardboard SDK for Android 创建您自己的虚拟实境 (VR) 体验. Android 演示版应用:Treasure Hunt 本教程中的代码 ...
- Xamarin.Android之定位
一.前言 打开我们手中的应用,可以发现越来越多的应用使用了定位,从而使我们的生活更加方便,所以本章我们将学习如何在Xamarin中进行定位的开发. 二.准备工作 因为我们的虚拟机是运行在电脑本地的,自 ...
- Knockout学习之表单绑定器(上)
表单绑定器 “click”绑定 Click 绑定器可以将javascript函数绑定到指定的dom元素,并且再该元素被点击时将触发绑定的函数,大多数情况下都会使用button.input和a元素,当然 ...
- MySQL Replication主从复制环境下修改主库IP
因为调整服务器子网, 数据库服务器的IP地址需要修改. 这个过程中, 需要确保的就是从库在断开主库后, 能从正确的位置再次启动. 具体的操作步骤如下 1) 需要获取的前提信息: 主库的新IP, 这在启 ...
- 【win7 + win server 2008】设置定时任务,设置.bat 文件去执行php脚本 == 用来配合爬虫程序简直不要太爽
Windows Server 2008中使用计划任务定时执行BAT bat进行PHP脚本的执行 一.首先进行任务管理器设置 每隔1分钟执行.BAT 文件配置 首先Windows Server 200 ...