Jenkins X–(7)虚拟机里搭建Jenkins X环境

  • 2019 年 11 月 28 日
  • 笔记

上一节《Jenkins X–(6)虚拟机里搭建Minikube环境》,我们已经完成了基于minikube的K8s环境的搭建,如果只是学习K8s这个环境就够了。这一节,我们要在这个K8s集群上,搭建一套云原生时代CICD的开源框架:Jenkins X

jenkins-x-versions:v1.0.118  https://github.com/jenkins-x/jenkins-x-versions  jx:                2.0.844   https://github.com/jenkins-x/jx  jenkins-x-platform:2.0.1413  https://github.com/jenkins-x/jenkins-x-platform

jenkins-x-versions是一个包含与jenkins-x及其相关程序一起使用的packages和helm charts的一致的版本集合。jenkins-x-versions v1.0.118 对应的jx版本是2.0.844,jenkins-x-platform的版本是2.0.1413。

1、首先安装jx

首先在本机上安装一个命令行工具jx,用于安装和使用Jenkins X

jx可以安装在MacOs,Linux和Window上。可以参考:https://github.com/jenkins-x/jx/releases

这里执行一下命令安装2.0.844版本的jx

curl -L https://github.com/jenkins-x/jx/releases/download/v2.0.844/jx-linux-amd64.tar.gz | tar xzv  sudo mv jx /usr/local/bin

验证jx是否安装成功,输入:jx,显示jx的命令清单。

  [root@learncloudnative ~]# jx  jx is a command line tool for working with Jenkins XWARNING: Unable to load managed plugins because customresourcedefinitions.apiextensions.k8s.io "plugins.jenkins.io" not found      Installing:    profile          Set your jx profile    boot             Boots up Jenkins X in a Kubernetes cluster using GitOps and a Jenkins X Pipeline    install          Install Jenkins X in the current Kubernetes cluster    uninstall        Uninstall the Jenkins X platform    upgrade          Upgrades a resource    create cluster   Create a new Kubernetes cluster    update cluster   Updates an existing Kubernetes cluster    create jenkins token Adds a new username and API token for a Jenkins server    delete jenkins token Deletes one or more Jenkins user API tokens    init             Init Jenkins X    Adding Projects to Jenkins X:    import           Imports a local project or Git repository into Jenkins    create archetype Create a new app from a Maven Archetype and import the generated code into Git and Jenkins for CI/CD    create spring    Create a new Spring Boot application and import the generated code into Git and Jenkins for CI/CD    create lile      Create a new Lile based application and import the generated code into Git and Jenkins for CI/CD    create micro     Create a new micro based application and import the generated code into Git and Jenkins for CI/CD    create quickstart Create a new app from a Quickstart and import the generated code into Git and Jenkins for CI/CD    create quickstartlocation Create a location of quickstarts for your team    Apps:    create addon     Creates an addon    create token addon Adds a new token/login for a user for a given addon    delete addon     Deletes one or more addons    delete token addon Deletes one or more API tokens for a user on an issue addon server    delete app       Deletes one or more apps from Jenkins X    delete application Deletes one or more applications from Jenkins    add app          Adds an app    Git:    create git server Creates a new Git server from a URL and kind    delete git server Deletes one or more Git servers    create git token Adds a new API token for a user on a Git server    delete git token Deletes one or more API tokens for a user on a Git server    repository       Opens the web page for the current Git repository in a browser    Working with Kubernetes:    compliance       Run compliance tests against Kubernetes cluster    completion       Output shell completion code for the given shell (bash or zsh)    context          View or change the current Kubernetes context (Kubernetes cluster)    environment      View or change the current environment in the current Kubernetes cluster    team             View or change the current team in the current Kubernetes cluster    namespace        View or change the current namespace context in the current Kubernetes cluster    prompt           Generate the command line prompt for the current team and environment    scan             Perform a scan action    shell            Create a sub shell so that changes to the Kubernetes context, namespace or environment remain local to the shell    status           status of the Kubernetes cluster or named node    Working with Applications:    console          Opens the Jenkins console    logs             Tails the log of the latest pod for a deployment    open             Open a service in a browser    rsh              Opens a terminal in a pod or runs a command in the pod    sync             Synchronises your local files to a DevPod    Working with CloudBees application:    cloudbees        Opens the CloudBees app for Kubernetes for visualising CI/CD and your environments    login            Onboard an user into the CloudBees application    Working with Environments:    preview          Creates or updates a Preview Environment for the current version of an application    promote          Promotes a version of an application to an Environment    create addon environment Create an Environment Controller to handle webhooks and promote changes from GitOps    create environment Create a new Environment which is used to promote your Team's Applications via Continuous Delivery    delete addon environment Deletes the Environment Controller    delete environment Deletes one or more Environments    edit environment Edits an Environment which is used to promote your Team's Applications via Continuous Delivery    get environments Display one or more Environments    Working with Jenkins X resources:    get              Display one or more resources    edit             Edit a resource    create           Create a new resource    update           Updates an existing resource    delete           Deletes one or more resources    add              Adds a new resource    start            Starts a process such as a pipeline    stop             Stops a process such as a pipeline    Jenkins X Pipeline Commands:    step             pipeline steps    Jenkins X services:    controller       Runs a controller    gc               Garbage collects Jenkins X resources    Other Commands:    diagnose         Print diagnostic information about the Jenkins X installation    docs             Open the documentation in a browser    help             Help about any command    version          Print the version information    Options:    -b, --batch-mode=false: Runs in batch mode without prompting for user input        --verbose=false: Enables verbose output        --version=false: version for jx  Usage:    jx [flags] [options]  Use "jx <command> --help" for more information about a given command.  Use "jx options" for a list of global command-line options (applies to all commands).  [root@learncloudnative ~]#

