之前在AlmaLinux上安装了2.356版本的Jenkins(Jenkins从Ubuntu迁移至AlmaLinux问题及相关解决记录),但最近由于爆出安全漏洞(https://www.jenkins.io/security/advisory/2024-01-24/),因此将Jenkins升级至最新的2.426.3版本,完成后发现之前已经解决的节点机不支持中文项目名称的问题又出现了。
2.356版本是最后一个支持jdk 8的版本,后续版本都需要至少jdk 11才能启动节点机,之前,我在节点机的JVM选项中设置了-Dfile.encoding=UTF8 -Dsun.jnu.encoding=UTF8
,其中sun.jnu.encoding能解决中文项目名称报错的问题,但使用jdk 11后,发现节点机启动后,sun.jnu.encoding属性依旧是ANSI_X3.4-1968,JVM选项不生效。
在查找相关文档(https://github.com/AdoptOpenJDK/openjdk-docker/issues/105)后,发现问题原因是,在JDK 8之后的某个版本中,官方移除了对sun.jnu.encoding命令行参数的支持,完全以OS设置为准,因此-Dsun.jnu.encoding=UTF8不再生效,而解决方案是在启动前设置环境变量(节点机启动不会读取用户自己设置的环境变量,只有默认值),将编码指定为UTF-8。注意到节点机配置中有一条Prefix Start Agent Command,将其设置为export LC_ALL=en_US.UTF-8 &&
,这条命令会拼接在启动remoting.jar之前执行,使sun.jnu.encoding被正确设置为UTF-8。