一、问题描述:

在Linux环境Centos操作系统下,通过Docker下载Jenkins镜像后创建了容器,并且通过服务器IP+端口访问Jenkins地址,进行相关的配置,然后创建任务job来构建跑java+selenium自动化测试脚本,目前构建Success,唯一不足之处是打印的日志出现就了乱码,如下图:

(备注:执行机就是jenkins本身,同一台机器)

Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题

二、排查Jenkins设置

Jenkins系统设置查看全局属性中语言部分

Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题

2.Jenkins详细信息(浏览器Jenkins地址后面加上/systemInfo)

Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题 Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题

三、代码log日志编码方式

1.打印的日志确认是否是utf-8,已确认是

Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题

四、 Linux服务器语言信息

1.查看宿主机语言配置,输入命令:locale -a

Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题

2.查看/.vimrc

此处没敢改,因为不确会影响范围,只是在CSDN找的文章

Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题

这块不是很明白,网上给出的答案是:

https://blog.csdn.net/u010189459/article/details/38338735

大概的意思是在vimrc里面encoding可同时做这几项设置:

set encoding=utf-8 set langmenu=zh_CN.UTF-8 language message zh_CN.UTF-8

五、终极排查

既然Jenkins系统设置、宿主机的语言都已经排查,现在开始排查容器

1.进入到Jenkins容器里面

docker exec -it 容器ID /bin/bash

查看语言

Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题

然后再输入

export LC_ALL="C.UTF-8"

在/etc/bash.bashrc里面末尾写入,然后source /etc/bash.bashrc然后发现没有vim,算了不折腾了。

lc_all实际上就是给上面的所有变量赋值,效果一样,不过试试也无妨,一般来说没有,docker本身就有完整的操作系统,跟宿主机没关系。

2.进入到Chrome浏览器容器里面

set LC_ALL="C.UTF-8"

Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题

3.然后Jenkins系统设置修改全局属性,将之前的LANG = zh_CN .UTF-8改成LANG = C.UTF-8 原因是:目前市场上做服务器基本被centos和debian占据吧,centos依靠redhat,debian自源,centos源于红帽,各种补丁以及服务更完善些,centos做服务器也较多吧,自动化部门我没猜错的话jenkins所在的宿主机用的是debian系统不是centos,因为debian中locale是支持zh_CN.UTF-8,centos支持C.UTF-8

Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题

最后重启下jenkins服务(jenkins地址后加上/restart),然后启动任务查看jenkins控制台的日志!

Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题

后记,可能是容器里面需要设置下语言,jenkins系统设置全局属性语言LANG = C.UTF-8有关系。

总结

以上所述是小编给大家介绍的Docker环境搭建Jenkins在构建任务时控制台日志出现中文乱码的问题,希望对大家有所帮助!

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!

RTX 5090要首发 性能要翻倍!三星展示GDDR7显存

三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。

首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。

据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。