gpt4 book ai didi

java - MacOS Jenkins : Locating JRE and importing self-signed certificate

转载 作者:太空宇宙 更新时间:2023-11-03 13:31:55 25 4
gpt4 key购买 nike

在这里使用 macOS 的新手。

我们在 MacOS 上安装了 Jenkins。

我需要知道它使用了哪些 JRE 和 cacerts,因为我需要导入 GitHub 企业服务器的自签名证书进行集成。我有 SSL 错误并试图遵循 resolving PKIX-path-building-failed-error-message guide我在 Windows 中成功完成了。

在 Windows Jenkins 安装中,它有自己的 JENKINS_HOME/jre 文件夹,其中可以找到 lib/security/cacerts。

问题 1:MacOS 中 Jenkins 使用的 jre 在哪里/如何找到?

到目前为止,我发现的是

中的 java_home
/usr/libexec/java_home

但是这个我不太确定,因为我接下来的步骤结果失败了。

问题2:如何将修改后的cacerts文件的truststore和password添加到jenkins启动中?

使用/usr/libexec/java_home 中的 jre,我已将/jre/lib/security/cacerts 复制到我的 JENKINS_HOME/custom-keystore/cacerts 并在那里导入自签名证书。

sudo keytool -importcert -alias github -file JENKINS_HOME/custom-keystore/selfsigned.cer -keystore JENKINS_HOME/custom-keystore/cacerts

之后,我修改了 Jenkins 启动参数:

-Djavax.net.ssl.trustStore=$JAVA_HOME/jre/lib/security/cacert
-Djavax.net.ssl.trustStorePassword=changeit

使用:

defaults write /Library/Preferences/org.jenkins-ci.plist Djavax.net.ssl.keyStore JENKINS_HOME/custom-keystore/cacerts
defaults write /Library/Preferences/org.jenkins-ci.plist Djavax.net.ssl.keyStorePassword changeit

然后使用以下命令重新启动 Jenkins:

sudo launchctl unload /Library/LaunchDaemons/org.jenkins-ci.plist
sudo launchctl load /Library/LaunchDaemons/org.jenkins-ci.plist

在此之后,我遇到了各种问题:

  1. 代理问题 -(在代理列表中添加服务器 URL 后解决 - macOS 网络配置)

  2. GitHub 和其他之前成功的集成现在出现以下错误:

    javax.net.ssl.SSLHandshakeException: 握手期间远程主机关闭连接

其他问题我的步骤有什么遗漏吗?

我在 Jenkins 启动中添加参数的方式是否正确? (在Windows中,我只是修改了jenkins.xml,也使用了带有“-”的参数,而这里似乎不需要“-”?)

由于我使用的是 Launch Daemon 而不是 Launch Agent,是否需要重新启动系统? - 或者默认卸载和加载应该足以应用更改?

最佳答案

现在已经成功解决了问题。我纠正了 1 步,然后又添加了一步。

  1. 而不是使用

sudo defaults write/Library/Preferences/org.jenkins-ci.plist Djavax.net.ssl.trustStore/Users/Shared/Jenkins/Home/custom-keystore/cacerts

sudo defaults write/Library/Preferences/org.jenkins-ci.plist Djavax.net.ssl.trustStorePassword changeit

我编辑了 /Library/Application\Support/Jenkins 中的 jenkins_runner.sh:

javaArgs="-Dfile.encoding=UTF-8 -Djavax.net.ssl.trustStore=/Users/Shared/Jenkins/Home/custom-keystore/cacerts -Djavax.net.ssl.trustStorePassword=changeit"
  1. (restart) 执行完

    launchctl 卸载/Library/LaunchDaemons/org.jenkins-ci.plist

    launchctl 加载/Library/LaunchDaemons/org.jenkins-ci.plist

我发现我所做的更改并没有完全应用。所以我不得不重新启动我的 mac。

事实证明,我用于 keytool 和导入 cacerts 的/usr/libexec/java_home 中的 Java/JRE 是正确的。

关于java - MacOS Jenkins : Locating JRE and importing self-signed certificate,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51814445/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com