项目背景:Springboot+Maven,使用Jenkins部署在Linux上。

问题描述:idea本地测试,控制台System.out.print显示无异常,Slf4j日志显示无异常。Jenkins部署jar包启动后,log文件中System.out.print显示中文乱码,Slf4j中log显示中文无异常。

分析一:

查看linux的编码(使用命令),发现无异常,为UTF-8。

关于Java部署后,控制台中文乱码问题。

在Jenkins中设置java 启动项 -Dfile.encoding=UTF-8

关于Java部署后,控制台中文乱码问题。

重新部署启动,问题依然存在。

分析二:

考虑,可能是Maven,导致的中文乱码,于是在pom文件中添加jvm启动项。

<plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
    <configuration>
        <includeSystemScope>true</includeSystemScope>
        <fork>true</fork>
        <!--增加jvm参数-->
        <jvmArguments>-Dfile.encoding=UTF-8</jvmArguments>
    </configuration>
</plugin>

关于Java部署后,控制台中文乱码问题。

重新部署启动,问题依然存在。

分析三:

这个时候,其实就不太确定是哪里的问题了。

将项目,手动打包成jar包,现在Windows下运行,发现无中文乱码,如下图。

关于Java部署后,控制台中文乱码问题。

讲jar包放在服务器上,命令行启动,发现无中文乱码,如下图。

关于Java部署后,控制台中文乱码问题。

此时发现,问题出现在Jenkins的部署上,然后设置了Jenkins的全局变量LANG = zh_CN.UTF-8

关于Java部署后,控制台中文乱码问题。

 

重启Jenkins,情况缓存,重新部署。乱码问题解决。

相关文章:

  • 2021-03-27
  • 2021-09-08
  • 2021-04-24
  • 2021-06-09
  • 2021-08-06
  • 2021-11-04
猜你喜欢
  • 2021-08-21
  • 2021-10-01
  • 2022-01-17
  • 2021-09-20
  • 2021-05-08
  • 2021-12-22
  • 2022-12-23
相关资源
相似解决方案