Jenkins X是基于Kubernetes的持续集成、持续部署平台,是基于Kubernetes的现代云原生应用的CI/CD解决方案。Jenkins X内置了很多最佳实践和开源工具,您可以不用安装Jenkins就能使用Jenkins X,Jenkins流水线作为安装的一部分。Jenkins X并不是要取代Jenkins,而是以更好的开源工具为基础来构建它。Jenkins X提供了以下特性来帮助我们实现持续交付。
命令行
Jenkins X 带来了一个方便使用的命令行工具 jx :
- 安装 Jenkins X 到你已经存在的 Kubernetes 集群(jx install)
- 创建一个新的 kubernetes 集群 并把 Jenkins X 安装进去 (jx create cluster)
- 导入项目 到 Jenkins X 中以及他们的持续部署流水线设置 (jx import)
- 创建新的 Spring Boot 应用 并导入 Jenkins X 中,以及他们的持续部署流水线设置(jx create spring)
流水线
不必深入了解 Jenkins 流水线的内部,Jenkins X 会默认给你的项目提供一些很好的流水线——基于DevOps 最佳实践实现了所有的持续集成和持续部署
环境
环境指的是应用部署的地方。开发人员通常使用缩写来描述环境,例如:“测试中(Testing)、Staging/UAT或者生产(Production)”。
在 Jenkins X 中每个团队都有一套自己的环境。默认情况下,Jenkins X 会给每个团队创建一个 Staging 和 生产 环境,但你可以通过命令 jx create environment创建一个新的环境。
我们使用 GitOps 来管理要部署到每个环境中的 Kubernetes 资源的配置和版本。因此,每个环境都有自己的 git 仓库,应用在这个环境中运行需要的 Helm Charts、版本以及配置都在库中。
在 Kubernetes 集群中一个环境对应一个命名空间。当 Pull Requests 被合并到环境所在的 git 库后,该环境的流水线就会把 git 库中的 Helm Charts 应用到环境命名空间中。
这意味着开发和运维都可以在同一个 git 库中,管理应用和资源在某个环境中的所有配置和版本,并且对环境的所有改变都可以在 git 中获取到。因此,这样很容易看到是谁作出的改变,而且,更重要的是当发生问题后很容易回滚改变。
如下图所示:一共有dev、staging、production三套环境,分别对应了jx、jx-staging、jx-production三个命名空间。
部署升级
部署升级是通过 GitOps 在环境关联的 git 库上发起一个 Pull Requests 来实现的,这样所有的改变都通过 git 来审查、批准,因此所有的改变的都很容易回滚。
当环境所关联的 git 库上有新的变化合并到 master 后,环境的流水线就会触发,helm 就会把任何改变应用到资源上。
Jenkins X 的持续部署流水线把改变了的版本自动做部署升级,这是需要把配置中的”部署升级策略“设置为”自动“。默认情况下,”Staging“环境使用自动部署升级,而”生产“环境使用”手动“部署升级。
要手动把某个版本的应用部署升级到一个环境中的话,你可以使用jx promote命令。
jx promote命令详解:
部署升级的过程:
预发环境
Jenkins X 允许你给 Pull Requests 设置一个预发环境,这样就可以在变更后合并到 master 之前得到更多的反馈。这使你的变更在被合并以及发布之前更快得到反馈,并允许你避免在你的发版流水线中有人为的批准,加速变更在合并后的部署。
当预发环境启动并运行后,Jenkins X 将会在你的 Pull Requests 中添加一个带链接的评论,这样你们团队的成员就可以点击来尝试它!
反馈
正如在上面看到的,当你使用预发环境时,Jenkins X 会在你的 Pull Requests 上自动添加评论。
如果你在提交日志中引用了 issues(例如:通过文本fixes #123),那么,Jenkins X 流水线将会生成发版记录,如下图所示。
同样地,在升级到Staging或者Production环境时,这些版本上也会在已修复的问题上自动添加对应环境可用的评论。例如:
应用
一些最好的软件工具已经被打包为 helm charts,部分预先集成在了 Jenkins X 中,例如:Nexus、ChartMuseum、Monocular、Prometheus、Grafana等等。
插件
部分应用是内置的;例如:Nexus、ChartMuseum、Monocular。其他的则是作为“插件”提供的。
要安装插件的话,使用命令jx create addon。例如:
jx create addon grafana
参考:Jenkins X官网