vieyahn2017 / repos

【已经迁移到goto/javaway】
2 stars 1 forks source link

Netflix 开源持续云交付平台 Spinnaker #20

Closed vieyahn2017 closed 7 months ago

vieyahn2017 commented 6 years ago

https://github.com/spinnaker/spinnaker

vieyahn2017 commented 6 years ago

Spinnaker 是 Netflix 的开源项目,是一个持续交付平台,它定位于将产品快速且持续的部署到多种云平台上。Spinnaker 通过将发布和各个云平台解耦,来将部署流程流水线化,从而降低平台迁移或多云品台部署应用的复杂度,它本身内部支持 Google、AWS EC2、Microsoft Azure、Kubernetes和 OpenStack 等云平台,并且它可以无缝集成其他持续集成(CI)流程,如 git、Jenkins、Travis CI、Docker registry、cron 调度器等。简而言之,Spinnaker 是致力于提供在多种平台上实现开箱即用的集群管理和部署功能的平台。

vieyahn2017 commented 6 years ago

集群管理主要用于管理云上的资源,它分为以下几个块:

Server Group:服务组,是资源管理单位,识别可部署组件和基础配置设置,它并且关联了一个负载均衡器和安全组,当部署完毕后,服务组就相当于一组运行中的软件实例集合,如(VM 实例,Kubernetes pods)。 Cluster:集群,由用户定义的,对服务组的逻辑分组。 Applications:应用,是对集群的逻辑分组。 Load Balancer:负载均衡,用于将外部网络流量重定向到服务组中的机器实例,还可以指定一系列规则,用来对服务组中的机器实例做健康监测。 Security Group:安全组,定义了网络访问权限,由IP、端口和通信协议组成的防火墙规则。

vieyahn2017 commented 6 years ago

部署管理功能用于创建一个持续交付流程,它可分为管道和阶段两大部分。

管道

这里写图片描述

部署管理的核心是管道,在Spinnaker的定义中,管道由一系列的阶段(stages)组成。管道可以人工触发,也可以配置为自动触发,比如由 Jenkins Job 完成时、Docker Images 上传到仓库时,CRON 定时器、其他管道中的某一阶段。同时,管道可以配置参数和通知,可以在管道一些阶段上执行时发送邮件消息。Spinnaker 已经内置了一些阶段,如执行自定义脚本、触发 Jenkins 任务等。

阶段

阶段在 Spinnaker 中,可以作为管道的一个自动构建模块的功能组成。我们可以随意在管道中定义各个阶段执行顺序。Spinnaker 提供了很多阶段供我们选择使用,比如执行发布(Deploy)、执行自定义脚本 (script)、触发 Jenkins 任务 (jenkins)等,功能很强大。

vieyahn2017 commented 6 years ago

Spinnaker 支持精细的部署策略,比如 红/黑(蓝/绿)部署,多阶段环境部署,滚动红/黑策略,canary 发布等。用户可以为每个环境使用不同部署策略,比如,测试环境可以使用红/黑策略,生产环境使用滚动红/黑策略,它封装好了必须的步骤,用户不需要复杂操作,就可以实现企业级上线。

vieyahn2017 commented 6 years ago

安装 Development Spinnaker

安装 Spinnaker 之前,有必要详细描述一下 Spinnaker 架构所依赖的各个组件。

Deck:面向用户 UI 界面组件,提供直观简介的操作界面,可视化操作发布部署流程。 API: 面向调用 API 组件,我们可以不使用提供的 UI,直接调用 API 操作,由它后台帮我们执行发布等任务。 Gate:是 API 的网关组件,可以理解为代理,所有请求由其代理转发。 Rosco:是构建 beta 镜像的组件,需要配置 Packer 组件使用。 Orca:是核心流程引擎组件,用来管理流程。 Igor:是用来集成其他 CI 系统组件,如 Jenkins 等一个组件。 Echo:是通知系统组件,发送邮件等信息。 Front50:是存储管理组件,需要配置 Redis、Cassandra 等组件使用。 Cloud driver 是它用来适配不同的云平台的组件,比如 Kubernetes,Google、AWS EC2、Microsoft Azure 等。 Fiat 是鉴权的组件,配置权限管理,支持 OAuth、SAML、LDAP、GitHub teams、Azure groups、 Google Groups 等。