- pom文件引入redis客户端,springboot对jedis和lettuce进行了封装。springboot2.x以前的版本默认使用jedis,2.x以后的版本默认使用lettuce。
// pom文件
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
- redis配置
# Redis配置
# 连接URL
spring.redis.host=192.168.216.128
# 端口号
spring.redis.port=6379
# 以毫秒为单位的连接超时。
spring.redis.timeout=1000
# Redis默认情况下有16个分片,这里配置具体使用的分片,默认是0
spring.redis.database=0
# 池在给定时间可以分配的最大连接数。使用负值无限制。
spring.redis.pool.max-active=40
# 池中“空闲”连接的最大数量。使用负值表示无限数量的空闲连接。
spring.redis.pool.max-idle=20
# 连接分配在池被耗尽时抛出异常之前应该阻塞的最长时间量(以毫秒为单位)。使用负值可以无限期地阻止。
spring.redis.pool.max-wait=1000
# 目标为保持在池中的最小空闲连接数。这个设置只有在正面的情况下才有效果。
spring.redis.pool.min-idle=10
- redis配置类
package com.honeybee.common.configure;
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
import org.springframework.boot.autoconfigure.data.redis.RedisAutoConfiguration;
import org.springframework.cache.annotation.CachingConfigurerSupport;
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;
/**
* redis配置类
* @author HXY
*/
@Configuration
@AutoConfigureAfter(RedisAutoConfiguration.class) //redis自动配置
public class RedisConfigure extends CachingConfigurerSupport {
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory factory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
// 配置连接工厂
redisTemplate.setConnectionFactory(factory);
// key的序列化类型
redisTemplate.setKeySerializer(new StringRedisSerializer());
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper objectMapper = new ObjectMapper();
// PropertyAccessor.ALL指定要序列化的域,field,get和set
// JsonAutoDetect.Visibility.ANY表示修饰符范围,ANY是包括private和public
objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
/**
* 序列化策略:
* 1. 默认使用JdkSerializationRedisSerializer序列化,存储的是字节数组,无法阅读,但空间小
* 2. StringRedisSerializer:Key或者value为字符串的场景,对:new String(bytes, charset)和string.getBytes(charset)进行封装。轻量级和高效的策略。
* 3. JacksonJsonRedisSerializer:将java对象序列化成json格式存储在redis中,也可以将json格式的数据转换成java对象。
* 4. jackson2JsonRedisSerializer: 和JacksonJsonRedisSerializer差不多
* 5. OxmSerializer:提供了将javabean与xml之间的转换能力
*
*/
redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
return redisTemplate;
}
}
- redis工具类,这里封装了对key和Sring类型的操作。后续补充。
package com.honeybee.utils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.TimeUnit;
/**
* redis工具类
* @author HXY
* @version 1.0
*/
@Component
public class RedisUtil {
@Autowired
private RedisTemplate redisTemplate;
// 默认过期时间 单位:秒
public static final long DEFAULT_EXPIRE_TIME = 24 * 60 * 60;
/**************************key的操作**************************/
/**
* del
* @param key
*/
public void delete(String key) {
redisTemplate.delete(key);
}
/**
* del
* @param keys key集合
*/
public void delete(Collection<String> keys) {
redisTemplate.delete(keys);
}
/**
* exists
* @param key key
* @return 判断结果
*/
public boolean exists(String key) {
return redisTemplate.hasKey(key);
}
/**
* expire
* @param key key
* @param timeout 过期时间
* @param unit 时间粒度
* @return 结果
*/
public boolean expire(String key, long timeout, TimeUnit unit) {
return redisTemplate.expire(key, timeout, unit);
}
/**
* ttl
* @param key key
* @return 结果
*/
public Long ttl(String key) {
return redisTemplate.getExpire(key);
}
/**
* persist
* @param key
* @return 结果
*/
public boolean persist(String key) {
return redisTemplate.persist(key);
}
/**
* keys
* @param pattern
* @return values
*/
public Set<String> keys(String pattern) {
return redisTemplate.keys(pattern);
}
/**************************String的操作**************************/
/**
* set
* @param key
* @param value
*/
public void set(String key, Object value) {
redisTemplate.opsForValue().set(key, value);
}
/**
* get
* @param key key
* @return value
*/
public Object get(String key) {
return redisTemplate.opsForValue().get(key);
}
/**
* mGet
* @param keys keys
* @return values
*/
public List<String> mGet(Collection<String> keys) {
return redisTemplate.opsForValue().multiGet(keys);
}
/**
* getRange
* @param key key
* @param start 起始偏移量
* @param end 结束偏移量
* @return value
*/
public String getRange(String key, long start, long end) {
return redisTemplate.opsForValue().get(key, start, end);
}
/**
* strLen
* @param key key
* @return 长度
*/
public Long strLen(String key) {
return redisTemplate.opsForValue().size(key);
}
/**
* incrby
* @param key key
* @param increment 增长量
* @return 增长后的value
*/
public Long incrBy(String key, long increment) {
return redisTemplate.opsForValue().increment(key, increment);
}
/**
* append
* @param key
* @param value
* @return
*/
public Integer append(String key, String value) {
return redisTemplate.opsForValue().append(key, value);
}
/**************************Hash的操作**************************/
/**
* hSet
* @param key key
* @param field field
*/
public void hSet(String key, Object field, Object value) {
redisTemplate.opsForHash().put(key, field, value);
}
/**
* hmSet
* @param key key
* @param field field-value
*/
public void hmSet(String key, Map<String, String> field) {
redisTemplate.opsForHash().putAll(key, field);
}
/**
* hGet
* @param key key
* @param field field
* @return value
*/
public Object hGet(String key, String field) {
return redisTemplate.opsForHash().get(key, field);
}
/**
* hGetAll
* @param key key
* @param fields fields
* @return values
*/
public List<Object> hGetAll(String key, Collection<Object> fields) {
return redisTemplate.opsForHash().multiGet(key, fields);
}
/**
* hDel
* @param key key
*/
public void hDel(String key, Object... fields) {
redisTemplate.opsForHash().delete(key, fields);
}
/**
* hKeys
* @param key
* @return fields
*/
public Set<Object> hKeys(String key) {
return redisTemplate.opsForHash().keys(key);
}
/**
* hVals
* @param key key
* @return values
*/
public List<Object> hVals(String key) {
return redisTemplate.opsForHash().values(key);
}
/**
* hExists
* @param key key
* @param field field
* @return 结果
*/
public boolean hExists(String key, Object field) {
return redisTemplate.opsForHash().hasKey(key, field);
}
/**
* hLen
* @param key key
* @return length
*/
public Long hLen(String key) {
return redisTemplate.opsForHash().size(key);
}
}
文章有部分参考自网上博客和代码。这里的代码全部托管在github:(https://github.com/HXY-0227/honeybee),测试可行,欢迎批评指正。