2、安装Jenkins-X到当前K8s集群

准备工作

jx在安装jenkinsX到K8s集群时,需要从github上clone相关的代码库,比如:预览环境和生产环境的模板代码库。也需要提供一个Git Server以及相关的账号、Token来上传相应的代码库。因此,验证git是否安装,并设置git config。

安装Git

centos里自带的git的版本有点低,可通过下面方法使用源码安装高版本git

# yum -y groupinstall Development tools# yum install gcc perl-ExtUtils-MakeMaker openssl-devel curl-devel expat-devel# yum -y remove git# wget https://www.kernel.org/pub/software/scm/git/git-2.16.5.tar.gz# tar -zxvf git-2.16.5.tar.gz# make prefix=/usr/local/git all# make prefix=/usr/local/git install# echo "export PATH=$PATH:/usr/local/git/bin" >> /etc/bashrc# source /etc/bashrc

设置Git Server Token

Git Server的token提前准备好,我这里是用的github,可以在个人设置Setting—Personal access tokens里添加新的token。权限包括:delete_repo, read:org, read:user, repo, user:email, write:repo_hook

下载JenkinsX的镜像

jenkinsX的镜像需要从国外网站上下载,jx并没有提供像minikube里指定镜像地址的参数,这里只能依靠之前写的《Jenkins X–(4)不用翻墙也能下载国外的镜像》,先提前把镜像准备好。各位幸运的是,这些镜像我都已经准备好了,可以在hub.docker.com里搜索,账号:xinglongjian下一般都有,如果没有,那就是在其他的账号里已经有了,我就没重复上传。如果都没有,可以安装文章里提供的方法,自行上传。

下载镜像

转成tag镜像

docker pull xinglongjian/jenkinsx:0.0.80

gcr.io/jenkinsxio/jenkinsx:0.0.80

docker pull xinglongjian/builder-jx:2.0.842-199

gcr.io/jenkinsxio/builder-jx:2.0.842-199

docker pull xinglongjian/jx:2.0.645

gcr.io/jenkinsxio/jx:2.0.645

docker pull xinglongjian/builder-maven:2.0.842-199

gcr.io/jenkinsxio/builder-maven:2.0.842-199

docker pull xinglongjian/nexus:0.1.7

gcr.io/jenkinsxio/nexus:0.1.7

docker pull xinglongjian/heapster:v1.5.2

k8s.gcr.io/heapster:v1.5.2

docker pull xinglongjian/addon-resizer:1.7

k8s.gcr.io/addon-resizer:1.7

docker pull xinglongjian/chartmuseum:v0.7.1

chartmuseum/chartmuseum:v0.7.1

