記録: 445
シナリオ: Spring Boot マイクロサービスで RedisTemplate の HashOperations を使用して、Redis クラスターのハッシュ ハッシュ データ型を操作します。
バージョン: JDK 1.8、Spring Boot 2.6.3、redis-6.2.5。
1.マイクロサービスでRedis 情報を構成する
1.1 pom.xml に依存関係を追加する
pom.xml ファイル:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.6.3</version>
</dependency>
分析: spring-boot-starter-data-redis と spring-boot のバージョンは一貫しています。
1.2 application.yml で Redis クラスター情報を構成する
(1) application.ymlの設定内容
spring:
redis:
cluster:
nodes:
- 192.168.19.161:27001
- 192.168.19.161:27002
- 192.168.19.162:27001
- 192.168.19.162:27002
- 192.168.19.163:27001
- 192.168.19.163:27002
password: demo12345678
timeout: 60000
(2) 分析
コンテンツソースを設定します。
jar包:spring-boot-autoconfigure-2.6.3.jar。
分類:org.springframework.boot.autoconfigure.data.redis.RedisProperties。
このパッケージは、spring-boot-starter が導入されたときにすでに導入されていました。
クラスターの他の情報を構成する必要がある場合は、RedisProperties クラスで情報を見つけて、application.yml で構成して有効にすることができます。
1.3 簡単なロジックをロードする
Spring Boot マイクロサービスが開始すると、自動アノテーション メカニズムが application.yml の構成情報を読み取り、それを RedisProperties オブジェクトの対応するプロパティに挿入します。そのため、Spring環境でRedisクラスタの構成情報を取得することができます。
Spring は RedisProperties オブジェクトから設定を取得し、それを RedisTemplate クライアントに注入します。したがって、RedisTemplate クライアントは、Redis クラスターに対して追加、削除、変更、クエリなどの操作を実行できます。
2. RedisTemplate の構成
RedisTemplateは、springframeworkフレームワークにカプセル化されたRedisを操作するためのクライアントである。
完全なクラス名: org.springframework.data.redis.core.RedisTemplate
2.1 RedisTemplate の構成
@Configuration
public class RedisConfig {
@Bean("redisTemplate")
public RedisTemplate<String, Object> redisTemplate(LettuceConnectionFactory lettuceConnectionFactory) {
// 1.创建RedisTemplate对象
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<String, Object>();
// 2.加载Redis配置
redisTemplate.setConnectionFactory(lettuceConnectionFactory);
// 3.配置key序列化
RedisSerializer<?> stringRedisSerializer = new StringRedisSerializer();
redisTemplate.setKeySerializer(stringRedisSerializer);
redisTemplate.setHashKeySerializer(stringRedisSerializer);
// 4.配置Value序列化
Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Object>(Object.class);
ObjectMapper objMapper = new ObjectMapper();
objMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
objMapper.activateDefaultTyping(objMapper.getPolymorphicTypeValidator(), ObjectMapper.DefaultTyping.NON_FINAL);
jackson2JsonRedisSerializer.setObjectMapper(objMapper);
redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
// 5.初始化RedisTemplate
redisTemplate.afterPropertiesSet();
return redisTemplate;
}
@Bean
public HashOperations<String, Object, Object> hashOperations(RedisTemplate<String, Object> redisTemplate) {
return redisTemplate.opsForHash();
}
}
2.2 分析
@Configuration と @Bean を使用して RedisTemplate を構成した後、 @Autowired アノテーションを使用して RedisTemplate と HashOperations インスタンスを注入し、Redis クラスターを操作します。
3. HashOperations を使用して Redis クラスターのハッシュ ハッシュを操作する
3.1 簡単な説明
ValueOperations を使用して、文字列や一般的な操作 (追加、確認、変更、削除、タイムアウトの設定など) を操作します。
3.2 動作例
@RestController
@RequestMapping("/hub/example/operateCluster")
@Slf4j
public class OperateClusterController {
@Autowired
private RedisTemplate redisTemplate;
@Autowired
private HashOperations hashOperations;
/**
* 使用HashOperations,操作Hash类型数据
*/
@GetMapping("/f04")
public Object f04() {
log.info("HashOperations操作Redis集群开始...");
// 1.增
hashOperations.put("D:2023060804:01", "hangzhou", "杭州");
hashOperations.put("D:2023060804:01", "suzhou", "苏州");
hashOperations.put("D:2023060804:01", "nanjing", "南京");
// 2.1查-获取map键值对数据
Map resultMap = hashOperations.entries("D:2023060804:01");
resultMap.forEach((key, value) -> {
System.out.println("key=" + key + ",value=" + value);
});
// 2.2查-获取Map的全部key
Set set = hashOperations.keys("D:2023060804:01");
set.forEach((key) -> {
System.out.println("key=" + key);
});
// 2.3查-获取Map的全部value
List list = hashOperations.values("D:2023060804:01");
list.forEach((value) -> {
System.out.println("value=" + value);
});
// 3.改
hashOperations.put("D:2023060804:01", "hangzhou", "杭州-西湖");
long time = 5000;
log.info("{}秒后,删除D:2023060804:01队列", time / 1000);
ThreadUtil.sleep(time);
// 4.1删,(删除指定值)
hashOperations.delete("D:2023060804:01", "hangzhou", "suzhou");
// 4.2删,(删除全部)
redisTemplate.delete("D:2023060804:01");
// 5.设置超时
hashOperations.put("D:2023060804:02", "hangzhou", "杭州");
redisTemplate.boundValueOps("D:2023060804:02").expire(5, TimeUnit.MINUTES);
redisTemplate.expire("D:2023060804:02", 10, TimeUnit.MINUTES);
// 6.查询Hash的元素个数
Long size = hashOperations.size("D:2023060804:02");
System.out.println("查询Hash的元素个数,size=" + size);
log.info("HashOperations操作Redis集群结束...");
return "执行成功";
}
}
3.3 テスト検証
ポストマンテストを使用します。
RUL のリクエスト: http://127.0.0.1:18205/hub-205-redis/hub/example/operateCluster/f04
以上、ありがとうございます。
2023 年 6 月 8 日