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

石家庄货运做网站公司身高差效果图网站

石家庄货运做网站公司,身高差效果图网站,西安网站制作百亿科技,上海奉贤网站建设一.线上 stackOverFlowError xxx日,突然收到线上日志关键字频繁告警 classCastException.从字面上的报警来看,仅仅是类型转换异常,查看细则发现其实是 stackOverFlowError.很多同学面试的时候总会被问到有没有遇到过线上stackOverFlowError?有么有遇到栈溢出?具体栈溢出怎么来…一.线上 stackOverFlowError xxx日,突然收到线上日志关键字频繁告警 classCastException.从字面上的报警来看,仅仅是类型转换异常,查看细则发现其实是 stackOverFlowError.很多同学面试的时候总会被问到有没有遇到过线上stackOverFlowError?有么有遇到栈溢出?具体栈溢出怎么来解决?今天他来了,他带着问题走来了.话不说多,直入正题.具体打印的stackOverFlowError细则如下 二.优先线上问题解决 请原谅我抽象的画风 temp 方案.首先的线上的稳定性肯定是第一要义,客户可不会等你长篇大论抓包,分析,debug.过了30min还不恢复,资本的大刀就要砍到你身上了.所以我们先想到的是代码回退,镜像回滚解决问题优先.虽然说是临时方案,那这时候我觉得这可能是最重要的最佳方案.毕竟老镜像是不会出任何问题的. 三.继续深入分析 解决完线上的问题后,先从外层的堆栈打印来看,找到 ClassCastException 这里找到真实的原因,毕竟退下来的不仅仅是坏代码,还有需求迭代的正常需求还是需要继续推上去上线. 3.1 整体的流程梳理 找到报错第一步: 3.1.1 step1: classCastException 先表象开始分析 从这里可以看到判断了是否为 Throwable 类型.如果是就进行 Exception 强转.这里就要复习一下了. StackOverFlowError 继承 Error ,Error 从Throwable 继承而来. Exception 则是另外的分支. 对于 Error 和 Exception 也有通行的原则. Exception 一般是程序中用以来抛出程序异常所使用的且一般是能够通过编码优化来解决的,或是用来 try catch exception 来进行捕获处理的. Error 则是用来表达程序运行期间出现的严重错误,这时候通常是jvm级别的.如常见的OutOfMemoryError,stackOverFlowError.等.通常则是无法通过代码来进行捕获的. 有了这些基础知识后,再回来这里虽然StackOverFlowError与Exception都继承于 Throwable .但这是两个子的实现,没法做到强转.由之得到了 ClassCastException .后面这就是转成了 ClassCastException .这个类则是继承自 Exception .通过 try catch 捕获异常后,得到了正常的日志打印,也就是收到的日志告警. 然后这仅仅是表现.根因还没有找到. 当然这段代码也需要进行优化.如果得到的是Error的类型就要对应的进行Error的处理而不是仅仅对Throwable都统一强转为Exception 代码优化 Exception exception null;f(ar instanceof Error){Error arError(Error)ar; exceptionnew Exception (arError);}else if(ar instanceof Exception){exception (Exception) ar;}3.1.2 step2:事情远没有结束,到底是哪里出问题 StackOverFlowError 本质上还是由于StackOverFlowError才得到的如上的 ClassCastException. 回忆下 JVM 的内存布局(如下图) 能发生 StackOverFlowError 只有在线程私有的 stack(native method stack | virtual method stack) 这里.这里通常发生这个错误的原因是因为方法调度的深度过长了或是线程本身分别的内存太小不足以支持现在的复杂调用. 第一种场景:常见的如递归调用.第二种场景: jvm 在1.5 之后默认的xss 大小默认为 1m.一般场景下支持1000-2000个深度调用没问题.包括递归.(没试过.数值参考自:深入理解java虚拟机) 3.1.3 找到问题对比代码 从一般情况下第二种场景不太可能出现.还是回到递归调用引起的.排查代码.花不多少,看代码,通过对比版本之间diff(对比时间稍微有点长).简略如下: 无问题代码 private static void error(Logger logger, String message, Object... arg) {if (isLogOn(LogLevelEnum.ERROR, logger)) {if (arg ! null arg.length 0 arg[0] instanceof Throwable) {logger.error(message, arg[0]);} else {logger.error(message, arg);}TRACER_LOGGER.error(message, arg);}} public static void error(Object... arg) {String message getMessage({}, 4, arg);error(getSoaErrorLogger(), message, arg);}public static void error(String message, Object... arg) {message getMessage(message, 4, arg);error(getSoaErrorLogger(), message, arg);}代码优化后的代码 有问题版 private static void error(Logger logger,String realMessage, String message, Object... arg) {if (isLogOn(LogLevelEnum.ERROR, logger)) {if (arg ! null arg.length 0 arg[0] instanceof Throwable) {logger.error(message, arg[0]);} else {logger.error(message, arg);}TRACER_LOGGER.error(message, arg);}} public static void error(Object... arg) {String message getMessage({}, 4, arg);error(getSoaErrorLogger(), message, arg);}public static void error(String message, Object... arg) {message getMessage(message, 4, arg);final String realMessagemessage;error(getSoaErrorLogger(),realMessage, message, arg);}代码优化后的代码 完善版 private static void error(Logger logger,String realMessage, String message, Object... arg) {if (isLogOn(LogLevelEnum.ERROR, logger)) {if (arg ! null arg.length 0 arg[0] instanceof Throwable) {logger.error(message, arg[0]);} else {logger.error(message, arg);}TRACER_LOGGER.error(message, arg);}} public static void error(Object... arg) {String message getMessage({}, 4, arg);final String realMessagemessage;error(getSoaErrorLogger(),realMessage, message, arg);}public static void error(String message, Object... arg) {final String realMessagemessage;message getMessage(message, 4, arg); error(getSoaErrorLogger(),realMessage, message, arg);}咋一看没有任何问题.但是上线后出现第二个方法递归调用自身(但是第二个方法没有变更内容哈).本质上的原因就是因为修改第一个方法增加了入参.但是仅修改了第三个方法,第二个方法没有修改.没有出现编译问题.因为本身第二个方法是一个Object… arg的数组调用.好坑. 四.总结 区别Error与Exception.系统最外层建议捕获所有异常,也就是Throwable,但是具体是Error,还是Exception要进行区分处理.尽量不使用,少使用数组式使用.如String… args.Integer… args .即使要用,也尽量不要用Object… args .避免调用错误.在做技术优化时,尽可能评估影响,对线上抱有充分的敬畏.慎之又慎.如没有特别的收益,可不上线.上线也要保证每一行改动与本次受影响的代码做到测试修改代码找到所有find usage ,避免出现错改,漏改.可以利用自带IDE的工具 做到. 赠人玫瑰 手有余香,我是柏修 求关注、求点赞加个关注不迷路感谢 点赞是对我最大的鼓励 ↓↓↓↓↓↓
http://www.dnsts.com.cn/news/252404.html

