redis在java中的使⽤,基本存取操作(RedisTemplate)
redis
REmote DIctionary Server(Redis) 是⼀个由 Salvatore Sanfilippo 写的 key-value 存储系统,是跨平台的⾮关系型数据库。
Redis 是⼀个开源的使⽤ ANSI C 语⾔编写、遵守 BSD 协议、⽀持⽹络、可基于内存、分布式、可选持久性的键值对(Key-Value)存储数据库,并提供多种语⾔的 API。
Redis 通常被称为数据结构服务器,因为值(value)可以是字符串(String)、哈希(Hash)、列表(list)、集合(sets)和有序集合(sorted sets)等类型。
RedisTemplate
spring 封装了 RedisTemplate 对象来进⾏对redis的各种操作,它⽀持所有的 redis 原⽣的 api。StringRedisTemplate与RedisTemplate
两者的关系是StringRedisTemplate继承RedisTemplate。
redis五种数据结构两者的数据是不共通的;也就是说StringRedisTemplate只能管理StringRedisTemplate⾥⾯的数据,RedisTemplate只能管理RedisTemplate中的数据。
SDR默认采⽤的序列化策略有两种,⼀种是String的序列化策略,⼀种是JDK的序列化策略。
StringRedisTemplate默认采⽤的是String的序列化策略,保存的key和value都是采⽤此策略序列化保存的。
RedisTemplate默认采⽤的是JDK的序列化策略,保存的key和value都是采⽤此策略序列化保存的。
set void set(K key, V value);
使⽤:redisTemplate.opsForValue().set("name","tom");
结果:redisTemplate.opsForValue().get("name")输出结果为tom
set void set(K key, V value, long timeout, TimeUnit unit);
使⽤:redisTemplate.opsForValue().set("name","tom",10,TimeUnit.SECONDS);
结果:redisTemplate.opsForValue().get("name")由于设置的是10秒失效,⼗秒之内查询有结果,⼗秒
之后返回为null
这⾥只讨论对string数据的使⽤,附上⼀个⼩demo
⾸先需要导⼊相关的依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
序列化,序列化是为了⽅便数据传输
这⾥提供两种序列化封装操作:
第⼀种
@Service
public class TokenServiceTask {
public static final String ONLINE_OPERRATOR ="";
/**
* redis序列化存储
*
* @param redisTemplate
*/
@SuppressWarnings({"rawtypes","unchecked"})
@Autowired(required =false)
public void setRedisTemplate(RedisTemplate redisTemplate){
RedisSerializer stringSerializer =new StringRedisSerializer();
redisTemplate.setKeySerializer(stringSerializer);
redisTemplate.setValueSerializer(stringSerializer);
redisTemplate.setHashKeySerializer(stringSerializer);
redisTemplate.setHashValueSerializer(stringSerializer);
}
@Resource
private RedisTemplate<String, String> redisTemplate;
public void setToken(String key, String token){
ValueOperations<String, String> value = redisTemplate.opsForValue();
value.set(ONLINE_OPERRATOR + key, token);
}
public void setTokenWithTime(String key, String token,long number, TimeUnit timeUnit){        ValueOperations<String, String> value = redisTemplate.opsForValue();
value.set(ONLINE_OPERRATOR + key, token, number, timeUnit);
}
public void freshTime(String key){
}
public String getToken(String key){
return redisTemplate.boundValueOps(key).get();
}
}
第⼆种
@Configuration
@EnableCaching//启⽤缓存,这个注解很重要;
public class RedisCacheConfig extends CachingConfigurerSupport {
/**
* 缓存管理器.
* @param redisTemplate
* @return
*/
@Bean
public CacheManager cacheManager(RedisTemplate<?,?> redisTemplate){
CacheManager cacheManager =new RedisCacheManager(redisTemplate);
return cacheManager;
}
/**
* redis模板操作类,类似于jdbcTemplate的⼀个类;
*
* 虽然CacheManager也能获取到Cache对象,但是操作起来没有那么灵活;
*
* 这⾥在扩展下:RedisTemplate这个类不见得很好操作,我们可以在进⾏扩展⼀个我们
*
* ⾃⼰的缓存类,⽐如:RedisStorage类;
*
* @param factory : 通过Spring进⾏注⼊,参数在application.properties进⾏配置;
* @return
*/
@Bean
public RedisTemplate<String, String>redisTemplate(RedisConnectionFactory factory){
RedisTemplate<String,String> redisTemplate =new RedisTemplate<String, String>();
redisTemplate.setConnectionFactory(factory);
//key序列化⽅式;(不然会出现乱码;),但是如果⽅法上有Long等⾮String类型的话,会报类型转换错误;
//所以在没有⾃⼰定义key⽣成策略的时候,以下这个代码建议不要这么写,可以不配置或者⾃⼰实现ObjectRedisSerializer //或者JdkSerializationRedisSerializer序列化⽅式;
RedisSerializer<String> redisSerializer =new StringRedisSerializer();//Long类型不可以会出现异常信息;
redisTemplate.setKeySerializer(redisSerializer);
redisTemplate.setHashKeySerializer(redisSerializer);
return redisTemplate;
}
}
接下来上操作
public void test01(){
redisTemplate.opsForValue().set("chenlianghongtest","chenlianghong",30, TimeUnit.SECONDS);        String test = redisTemplate.opsForValue().get("chenlianghongtest");
System.out.println(test);
logger.info("⽜啊⽜啊");
}

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。