springboot-redis

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


序列化配置

安装redis

代码如下(示例):

#安装gcc环境,选择都选 y
yum install gcc-c++
#解压
tar zxvf redis-4.0.14.tar.gz
#安装
cd edis-4.0.14
make && make install

自定义RedisTemplate

代码如下(示例):

package com.config;

import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.jsontype.impl.LaissezFaireSubTypeValidator;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;

import java.net.UnknownHostException;

@Configuration
public class MyRedisConfig {

    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory)
            throws UnknownHostException {
        RedisTemplate<String, Object> template = new RedisTemplate<>();
        template.setConnectionFactory(redisConnectionFactory);

        //string序列化配置
        StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
        //key采用string的序列化方式
        template.setKeySerializer(stringRedisSerializer);
        //hash-key也采用string的序列化方式
        template.setHashKeySerializer(stringRedisSerializer);
        //value采用jackson序列化方式
        template.setValueSerializer(serializer());
        //hash-value也采用jackson序列化方式
        template.setHashValueSerializer(serializer());
        template.afterPropertiesSet();

        return template;
    }

    private Jackson2JsonRedisSerializer<Object> serializer() {
        // 使用Jackson2JsonRedisSerializer来序列化和反序列化redis的value值
        Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<>(Object.class);
        ObjectMapper objectMapper = new ObjectMapper();
        // 指定要序列化的域,field,get和set,以及修饰符范围,ANY是都有包括private和public
        objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        //objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        // 指定序列化输入的类型,类必须是非final修饰的,final修饰的类,比如String,Integer等会跑出异常
        objectMapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
        return jackson2JsonRedisSerializer;
    }
}

Linux-redis(一些简单的配置说明)

//默认为127.0.0.1  可以改成*  也可以改成0.0.0.0允许所有访问
bind 127.0.0.1
//保护模式
protected-mode yes
//端口号
port 6379
//默认为no,改为yes(后台运行)
daemonize yes
//如果以后台方式运行,我们需要一个pid文件
pidfile /var/run/redis_6379.pid
//日志,此处为生产环境
loglevel notice
//日志的文件位置名
logfile ""
//数据库的数量,默认是16个
databases 16
//是否总是显示logo
always-show-logo yes

//rdb配置
//redis是内存数据库,没有持久化,那么数据断电即失
//如果900内,如果至少有1个key进行了修改我们就进行持久化操作
save 900 1
//如果300内,如果至少有10个key进行了修改我们就进行持久化操作
save 300 10
//如果60内,如果至少有10000个key进行了修改我们就进行持久化操作
save 60 10000
//持久化错误之后,是否继续进行工作
stop-writes-on-bgsave-error yes
//是否压缩rdb文件,需要消耗一些cpu资源
rdbcompression yes
//保存rdb文件时,是否检查校验
rdbchecksum yes
//持久化生成的目录,默认就是当前目录下
dir ./

//aof配置
//默认不开启,在大部分所有的情况下,rdb基本就够用了
appendonly no
//持久化的文件名字
appendfilename "appendonly.aof"
# appendfsync always    //每次修改都会同步
appendfsync everysec    //每秒执行一次,可能会丢失这1s的数据
# appendfsync no        //不执行同步,这个时候操作系统自己同步数据,速度是最快的

总结

一只勤奋的菜鸡

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值