相关文章:

  • 企业模板网站vueseo哪家强
  • 门户网站建设运营互联网之光博览会第六届
  • 河南城源建设工程有限公司网站wordpress 生成主题包
  • 58网站怎么做才有客户问wordpress 订餐模板
  • 网站建设 环保素材新网站怎么做才能让搜狗收录
  • 最常见的企业建站程序有线下推广是什么意思
  • 单页面网站做排名Wordpress下拉选择默认
  • dw怎么把网站做的漂亮python网站开发实践
  • 湖南营销型网站建设公司排名做蓝牙app的网站
  • 设计作品展示网站网站 没有备案 访问不了
  • 国外免备案域名注册长沙seo网络公司
  • php做网站开发大型网站建设平台
  • wordpress 商城站下载地址做外贸哪些网站可以发布产品
  • 怎么做网站卖空间场景营销
  • 网站维护的过程及方法试卷页面设计模板
  • 深圳网站建设及优化开一个网站建设公司
  • 怎么电话销售网站建设加急网站备案
  • 网站建设的仿站电商类网站怎么做推广
  • 如何寻找一批做网站的公司wordpress 短代码嵌套
  • 做辅食网站上海网站建设服务器
  • 克拉玛依市建设局官方网站电脑网站上的电影怎么下载
  • 石家庄建站系统网站架构设计师面试技巧
  • 深圳网站建设公司那家好网页美工设计论文
  • html5 网站模板 米宁波软件开发公司排名
  • 百度搜不到自己的网站做网站运维的待遇
  • 便捷网站建设哪家好高端装修公司名称
  • 电子商务网站开发主要实现功能在线绘制流程图的网站
  • angular做门户网站优秀网站设计网站
  • 深圳培训公司网站建设wordpress 500一片空白
  • 深圳品牌网站设计好看简洁的logo