springboot + redis
生活随笔
收集整理的這篇文章主要介紹了
springboot + redis
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
上一篇文章中我們引入了mysql的配置,接下來我們引入使用非常廣泛的緩存組件redis;
(注意,以下我引用的是自定義的redis配置,目的是更好的定制化一些功能以及多實例redis處理,并沒有采用spring自身封裝的RedisTemplate,個人認為spring封裝的redisTemplate還存在一些問題,所以有條件的童鞋最好自定義redis相關功能)。
注:基于demo-springboot;
1.打開application-dev.properties并加入以下內容:
#redis #redis db spring.redis.database=0 #redis host & port spring.redis.host=10.0.2.13 spring.redis.port=6379 spring.redis.password= #連接池最大連接數(使用負值表示沒有限制) spring.redis.jedis.pool.max-active=1000 # 連接池中的最大空閑連接 spring.redis.jedis.pool.max-idle=100 #連接池最大阻塞等待時間(使用負值表示沒有限制) spring.redis.jedis.pool.max-wait=-1 # 連接池中的最小空閑連接 spring.redis.jedis.pool.min-idle=0 # 連接超時時間(毫秒) spring.redis.timeout=0以上為redis常用的相關配置以及說明;
pom.xml中加入相關依賴:
<!--redis--> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.9.0</version> </dependency> <dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>21.0</version> </dependency> <dependency> <groupId>com.caucho</groupId> <artifactId>hessian</artifactId> <version>4.0.38</version> </dependency>2.在demo下新建package config,創建RedisConfig類
@Configuration @EnableAutoConfiguration @ConfigurationProperties(prefix = "spring.redis") public class RedisConfig {private static Logger logger = LoggerFactory.getLogger(RedisConfig.class); private String host; private int port; private String password; @Value("${spring.redis.timeout}")private int timeout; @Value("${spring.redis.jedis.pool.max-idle}")private int maxIdle; @Value("${spring.redis.jedis.pool.min-idle}")private int minIdle; @Value("${spring.redis.jedis.pool.max-wait}")private int maxWaitMillis; @Value("${spring.redis.jedis.pool.max-active}")private int maxActive; private boolean testOnBorrow = true; @Bean public JedisPoolConfig getRedisConfig() {JedisPoolConfig config = new JedisPoolConfig(); config.setMaxIdle(maxIdle); config.setMinIdle(minIdle); config.setMaxTotal(maxActive); config.setMaxWaitMillis(maxWaitMillis); config.setTestOnBorrow(testOnBorrow); return config; }@Bean("redisExtendClient")public RedisExtendClient redisExtendClient() {RedisExtendClient client = new RedisExtendClient(shardedJedisPool()); return client; }@Bean("shardedJedisPool")public ShardedJedisPool shardedJedisPool() {JedisPoolConfig config = getRedisConfig(); List<JedisShardInfo> jdsInfoList =new ArrayList<JedisShardInfo>(2); JedisShardInfo infoA = new JedisShardInfo(host, port); jdsInfoList.add(infoA); ShardedJedisPool pool = new ShardedJedisPool(config, jdsInfoList, Hashing.MURMUR_HASH, Sharded.DEFAULT_KEY_TAG_PATTERN); return pool; }public int getPort() {return port; }public void setPort(int port) {this.port = port; }public String getPassword() {return password; }public void setPassword(String password) {this.password = password; }public int getTimeout() {return timeout; }public void setTimeout(int timeout) {this.timeout = timeout; }public String getHost() {return host; }public void setHost(String host) {this.host = host; } }以上為自定義的redis config,采用了多實例(多分片),RedisExtendClient 為我自定的redis操作工具類(封裝了各種redis的相關操作,在此我就不貼出來了); ok一切配置就緒,接下來我們開始測試一下吧!
3.編寫單元測試:
至此,你已成功引入redis緩存組件,congratulation!
總結
以上是生活随笔為你收集整理的springboot + redis的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何获取一个网站的cdn节点
- 下一篇: springboot + kafka