range

If there were you, the world would be just right

分布式架构的演变过程

1.单机负载
2.单机负载越来越高,数据库服务器和应用服务器分离
3.利用缓存改善网站性能
4.利用集群改善应用服务器性能
5.数据库压力变大,数据库读写分离
6.使用Nosql和搜索引擎缓解读库压力
7.使用cdn和反向代理提高网站性能
8.将应用服务器进行业务拆分
9.数据库水平、垂直拆分
10.服务拆分

什么是分布式

对项目进行分层分割拆分,最终分布在不同服务器上

分布式和集群的区别

分布式:一个业务分布成多个子系统,部署在不同的服务器上
集群: 同一个业务,部署在多个服务器上。做的都是同样的事

分布式和微服务的区别

微服务是分布式的一种实现方式
微服务关注的是分布式中的服务环节,而分布式是关注整个系统闭环

架构模式

分层:一般可分为应用层、服务层、数据层、管理层与分析层;
分割:一般按照业务/模块/功能特点进行划分,比如应用层分为首页、用户中心。
分布式:将应用分开部署(比如多台物理机),通过远程调用协同工作。
集群:一个应用/模块/功能部署多份(如:多台物理机),通过负载均衡共同提供对外访问。
缓存:将数据放在距离应用或用户最近的位置,加快访问速度。
异步:将同步的操作异步化。客户端发出请求,不等待响应,服务端处理完毕使用通知或轮询告知请求方。一般指:请求——响应——通知模式。
冗余:增加副本,提高可用性、安全性与性能。
安全:对已知问题有有效的解决方案,对未知/潜在问题建立发现和防御机制。
自动化:将重复的、不需要人工参与的事情,通过工具的方式,使用机器完成。
敏捷性:积极接受需求变更,快速响应业务发展需求

架构方向

高性能:提供快速的访问体验。
高可用:网站服务一直可以正常访问。
可伸缩:通过硬件增加/减少,提高/降低处理能力。
安全性:提供网站安全访问和数据加密、安全存储等策略。
扩展性:方便地通过新增/移除方式,增加/减少新的功能/模块。

1 、高性能架构

前端优化:网站业务逻辑之前的部分;
浏览器优化:减少HTTP请求数,使用浏览器缓存,启用压缩,CSS JS位置,JS异步,减少Cookie传输;CDN加速,反向代理;
应用层优化:处理网站业务的服务器。使用缓存,异步,集群
代码优化:合理的架构,多线程,资源复用(对象池,线程池等),良好的数据结构,JVM调优,单例,Cache等
存储优化:缓存、固态硬盘、光纤传输、优化读写、磁盘冗余、分布式存储(HDFS)、NoSQL等。

2 、高可用架构

应用层:负载均衡技术
服务层:负载均衡,分级管理,快速失败(超时设置),异步调用,服务降级,幂等设计等。
数据层:冗余备份(冷,热备[同步,异步],温备),失效转移(确认,转移,恢复)。

3 、可伸缩架构

伸缩性是指在不改变原有架构设计的基础上,通过添加/减少硬件(服务器)的方式,提高/降低系统的处理能力
应用层:对应用进行垂直或水平切分。然后针对单一功能进行负载均衡
服务层:与应用层类似;
数据层:分库、分表、NoSQL等

4 、可扩展架构

可以方便地进行功能模块的新增/移除,提供代码/模块级别良好的可扩展性。
模块化,组件化:高内聚,低耦合,提高复用性,扩展性。
稳定接口:定义稳定的接口,在接口不变的情况下,内部结构可以“随意”变化。
设计模式:应用面向对象思想,原则,使用设计模式,进行代码层面的设计。
消息队列:模块化的系统,通过消息队列进行交互,使模块之间的依赖解耦。
分布式服务:公用模块服务化,提供其他系统使用,提高可重用性,扩展性。

5 、安全架构


添加新评论 »

在这里输入你的评论...