当前位置: 首页 > news >正文

RedisTemplate 使用 pipeline 时需要注意的问题

RedisTemplate 使用 pipeline 时需要注意的问题

RedisTemplate 使用 pipeline 进行批量 set 时,需要把 key 和 value 都转为字节
1. 直接使用 getBytes() 转为字节,在读取数据时,会抛出以下序列化异常
//错误代码
protected void process(ReconRedisContext reconRedisContext) {String key = this.getLockKey(reconRedisContext);Pagination pagination = this.queryReconData(reconRedisContext);if (ObjectUtils.isNotEmpty(pagination)&& CollectionUtils.isNotEmpty(pagination.getList())) {List<?> resList = pagination.getList();redisTemplate.executePipelined(new RedisCallback<Set<?>>() {@Overridepublic Set<?> doInRedis(RedisConnection connection) throws DataAccessException {resList.stream().forEach(value -> {connection.sAdd(key.getBytes(StandardCharsets.UTF_8), value.toString().getBytes(StandardCharsets.UTF_8));});return null;}});}}// 抛出序列化异常
org.springframework.data.redis.serializer.SerializationException: Could not read JSON: Unrecognized token 'value': was expecting (JSON String, Number, Array, Object or token 'null', 'true' or 'false')
2. 需要使用 RedisTemplate 已经设置的 Serializer ,将key 和 value 序列化成byte数据,代码如下:
protected void process(ReconRedisContext reconRedisContext) {RedisSerializer keySerializer = redisTemplate.getKeySerializer();RedisSerializer valueSerializer = redisTemplate.getValueSerializer();String key = this.getLockKey(reconRedisContext);Pagination pagination = this.queryReconData(reconRedisContext);if (ObjectUtils.isNotEmpty(pagination)&& CollectionUtils.isNotEmpty(pagination.getList())) {List<?> resList = pagination.getList();redisTemplate.executePipelined(new RedisCallback<Set<?>>() {@Overridepublic Set<?> doInRedis(RedisConnection connection) throws DataAccessException {resList.stream().forEach(value -> {connection.sAdd(keySerializer.serialize(key), valueSerializer.serialize(value));});return null;}});}}
3. 异常原因:
// RedisTemplate 默认使用 DefaultSetOperations 存放数据的源码如下:
public Long add(K key, V... values) {byte[] rawKey = rawKey(key);byte[][] rawValues = rawValues((Object[]) values);return execute(connection -> connection.sAdd(rawKey, rawValues));
}byte[] rawKey(Object key) {Assert.notNull(key, "non null key required");if (keySerializer() == null && key instanceof byte[]) {return (byte[]) key;}return keySerializer().serialize(key);
}byte[] rawValue(Object value) {if (valueSerializer() == null && value instanceof byte[]) {return (byte[]) value;}return valueSerializer().serialize(value);
}

看源码,RedisTemplate 也是把 key 和 value 都转为了字节,但是使用了我们自己设置的 Serializer ,所以,我们在使用 pipeline 时,也需要使用我们设置的 Serializer。

注意:根据源码来看,Redis 的其他数据结构,使用 pipeline 时,也会存在序列化的问题,在代码编写的时候,需要注意。
源自

http://www.lryc.cn/news/223504.html

相关文章:

  • uniapp 下载文件到手机
  • 使用Drupal管理小型项目?试试Docker快速部署Drupal结合内网穿透实现远程访问
  • BSP-STM32移植FreeRTOS
  • 【Spring】Spring IOCDI(万字详解)
  • ts 使用泛型来做类型映射
  • Compose - 使用 Paging
  • 数据结构与算法-(11)---有序表(OrderedList)
  • 佳易王会员管理系统软件如何下载,基本功能有哪些
  • docker搭建mysql环境
  • 优思学院|推行精益六西格玛困难重重?7大原因分析助你避坑
  • 四川思维跳动商务信息咨询有限公司可信吗?
  • 高防CDN与高防服务器:谁更胜一筹?
  • 2.Netty简单应用
  • 80个10倍提升Excel技能的ChatGPT提示
  • jenkins结合k8s部署动态slave
  • 搜索引擎Elasticsearch基础与实践
  • vue项目electron打包
  • 英伟达发布RAPIDS cuDF框架 pandas在GPU上运行速度快了150倍
  • (a)Mask RCNN总体流程
  • 浅谈数据中心机房末端配电技术与产品监控选型-安科瑞黄安南
  • 红包算法 java实现
  • MVCC中的可见性算法
  • Leetcode73矩阵置零
  • linux重要的目录之proc和dev目录
  • 【组件自定义事件+全局事件总线+消息订阅与发布+TodoList案例——编辑+过度与动画】
  • 单独封装export default .js 在引入
  • 【带头学C++】----- 三、指针章 ---- 3.11 补充重要指针知识(二,拓展基础知识)
  • Jmeter分布式性能测试细节+常见问题解决,资深老鸟带你避坑...
  • 动态表单获取某一项值
  • 短路表达式