提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
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 //不执行同步,这个时候操作系统自己同步数据,速度是最快的
总结
一只勤奋的菜鸡