docker pull xinglongjian/exposecontroller:2.3.111

gcr.io/jenkinsxio/exposecontroller:2.3.111

docker pull xinglongjian/nginx-ingress-controller:0.25.1

quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.25.1

docker pull registry:2.6.2

执行安装

jx install --versions-ref='v1.0.118' 

执行过程如下:执行过程中会设置git config,以及连接github的账号和token,jx install根据指定的版本下载相应的代码库和镜像,同时会给自己的代码库中创建好环境代码库(test,stage,production)。

[root@learncloudnative ~]# jx install --versions-ref='v1.0.118'  ? Select Jenkins installation type:  [Use arrows to move, space to select, type to filter]  > Serverless Jenkins X Pipelines with Tekton    Static Jenkins Server and Jenkinsfiles  ? Select Jenkins installation type:  [Use arrows to move, space to select, type to filter]    Serverless Jenkins X Pipelines with Tekton  > Static Jenkins Server and Jenkinsfiles  ? Select Jenkins installation type: Static Jenkins Server and Jenkinsfiles  Namespace jx created  Context "minikube" modified.  set exposeController Config Domain 192.168.117.129.nip.io  Git configured for user: xinglongjian and email [email protected]  helm installed and configured  nginx ingress controller already enabled  Set up a Git username and API token to be able to perform CI/CD  ? Do you wish to use xinglongjian as the local Git user for GitHub server: Yes  Select the CI/CD pipelines Git server and user  ? Do you wish to use GitHub as the pipelines Git server: Yes  Setting the pipelines Git server https://github.com and user name xinglongjian.  Deleting and cloning the Jenkins X versions repo  Cloning the Jenkins X versions repo https://github.com/jenkins-x/jenkins-x-versions.git with revision v1.0.118 to /root/.jx/jenkins-x-versions  remote: Enumerating objects: 2, done.  remote: Counting objects: 100% (2/2), done.  remote: Compressing objects: 100% (2/2), done.  remote: Total 2 (delta 0), reused 2 (delta 0), pack-reused 0  展开对象中: 100% (2/2), 完成.  来自 https://github.com/jenkins-x/jenkins-x-versions   * tag               v1.0.118   -> FETCH_HEAD  Cloning the Jenkins X cloud environments repo to /root/.jx/cloud-environments  ? A local Jenkins X cloud environments repository already exists, recreating with latest: Yes  Cloning the Jenkins X cloud environments repo to /root/.jx/cloud-environments  Enumerating objects: 1440, done.  Total 1440 (delta 0), reused 0 (delta 0), pack-reused 1440  ? Defaulting workload build pack: Kubernetes Workloads: Automated CI+CD with GitOps Promotion  Setting the team build pack to kubernetes-workloads repo: https://github.com/jenkins-x-buildpacks/jenkins-x-kubernetes.git ref: master  Installing jx into namespace jx  Installing jenkins-x-platform version: 2.0.1413  Deleting and cloning the Jenkins X versions repo  Cloning the Jenkins X versions repo https://github.com/jenkins-x/jenkins-x-versions.git with revision v1.0.118 to /root/.jx/jenkins-x-versions  remote: Enumerating objects: 2, done.  remote: Counting objects: 100% (2/2), done.  remote: Compressing objects: 100% (2/2), done.  remote: Total 2 (delta 0), reused 2 (delta 0), pack-reused 0  展开对象中: 100% (2/2), 完成.  来自 https://github.com/jenkins-x/jenkins-x-versions   * tag               v1.0.118   -> FETCH_HEAD      WARNING: waiting for install to be ready, if this is the first time then it will take a while to download images  Jenkins X deployments ready in namespace jx  Configuring the TeamSettings for ImportMode Jenkinsfile  Configure Jenkins API Token  Generating the API token...  Logged in admin to Jenkins server at http://jenkins.jx.192.168.117.129.nip.io via legacy security realm  Enable CSRF protection at: http://jenkins.jx.192.168.117.129.nip.io/configureSecurity/  Created user admin API Token for Jenkins server jenkins.jx.192.168.117.129.nip.io at http://jenkins.jx.192.168.117.129.nip.io  Updating Jenkins with new external URL details http://jenkins.jx.192.168.117.129.nip.io  Creating default staging and production environments  ? Select the organization where you want to create the environment repository:  [Use arrows to move, space to select, type to filter]  > xinglongjian  ? Select the organization where you want to create the environment repository: xinglongjian  Using Git provider GitHub at https://github.com  ? Using Git user name: xinglongjian  ? Using organisation: xinglongjian  Creating repository xinglongjian/environment-healerwheat-staging  Creating Git repository xinglongjian/environment-healerwheat-staging  Pushed Git repository to https://github.com/xinglongjian/environment-healerwheat-staging    Creating staging Environment in namespace jx  Created environment staging  Created Jenkins Project: http://jenkins.jx.192.168.117.129.nip.io/job/xinglongjian/job/environment-healerwheat-staging/    Note that your first pipeline may take a few minutes to start while the necessary images get downloaded!    Creating GitHub webhook for xinglongjian/environment-healerwheat-staging for url http://jenkins.jx.192.168.117.129.nip.io/github-webhook/  Using Git provider GitHub at https://github.com  ? Using Git user name: xinglongjian  ? Using organisation: xinglongjian  Creating repository xinglongjian/environment-healerwheat-production  Creating Git repository xinglongjian/environment-healerwheat-production  Pushed Git repository to https://github.com/xinglongjian/environment-healerwheat-production    Creating production Environment in namespace jx  Created environment production  Namespace jx-production created  Created Jenkins Project: http://jenkins.jx.192.168.117.129.nip.io/job/xinglongjian/job/environment-healerwheat-production/    Note that your first pipeline may take a few minutes to start while the necessary images get downloaded!    Creating GitHub webhook for xinglongjian/environment-healerwheat-production for url http://jenkins.jx.192.168.117.129.nip.io/github-webhook/    Jenkins X installation completed successfully              ********************************************************                 NOTE: Your admin password is: wn4vA4abe+ncULd48g~s            ********************************************************      Your Kubernetes context is now set to the namespace: jx  To switch back to your original namespace use: jx namespace jx  Or to use this context/namespace in just one terminal use: jx shell  For help on switching contexts see: https://jenkins-x.io/developing/kube-context/  To import existing projects into Jenkins:       jx import  To create a new Spring Boot microservice:       jx create spring -d web -d actuator  To create a new microservice from a quickstart: jx create quickstart  [root@learncloudnative ~]#

