现在的程序当中,由于对性能的要求越来越高,传统的数据库已经不能够应对需求,所以出现了nosql,其中的redis就是其中比较优秀的一个。以下为redis的优势:
(1) 速度快,因为数据存在内存中,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)
(2) 支持丰富数据类型,支持string,list,set,sorted set,hash
(3) 支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行
(4) 丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除
由于redis各种优势,可能会作为大部分java程序员nosql的首选,那么,我们使用想在程序当中使用redis,首先需要进行配置。
我们如何在spring boot 程序当中对redis进行配置?(假设已经安装好了redis)
第一步:maven引入相应的jar包
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
第二步:我们在application.properties文件当中,添加redis的访问配置
# REDIS (RedisProperties)
# Redis数据库索引(默认为0)
spring.redis.database=0
# Redis服务器地址
spring.redis.host=127.0.0.1
# Redis服务器连接端口
spring.redis.port=6379
# Redis服务器连接密码(默认为空)
#spring.redis.password=
# 连接池最大连接数(使用负值表示没有限制)
spring.redis.poolMaxActive=20
# 连接池最大阻塞等待时间(使用负值表示没有限制)
spring.redis.poolMaxWait=-1
# 连接池中的最大空闲连接
spring.redis.poolMaxIdle=8
# 连接池中的最小空闲连接
spring.redis.poolMinIdle=0
# 连接超时时间(毫秒)
spring.redis.timeout=5000
第三步:在config这个包里面,增加RedisConfig.java这个类。
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Scope;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
@Configuration
public class RedisConfig {
private final Logger logger = LoggerFactory.getLogger(this.getClass());
//Logger logger = LoggerFactory.getLogger(RedisConfig.class);
@Value("${spring.redis.host}")
private String host;
@Value("${spring.redis.port}")
private int port;
@Value("${spring.redis.timeout}")
private int timeout;
@Value("${spring.redis.poolMaxIdle}")
private int maxIdle;
@Value("${spring.redis.poolMaxWait}")
private long maxWaitMillis;
/*@Value("${spring.redis.password}")
private String password;*/
@Bean
@Scope("singleton")
public JedisPool redisPoolFactory() {
System.out.println("jedispool");
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
jedisPoolConfig.setMaxIdle(maxIdle);
jedisPoolConfig.setMaxWaitMillis(maxWaitMillis);
JedisPool jedisPool = new JedisPool(jedisPoolConfig, host, port, timeout, null);
logger.info("host:"+host);
logger.info("port:"+port);
logger.info("timeout:"+timeout);
return jedisPool;
}
}
第四步:在程序里面去使用JedisPool,首先注入jedisPool
第五步:通过jedisPool.getResource()这个方法从连接池里面获取一个连接,然后取得连接之后就可以进行各种操作了。