记一次生产的bug

  第一个在代码中使用 new SimpleDateFormat("EEEE")来判断周几。在本地测试过程中通过日志打印出来的周几 比如周日对应的是中文汉字“星期日”,然后使用判断 if("星期日".equals(weekDay)){   } (其中weekDay是要使用的日期)。在本地测试通过后就愉快的上线了。

  这是一个发邮件的功能,我把生产上发邮件的时间定在了周六上午10点。到了周六,我就正好去了外地玩,也没有带笔记本。周六上午我就在玩的地方等邮件发出,等着见证奇迹的时刻。终于10点到了,为什么没发出来,难道是生产上数据太多,好吧,再等一会儿。10:30了,为什么还没发出来,我意识到是代码出问题了(心中一万匹****)。于是找同事帮忙看日志,但是日志中并没有显示异常,找不出来原因,心中万分焦虑。

  终于在周日晚上返回家里,打开电脑,连上VPN,在代码中打日志,上线测试日志打印情况,最后发现到某个地方之后的日志打印不了了。我看下源代码,这附近我写了一直 if(){}else if() {} else {return;}。那问题很可能就在return这里了,我又把要比较的日期weekDay打印出来,生产上显示的竟然是“Sunday”,一口老血喷出。问题终于找到,原来每次到了else这里它都默默地返回了,怪不得我在日志里什么也看不出来。

  这次经历暴露了我写代码的一个很大毛病,记录下来,前事不忘后事之师。

  1、在写代码的过程中,不要把问题隐藏起来,不要直接return,catch到了错误也不要直接return或者在catch里什么都不做,要么打日志,要么发短信,要么把问题抛给上层处理,根据需要把选择相应的方式。一定不要把代码中的问题隐藏到代码中,显示出来,崩溃都可以。

  2、在代码上线前,无论多么少的代码,一定要按照正规的流程放到测试环境测试,即使本地和测试环境都通过了,在生产上也可能因为机器或者数据量的不同而导致问题,一定要进行充分的测试,那些bug永远在你见识过的之外,不通过充分的测试是暴露不出来的。

转载于:https://www.cnblogs.com/coderjie/p/7472365.html

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
这次的文章标题原本想叫《一次因错用HashMap造成的生产BUG》,但作者觉得这个标题可能会让人联想到某些Java公众号写的标题党文章,所以改成了现在这个标题。在文章中,作者承认在A接口中将所有产品都放到HashMap中并不太规范,但在实际实现中是可行的,所以并不算是“错用”。然而,作者在写代码时疏忽了缓存的问题,忽视了HashMap在多线程环境下不能使用的要求,结果写出了有BUG的代码。 作者从这次线上BUG中学到了几个教训:首先,在使用直接存放对象引用的内存缓存时,要注意不要修改从缓存中获取的内容;其次,在修改代码时,要全面考虑前后逻辑,思考修改的后果;再次,不要困于思维陷阱,在寻找问题时不定问题出在前面的代码;最后,遇到解决不了的问题时,寻求帮助是很重要的,领导在几分钟内就发现了作者几个小时都没找到的BUG。 问题出现在addDisplayStyle()方法中。当有多个APP请求A接口时,业务线程执行到product.put("displayStyle", displayStyle)这行代码时,实际上是在往同个Map中放入元素。由于key相同,就会发生哈希冲突。如果此时某个Map的元素个数达到了扩容条件,就会触发扩容,并有可能出现链表成环的情况。当有新的请求到来时,工作线程执行到recommends = deduplicateAndGetFirstN(recommends, 3)这行代码。 综上所述,这次的文章是关于作者经历的一次因错用HashMap而导致生产BUG的经历。作者从中学到了关于使用缓存、修改代码、寻找问题和寻求帮助等方面的教训。问题出现在addDisplayStyle()方法中,当多个APP请求A接口时,可能会触发HashMap的扩容并导致链表成环的情况。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值