jenkins X安装时默认,在k8s集群中安装一个名为jx的命名空间。同时也会为每个环境创建一个命名空间,如下表:

[root@learncloudnative ~]# kubectl get ns  NAME            STATUS   AGE  default         Active   4d18h  jx              Active   25m  jx-production   Active   20m  jx-staging      Active   14h  kube-public     Active   4d18h  kube-system     Active   4d18h  [root@learncloudnative ~]# kubectl get pod -n jx  NAME                                            READY   STATUS    RESTARTS   AGE  jenkins-5c95d5bf9b-p94qh                        1/1     Running   0          23m  jenkins-x-chartmuseum-67f75c4884-kc9f8          1/1     Running   0          23m  jenkins-x-controllerrole-7f7d94659c-8fnbx       1/1     Running   0          23m  jenkins-x-controllerteam-9775fbf47-4cggm        1/1     Running   0          23m  jenkins-x-controllerworkflow-578f9cbf9b-4bmt5   1/1     Running   0          23m  jenkins-x-docker-registry-589d4d79c4-dx4jq      1/1     Running   0          23m  jenkins-x-heapster-fbdccf687-vchkq              2/2     Running   0          23m  jenkins-x-nexus-57c8447c4-7gnw8                 1/1     Running   0          23m  maven-ns5xq                                     2/2     Running   0          20m  maven-x1293                                     2/2     Running   0          20m  [root@learncloudnative ~]# kubectl get all -n jx  NAME                                                READY   STATUS    RESTARTS   AGE  pod/jenkins-5c95d5bf9b-p94qh                        1/1     Running   0          23m  pod/jenkins-x-chartmuseum-67f75c4884-kc9f8          1/1     Running   0          23m  pod/jenkins-x-controllerrole-7f7d94659c-8fnbx       1/1     Running   0          23m  pod/jenkins-x-controllerteam-9775fbf47-4cggm        1/1     Running   0          23m  pod/jenkins-x-controllerworkflow-578f9cbf9b-4bmt5   1/1     Running   0          23m  pod/jenkins-x-docker-registry-589d4d79c4-dx4jq      1/1     Running   0          23m  pod/jenkins-x-heapster-fbdccf687-vchkq              2/2     Running   0          23m  pod/jenkins-x-nexus-57c8447c4-7gnw8                 1/1     Running   0          23m  pod/maven-ns5xq                                     2/2     Running   0          20m  pod/maven-x1293                                     2/2     Running   0          20m    NAME                                TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)     AGE  service/heapster                    ClusterIP   10.110.166.28    <none>        8082/TCP    23m  service/jenkins                     ClusterIP   10.99.2.200      <none>        8080/TCP    23m  service/jenkins-agent               ClusterIP   10.104.2.199     <none>        50000/TCP   23m  service/jenkins-x-chartmuseum       ClusterIP   10.111.135.247   <none>        8080/TCP    23m  service/jenkins-x-docker-registry   ClusterIP   10.108.62.53     <none>        5000/TCP    23m  service/nexus                       ClusterIP   10.109.97.154    <none>        80/TCP      23m    NAME                                           READY   UP-TO-DATE   AVAILABLE   AGE  deployment.apps/jenkins                        1/1     1            1           23m  deployment.apps/jenkins-x-chartmuseum          1/1     1            1           23m  deployment.apps/jenkins-x-controllerrole       1/1     1            1           23m  deployment.apps/jenkins-x-controllerteam       1/1     1            1           23m  deployment.apps/jenkins-x-controllerworkflow   1/1     1            1           23m  deployment.apps/jenkins-x-docker-registry      1/1     1            1           23m  deployment.apps/jenkins-x-heapster             1/1     1            1           23m  deployment.apps/jenkins-x-nexus                1/1     1            1           23m    NAME                                                      DESIRED   CURRENT   READY   AGE  replicaset.apps/jenkins-5c95d5bf9b                        1         1         1       23m  replicaset.apps/jenkins-x-chartmuseum-67f75c4884          1         1         1       23m  replicaset.apps/jenkins-x-controllerrole-7f7d94659c       1         1         1       23m  replicaset.apps/jenkins-x-controllerteam-9775fbf47        1         1         1       23m  replicaset.apps/jenkins-x-controllerworkflow-578f9cbf9b   1         1         1       23m  replicaset.apps/jenkins-x-docker-registry-589d4d79c4      1         1         1       23m  replicaset.apps/jenkins-x-heapster-7489b8d655             0         0         0       23m  replicaset.apps/jenkins-x-heapster-fbdccf687              1         1         1       23m  replicaset.apps/jenkins-x-nexus-57c8447c4                 1         1         1       23m    NAME                                   SCHEDULE         SUSPEND   ACTIVE   LAST SCHEDULE   AGE  cronjob.batch/jenkins-x-gcactivities   0/30 */3 * * *   False     0        <none>          23m  cronjob.batch/jenkins-x-gcpods         0/30 */3 * * *   False     0        <none>          23m  cronjob.batch/jenkins-x-gcpreviews     0 */3 * * *      False     0        <none>          23m    NAME                                                                                   GIT URL   STATUS  pipelineactivity.jenkins.io/xinglongjian-environment-healerwheat-production-master-1             Running  pipelineactivity.jenkins.io/xinglongjian-environment-healerwheat-staging-master-1                Running  [root@learncloudnative ~]#

以界面启动,在终端输入:jx console,可以在浏览器中打开jenkins X的控制台。

[root@learncloudnative ~]# jx console  Jenkins Console: http://jenkins.jx.192.168.117.129.nip.io/blue  This tool has been deprecated, use 'gio open' instead.  See 'gio help open' for more info.  

在浏览器中打开这个地址,使用上面的管理员密码登录。

登录后,就进入到Jenkins的主界面了,同时有我们上面自动创建的两个环境(staging和production)流水线。

查看environment-healerwheat-production流水线的执行状态和执行日志。

这样,Jenkins X的环境就搭建好了,Jenkins X是云原生时代的CICD实现,以DevOps最佳实践和原则为指导,真正能够做到自动化,高效。