Jenkins Pipeline Kubernetes Agent共享卷

33次阅读
没有评论

问题描述

在使用Jenkins Pipeline和Kubernetes Agent时,遇到了一个问题。他在pod模板中调度了多个容器,并希望为其中的一些容器创建共享卷,但遇到了困难。他需要知道如何创建一个在pod中的2个或多个容器之间共享的卷,并且该卷应该挂载到每个容器的特定路径上。用户还提到了文档的缺乏,希望能够获得相关的指导。

解决方案

请注意以下操作注意版本差异及修改前做好备份。
为了解决这个问题,你需要在容器的volumeMounts中包含卷的挂载路径。以下是修改后的示例Jenkinsfile

pipeline {
    agent {
        kubernetes {
            label 'test-pod'
            defaultContainer 'jnlp'
            yaml """
apiVersion: v1
kind: Pod
spec:
  containers:
  - name: frontend-test
    image: centos:7
    command:
    - cat
    tty: true
    volumeMounts:
    - mountPath: '/opt/app/shared'
      name: sharedvolume
  - name: backend-test
    image: centos:7
    command:
    - cat
    tty: true
    volumeMounts:
    - mountPath: '/opt/app/shared'
      name: sharedvolume
  volumes:
  - name: sharedvolume
    emptyDir: {}
"""
        }
    }
    stages {
        stage('Test Pipeline Configuration') {
            steps {
                container('frontend-test') {
                    sh 'touch /opt/app/shared/test_file'
                }
                container('backend-test') {
                    sh 'ls /opt/app/shared/test_file ; echo $?'
                }
            }
        }
    }
}

在上面的示例中,我们在容器的volumeMounts中指定了共享卷的挂载路径。这样就可以确保这两个容器都可以访问到共享卷。修改后的Jenkinsfile将解决这个问题。
请注意,这里使用的是emptyDir卷,它是一个临时卷,适用于容器之间共享数据。如果需要持久化的卷,可以根据实际需求选择其他类型的卷。

结果

修改后的Jenkinsfile解决了这个问题。

[Pipeline] podTemplate
[Pipeline] {
[Pipeline] node
Still waiting to schedule task
All nodes of label ‘test-pod’ are offline
Agent test-pod-wv12q-brfxj is provisioned from template Kubernetes Pod Template
Agent specification [Kubernetes Pod Template] (test-pod): Running on test-pod-wv12q-brfxj in /home/jenkins/workspace/pipeline-test
[Pipeline] {
[Pipeline] container
[Pipeline] {
[Pipeline] stage
[Pipeline] { (Test Pipeline Configuration)
[Pipeline] container
[Pipeline] {
[Pipeline] sh
[pipeline-test] Running shell script
+ touch /opt/app/shared/test_file
[Pipeline] }
[Pipeline] // container
[Pipeline] container
[Pipeline] {
[Pipeline] sh
[pipeline-test] Running shell script
+ ls /opt/app/shared/test_file
/opt/app/shared/test_file
+ echo 0
[Pipeline] }
[Pipeline] // container
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // container
[Pipeline] }
[Pipeline] // node
[Pipeline] }
[Pipeline] // podTemplate
[Pipeline] End of Pipeline
Finished: SUCCESS

正文完