SpringBoot 中使用redis以及redisTemplate
1.首先在pom.xml中添加依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>1.5.2.RELEASE</version>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
</dependency>
2.在git上的配置文件中添加redis集群配置
spring.redis.cluster.nodes=10.10.10.236:7001,10.10.10.236:7002,10.10.10.236:7003,10.10.10.236:7004,10.10.10.236:7005,10.10.10.236:7006
spring.redis.cluster.host=10.10.10.236
spring.redis.cluster.port=7001
spring.redis.cluster.passwd=
spring.redis.cluster.timeOut=2000
spring.redis.cluster.max-redirects=8
3.在程序中读取配置文件中的值
package cn.lz.auth.redis;
import java.util.HashMap;
import java.util.Map;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.env.MapPropertySource;
import org.springframework.data.redis.connection.RedisClusterConfiguration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.data.redis.serializer.SerializationException;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;
//@Component
@EnableRedisHttpSession
@Configuration
public class RedisConfig
{
@Value("${spring.redis.cluster.nodes}")
private String clusterNodes;
@Value("${spring.redis.cluster.host}")
private String redisHost;
@Value("${spring.redis.cluster.port}")
private int redisPort;
@Value("${spring.redis.cluster.passwd}")
private String redisPasswd;
@Value("${spring.redis.cluster.timeOut}")
private int timeOut = 2000;
@Value("${spring.redis.cluster.max-redirects}")
private int redirects = 8;
@Bean
public RedisClusterConfiguration getClusterConfiguration()
{
Map<String, Object> source = new HashMap<String, Object>();
source.put("spring.redis.cluster.nodes", clusterNodes);
source.put("spring.redis.cluster.timeout", timeOut);
source.put("spring.redis.cluster.max-redirects", redirects);
return new RedisClusterConfiguration(new MapPropertySource("RedisClusterConfiguration", source));
}
@Bean
public RedisConnectionFactory redisConnectionFactory()
{
JedisConnectionFactory cf = null;
if( clusterNodes != null && !clusterNodes.isEmpty() ){
cf = new JedisConnectionFactory( getClusterConfiguration() );
}
else{
cf = new JedisConnectionFactory();
cf.setHostName( redisHost );
cf.setPort( redisPort );
cf.setPassword( redisPasswd);
cf.setTimeout( timeOut );
}
cf.afterPropertiesSet();
return cf;
}
@Bean
public RedisTemplate<String, Object> redisTemplate()
{
RedisTemplate<String, Object> rt = new RedisTemplate<String, Object>();
rt.setConnectionFactory( redisConnectionFactory() );
return rt;
}
public static enum StringSerializer implements RedisSerializer<String>
{
INSTANCE;
@Override
public byte[] serialize(String s) throws SerializationException
{
return (null != s ? s.getBytes() : new byte[0]);
}
@Override
public String deserialize(byte[] bytes) throws SerializationException
{
if (bytes.length > 0){
return new String(bytes);
}
else{
return null;
}
}
}
public static enum LongSerializer implements RedisSerializer<Long>
{
INSTANCE;
@Override
public byte[] serialize(Long aLong) throws SerializationException
{
if (null != aLong){
return aLong.toString().getBytes();
}
else{
return new byte[0];
}
}
@Override
public Long deserialize(byte[] bytes) throws SerializationException
{
if (bytes.length > 0){
return Long.parseLong(new String(bytes));
}
else{
return null;
}
}
}
public static enum IntSerializer implements RedisSerializer<Integer>
{
INSTANCE;
@Override
public byte[] serialize(Integer i) throws SerializationException
{
if (null != i){
return i.toString().getBytes();
}
else{
return new byte[0];
}
}
@Override
public Integer deserialize(byte[] bytes) throws SerializationException
{
if (bytes.length > 0){
return Integer.parseInt(new String(bytes));
}
else{
return null;
}
}
}
}
4.根据redisTemplate编写set,get,delete方法
package cn.lz.auth.redis;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.stereotype.Component;
@Component
public class RedisService<T>
{
@Autowired
private RedisTemplate<String, Object> redis;
public void setObject( String uuid, T object, Class<T> type )
{
redis.setKeySerializer( RedisConfig.StringSerializer.INSTANCE );
redis.setValueSerializer( new Jackson2JsonRedisSerializer<T>(type) );
redis.afterPropertiesSet();
ValueOperations<String, Object> ops = redis.opsForValue();
ops.set( uuid, object );
}
@SuppressWarnings("unchecked")
public T getObject( String uuid, Class<T> type )
{
redis.setKeySerializer( RedisConfig.StringSerializer.INSTANCE );
redis.setValueSerializer( new Jackson2JsonRedisSerializer<T>(type) );
redis.afterPropertiesSet();
ValueOperations<String, Object> ops = redis.opsForValue();
return (T)ops.get( uuid );
}
public void delObject( String uuid )
{
redis.setKeySerializer( RedisConfig.StringSerializer.INSTANCE );
redis.afterPropertiesSet();
redis.delete( uuid );
}
}
5.调用set,get,delete方法操作redis中的数据
好文链接:http://www.cnblogs.com/langtianya/p/5190201.html
SpringBoot 中使用redis以及redisTemplate的更多相关文章
- 由浅入深学习springboot中使用redis
很多时候,我们会在springboot中配置redis,但是就那么几个配置就配好了,没办法知道为什么,这里就详细的讲解一下 这里假设已经成功创建了一个springboot项目. redis连接工厂类 ...
- (一)由浅入深学习springboot中使用redis
很多时候,我们会在springboot中配置redis,但是就那么几个配置就配好了,没办法知道为什么,这里就详细的讲解一下 这里假设已经成功创建了一个springboot项目. redis连接工厂类 ...
- SpringBoot中使用Redis
在SpringBoot中使用Redis,思路如下: 查询时先查Redis缓存,如果缓存中存在信息,就直接从缓存中获取. 如果缓存中没有相关信息,就去数据库中查找,查完顺便将信息存放进缓存里,以便下一次 ...
- 在springboot中使用redis缓存,将缓存序列化为json格式的数据
背景 在springboot中使用redis缓存结合spring缓存注解,当缓存成功后使用gui界面查看redis中的数据 原因 springboot缓存默认的序列化是jdk提供的 Serializa ...
- SpringBoot中整合Redis、Ehcache使用配置切换 并且整合到Shiro中
在SpringBoot中Shiro缓存使用Redis.Ehcache实现的两种方式实例 SpringBoot 中配置redis作为session 缓存器. 让shiro引用 本文是建立在你是使用这sh ...
- 在SpringBoot中引入Redis
前言 之前我们只是在Spring中加入Redis用于session的存放,并没有对redis进行主动的存放,这次我们需要加入redis工具类来方便我们在实际使用过程中操作redis 已经加入我的git ...
- SpringBoot中集成redis
转载:https://www.cnblogs.com/zeng1994/p/03303c805731afc9aa9c60dbbd32a323.html 不是使用注解而是代码调用 需要在springbo ...
- 在SpringBoot中添加Redis
前言 在实际的开发中,会有这样的场景.有一个微服务需要提供一个查询的服务,但是需要查询的数据库表的数据量十分庞大,查询所需要的时间很长. 此时就可以考虑在项目中加入缓存. 引入依赖 在maven项目中 ...
- 你知道如何在springboot中使用redis吗
特别说明:本文针对的是新版 spring boot 2.1.3,其 spring data 依赖为 spring-boot-starter-data-redis,且其默认连接池为 lettuce ...
随机推荐
- python FTP服务器实现(Python3)
创建一个ftp.py文件(Linux环境),插入以下代码: from pyftpdlib.authorizers import DummyAuthorizer from pyftpdlib.handl ...
- axios常用操作
axios常用操作 一:函数化编程 1:编写可复用的方法 axios(config)的方法中,有必须的url参数和非必须的options参数.所以我们可以先写一个接受这两个参数的方法,在这个方法中我们 ...
- 浅谈jQuery构造函数
$()函数到底做的什么 jQuery在前端领域路人皆知,对于一向喜欢玩js的博主来说,虽然能力有限,但是还是很喜欢研究他的做为.那么一个简单的美元符号$与一对常见的()括号,jQuery底层到底做了哪 ...
- Oracle安装后出现的问题
安装oracle没有勾选"安装模板数据库",可以通过执行以下命令进行修改: cd $ORACLE_HOME/rdbms/admin 到这个目录下sqlplus /as sysdba ...
- 配置树莓派/Linux默认声卡设备
1.设置默认声卡为USB声卡 在$HOME下新建.asoundrc $cd $HOME $nano .asoundrc 输入以下内容 defaults.ctl.card 1 defaults.pcm. ...
- angularJS1笔记-(11)-自定义指令(transclude/priority/terminal)
自定义指令的属性 transclude:为true时,允许把html中新定义的指令中原来的dom运用到该指令的template中. 属性priority,设置该指令的优先级,优先级大的先执行,默认指令 ...
- iOS UIView性能最优的设计圆角并且绘制边框颜色
//以给cell切圆角为例- (void)collectionView:(UICollectionView *)collectionView willDisplayCell:(UICollection ...
- vue 过渡效果
Vue中提供了`<transition>`和`<transition-group>`来为元素增加过渡动画.文档写的很清楚,但是实际使用起来还是费了一番功夫.这里做一个简单的记录 ...
- 软工网络15团队作业8——Beta阶段敏捷冲刺(Day2)
提供当天站立式会议照片一张 每个人的工作 1.讨论项目每个成员的昨天进展 赵铭: 根据计划安排,继续学习数据库. 吴慧婷:做Beta阶段的计划,并为界面设计寻找素材,学习界面优化. 陈敏: 根据任务, ...
- Rsyslog日志服务搭建
rsyslog是比syslog功能更强大的日志记录系统,可以将日志输出到文件,数据库和其它程序.Centos 6.x默认的rsyslog版本是5.x. 网上关于rsyslog的安装配置文档倒是不少,但 ...