如何通过实际运行的JNLP连接强制jenkins从属服务器通过其运行命令连接到内部主机名?
以下是有关实际问题的更多信息(使用伪造域)
命令运行:
java -jar slave.jar \
-jnlpUrl http://jenkins.fakehost.internal/computer/SLAVE_NAME/slave-agent.jnlp \
-secret SECRET;
Run Code Online (Sandbox Code Playgroud)
输出...
Sep 04, 2016 5:21:38 PM hudson.remoting.jnlp.Main$CuiListener status
9/5/2016 1:21:38 AMINFO: Locating server among [https://jenkins.fakehost.com/, http://jenkins-internal.fakehost.com/]
9/5/2016 1:21:38 AMSep 04, 2016 5:21:38 PM hudson.remoting.jnlp.Main$CuiListener status
9/5/2016 1:21:38 AMINFO: Handshaking
9/5/2016 1:21:38 AMSep 04, 2016 5:21:38 PM hudson.remoting.jnlp.Main$CuiListener status
9/5/2016 1:21:38 AMINFO: Connecting to jenkins.fakehost.com:50000
Run Code Online (Sandbox Code Playgroud)
随后导致。
9/5/2016 1:23:56 AM java.net.ConnectException: Connection timed out
9/5/2016 1:23:56 AM at java.net.PlainSocketImpl.socketConnect(Native Method)
9/5/2016 1:23:56 AM at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)
9/5/2016 1:23:56 AM at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
9/5/2016 1:23:56 AM at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
9/5/2016 1:23:56 AM at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
9/5/2016 1:23:56 AM at java.net.Socket.connect(Socket.java:589)
9/5/2016 1:23:56 AM at java.net.Socket.connect(Socket.java:538)
9/5/2016 1:23:56 AM at hudson.remoting.Engine.connect(Engine.java:369)
9/5/2016 1:23:56 AM at hudson.remoting.Engine.run(Engine.java:267)
Run Code Online (Sandbox Code Playgroud)
问题是,尽管提供了内部主机名,但从代理仍尝试检查其公共主机名。并且作为其https端口,但50k内部端口无效。绝望地尝试无法到达的港口。
我试图覆盖命令以强制其使用内部主机名,从属设备支持
在您的JNLP从站的高级配置选项卡中,有一个选项Tunnel connection through。
输入jenkins.fakehost.internal:应该可以解决问题。
| 归档时间: |
|
| 查看次数: |
1122 次 |
| 最近记录: |