当前位置: 首页 > 面试题库 >

将Jedis与Spring Data结合使用时,为什么在Redis中使用奇怪的键存储数据?

张丁雷
2023-03-14
问题内容

我正在使用Jedis的Spring Data
Redis。我试图用key存储哈希vc:${list_id}。我能够成功插入Redis。但是,当我使用redis-
cli检查密钥时,看不到密钥vc:501381。相反,我看到了\xac\xed\x00\x05t\x00\tvc:501381

为什么会发生这种情况,我该如何更改?


问题答案:

好的,谷歌搜索了一段时间,并在http://java.dzone.com/articles/spring-data-
redis
找到了帮助。

它的发生是由于Java序列化。

需要将redisTemplate的密钥序列化器配置为StringRedisSerializer

<bean 
    id="jedisConnectionFactory" 
    class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" 
    p:host-name="${redis.server}" 
    p:port="${redis.port}" 
    p:use-pool="true"/>

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

<bean 
    id="redisTemplate" 
    class="org.springframework.data.redis.core.RedisTemplate"
    p:connection-factory-ref="jedisConnectionFactory" 
    p:keySerializer-ref="stringRedisSerializer"
    p:hashKeySerializer-ref="stringRedisSerializer" 
/>

现在redis的关键是vc:501381

或就像@niconic所说的,我们也可以将默认的序列化器本身设置为字符串序列化器,如下所示:

<bean 
    id="redisTemplate" 
    class="org.springframework.data.redis.core.RedisTemplate"
    p:connection-factory-ref="jedisConnectionFactory" 
    p:defaultSerializer-ref="stringRedisSerializer"
/>

这意味着我们所有的键和值都是字符串。但是请注意,这可能不是可取的,因为您可能希望您的值不只是字符串。

如果您的值是一个域对象,那么您可以使用Jackson序列化程序并按此处所述配置一个序列化程序,即:

<bean id="userJsonRedisSerializer" class="org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer">
    <constructor-arg type="java.lang.Class" value="com.mycompany.redis.domain.User"/>
</bean>

并将模板配置为:

<bean 
    id="redisTemplate" 
    class="org.springframework.data.redis.core.RedisTemplate"
    p:connection-factory-ref="jedisConnectionFactory" 
    p:keySerializer-ref="stringRedisSerializer"
    p:hashKeySerializer-ref="stringRedisSerializer" 
    p:valueSerialier-ref="userJsonRedisSerializer"
/>


 类似资料:
  • 我正在使用spring数据雷迪斯与绝地武士。我正在尝试使用键存储哈希。我能成功插入Redis。但是,当我使用redis-cli检查键时,我看不到键。相反,我看到的是。 为什么会发生这种情况?我该如何改变这种情况?

  • 问题内容: 我已经阅读了有关键/值存储(例如Redis)的很棒的文章,但是我似乎无法弄清楚何时该在应用程序中使用它。 假设我正在设计一个基于Web的应用程序;我知道前端,后端,数据库等将使用什么堆栈。在某些情况下,我会使用“哦,我们还需要Redis用于X,Y或Z”。 我会喜欢node.js示例以及非node.js示例。 问题答案: 我似乎无法弄清楚何时在应用程序中使用它。 我建议您阅读本教程,其中

  • 在更改配置值和SVN提交之后,我将触发refresh POST调用,URL:http://localhost:8080/Actuator/refresh[8080是客户端端口]。SVN中更新的值没有被刷新。 众所周知,config-server在本地存储SVN数据。[在我的例子中,文件夹位置-/tmp/config-repo-5393789580706388886]这里奇怪的是,一旦触发了“ref

  • 我正在为我的应用程序创建一个简单的活动流。 用户执行操作,活动直接存储在MYSQL中的“activities”表中,并返回唯一的“activity_id”。 从数据库中检索该用户的“followers”的数组,并且对于每个followers我将这个新的activity_id推入Redis中的列表。 当用户查看他们的流时,我根据他们的用户ID从redis检索活动ID的数组。然后,我执行一个简单的MY

  • 谷歌云存储(与谷歌硬盘不同)似乎与S3应用编程接口兼容: https://developers.google.com/storage/docs/migrating#migration-simple 有人知道我是否可以使用aws/aws-sdk-php(https://packagist.org/packages/aws/aws-sdk-php)包并将其配置为连接到我的谷歌云存储而不是AWS S3吗