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

长葛住房和城乡建设局网站play商店

长葛住房和城乡建设局网站,play商店,lol网站怎么做,网站建设公司的公司文章目录 问题现象栈溢出(不断的重连)读取超时未知响应尝试读取损坏的链接读取到的数据和自己要读的无关,导致空指针、类型转换错误,数据读取错乱 问题写法问题分析修复注意点 问题现象 栈溢出(不断的重连&#xff09…

文章目录

    • 问题现象
      • 栈溢出(不断的重连)
      • 读取超时
      • 未知响应
      • 尝试读取损坏的链接
      • 读取到的数据和自己要读的无关,导致空指针、类型转换错误,数据读取错乱
    • 问题写法
    • 问题分析
    • 修复
    • 注意点

问题现象

栈溢出(不断的重连)

		at redis.clients.jedis.Connection.sendCommand(Connection.java:163)at redis.clients.jedis.Connection.sendCommand(Connection.java:154)at redis.clients.jedis.BinaryClient.auth(BinaryClient.java:815)at redis.clients.jedis.BinaryClient.connect(BinaryClient.java:145)at redis.clients.jedis.Connection.sendCommand(Connection.java:163)at redis.clients.jedis.Connection.sendCommand(Connection.java:154)at redis.clients.jedis.BinaryClient.auth(BinaryClient.java:815)at redis.clients.jedis.BinaryClient.connect(BinaryClient.java:145)

在这里插入图片描述

读取超时

在这里插入图片描述

未知响应

在这里插入图片描述

尝试读取损坏的链接

在这里插入图片描述

读取到的数据和自己要读的无关,导致空指针、类型转换错误,数据读取错乱

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

问题写法

对Redis操作封装了一个Redis类
在这里插入图片描述
同事对pipeline加了这个方法
在这里插入图片描述
使用的时候

   public Map<String, AnswerModel> batchGetAnswersPipeline(List<String> answerIdList) {Map<String, AnswerModel> resultMap = new HashMap<>();try (Pipeline pipelined = redis.pipelined()) {List<Response<Map<String, String>>> responses = new ArrayList<>();for (String answerId : answerIdList) {String key = String.format(MOMENT_ANSWER_INFO, answerId);responses.add(pipelined.hgetAll(key));}pipelined.sync();for (Response<Map<String, String>> response : responses) {Map<String, String> map = response.get();AnswerModel answers = BeanUtil.mapToBean(map, AnswerModel.class);if (answers != null){resultMap.put(answers.getAnswerId(), answers);}}} catch (Exception e) {log.error("执行batchGetAnswersPipeline发生异常, redis pipeline error", e);throw new CatVillageException();}return resultMap;}

问题分析

在redis这个工具类中调pipelined时获取一个Pinelined对象,而获取这个方法里用了try with ,with了一个jedis链接,当try结束时链接会被归还jedispool连接池。而返回的这个pipeline仍然在用这个链接,当其他线程去拿链接的时候可能拿到的正好是这个链接,导致多个线程共用一个链接,一个线程在执行pipeline多条命令,另一个线程也在用这个链接。而jedis底层执行命令的时候是使用的OutputStream流式去执行命令,使用二进制流读取结果。当出现这种线程不安全问题的时候,读取写入就会有问题。

修复

删除Redis工具类中的pipelined方法,使用getJedis方法获取链接对象,再获取管道Pineline对象,自行close管道,最后执行完释放管道,链接。

public Map<String, QuestionModel> batchGetQuestionPipeline(List<String> questionIdList) {if (CollectionUtils.isEmpty(questionIdList)){return new HashMap<>();}Map<String, QuestionModel> resultMap = new HashMap<>();try (Jedis jedis = redis.getJedis()) {Pipeline pipelined = jedis.pipelined();List<Response<Map<String, String>>> responses = new ArrayList<>();for (String questionId : questionIdList) {String key = String.format(MOMENT_QUESTION_INFO, questionId);responses.add(pipelined.hgetAll(key));}pipelined.sync();for (Response<Map<String, String>> response : responses) {Map<String, String> map = response.get();QuestionModel question = convertFromMap(map);if (question != null) {resultMap.put(question.getPostId(), question);}}pipelined.close();} catch (Exception e) {log.error("执行batchGetQuestionPipeline发生异常, redis pipeline error", e);throw new CatVillageException();}return resultMap;}

注意点

若jedis在3.7版本以下的版本也会有管道二进制读取异常问题,请升级到3.7.0+版本

http://www.dtcms.com/a/563102.html

相关文章:

  • 网站建设入什么会计科目三网合一的模板网站
  • 贵州企业网站建设价格临沂建设网
  • 网络推广方案p网站的优化和推广方案
  • 网页基础海南短视频搜索seo哪家实惠
  • 赤峰市住房和城乡建设局官方网站广东网站制作报价
  • 小企业网站建设哪家便宜泰安网站建设总结
  • 网站建设方案可以乱写吗桂林市有几个区和县
  • 迪庆州建设局网站佛山seo整站优化
  • 房地产网站欣赏wordpress百科网
  • wordpress博客站点wordpress连数据库很慢
  • 郑州网站建设招标变更网站做推广需要备案
  • 自己给网站做支付接口iis 里没有网站
  • 网站建设开发合同模板下载wordpress获取文章浏览次数
  • vf建设银行网站深圳做微信网站公司哪家好
  • 河北廊坊建设银行网站软件界面设计的原则
  • 建一个网站花多少钱伊犁做网站
  • 怎么做网站旺铺装修东莞企业推广网站制作
  • 水果网站 模板如何做高网站的浏览量
  • 福建省建设厅网站投诉网页设计与制作教案模板
  • 旗舰店的网站怎么做wordpress 修改上传路径
  • 4.游戏逆向-pxxx-得到GName偏移
  • 建站费用报价单聊城开发区网络公司排名
  • 搭建一个网站 优帮云应用商店app下载安装
  • 网站建设与优化及覆盖率方案php旅游类网站开发毕业设计
  • 网站建设排名的公司哪家好discuz可以做公司网站
  • 营销型网站标准网页源码用一个域名免费做网站
  • 网站建设制作人员招聘要求小说类网站功能建设
  • 兼职做网站的软件企业建站模板价格
  • 苏州做网站建设公司南通网站设计制作公司
  • wordpress的php.ini沈阳seo建站