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。

两者的数据是不共通的;也就是说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);
        this.redisTemplate = redisTemplate;
    }

    @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) {
        redisTemplate.expire(key, 1800, TimeUnit.SECONDS);
    }

    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("牛啊牛啊");
    }

对redis操作别的结构数据有了解可以参考这篇文章

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值