普通网站架构
一般网站,刚开始的做法,是三台服务器,一台部署应用,一台部署数据库,一台部署NFS文件系统。这是前几年比较传统的做法,之前见到一个网站10万多会员,垂直服装设计门户,N多图片。使用了一台服务器部署了应用,数据库以及图片存储。出现了很多性能问题。
但是,目前主流的网站架构已经发生了翻天覆地的变化。一般都会采用集群的方式,进行高可用设计。
1, 使用集群对应用服务器进行冗余,实现高可用;(负载均衡设备可与应用一块部署),
2, 使用数据库主备模式,实现数据备份和高可用;
网站架构分析
根据前面的容量预估,有几个问题:
- ·需要部署大量的服务器,高峰期计算,可能要部署30台web服务器。并且这三十台服务器,只有秒杀,活动时才会用到,存在大量的浪费。
- ·所有的应用部署在同一台服务器,应用之间耦合严重。需要进行垂直切分和水平切分。
- ·大量应用存在冗余代码。
- ·服务器SESSION同步耗费大量内存和网络带宽。
- ·数据需要频繁访问数据库,数据库访问压力巨大。
大型网站一般需要做以下架构优化(优化是架构设计时,就要考虑的,一般从架构/代码级别解决,调优主要是简单参数的调整,比如JVM调优;如果调优涉及大量代码改造,就不是调优了,属于重构):
- ·业务拆分
- ·应用集群部署(分布式部署,集群部署和负载均衡)
- ·多级缓存
- ·单点登录(分布式Session)
- ·数据库集群(读写分离,分库分表)
- ·服务化
- ·消息队列
- ·其他技术
网站架构优化
分布式部署:
将业务拆分后的应用单独部署,应用直接通过RPC进行远程通信;
集群部署:
电商网站的高可用要求,每个应用至少部署两台服务器进行集群部署;
负载均衡:
是高可用系统必须的,一般应用通过负载均衡实现高可用,分布式服务通过内置的负载均衡实现高可用,关系型数据库通过主备方式实现高可用。
数据库表
由于当前项目是互联网电商项目,并发量大,涉及的查询量大,表设计要尽量冗余,也就是表之间的关联要尽量少,这样就能减少关联查询,提高查询效率,提升用户体验
框架组合
SSM是当前互联网项目的基础框架首选,框架都是轻量级的,开发效率也都比较高,使用也比较简单
Dubbox是做java远程调用并且与spring结合最好的框架,是分布式项目的基础技术
AngularJS是当前互联网最火的前端框架之一,其双向数据绑特性使得前端开发前所未有的简单