有关可伸缩性系统的十三条军规

开发 架构
本文总结了一些构建可伸缩性系统的最佳实践,可谓是构建可伸缩性系统的金玉良言。

这篇文章中总结了一些构建可伸缩性系统的***实践,总结的不错,于是翻译了下,翻译内容如下:

可伸缩性系统的***实践

下面是我们认为的一些可伸缩性的***实践:

1、异步;尽可能的使用异步,同步调用会导致两个服务的可用性绑在一起,意味着一个服务出问题或变慢,另一个也会受到影响,这点也是eBay一直强调的;

2、泳道设计;错误隔离机制,避免一个失败影响全局,这种机制也有助于错误查找和代码替换;

3、缓存;在所有层次均使用缓存,例如数据、页面、页面片段等;

4、监测;从用户角度来看系统的性能。这包括从外部网络来对系统进行性能的监测,以及内部的系统间交互次数以及时间的监测;

5、数据复制;一方面是为了容灾,另一方面是为了提供多个用于读的数据库,降低写库的压力;

6、拆分;包括了应用的拆分以及数据库的拆分;

7、尽量少的使用数据库特性;尽可能的把数据库仅作为一个在线存储的功能而使用,不要把业务逻辑放在数据库里,否则将来会非常难扩展;

8、缓慢发布;发布时应缓慢发布,以保证新版本是正常的,避免由于某个压力测试时没测到的点,导致全站出问题;

9、压力以及性能测试;在发布前测试性能,尽管这不一定能发现全部问题,因此在发布前仍然要做好回滚的方案;

10、容量规划;提前判断系统能支撑多大的量,并做好扩容计划;

11、回滚;每次都要做好回滚的准备;

12、根源分析;确认有办法找到线上问题的根源所在,从而能够真正的解决问题;

13、从一开始就要注重质量;质量不能仅靠测试来保证,必须从设计阶段开始就去保证。

译注:
以上说的这十三点可谓是构建可伸缩性系统的金玉良言,但可惜缺乏了实例引导,没有经验的同学估计会很难看明白为什么一定要这样做,如果有些实例来说明的话,就更帅了!

本文来自BlueDavy的博客:《【译】可伸缩性***实践》

【编辑推荐】

  1. 新应用框架Jazzmaster:将可伸缩性与敏捷相结合
  2. 动态和静态程序设计语言的可伸缩性
  3. 高性能服务器网络可伸缩性
  4. 你真的明白什么是可伸缩性吗?
  5. Scala是什么?可伸展的语言!
责任编辑:yangsai 来源: BlueDavy的博客
相关推荐

2009-09-16 10:00:14

可伸缩性Web服务

2009-11-11 16:07:09

OSPF路由协议

2016-11-03 13:11:21

phpphp框架

2015-09-17 09:30:50

云架构可伸缩性风险

2013-10-16 10:45:29

JVMJava

2010-07-01 14:05:34

SQL Server数

2010-05-18 17:18:32

IIS服务器

2024-04-03 08:58:48

软件架构隔板

2013-05-30 10:20:39

系统架构

2017-09-07 16:50:47

MySQL性能优化

2011-02-23 09:50:56

2011-02-13 10:12:24

SQL语句

2018-01-29 11:11:35

Linux入门学习

2011-09-20 17:08:21

JavaScript

2012-02-21 22:55:55

MDT 2010Windows 7

2009-04-16 17:30:00

可伸缩管理集成

2011-01-14 15:58:01

Linux集群系统

2011-01-14 15:51:26

Linux集群系统

2011-01-14 16:14:41

Linux集群系统

2011-01-14 16:04:01

Linux集群系统
点赞
收藏

51CTO技术栈公众号