Heroku创始人Adam Wiggins发布十二要素应用宣言

  • 时间:
  • 浏览:3
  • 来源:5分3D_5分排列5

12-Factor应用不让区别对待本地或第三方服务。 对进程而言,类似都有附加资源,通过一个多 url或是类似存储在 配置 中的服务定位/服务证书来获取数据。12-Factor应用的任意 部署 ,都应该还还还都里能 在不进行任何代码改动的请况下,将本地MySQL数据库加在第三方服务(类似 Amazon RDS)。类似的,本地SMTP服务应该也还还还都里能 和第三方SMTP服务(类似Postmark)互换。

https://www.12factor.net/

12-factor应用想要 做到持续部署就需用缩小本地与线上差异。12-factor应用的开发人员应该反对在不同环境间使用不同的后端服务 ,即使适配器而且还还还都里能 几乎消除使用上的差异。

所有部署的基准代码相同,但每份部署还还还都里能 使用其不同的版本。

http://www.infoq.com/cn/news/2012/09/12-factor-app

你们都都都的初衷是分享在现代软件开发过程中发现的类似系统性什么的问题,并加深对类似什么的问题的认识。你们都都都提供了讨论类似什么的问题时所需的共享词汇,一并使用相关术语给出一套针对类似什么的问题的广义出理 方案。本文格式的灵感来自于Martin Fowler的书籍: Patterns of Enterprise Application Architecture, Refactoring 。

本文的贡献者者参与过数以百计的进程的开发和部署,并通过Heroku平台间接见证了数十万进程的开发,运作以及扩展的过程。

本文综合了你们都都都关于SaaS应用几乎所有的经验和知慧,是开发此类应用的理想实践标准,并有点硬关注于进程怎样保持良性成长,开发者之间怎样进行有效的代码合作,以及怎样出理 软件污染 。

12-Factor规则下的进程不让隐式依赖系统级的类库。 它一定通过依赖清单 ,确切地声明所有依赖项。此外,在运行过程中通过 依赖隔离 工具来确保进程不让调用系统中存在但清单中未声明的依赖项。类似做法会统一应用到生产和开发环境。

每一个多 发布版本需用对应一个多 唯一的发布ID。

在12-factor应用中,进程是一等公民。 12-factor应用的进程主要借鉴于 unix守护进程模型 。开发人员还还还都里能 运用类似模型去设计应用架构,将不同的工作分配给不同的进程类型 。

12-factor应用类似未必考虑存储另一方的输出流。 不应该试图去写而且管理日志文件。相反,每一个多 运行的进程不会直接的标准输出(stdout)事件流。开发环境中,开发人员还还还都里能 通过类似数据流,实时在终端就看应用的活动。

12-factor应用的进程需用无请况且无共享 。任何需用持久化的数据都有存储在后端服务内,比如数据库。粘性Session是twelve-factor极力反对的。Session中的数据应该保存在诸如Memcached 或 Redis 还还还都里能还还还都里能 的涵盖过期时间的缓存中。

12-factor应用的进程是可支配的,意思是说它们还还还都里能 瞬间开启或停止。 这不不利于快速、弹性的伸缩应用,越来很慢部署变化的代码或配置,稳健地部署应用。进程应当追求最小启动时间;进程一旦接收终止信号(SIGTERM) 就会优雅的终止 。进程还应当在面对经常死亡时保持健壮 ,

Heroku是业内知名的云应用平台,从对外提供服务以来,你们都都都而且有上百万应用的托管和运营经验。前不久,创始人Adam Wiggins根据类似经验,发布了一个多 “十二累积应用宣言(The Twelve-Factor App)”,该宣言由国内工作于安居客的进程员梁山将其翻译为中文,InfoQ中文站摘录如下。

尽管每个应用只对应一份基准代码,但还还还都里能 一并存在多份部署。

新的代码在部署而是,需用开发人员触发构建操作。而且,运行阶段不一定需用人为触发,而是还还还都里能 自动进行。

这套理论适用于任意语言和后端服务(数据库、消息队列、缓存等)开发的进程。

基准代码和应用之间经常保持一一对应的关系:

12-Factor推荐将应用的配置存储于环境变量 中 (env vars, env) 。环境变量还还还都里能 非常方便地在不同的部署间做修改,却不动一行代码;与配置文件不同,不小心把它们签入代码库的概率微乎其微;与类似传统的出理 配置什么的问题的机制(比如Java的属性配置文件)相比,环境变量与语言和系统无关。

12-facfor应用严格区分构建,发布,运行类似个 步骤。

一次性管理进程应该和正常的 常驻进程 使用同样的环境。类似管理进程和任何类似的进程一样使用相同的代码和配置,基于某个发布版本运行。后台管理代码应该随类似进程代码一并发布,从而出理 同步什么的问题。所有进程类型应该使用同样的依赖隔离技术。12-factor尤其青睐类似提供了REPL shell的语言,而且那会让运行一次性脚本变得简单。

希望完整篇 了解“十二累积应用宣言”的同学,还还还都里能 点击这里查看英文版,或是直接查看梁山同学翻译的中文版。

任何SaaS应用的开发人员。部署和管理此类应用的运维工程师。

如今,软件通常会作为类似服务来交付,它们被称为网络进程,或“软件即服务”(SaaS)。“十二累积进程”(12-Factor App)为构建如下的SaaS应用提供了法律妙招论:

12-Factor应用中,环境变量的粒度要足够小,且相对独立。它们永远而是会组合成一个多 所谓的“环境”,而是独立存在于每个部署之中。当进程不断扩展,需用更多种类的部署时,类似配置管理法律妙招都还还还都里能做到平滑过渡。

12-factor应用完整篇 自我加载而不依赖于任何网络服务器就还还还都里能 创建一个多 面向网络的服务。互联网应用 通过端口绑定来提供服务,并监听发送至该端口的请求。