写点什么

高可扩展分布式应用程序的架构原则

  • 2015-11-02
  • 本文字数:1054 字

    阅读完需:约 3 分钟

Elastisys 云平台诞生于瑞典默奥大学分布式系统研究小组。它由一组以预测性扩展引擎为中心的工具组成,可以自动扩展云部署。近日,其官方网站发表了一篇文章,介绍他们在高可扩展分布式应用程序设计和开发方面的经验。

他们将可扩展性分成了如下四个维度:

  • 性能可扩展:性能无法完全实现线性扩展,但要尽量使用具有并发性和异步性的组件。具备完成通知功能的工作队列要优于同步连接到数据库。
  • 可用性可扩展 CAP 理论表明,分布式系统无法同时提供一致性、可用性和分区容错性保证。许多大规模 Web 应用程序都为了可用性和分区容错性而牺牲了强一致性,而后者则有赖于最终一致性来保证。
  • 维护可扩展:软件和服务器都需要维护。在使用平台 & 工具监控和更新应用程序时,要尽可能地自动化。
  • 成本可扩展:总拥有成本包括开发、维护和运营支出。在设计一个系统时,要在重用现有组件和完全新开发组件之间进行权衡。现有组件很少能完全满足需求,但修改现有组件的成本还是可能低于开发一个完全不同的方案。另外,使用符合行业标准的技术使组织更容易聘到专家,而发布独有的开源方案则可能帮助组织从社区中挖掘人才。

以上各项,他们在设计应用程序时都会考虑和权衡。下面是他们根据上述内容总结出的 10 个设计原则:

  1. 避免单点故障:任何东西都要有两个。这增加了成本和复杂度,但却能在可用性和负载性能上获益。而且,这有助于设计者采用一种分布式优先的思维。
  2. 横向扩展,而不是纵向扩展:升级服务器(纵向)的成本是指数增长的,而增加另一台商用服务器(横向)的成本是线性增长的。
  3. 尽量减少应用程序核心所需要完成的工作。
  4. API 优先:将应用程序视为一个提供 API 的服务,而且,不假定服务的客户端类型(手机应用、Web 站点、桌面应用程序)。
  5. 总是缓存。
  6. 提供尽可能新的数据:用户可能不需要立即看到最新的数据,最终一致性可以带来更高的可用性。
  7. 设计时要考虑维护和自动化:不要低估应用程序维护所需要的时间和工作量。软件首次公开发布是一个值得称赞的里程碑,但也标志着真正的工作要开始了。
  8. 宁异步,不同步。
  9. 努力实现无状态:状态信息要保存在尽可能少的地方,而且要保存在专门设计的组件中。
  10. 为故障做好准备:将故障对终端用户的影响最小化。

关于分布式系统的设计,InfoQ 曾有过一些报道( 1 , 2 ),感兴趣的读者可以对照阅读。


感谢郭蕾对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群)。

2015-11-02 18:004690
用户头像

发布了 1008 篇内容, 共 393.2 次阅读, 收获喜欢 345 次。

关注

评论

发布
暂无评论
发现更多内容

openGauss数据库从3.0.0升级到3.1.0操作实践

daydayup

HarmonyOS NEXT,生命之树初长成

脑极体

鸿蒙 AI 应用

10分钟入门Flink--架构和原理

程序员半支烟

flink

新专辑《AI秘籍》,你所感兴趣的一切

茶桁

Python AI CV nlp BI

程序员创业踩过的10个坑

程序员半支烟

创业 程序员

从价值的角度看,为何 POSE 通证值得长期看好

BlockChain先知

3. Python3 运算符

茶桁

Python

10分钟了解Flink窗口计算

程序员半支烟

2. 初识Python脚本

茶桁

Python

服务端apk打包教程

越长大越悲伤

Java 服务端打apk包

多家合作伙伴与华为终端云服务签约 全面合作共建鸿蒙服务分发新生态

最新动态

文心一言 VS 讯飞星火 VS chatgpt (71)-- 算法导论7.1 1题

福大大架构师每日一题

福大大架构师每日一题

从价值的角度看,为何 POSE 通证值得长期看好

股市老人

技术问题--查询过大引发的Dubbo问题

程序员半支烟

openGauss内核荣获中国首个国际CC EAL4+级别认证

daydayup

ChatGenTitle:使用百万arXiv论文信息在LLaMA模型上进行微调的论文题目生成模型

汀丶人工智能

人工智能 自然语言处理 LLM模型

CTO如何帮助业务成功

程序员半支烟

程序员是否适合创业

程序员半支烟

创业 程序员

Flink DataStream API-概念、模式、作业流程和程序

程序员半支烟

Flink DataStream API-数据源、数据转换、数据输出

程序员半支烟

1. Python的特性和语法

茶桁

Python

Programming Abstractions in C阅读笔记:p72-p75

codists

4. Python的流程控制

茶桁

Python

华为阅读看好“短故事”新赛道 签约知乎盐言故事开启轻阅读

最新动态

10分钟入门Flink--安装

程序员半支烟

Flink 平台 Flink安装

只凭阿里大牛珍藏的并发编程笔记,我拿下了30K offer!

小小怪下士

Java 编程 程序员 并发编程 高并发

Zebec Payroll :计划推出 WageLink On-Demand Pay,进军薪酬发放领域

股市老人

Zebec Payroll :计划推出 WageLink On-Demand Pay,进军薪酬发放领域

BlockChain先知

C++实现对回收站里的文件进行操作

芯动大师

高可扩展分布式应用程序的架构原则_语言 & 开发_谢丽_InfoQ精选文章