【发布时间】:2016-11-24 00:28:53
【问题描述】:
我正在尝试使用 Jenkins/Kubernetes 插件与 Jenkins 协调 docker slaves。
我正在使用这个插件:https://github.com/jenkinsci/kubernetes-plugin
我的问题是所有的slave都离线了,所以作业无法执行:
我已经在我的本地机器上使用 minikube 以及在我们的操作组托管的 K8 集群上进行了尝试。我已经尝试过 Jenkins 1.9 和 Jenkins 2。我总是得到相同的结果。截图来自 Jenkins 1.642.4, K8 v1.2.0
这是我的配置...请注意,当我单击“测试连接”时,我会成功。另请注意,我不需要任何凭据(这是我能看到的与记录示例的唯一区别)。
Jenkins 日志一遍又一遍地显示以下内容:
Waiting for slave to connect (11/100): docker-6b55f1b7fafce
Jul 20, 2016 5:01:06 PM INFO org.csanchez.jenkins.plugins.kubernetes.KubernetesCloud$ProvisioningCallback call
Waiting for slave to connect (12/100): docker-6b55f1b7fafce
Jul 20, 2016 5:01:07 PM INFO org.csanchez.jenkins.plugins.kubernetes.KubernetesCloud$ProvisioningCallback call
Waiting for slave to connect (13/100): docker-6b55f1b7fafce
Jul 20, 2016 5:01:08 PM INFO org.csanchez.jenkins.plugins.kubernetes.KubernetesCloud$ProvisioningCallback call
当我运行kubectl get events 时,我看到了这个:
24s 24s 1 docker-6b3c2ff27dad3 Pod Normal Scheduled {default-scheduler } Successfully assigned docker-6b3c2ff27dad3 to 96.xxx.xx.159
24s 23s 2 docker-6b3c2ff27dad3 Pod Warning MissingClusterDNS {kubelet 96.xxx.xx.159} kubelet does not have ClusterDNS IP configured and cannot create Pod using "ClusterFirst" policy. Falling back to DNSDefault policy.
23s 23s 1 docker-6b3c2ff27dad3 Pod spec.containers{slave} Normal Pulled {kubelet 96.xxx.xx.159} Container image "jenkinsci/jnlp-slave" already present on machine
23s 23s 1 docker-6b3c2ff27dad3 Pod spec.containers{slave} Normal Created {kubelet 96.xxx.xx.159} Created container with docker id 82fcf1bd0328
23s 23s 1 docker-6b3c2ff27dad3 Pod spec.containers{slave} Normal Started {kubelet 96.xxx.xx.159} Started container with docker id 82fcf1bd0328
有什么想法吗?
更新:csanchez 建议的更多日志信息
➜ docker git:(master) ✗ kubectl get pods --namespace default -o wide
NAME READY STATUS RESTARTS AGE NODE
docker-6bb647254a2a4 1/1 Running 0 1m 96.x.x.159
➜ docker git:(master) ✗ kubectl log docker-6bafbac10b392
Jul 20, 2016 6:45:10 PM hudson.remoting.jnlp.Main$CuiListener status
INFO: Connecting to 96.x.x.159:50000 (retrying:10)
java.net.ConnectException: Connection refused
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
我得看看这个50000端口是干什么用的??
【问题讨论】:
-
您需要检查您的 pod 连接失败的原因。
kubectl get pods和检查失败 pod 的日志 -
已更新日志信息,谢谢!
-
知道了,@csanchez!所以问题是 jenkins 也在 k8 中运行,所以端口 50000 是动态的。将 jenkins 隧道更改为 k8 分配的端口解决了问题。
标签: jenkins docker kubernetes