springboot项目异常堆栈信息不显示行号Unknown Source问题解决办法

当代码报错时不显示自己写的代码错误行号,而显示Unknown Source 在排查问题是非常不方便定位问题

[http://dhr-recruitment-cloud-service-stage.apps.paas-wh-01-uat.wzd.com/robot/feishuBotMessage]响应报文为:200
com.wzd.platform.common.exception.PlatFormException
    at com.wzd.platform.common.auth.LoginUtil.getAuthentication(Unknown Source)
    at com.wzd.platform.common.auth.LoginUtil.getLoginUser(Unknown Source)
    at com.wzd.platform.db.config.DateMetaObjectHandler.updateFill(Unknown Source)
    at com.baomidou.mybatisplus.core.MybatisParameterHandler.lambda$updateFill$1(MybatisParameterHandler.java:167)
    at java.base/java.util.Optional.ifPresent(Optional.java:183)
    at com.baomidou.mybatisplus.core.MybatisParameterHandler.updateFill(MybatisParameterHandler.java:165)
    at com.baomidou.mybatisplus.core.MybatisParameterHandler.process(MybatisParameterHandler.java:115)
    at com.baomidou.mybatisplus.core.MybatisParameterHandler.processParameter(MybatisParameterHandler.java:81)
    at com.baomidou.mybatisplus.core.MybatisParameterHandler.<init>(MybatisParameterHandler.java:64)
    at com.baomidou.mybatisplus.core.MybatisXMLLanguageDriver.createParameterHandler(MybatisXMLLanguageDriver.java:35)

springboot项目 只需要在pom.xml中<debuglevel>设置source属性即可

<pluginManagement>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                    <configuration>
                        <includeSystemScope>true</includeSystemScope>
                    </configuration>
                </plugin>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-compiler-plugin</artifactId>
                    <configuration>
                        <release>${java.version}</release>
                        <!--                        <compilerArgs>&#45;&#45;enable-preview</compilerArgs>-->
                        <debug>true</debug>
                        <debuglevel>lines,vars,source</debuglevel>
                    </configuration>
                </plugin>
            </plugins>
        </pluginManagement>

在javac编译jar包是使用debuglevel的参数不同,编译出来的jar包大小存在差异。

如果没有vars参数,jar包进行远程调试的时候将不会显示局部变量名的值;

如果没有source参数时,异常打印的时候将会呈现Unknown Source这种形式;

java.lang.ArithmeticException: / by zero
 at Main.test(Unknown Source)
 at Common.getInfo(Unknown Source)
 at TestDumpStack.main(Unknown Source)

如果没有lines参数时,异常打印的时候将会呈现类名这种形式;

java.lang.ArithmeticException: / by zero
 at Main.test(Main.java)
 at Common.getInfo(TestDumpStack.java)
 at TestDumpStack.main(TestDumpStack.java)

项目Jenkins+k8s+springboot,本地启动测试时日志正常,只有测试和生产环境才不显示行号,一开始怀疑是jdk版本镜像和Jenkins打包配置问题,后多次尝试都不能解决,很多文章说设置debug = true就行,但原来设置的就是true后自己验证后是debuglevel参数缺少导致

参考文章:debuglevel="lines,vars,source"什么意思,有什么用? - 知乎

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值