强迫詹金斯奴隶使用内部主机?

Pic*_*tor 3 jenkins

如何通过实际运行的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内部端口无效。绝望地尝试无法到达的港口。

我试图覆盖命令以强制其使用内部主机名,从属设备支持

Ale*_*x O 5

在您的JNLP从站的高级配置选项卡中,有一个选项Tunnel connection through

输入jenkins.fakehost.internal:应该可以解决问题。