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

项目背景: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,情况缓存,重新部署。乱码问题解决。