当代码报错时不显示自己写的代码错误行号,而显示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>--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参数缺少导致