记录一个跌宕起伏的解决bug过程

2023-11-21 19:10

本文主要是介绍记录一个跌宕起伏的解决bug过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题症状:测试发现在服务在运行一段时间之后就会挂掉,尤其是在进行安全漏洞扫描和性能测试时更加明显,后台没有报错日志,单纯的应用不再接收新的请求;

问题重现、分析和解决:刚开始很难在开发环境上复现这个问题(我们自己开发环境经常会重启),而且无法定位到在进行什么操作的时候才会导致服务器挂掉;只能通过多次进行扫描然后查看导致服务挂掉的请求时什么,发现每次扫描卡住之后最后一个请求都是登录请求,所以我们初步判断可能是登录导致应用挂掉,但是让人疑惑的是为什么正常操作时应用没有挂掉,而是操作一段时间之后应用才会挂掉,然后网上一顿搜索分析,发现服务不再响应的特征是数据库的连接数达到一定的数量而且这些连接由于被阻塞不能释放,导致数据库卡死;到这基本是找到了导致服务挂掉的罪魁祸首了,但是怎么解决这个问题呢,是那一块的代码导致了这个问题呢?然后我首先将可能导致数据库发生阻塞的代码重新走了一遍,甚至将很多不规范的写法都重新规范了一遍,还是不行,然后我又回想起每次挂掉前的最后一个扫描请求时登录,所以我又回到登录页面去查(因为我们登录时做的单点登录,在跳转到另一个系统进行登录的)一遍遍的修改调试都无果,而这时通过大量在开发环境的测试(我们在开发环境将最大连接数设置小一些,问题也更容易复现)我们发现不止是进行一定量的登录请求后会发生这个问题,不停的刷新首页也会导致这个问题,然后我们排除了登录的问题,而扫描漏洞导致服务挂掉前的最后一个请求每次都是登录请求也可以理解,因为我们某些页面有登录拦截,然后扫描漏洞的程序在每隔一定的时间就会进行登录操作,而一旦发现登录不上去了,程序就停止扫描了,而服务也许在这之前就已经挂掉了;言归正传,这时我们把问题锁定到首页上,因为不断f5刷新首页,确实可以看到后台数据库的阻塞进程在增加,然后就是分析首页的代码,一段一段的屏蔽排除发现是页面上的的图片加载会导致这个问题,这让我们又疑惑了,但是随着继续深入的测试,点击一个加载失败的图片链接让我们有了新的发现,这个加载失败的图片跳转到的一个404页面里面包含了获取后台用户数据的操作,继续前面的排除法,删除这部分代码就不会出现问题了,到这里我们至少知道该怎么去解决项目上的问题了,但是这并没有解决疑惑,为什么在404页面获取用户信息会导致这个问题,继续深入研究发现是数据库配置的问题,发现是在openSessionInViewFilter的拦截没有配置Error这个选项,导致在error页打开的session没有正常关闭,加上这个不修改error的tag页也可以解决问题!

这篇关于记录一个跌宕起伏的解决bug过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/404452

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

将Mybatis升级为Mybatis-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

Spring事务中@Transactional注解不生效的原因分析与解决

《Spring事务中@Transactional注解不生效的原因分析与解决》在Spring框架中,@Transactional注解是管理数据库事务的核心方式,本文将深入分析事务自调用的底层原理,解释为... 目录1. 引言2. 事务自调用问题重现2.1 示例代码2.2 问题现象3. 为什么事务自调用会失效3

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu