网站架构(品优购)

普通网站架构

一般网站,刚开始的做法,是三台服务器,一台部署应用,一台部署数据库,一台部署NFS文件系统。这是前几年比较传统的做法,之前见到一个网站10万多会员,垂直服装设计门户,N多图片。使用了一台服务器部署了应用,数据库以及图片存储。出现了很多性能问题。

但是,目前主流的网站架构已经发生了翻天覆地的变化。一般都会采用集群的方式,进行高可用设计。

1,  使用集群对应用服务器进行冗余,实现高可用;(负载均衡设备可与应用一块部署),

2,  使用数据库主备模式,实现数据备份和高可用;

网站架构分析

根据前面的容量预估,有几个问题:

  • ·需要部署大量的服务器,高峰期计算,可能要部署30台web服务器。并且这三十台服务器,只有秒杀,活动时才会用到,存在大量的浪费。
  • ·所有的应用部署在同一台服务器,应用之间耦合严重。需要进行垂直切分和水平切分。
  • ·大量应用存在冗余代码。
  • ·服务器SESSION同步耗费大量内存和网络带宽。
  • ·数据需要频繁访问数据库,数据库访问压力巨大。

大型网站一般需要做以下架构优化(优化是架构设计时,就要考虑的,一般从架构/代码级别解决,调优主要是简单参数的调整,比如JVM调优;如果调优涉及大量代码改造,就不是调优了,属于重构):

  • ·业务拆分
  • ·应用集群部署(分布式部署,集群部署和负载均衡)
  • ·多级缓存
  • ·单点登录(分布式Session)
  • ·数据库集群(读写分离,分库分表)
  • ·服务化
  • ·消息队列
  • ·其他技术

网站架构优化

分布式部署:将业务拆分后的应用单独部署,应用直接通过RPC进行远程通信;

集群部署:电商网站的高可用要求,每个应用至少部署两台服务器进行集群部署;

负载均衡:是高可用系统必须的,一般应用通过负载均衡实现高可用,分布式服务通过内置的负载均衡实现高可用,关系型数据库通过主备方式实现高可用。

数据库表

         由于当前项目是互联网电商项目,并发量大,涉及的查询量大,表设计要尽量冗余,也就是表之间的关联要尽量少,这样就能减少关联查询,提高查询效率,提升用户体验

框架组合

         SSM是当前互联网项目的基础框架首选,框架都是轻量级的,开发效率也都比较高,使用也比较简单

         Dubbox是做java远程调用并且与spring结合最好的框架,是分布式项目的基础技术

         AngularJS是当前互联网最火的前端框架之一,其双向数据绑特性使得前端开发前所未有的简单

猜你喜欢

转载自www.cnblogs.com/coder-wf/p/12222058.html