产品动态
公告
参数名 | 类型 | 默认值 | 解释 | 推荐值 |
connectTimeout | int | 2000ms | 设置连接超时时间 | 3000ms |
readTimeout | int | 2000ms | 设置命令超时时间 | 2000ms |
poolMinIdle | int | 无 | 连接池最小空闲连接数 | 50 |
poolMaxIdle | int | 无 | 连接池最大空闲连接数 | 200 |
poolMaxTotal | int | 无 | 连接池最大连接数 | 200 |
tencent.redis.host=XX.XX.XX.XXtencent.redis.port=6379tencent.redis.database=0tencent.redis.password=XXXXtencent.redis.connect.timeout=3000tencent.redis.read.timeout=2000tencent.redis.pool.minSize=50tencent.redis.pool.maxSize=200
tencent:redis:host: XX.XX.XX.XXport: 6379database: 0password: XXXXconnect:timeout: 3000read:timeout: 2000pool:minSize: 50maxSize: 200
<!-- 引入spring-data-redis组件 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId><!--spring boot 2.0之后默认lettuce客户端, 使用jedis时需要排包--><exclusions><exclusion><groupId>io.lettuce</groupId><artifactId>lettuce-core</artifactId></exclusion></exclusions></dependency><!-- 引入jedis依赖包 --><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>5.1.2</version></dependency>
import java.time.Duration;import org.springframework.beans.factory.annotation.Value;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.data.redis.connection.RedisConnectionFactory;import org.springframework.data.redis.connection.RedisStandaloneConfiguration;import org.springframework.data.redis.connection.jedis.JedisClientConfiguration;import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;import redis.clients.jedis.JedisPoolConfig;@Configurationpublic class JedisConfig {@Value("${tencent.redis.host}")private String redisHost;@Value("${tencent.redis.port:6379}")private Integer redisPort = 6379;@Value("${tencent.redis.database:0}")private Integer redisDatabase = 0;@Value("${tencent.redis.password:}")private String redisPassword;@Value("${tencent.redis.connect.timeout:3000}")private Integer redisConnectTimeout = 3000;@Value("${tencent.redis.read.timeout:2000}")private Integer redisReadTimeout = 2000;@Value("${tencent.redis.pool.minSize:50}")private Integer redisPoolMinSize = 50;@Value("${tencent.redis.pool.maxSize:200}")private Integer redisPoolMaxSize = 200;@Beanpublic RedisConnectionFactory redisConnectionFactory(JedisClientConfiguration clientConfiguration) {RedisStandaloneConfiguration standaloneConfiguration = new RedisStandaloneConfiguration();standaloneConfiguration.setHostName(redisHost);standaloneConfiguration.setPort(redisPort);standaloneConfiguration.setDatabase(redisDatabase);standaloneConfiguration.setPassword(redisPassword);return new JedisConnectionFactory(standaloneConfiguration, clientConfiguration);}@Beanpublic JedisClientConfiguration clientConfiguration() {JedisClientConfiguration clientConfiguration = JedisClientConfiguration.builder().connectTimeout(Duration.ofMillis(redisConnectTimeout)).readTimeout(Duration.ofMillis(redisReadTimeout)).usePooling().poolConfig(redisPoolConfig()).build();return clientConfiguration;}private JedisPoolConfig redisPoolConfig() {JedisPoolConfig poolConfig = new JedisPoolConfig();//连接池的最小连接数poolConfig.setMinIdle(redisPoolMinSize);//连接池的最大空闲连接数poolConfig.setMaxIdle(redisPoolMaxSize);//连接池的最大连接数poolConfig.setMaxTotal(redisPoolMaxSize);//创建连接时校验有效性(ping),默认falsepoolConfig.setTestOnCreate(false);//获取连接时校验有效性(ping),默认false,业务量大时建议设置为false减少开销poolConfig.setTestOnBorrow(true);//归还连接时校验有效性(ping),默认false,业务量大时建议设置为false减少开销poolConfig.setTestOnReturn(false);//关闭lifo,将 LIFO 配置改为FIFO(先进先出),以确保连接建立顺序公平poolConfig.setLifo(false);return poolConfig;}}
文档反馈