Po prostu skonsolidowałem odpowiedzi, które widzieliśmy tutaj.
Oto dwa sposoby uzyskiwania kluczy od Redis, kiedy używamy RedisTemplate.
1. Bezpośrednio z RedisTemplate
Set<String> redisKeys = template.keys("samplekey*"));
// Store the keys in a List
List<String> keysList = new ArrayList<>();
Iterator<String> it = redisKeys.iterator();
while (it.hasNext()) {
String data = it.next();
keysList.add(data);
}
Uwaga: Należy mieć skonfigurowany redisTemplate z StringRedisSerializer w fasoli
Jeśli używasz Java konfiguracja fasola
redisTemplate.setDefaultSerializer(new StringRedisSerializer());
Jeśli używasz oparty spring.xml konfiguracja fasola
<bean id="stringRedisSerializer" class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
<!-- redis template definition -->
<bean
id="redisTemplate"
class="org.springframework.data.redis.core.RedisTemplate"
p:connection-factory-ref="jedisConnectionFactory"
p:keySerializer-ref="stringRedisSerializer"
/>
2. Od JedisConnectionFactory
RedisConnection redisConnection = template.getConnectionFactory().getConnection();
Set<byte[]> redisKeys = redisConnection.keys("samplekey*".getBytes());
List<String> keysList = new ArrayList<>();
Iterator<byte[]> it = redisKeys.iterator();
while (it.hasNext()) {
byte[] data = (byte[]) it.next();
keysList.add(new String(data, 0, data.length));
}
redisConnection.close();
Jeśli nie zamykać tego połączenia wprost, będziesz napotkasz na wyczerpaniu podstawową pulę połączeń jedis, jak podano w https://stackoverflow.com/a/36641934/3884173.
Bardzo mi to pomogło, zasługuje na więcej awansów !! – varunkr
To powinna być zaakceptowana odpowiedź. –