Zeeshan Zeeshan - 1 year ago 293
Java Question

Get Set value from Redis using RedisTemplate

I am able to retrieve values from


public static void main(String[] args) {
Jedis jedis = new Jedis(HOST, PORT);
Set<String> set = jedis.smembers(KEY);
for (String s : set) {

But when I am trying to use Spring's
, I am not getting any data. My data is stored in
as a

// inject the actual template
private RedisTemplate<String, Object> template;

// inject the template as SetOperations
private SetOperations<String,String> setOps;

public String logHome() {
Set<String> set = setOps.members(KEY);
for(String str:set){
System.out.println(str); //EMPTY
Set<byte[]> keys = template.getConnectionFactory().getConnection().keys("*".getBytes());
Iterator<byte[]> it = keys.iterator();
byte[] data = (byte[])it.next();
System.out.println(new String(data, 0, data.length)); //KEYS are printed.
Set<Object> mySet = template.boundSetOps(KEY).members();
System.out.println(mySet); //EMPTY
return "";

Can someone please point out to me what am I missing?

EDIT : My xml config for RedisTemplate.

<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"

<bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
p:host-name="myhostname" p:port="6379" />

Answer Source

In short

You have to configure serializers.


The Redis template uses serializers for keys, values and hash keys/values. Serializers are used to convert the Java input into the representation that is stored within Redis. If you do not configure anything, the serializer defaults to JdkSerializationRedisSerializer. So if you ask for a key key in your Java code, the serializer converts it to


and Spring Data Redis uses those bytes as the key to query Redis.

You can add data with Spring Data Redis and query it using the redis-cli:

template.boundSetOps("myKey").add(new Date());

and then in the redis-cli> keys *
1) "\xac\xed\x00\x05t\x00\x05myKey"> SMEMBERS "\xac\xed\x00\x05t\x00\x05myKey"
1) "\xac\xed\x00\x05sr\x00\x0ejava.util.Datehj\x81\x01KYt\x19\x03\x00\x00xpw\b\x00\x00\x01N\xcf#\x9cHx"

As you see, the String and the Date are serialized into some crazy bytes that represent a Java-serialized object.

Your code suggests you want to store String-based keys and values. Just set the StringRedisSerializer in your RedisTemplate

Java configuration

redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new StringRedisSerializer());

XML configuration

<bean id="stringSerializer" class="org.springframework.data.redis.serializer.StringRedisSerializer"/>

<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate" 
    <property name="keySerializer" ref="stringSerializer"/>
    <property name="valueSerializer" ref="stringSerializer"/>

<bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" 
    p:host-name="myhostname" p:port="6379"/>

The output after running your code looks like then:


Spring Data Redis has some interesting serializers that allow message exchange between various systems. You can choose either from the built-in serializers

  • JacksonJsonRedisSerializer
  • Jackson2JsonRedisSerializer
  • JdkSerializationRedisSerializer (default)
  • OxmSerializer
  • GenericToStringSerializer

or create your own.

I used Spring Data Redis 1.5.1.RELEASE and jedis 2.6.2 to verify the result of your question. HTH, Mark

Further read:

Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download