Jenkins CLI 连接被拒绝
Jenkins CLI connection refused
执行时
java -jar jenkins-cli.jar -s https://jenkins_url help
由于某种原因,我的连接被拒绝。 Jenkins 版本是 1580.3,用户在 Jenkins 服务器上有权限,cli jar 是最新的并且 ssh public 密钥配置正确。知道是什么原因造成的吗?如果有帮助,这里是堆栈跟踪:
Exception in thread "main" java.net.ConnectException: Connection refused
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.AbstractPlainSocketImpl.doConnect(Unknown Source)
at java.net.AbstractPlainSocketImpl.connectToAddress(Unknown Source)
at java.net.AbstractPlainSocketImpl.connect(Unknown Source)
at java.net.SocksSocketImpl.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at hudson.cli.CLI.connectViaCliPort(CLI.java:203)
at hudson.cli.CLI.<init>(CLI.java:126)
at hudson.cli.CLIConnectionFactory.connect(CLIConnectionFactory.java:72)
at hudson.cli.CLI._main(CLI.java:466)
at hudson.cli.CLI.main(CLI.java:382)
Suppressed: java.io.EOFException: unexpected stream termination
at hudson.remoting.ChannelBuilder.negotiate(ChannelBuilder.java:331)
at hudson.remoting.Channel.<init>(Channel.java:421)
at hudson.remoting.Channel.<init>(Channel.java:400)
at hudson.remoting.Channel.<init>(Channel.java:396)
at hudson.remoting.Channel.<init>(Channel.java:385)
at hudson.remoting.Channel.<init>(Channel.java:377)
at hudson.remoting.Channel.<init>(Channel.java:353)
at hudson.cli.CLI.connectViaHttp(CLI.java:157)
at hudson.cli.CLI.<init>(CLI.java:130)
... 3 more
如果连接被拒绝,可能是 CLI 被禁用,但更有可能是防火墙或网络问题。
对 Jenkins 的每个成功 HTTP 请求都会以 CLI 端口作为 HTTP header 进行响应,因此您可以快速检查它是否已启用:
curl -sI http://jenkins/ | grep CLI
或者,如 documented on the wiki, you can check whether the TCP port is enabled. Look for "TCP port for JNLP slave agents" at http://jenkins/configureSecurity/
但是,由于您的堆栈跟踪指示 CLI 客户端正在尝试建立到特定端口的连接,这表明 CLI 已启用,并且 Jenkins 正在其 HTTP 响应中公布该端口号。
因此您可以尝试手动连接到该端口,以检查它是否打开:
telnet jenkins <cli-port>
如果您在此处也看到 "Connection refused",那么您就知道您的 Jenkins 和 CLI 客户端设置似乎没问题,但您遇到了网络问题。在这种情况下,请检查 Jenkins 服务器上的防火墙是否允许该 CLI 端口上的传入连接。
为了使防火墙配置更简单,您可以在上述"configure security"页面中从随机端口切换到固定端口。
我在 Ubuntu 16.04 上遇到了这个问题。
注意:这个错误发生在我身上很好之前设置并有 运行 成功的构建作业。这发生在我 运行 一个特别繁重的构建工作之后。因此,假设错误不是防火墙问题,我的修复可能会起作用。
首先,我尝试使用 jenkins-cli.jar
工具通过命令行安全重启:
java -jar jenkins-cli.jar -s http://localhost:8080 -auth <username>:<password> safe-restart
但也收到了相同的 Connection refused
错误消息。
所以作为最后的手段,我尝试像这样在服务器上重新启动 Jenkins 服务:
sudo systemctl restart jenkins
然后修复了它。
执行时
java -jar jenkins-cli.jar -s https://jenkins_url help
由于某种原因,我的连接被拒绝。 Jenkins 版本是 1580.3,用户在 Jenkins 服务器上有权限,cli jar 是最新的并且 ssh public 密钥配置正确。知道是什么原因造成的吗?如果有帮助,这里是堆栈跟踪:
Exception in thread "main" java.net.ConnectException: Connection refused
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.AbstractPlainSocketImpl.doConnect(Unknown Source)
at java.net.AbstractPlainSocketImpl.connectToAddress(Unknown Source)
at java.net.AbstractPlainSocketImpl.connect(Unknown Source)
at java.net.SocksSocketImpl.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at hudson.cli.CLI.connectViaCliPort(CLI.java:203)
at hudson.cli.CLI.<init>(CLI.java:126)
at hudson.cli.CLIConnectionFactory.connect(CLIConnectionFactory.java:72)
at hudson.cli.CLI._main(CLI.java:466)
at hudson.cli.CLI.main(CLI.java:382)
Suppressed: java.io.EOFException: unexpected stream termination
at hudson.remoting.ChannelBuilder.negotiate(ChannelBuilder.java:331)
at hudson.remoting.Channel.<init>(Channel.java:421)
at hudson.remoting.Channel.<init>(Channel.java:400)
at hudson.remoting.Channel.<init>(Channel.java:396)
at hudson.remoting.Channel.<init>(Channel.java:385)
at hudson.remoting.Channel.<init>(Channel.java:377)
at hudson.remoting.Channel.<init>(Channel.java:353)
at hudson.cli.CLI.connectViaHttp(CLI.java:157)
at hudson.cli.CLI.<init>(CLI.java:130)
... 3 more
如果连接被拒绝,可能是 CLI 被禁用,但更有可能是防火墙或网络问题。
对 Jenkins 的每个成功 HTTP 请求都会以 CLI 端口作为 HTTP header 进行响应,因此您可以快速检查它是否已启用:
curl -sI http://jenkins/ | grep CLI
或者,如 documented on the wiki, you can check whether the TCP port is enabled. Look for "TCP port for JNLP slave agents" at http://jenkins/configureSecurity/
但是,由于您的堆栈跟踪指示 CLI 客户端正在尝试建立到特定端口的连接,这表明 CLI 已启用,并且 Jenkins 正在其 HTTP 响应中公布该端口号。
因此您可以尝试手动连接到该端口,以检查它是否打开:
telnet jenkins <cli-port>
如果您在此处也看到 "Connection refused",那么您就知道您的 Jenkins 和 CLI 客户端设置似乎没问题,但您遇到了网络问题。在这种情况下,请检查 Jenkins 服务器上的防火墙是否允许该 CLI 端口上的传入连接。
为了使防火墙配置更简单,您可以在上述"configure security"页面中从随机端口切换到固定端口。
我在 Ubuntu 16.04 上遇到了这个问题。
注意:这个错误发生在我身上很好之前设置并有 运行 成功的构建作业。这发生在我 运行 一个特别繁重的构建工作之后。因此,假设错误不是防火墙问题,我的修复可能会起作用。
首先,我尝试使用 jenkins-cli.jar
工具通过命令行安全重启:
java -jar jenkins-cli.jar -s http://localhost:8080 -auth <username>:<password> safe-restart
但也收到了相同的 Connection refused
错误消息。
所以作为最后的手段,我尝试像这样在服务器上重新启动 Jenkins 服务:
sudo systemctl restart jenkins
然后修复了它。