Redis
 sql >> Baza danych >  >> NoSQL >> Redis

Jak zdobyć wszystkie klucze z Redis za pomocą szablonu redis

Właśnie skonsolidowałem odpowiedzi, które widzieliśmy tutaj.

Oto dwa sposoby uzyskania kluczy z Redis, gdy 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:powinieneś mieć skonfigurowany redisTemplate za pomocą StringRedisSerializer w twojej fasoli

Jeśli używasz konfiguracji bean opartej na javie

redisTemplate.setDefaultSerializer(new StringRedisSerializer());

Jeśli używasz konfiguracji ziaren opartej na spring.xml

<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. Z 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 zamkniesz tego połączenia jawnie, napotkasz wyczerpanie podstawowej puli połączeń jedis, jak wspomniano na https://stackoverflow.com/a/36641934/3884173.



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. LogicException:Upewnij się, że rozszerzenie PHP Redis jest zainstalowane i włączone

  2. jak mogę przekazać nieskończoność do redis z Pythona?

  3. Osiągnięto maksymalną liczbę połączeń Azure Redis Cache

  4. Dlaczego nie zaleca się używania KEYS w Redis?

  5. ServiceStack.Redis Nie można odczytać transportu — BasicRedisClientManager