前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CI/CD:基于K8s弹性资源池的配置【第二步】编写Pipeline脚本实现自动化

CI/CD:基于K8s弹性资源池的配置【第二步】编写Pipeline脚本实现自动化

作者头像
DevOps云学堂
发布2022-10-04 14:48:40
9080
发布2022-10-04 14:48:40
举报
文章被收录于专栏:DevOps持续集成

上一篇文章 CI/CD:基于K8s弹性资源池的配置【第一步】自动化创建Jenkins的Agent节点 我们通过运行Jenkins Groovy脚本来增加了一个Jenkins Agent节点。那么现在思考一个问题,弹性构建的实现方式有多种, 如果我们的实现方式是:

运行Pipeline作业时启动一个Jenkins Agent 节点,然后作业结束后回收此节点。

该如何实现?大概的步骤:

  1. 创建Jenkins Agent;
  2. 获取Jenkins Agent的参数;
  3. 渲染yaml模板;
  4. 调用K8s API在固定的NS中创建一个Pod;
  5. 调度Jenkins pipeline到agent;

这么多步骤实现起来还是有点复杂的, 本文我们先实现第1和2步骤。(还记得上篇文章中提到的一个关于序列化的问题,这次我们通过ScriptConsole 来解决)

实现思路

也就是说我们将上篇文章写的groovy脚本,存储到SharedLibrary中,然后调用ScriptConsole来运行。

将脚本上传到resources/scripts 目录中,然后pipeline中导入共享库,并加载 libraryResource

代码语言:javascript
复制
@Library("mylib@feature-k8s") _     //加载共享库
import org.devops.*      

env.namespace = "jenkins"
env.agentName = "jenkinsagent${UUID.randomUUID().toString()[0..7]}"

因为脚本是通过ScriptConsole运行,所以这里需要通过API来完成,于是有了下面的方法:

代码语言:javascript
复制
// ScriptConsole运行脚本
def RunScriptConsole(scriptContent, crumb){
    response = sh returnStdout: true, 
                  script: """
                    curl -s -d "script=\$(cat ${scriptContent})" \
                    --header "Jenkins-Crumb:${crumb}" \
                    -X  POST http://admin:112374bd5c557010386b55bb85a777aded@192.168.1.200:8080/scriptText
                    """
    try {
        response = readJSON text: response - "Result: "
    } catch(e){
        println(e)
    }
    return response
}


// 获取Crumb值
def GetCrumb(){
    response = sh returnStdout: true, 
                  script: """ curl -s -u admin:admin \
                                   --location \
                                   --request GET 'http://192.168.1.200:8080/crumbIssuer/api/json' """
    response = readJSON text: response
    return  response.crumb
}

上面的代码没有做太多的优化,存在明文密码的问题,后面可以试着放到凭据中完善一下。这里注意:

  • 需要通过Crumb API获取value,并添加到HTTP request中的header中。
  • 使用Jenkis用户名和API token进行认证。

封装Pipeline

加载resource中的脚本,然后写到本地文件,然后通过API 在 ScriptConsole中运行。

代码语言:javascript
复制
stage("CreateBuildENV"){
    steps{
        script{
            // Get agent create script
            scriptContent = libraryResource 'scripts/create_jenkins_agent.groovy'
            scriptContent = scriptContent.replaceAll("__AGENT_NAME__","${env.agentName}")
            writeFile file: 'create_jenkins_agent.groovy', text: scriptContent

            // Run agent create script
            jenkinsCrumb = GetCrumb()
            agentConfig = RunScriptConsole("create_jenkins_agent.groovy", jenkinsCrumb)
        }
    }
}

代码语言:javascript
复制
 stage("DeleteBuildENV"){
      steps{
          script{
              //Delete kubernetes agent pod


              //Delete jenkins agent
              // Get agent delete script
              scriptContent = libraryResource 'scripts/delete_jenkins_agent.groovy'
              scriptContent = scriptContent.replaceAll("__AGENT_NAME__","${env.agentName}")
              writeFile file: 'delete_jenkins_agent.groovy', text: scriptContent

              // Run agent delete script
              jenkinsCrumb = GetCrumb()
              agentConfig = RunScriptConsole("delete_jenkins_agent.groovy", jenkinsCrumb)
          }
      }
  }


总结

通过上述的步骤,当你运行流水线的时候会自动创建一个Jenkins Agent(当然现在仅是创建Agent,但是Agent并没有连接到Master节点,所以无法运行Pipeline) 能够看到效果是Agent的自动添加和销毁。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-07-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 DevOps云学堂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 实现思路
  • 封装Pipeline
  • 总结
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档