且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

云计算时代应用设计十二要素

更新时间:2022-08-22 14:55:08

云计算时代应用设计十二要素

  • 什么样的软件才是可用性和可维护性好的软件?
  • 什么样的代码才能避免后续开发的上手障碍?
  • 什么样的实行才能稳定的运行在分布式的环境中?

Heroku (一家 PaaS 服务提供者,2010 年被 Salesforce 收购)平台创始人 Adam Winggins,对我们在云时代的应用设计设计和实现提出了十二种风格,对设计高效的应用,特别是在 PaaS 和 SaaS都有很好的参考意义。

一、代码

每个子系统都用一个代码库管理,使用版本管理,实现独立的部署。

二、依赖

显式声明依赖,通过环境来严格隔离不同依赖。

三、配置

在环境变量中保存配置信息,而避免放在源码或配置文件中。

四、后端服务

后端服务作为可挂载资源来使用,这样系统跟外部依赖尽量松耦合。

五、生命周期

区分不同声明周期的运行环境,包括创建、发布、部署,各个步骤要相互隔离。

六、进程

以一个或多个无状态的进程来运行应用,即尽量实现无状态,不要在进程中保存数据。

七、端口

通过端口绑定来对外提供服务。

八、并发

通过进程控制来扩展,即以多进程模型进行扩展。

九、可丢弃性

快速启动,优雅关闭,并尽量鲁棒(随时 kill,随时 crash)。

十、开发与生产环境的差异性

尽量保持从开发到生产部署环境的相似性。

十一、日志

将日志当作事件流来进行统一的管理和维护(使用 Logstash 等工具)。

十二、管理

将管理作为一次性的系统服务来使用。


本文作者:yeasy

来源:51CTO