Jenkins从属JNLP4-连接超时

Jenkins从属JNLP4-连接超时,jenkins,jnlp,Jenkins,Jnlp,我在詹金斯的一些工作中看到了这个错误 Cannot contact jenkins-slave-l65p0-0f7m0: hudson.remoting.ChannelClosedException: Channel "unknown": Remote call on JNLP4-connect connection from 100.99.111.187/100.99.111.187:46776 failed. The channel is closing down or has closed

我在詹金斯的一些工作中看到了这个错误

Cannot contact jenkins-slave-l65p0-0f7m0: hudson.remoting.ChannelClosedException: Channel "unknown": Remote call on JNLP4-connect connection from 100.99.111.187/100.99.111.187:46776 failed. The channel is closing down or has closed down
我有一个詹金斯主-从设置

在从属服务器上找到以下日志

java.nio.channels.ClosedChannelException
    at org.jenkinsci.remoting.protocol.NetworkLayer.onRecvClosed(NetworkLayer.java:154)
    at org.jenkinsci.remoting.protocol.impl.NIONetworkLayer.ready(NIONetworkLayer.java:142)
    at org.jenkinsci.remoting.protocol.IOHub$OnReady.run(IOHub.java:795)
    at jenkins.util.ContextResettingExecutorService$1.run(ContextResettingExecutorService.java:28)
    at jenkins.security.ImpersonatingExecutorService$1.run(ImpersonatingExecutorService.java:59)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at java.lang.Thread.run(Thread.java:748)
詹金斯在库伯内特斯星系团

apiVersion: apps/v1beta1
kind: StatefulSet
metadata:
  namespace: default
  name: jenkins-deployment
spec:
  serviceName: "jenkins-pod"
  replicas: 1
  template:
    metadata:
      labels:
        app: jenkins-pod
    spec:
      initContainers:
      - name: volume-mount-hack
        image: busybox
        command: ["sh", "-c", "chmod -R 777 /usr/mnt"]
        volumeMounts:
        - name: jenkinsdir
          mountPath: /usr/mnt
      containers:
      - name: jenkins-container
         imagePullPolicy: Always
        readinessProbe:
          exec:
            command:
              - curl
              - http://localhost:8080/login
              - -o
              - /dev/null
        livenessProbe:
          httpGet:
            path: /login
            port: 8080
          initialDelaySeconds: 120
          periodSeconds: 10
        env:
         - name: JAVA_OPTS
           value: "-Dhudson.slaves.NodeProvisioner.initialDelay=0 -Dhudson.slaves.NodeProvisioner.MARGIN=50 -Dhudson.slaves.NodeProvisioner.MARGIN0=0.85"
        resources:
          requests:
            memory: "7100Mi"
            cpu: "2000m"
        ports:
        - name: http-port
          containerPort: 8080
        - name: jnlp-port
          containerPort: 50000
        volumeMounts:
          - mountPath: /var/run
            name: docker-sock
          - mountPath: /var/jenkins_home
            name: jenkinsdir
      volumes:
        - name: jenkinsdir
          persistentVolumeClaim:
            claimName: "jenkins-persistence"
        - name: docker-sock
          hostPath:
            path: /var/run
---
apiVersion: v1
kind: Service
metadata:
  namespace: default
  name: jenkins
  labels:
    app: jenkins
spec:
  type: NodePort
  ports:
  - name: http
    port: 8080
    targetPort: 8080
    nodePort: 30099
    protocol: TCP
  selector:
    app: jenkins-pod
---
apiVersion: v1
kind: Service
metadata:
  namespace: default
  name: jenkins-external
  annotations:
        service.beta.kubernetes.io/aws-load-balancer-internal: 0.0.0.0/0
  labels:
    app: jenkins
spec:
  type: LoadBalancer
  ports:
  - name: http
    port: 8080
    targetPort: 8080
    protocol: TCP
  selector:
    app: jenkins-pod
---
apiVersion: policy/v1beta1
kind: PodDisruptionBudget
metadata:
  name: jenkins-master-pdb
  namespace: default
spec:
  maxUnavailable: 0
  selector:
    matchLabels:
      app: jenkins-pod
---
apiVersion: policy/v1beta1
kind: PodDisruptionBudget
metadata:
  name: jenkins-slave-pdb
  namespace: default
spec:
  maxUnavailable: 0
  selector:
    matchLabels:
      jenkins: slave
---
kind: Service
apiVersion: v1
metadata:
  name: jenkins-discovery
  namespace: default
  labels:
    app: jenkins
spec:
  selector:
    app: jenkins-pod
  ports:
    - protocol: TCP
      port: 50000
      targetPort: 50000
      name: slaves

我怀疑这和库伯内特斯有什么关系,但还是把它说出来

您是否在Jenkins本身中配置了JNLP端口?它位于管理Jenkins>配置全局安全>代理中。单击“修复”单选按钮(因为您已经分配了TCP端口)。将“JNLP代理的TCP端口”设置为50000

我假设您正在使用

您可以在Kubernetes吊舱模板下增加Jenkins连接的超时时间(以秒为单位)。它可能会解决你的问题

Jenkins连接的超时说明(秒):

指定Jenkins等待JNLP的时间(以秒为单位) 代理来建立连接。值应为正整数, 默认值为100

我认为,“詹金斯奴隶”不是一个有效的名字。您可以尝试将其重命名为“jnlp”

请在此解释:


您是否会尝试此功能?有什么帮助吗?你是如何解决这个问题的?我也有同样的错误,只是我们使用的是Docker而不是Kubernetes。没有可靠地解决这个问题,但是升级图片/插件版本有帮助。具体是哪个图片/插件?