网站的可扩性展架构

扩展性(Extensibility) - 指对现有系统影响最小的状况下,系统功能可持续扩展或提高的能力。表如今系统基础设施稳定不须要常常变动,应用之间较少依赖和耦合,对需求变动能够敏捷响应。它是系统架构设计层面的开闭原则(对扩展开放、对修改关闭),架构设计考虑将来功能扩展,当系统增长新功能时,不须要对现有系统的结构和代码进行修改。数据库

伸缩性(Scalability) - 指系统可以经过增长减小自身资源规模的方式增减本身计算处理事务的能力。若是这种增减是成比例的,就被称做线性伸缩性。在网站架构中 ,一般指利用集群的方式增长服务器数量、提升系统的总体事务吞吐能力。服务器

1. 构建可扩展的网站架构

低耦合的系统更容易扩展、复用。数据结构

设计网站可扩展架构的核心思想是模块化,并在此基础上,下降模块间的耦合性,提升模块的复用性。架构

分层和分割不只能够进行架构伸缩,也是模块化设计的重要手段,利用分层和分割的方式将软件分割为若干个低耦合的独立的组件模块,这些组件模块以消息传递及依赖调用的方式聚合成一个完整的系统。负载均衡

在大型网站中,这些模块经过分布式部署的方式,独立的模块部署在独立的服务器上,从物理上分离模块间的耦合关系,进一步下降耦合性提升复用性。分布式

2. 利用分布式消息队列下降系统耦合性

2.1. 事件驱动架构

事件驱动架构经过在低耦合的模块间传输事件消息,以保持模块的松散耦合,并借助事件消息的通讯完成模块间合做。典型的事件驱动架构就是操做系统中常见的生产者消费者模式。在大型网站中,最多见的实现手段就是分布式消息队列。模块化

2.2. 分布式消息队列

消息生产者应用程序经过远程访问接口将消息推送给消息队列服务器,消息队列服务器将消息写入本地内存队列后当即返回成功响应给消息生产者。消息队列服务器根据消息订阅列表查找订阅该消息的消息消费者应用程序,将消息队列中的消息按照先进先出(FIFO)的原则将消息经过远程通讯接口发送给消息消费者程序。网站

在伸缩性方面,因为消息队列服务器上的数据能够看做是即时处理的,所以相似于无状态的服务器,伸缩性设计比较简单。将新服务器加入分布式消息队列集群中,通知生产者服务器更改消息队列服务器列表便可。spa

在可用性方面,为了不消费者进程处理缓慢,分布式消息队列服务器内存空间不足形成的问题,若是内存队列已满,会将消息写入磁盘,消息推送模块在将内存队列消息处理完成之后,将磁盘内容加载到内存队列继续处理。操作系统

3. 利用分布式服务打造可复用的业务平台

分布式服务则经过接口分解系统耦合性,不一样子系统经过相同的接口描述进行服务调用。

大型网站分布式服务的需求与特色:

  • 负载均衡
  • 失效转移
  • 高效的远程通讯
  • 整合异构系统
  • 对应用最少侵入
  • 版本管理
  • 实时监控

4. 可扩展的数据结构

传统的关系型数据库为了保证关系运算的正确性,在设计数据库表结构的时候,就须要指定表的 schema ——字段名称,数据类型等,并要遵循特定的设计范式。这些规范带来一个问题:难以面对需求变动带来的挑战,因此有人经过预先设计一些冗余字段来应对。

许多 NoSql 数据库使用 ColumnFamily 设计来设计可扩展的数据结构。

相关文章
相关标签/搜索