Jenkinsfile 自动部署到 EKS


当我

运行 Jenkinsjob 时,如何传递我的 aws 凭证以此为例 https://github.com/PaulMaddox/amazon-eks-kubectl

$ docker run -v ~/.aws:/home/kubectl/.aws -e CLUSTER=demo    maddox/kubectl get services

以上适用于我的笔记本电脑,但我想在文件上传递 aws 凭据。我在我的 Jenkins 中配置了 aws-->凭证。我还有一个 bitbucket 存储库,其中包含一个 Jenkinsfile 和一个用于"服务"和"部署"的 yam 文件

我现在这样做的方式是运行 kubectl create -f 文件名.yaml 并部署到 eks .. 只想做同样的事情,但使用 Jenkinsfile 自动化它,关于如何使用 kubectl 或 helm 执行此操作的建议

在你的 Jenkinsfile 中,你应该包括类似的部分:

 stage('Deploy on Dev') {
    node('master'){
        withEnv(["KUBECONFIG=${JENKINS_HOME}/.kube/dev-config","IMAGE=${ACCOUNT}.dkr.ecr.us-east-1.amazonaws.com/${ECR_REPO_NAME}:${IMAGETAG}"]){
            sh "sed -i 's|IMAGE|${IMAGE}|g' k8s/deployment.yaml"
            sh "sed -i 's|ACCOUNT|${ACCOUNT}|g' k8s/service.yaml"
            sh "sed -i 's|ENVIRONMENT|dev|g' k8s/*.yaml"
            sh "sed -i 's|BUILD_NUMBER|01|g' k8s/*.yaml"
            sh "kubectl apply -f k8s"
            DEPLOYMENT = sh (
                script: 'cat k8s/deployment.yaml | yq -r .metadata.name',
                returnStdout: true
            ).trim()
            echo "Creating k8s resources..."
            sleep 180
            DESIRED= sh (
                script: "kubectl get deployment/$DEPLOYMENT | awk '{print $2}' | grep -v DESIRED",
                returnStdout: true
            ).trim()
            CURRENT= sh (
                script: "kubectl get deployment/$DEPLOYMENT | awk '{print $3}' | grep -v CURRENT",
                returnStdout: true
            ).trim()
            if (DESIRED.equals(CURRENT)) {
                currentBuild.result = "SUCCESS"
                return
            } else {
                error("Deployment Unsuccessful.")
                currentBuild.result = "FAILURE"
                return
            }
        }
    }
  }
}

这将负责自动化部署过程。

我希望它有所帮助。

最新更新