V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
EthanLiao
V2EX  ›  问与答

基于 kubernetes、jenkins、etcd 的高效构建工具

  •  
  •   EthanLiao · 2017-04-24 10:01:04 +08:00 · 3622 次点击
    这是一个创建于 2768 天前的主题,其中的信息可能已经有所发展或是发生改变。

    Kubernetes 是 Google 开源的容器集群管理系统,其提供应用部署、维护、 扩展机制等功能,利用 Kubernetes 能方便地管理跨机器运行容器化的应用。下面我将在 macos 上搭建 minikube 与 kubectl 的 k8s 环境。

    Jenkins 是一个开源项目,提供了一种易于使用的持续集成系统,使开发者从繁杂的集成中解脱出来,专注于更为重要的业务逻辑实现上。同时 Jenkins 能实施监控集成中存在的错误,提供详细的日志文件和提醒功能,还能用图表的形式形象地展示项目构建的趋势和稳定性。

    Etcd 是一个高可用的键值存储系统,主要用于共享配置和服务发现。下面利用 etcd 作为旁路系统,主要用来实现状态变更的定制化操作与配置同步。

    环境搭建

    • mac os 10.12.3
    • docker <sup id="fnref:docker">1</sup>
    • jenkins <sup id="fnref:jenkins">2</sup>
    • registry <sup id="fnref:registry">3</sup>
    • minikube && kubectl <sup id="fnref:minikube">4</sup>
    • etcd <sup id="fnref:etcd">5</sup>

    在 k8s 中创建应用

    deploy app in k8s 此时应用所使用的镜像为app-k8stest:2

    稍等片刻直到应用启动完毕! app runing

    minikube service k8stest --url

    输入上述 host 可以打开应用。 k8s app runing

    新建并配置 jinkins 工作空间

    配置 jinkins 工作空间 构建的代码仓库为[email protected]:mythsumm/k8s-test.git/test 构建时需执行build.sh这个 shell 脚本,主要有三个步骤。 1. 用新提交的代码构建新镜像。 2. 将镜像打上标签并推到 registry 服务中。 3. 将容器中的镜像动态更新为刚 build 好的 registry 服务中的镜像。

    #!/usr/bin/env sh
    
    JOB_NAME=${JOB_NAME:-"k8stest"}
    BUILD_NUMBER=${BUILD_NUMBER:-1}
    
    REGISTRY_URL=${REGISTRY_URL:-"127.0.0.1:5000/liaotao/"}
    
    #docker build
    echo execute : docker build -t app-${JOB_NAME}:${BUILD_NUMBER} .
    docker build -t app-${JOB_NAME}:${BUILD_NUMBER} .
    
    #docker tag
    echo execute : docker tag app-${JOB_NAME}:${BUILD_NUMBER} ${REGISTRY_URL}app-${JOB_NAME}:${BUILD_NUMBER}
    docker tag app-${JOB_NAME}:${BUILD_NUMBER} ${REGISTRY_URL}app-${JOB_NAME}:${BUILD_NUMBER}
    
    #docker push
    echo execute : docker push ${REGISTRY_URL}app-${JOB_NAME}:${BUILD_NUMBER}
    docker push ${REGISTRY_URL}app-${JOB_NAME}:${BUILD_NUMBER}
    
    #Update existing container image(s) of resources
    /usr/local/bin/kubectl set image deployment/k8stest k8stest=${REGISTRY_URL}app-${JOB_NAME}:${BUILD_NUMBER} --namespace=default --kubeconfig=/Users/ethanliao/.kube/config
    
    

    构建过程中生成的镜像 registry

    如若此时修改server.php中的代码提交且在 jenkins 中再构建完毕,应用将使用最近一次构建的镜像。

    -<?php
    -var_dump($_SERVER);
    
    +<?php
    +phpinfo();
    

    #### 构建: jenkins

    k8s 中的镜像已经改变:

    images

    此时,应用也改变了。

    kubernetes app runing

    若应用使用的变量经常发生改变,如数据库地址等,则完全没有必要再重复一遍上面的流程。可以搭建一套变量配置系统,当相关应用所使用的变量发生改变时则改变其在 etcd 中的值,如若此时该应用一直侦听 etcd 中的值,就可以同步至最新的变量。

    1. 搭建 etcd 服务器
    2. 变量配置系统中用 etcd 设置值 composer update “ linkorb/etcd-php ”: “ 1.2.1 ” && $client->set(‘’, ‘’);
    3. 容器在启动后运行bypass.sh循环监听值的变化

    结束语

    如上所述,则可以搭建一套高效的构建工具。既可以使用 k8s 的灵活伸缩性,也能方便的配置变量等…。

    refs:

    以上内容为本人原创( http://postdev.net ) 原文地址: http://postdev.net/2017/04/23/%E5%9F%BA%E4%BA%8Ekubernetes-jenkins-etcd%E7%9A%84%E9%AB%98%E6%95%88%E6%9E%84%E5%BB%BA%E5%B7%A5%E5%85%B7.html

    6 条回复    2018-08-27 16:21:32 +08:00
    yoke123
        1
    yoke123  
       2017-06-23 15:33:02 +08:00
    问下 如果只是单纯 需要 etcd 管理配置文件 可以吗?
    场景:
    项目需要 利用 etcd 管理项目配置文件 并且要有一个 etcd 管理界面
    请问你有什么心得吗
    EthanLiao
        2
    EthanLiao  
    OP
       2017-06-30 15:09:47 +08:00
    @yoke123 分享下我单位的实践。配置我们都是存放在 mysql 中的,etcd 只是在发布的时候被客户端调用,然后服务端通过 watch 的方式获取发布数据并修改服务器配置文件。
    yoke123
        3
    yoke123  
       2017-06-30 15:11:44 +08:00
    那 管理界面呢.....这蛋疼的需求
    EthanLiao
        4
    EthanLiao  
    OP
       2017-06-30 15:28:28 +08:00
    @yoke123 管理界面就是普通的 curd 界面额,我们是自己写的。总共两个页面,一个应用页面,应用页面下面带了一个配置页面。应用页面为应用列表,应用支持多类型( php,java...)多环境( dev,test,production )和多文件,可编辑。配置页面主要是某应用在某环境下的配置文件列表,可编辑、对比。发布是以某个应用下的某个环境为单位发布( etcd )。
    yoke123
        5
    yoke123  
       2017-06-30 15:36:59 +08:00
    谢谢解答
    37Y37
        6
    37Y37  
       2018-08-27 16:21:32 +08:00
    @yoke123 可以只用 etcd 来管理配置文件,看这文章:aHR0cHMlM0EvL21wLndlaXhpbi5xcS5jb20vcy91R1V2VjRqbDRZSXZOenR1ZXBkQzhB (base64 解下吧,发不了链接)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3142 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 00:18 · PVG 08:18 · LAX 16:18 · JFK 19:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.