我正在使用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吗