一、為什么選擇使用Redisson
因為它非常適用於分布式鎖,而我們的一項業務需要考慮分布式鎖這個應用場景,於是我整合它做一個初步簡單的例子(和整合redis一樣)。
Redisson、Jedis、Lettuce優缺點對比
(1)Redisson
優點:
實現了分布式特性和可擴展的 Java 數據結構,適合分布式開發;
API線程安全;
基於Netty框架的事件驅動的通信,可異步調用。
缺點:
API更抽象,學習使用成本高。
(2)Jedis
優點:
提供了比較全面的Redis操作特性的API
API基本與Redis的指令一一對應,使用簡單易理解。
缺點:
同步阻塞IO;
不支持異步;
線程不安全。
(3)Lettuce
優點:
線程安全;
基於Netty 框架的事件驅動的通信,可異步調用;
適用於分布式緩存。
缺點:
API更抽象,學習使用成本高。
其中Jedis是用的最普遍的(確實非常簡單),特別是很多單體應用或者偽分布式應用等。
二、SpringBoot整合Redisson
1.添加Maven依賴
<!-- redisson-springboot --> <dependency> <groupId>org.redisson</groupId> <artifactId>redisson-spring-boot-starter</artifactId> <version>3.11.4</version> </dependency>
2.配置文件
spring: redis: host: 127.0.0.1 port: 6379 database: 0 timeout: 5000
3.添加配置類
import org.redisson.Redisson; import org.redisson.api.RedissonClient; import org.redisson.config.Config; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.autoconfigure.data.redis.RedisProperties; import org.springframework.boot.context.properties.EnableConfigurationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class RedissonConfig { @Autowired private RedisProperties redisProperties; @Bean public RedissonClient redissonClient() { Config config = new Config(); String redisUrl = String.format("redis://%s:%s", redisProperties.getHost() + "", redisProperties.getPort() + ""); config.useSingleServer().setAddress(redisUrl).setPassword(redisProperties.getPassword()); config.useSingleServer().setDatabase(3); return Redisson.create(config); } }
4.代碼測試(簡單的存取)
import org.redisson.api.RedissonClient; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController @RequestMapping("/redisson") public class RedissonController { @Autowired private StringRedisTemplate stringRedisTemplate; @GetMapping("/save") public String save(){ stringRedisTemplate.opsForValue().set("key","redisson"); return "save ok"; } @GetMapping("/get") public String get(){ return stringRedisTemplate.opsForValue().get("key"); } }