中大型网站架构演变之路

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
传统型负载均衡 CLB,每月750个小时 15LCU
云原生内存数据库 Tair,内存型 2GB
简介: 前言 网上有很多文章类似于我今天要分享的课程,有架构师写的,有运维写的,还有开发些的,偏重点都不同,今天我以咱们运维角度全面讲解。 一个成熟的网站架构并不是一开始设计就具备高可用、高伸缩、高性能等特性的,它是随着用户量和业务线不断增加,基础架构才逐渐健壮的。

网上有很多文章类似于今天要分享的主题,有架构师写的,有运维写的,还有开发写的,偏重点各不同!今天我以运维角度讲解中大型网站架构演变之路。

一个成熟的网站架构并不是一开始设计就具备高可用、高伸缩、高性能等特性的,它是随着用户量和业务线不断增加,基础架构才逐渐健壮的。在发展初期,一般都是从0到1,不会一上来就整一些大而全的架构!


适用业务:电商/门户/招聘网站

开发语言:PHP和JAVA

Web服务:Nginx/Tomcat8

数据库:MySQL

操作系统:CentOS

物理服务器:Dell R730/R430


视频版:https://ke.qq.com/course/219551


cb9efab3d5743badb58add1860a97397fb307910


一、单台服务器部署

项目开发完成上线,用户访问量寥寥无几。

wKiom1l6nSbB5uCfAACPTOIseks145.png



二、WEB与数据库独立部署

有一定用户访问量,单台服务器性能有些吃力,想提高并发能力,增加一台服务器,将HTTP请求与SQL操作负载分散不同服务器。

wKioL1l6nWbyWBaKAACeKidaIj4646.png


三、动静分离-初期

什么是动静分离?

静态页面与动态页面分离部署。

wKiom1l6nZuDWWl5AADL8CP3zfY614.png

四、数据库主从与查询缓存


RedisCache

使用Redis缓存数据库查询结果,将热数据放到内存中,提高查询速度,减少数据库请求。

MySQL主从

基于binlog异步复制。

HA

MySQL:Keepalived

怎么保证Redis缓存时效性?

a)增加中间件,在主从同步延迟时间内,中间件将SQL读操作还路由到主。

b)主从同步延迟时间后,再异步发起一次淘汰Cache。

c)增加消息队列和清理Cache程序,入库同时也写入消息队列,缓存清理程序订阅消息队列,一旦有数据更新,重新Cache。

d)Cache中的Item一定要设置过期时间。

wKioL1l6ndeikFq6AADn8189B6A446.png

五、七层负载均衡、共享存储与Redis高可用


访问量越来越大,单台服务器性能已无法支撑,于是增加负载均衡,水平扩展WEB节点,同时调整动静分离。


七层负载均衡

根据域名或者后缀转发不同的upstream。

NFS网络文件系统

共享存储存放网站程序或者静态资源。

Redis主从

动静分离-中期

HA

LB:Keepalived

NFS:DRBD+Heartbeat

Redis:Sentinel/Keepalived

Session如何会话保持?

a)源IP Hash

b)Session共享

c)Session Sticky(粘滞会话)

d)Session复制

wKiom1l6nh_RMKsWAAFb-Q6rCq8390.png

六、数据库架构扩展

访问量上来了,SQL操作自然也就多了,单台数据库读性能到达瓶颈,响应很慢;业务读多写少,需要提升读性能,考虑扩展数据库架构。

一主多从

基于binlog异步复制,多个从库同步主库。

读写分离

a)代码逻辑层区分读写库。

b)使用中间件代理,对SQL解析区分处理;开源主流的有:Atlas、MyCat等。

分库、分表、分区

分库:根据业务类型分离相关表到不同数据库;例如WEB、BBS、Blog等。

分表:单个表上千万条记录,操作耗时长,采用垂直拆分和水平拆分,将数据分散存储到不同小表上。

分区:根据表字段分成多个区块,这些区块可以分布在不同磁盘上。

以上主要是分散磁盘I/O压力,提高处理性能。

从库四层负载均衡

当多个从库时,采用LVS实现负载均衡,对程序提供VIP,访问透明。

HA

主库和从库LB:Keepalived

72cb9be930533da94d278bae88dcfd1d42e55086

七、SOA面向服务架构

SOA

面向服务架构设计理念,拆分臃肿程序架构,以核心业务为单位分解,服务化、模块化,分布式部署。

服务化治理

使用Dubbo分布式框架,治理SOA服务化,Dubbo提供高性能和透明化RPC远程调用方案 。

配置中心

使用Zookeeper存储服务连接信息。

消息队列

使用RabbitMQ解耦服务,保障服务直接通信。

wKioL1l6nongprQ4AAHzSvpUlxs526.png

八、DNS轮训与数据库全文检索引擎

DNS轮训

DNS负载均衡技术实现原理是在DNS服务器上一个主机名配置多个IP地址,用户访问时,轮训返回解析记录,从而达到负载均衡目的。

全文检索引擎

像电商网站首页都会有查询表单,当商品多且品种多,关系型数据库庞大,想要快速从数据库中精确检索出用户想要的商品就显的力不从心了。

引入全文检索引擎,建立索引缓存,快速查询海量数据,缓解数据库压力;开源主流的有:ElasticSearch、Sphinx。

wKioL1l6nsLQoiCVAAIreyFNjmQ657.png


九、静态缓存服务器


每次请求静态资源负载都会落在WEB节点和NFS存储上,而且这些资源都是很少变动的,我们把这些资源缓存到上层,请求到来时先判断本地是否有缓存,如果有就直接返回,从而减少后端HTTP请求,响应会快很多。

wKiom1l6nwTjwb6VAAI-xifkl70723.png

十、分布式文件系统与CDN

分布式文件系统

当图片、视频很多时,NFS在处理效率和存储容量上受局限,这时用分布式文件系统(DFS)就比较合适了,DFS是一种NAS存储架构,C/S模式,多台廉价服务器组成存储集群,提供高性能、高可用、高扩展等特性。客户端挂载到本地,就像访问本地文件系统一样访问远程服务器文件。

CDN

每次请求静态资源都会落在WEB节点和存储上,而且这些资源都是很少变动的,如果把这些资源放到网站入口,岂不减少后端大量HTTP请求,有什么方法呢?

使用CDN技术,它通过一种缓存技术将频繁访问的资源(主要静态)分布到全国各地边缘服务器,用户先访问CDN服务器,CDN根据职能DNS返回客户端就近网络中的缓存服务器,如果这个缓存服务器有缓存请求的静态资源就直接返回,否则回源站获取返回,从而提高网站访问速度,减少后端服务器压力。

wKioL1l6nzHhUf50AAHX8l2CeKk159.png

wKioL1l6n1rgc5p8AAIwttHqol4405.png

十一、四层负载均衡与NoSQL数据库

四层负载均衡

七层负载均衡要分析应用层协议,效率没有四层高,有些应用场景并不需要分析应用层协议,只想实现转发负载,那么,四层负载均衡是首选。

当然,也可以四层代理七层负载均衡,方面扩展七层负载均衡。

NoSQL数据库

由于个别SQL查询量大,已经无法在深度优化,可以考虑使用NoSQL非关系型数据库,它的产生就是解决大规模、高并发、大数据量等问题。但比较适合非结构化数据存储,比如详情页内容、原始数据等。

a7c9568d967917ec8682a133519bcab6ca663c92

十二、现在

弹性伸缩

自动扩容,节点降级。

微服务

更细粒度拆分应用,实现服务化、轻量级、自动化部署等。

内存化

磁盘数据尽可能在内存中处理。

异地容灾

如果不可容忍网站不可用,应考虑到异地备份或异地双活。

应急预案


十三、谈古至今

尽量将请求拦截在前面,从而减少数据库和HTTP请求

数据库层是架构瓶颈,需要精心设计,比如架构扩展、SQL优化(压缩、索引等)

避免单点

分解压力

扩展性

找瓶颈出方案


十三、应急预案

SRE:网站可靠性工程师

保证网站不宕机是他们的使命!


制作应急预案大致以下几步:

1、系统分级

按照业务系统重要性划分,比如订单服务挂了,将影响用户无法下单,因此需要投入更多的资源保障;比如管理后台挂了,不会影响到用户;根据业务划分不同级别,实施不同的质量保障和成本投入。

2、全链路分析

梳理从网站入口到数据存储的各个环节,找出依赖服务,假设性去分析问题,如果某环节故障,影响范围怎样。

3、全方位监控

对相关链路实施全面监控,包括基础资源监控、服务状态监控、接口监控、日志监控等,确保出现问题有依据可追溯。

4、制定应急预案

多思考方案可行性,不定期进行预案演习,验证预案正确性和可控性及掌握恢复时间。


十四、应对策略

网络接入层:

a)机房故障:从DNS轮训摘除该机房或者切换到其他机房

b)VIP网络异常:切换备用VIP

代理层:

a)IP限流:某些IP访问太大导致后端负载压力过高;实施IP限流

b)后端应用异常:如软硬件故障,摘除异常节点;如果某机房问题切换到其他机房

应用层和服务层:

a)服务异常:某服务访问超时,响应慢;摘除服务或切换到正常服务

b)程序线程池不够用:线程池设置太小,导致请求堆积;提供参数开关,比如动态调整线程池大小

c)请求量太大:请求量太大,超过实际处理能力;请求限流或者设置请求阈值自动扩展节点

缓存层和数据层:

a)Redis挂掉:主从切换

b)MySQL挂掉:主从切换,切换后验证

c)机房故障:切换缓存库/数据库到其他机房


每个互联网公司都有网站!而熟悉网站架构流程已成为运维/开发/测试工程师必备技能之一,同样面试中也经常提问,希望大家好好看看,温故思路及经验总结。



相关实践学习
Serverless极速搭建Hexo博客
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
目录
相关文章
|
3月前
|
设计模式 前端开发 数据库
从MVC到MVVC:软件架构的演变和迭代(二)
从MVC到MVVC:软件架构的演变和迭代
|
18天前
|
消息中间件 运维 Kubernetes
探索微服务架构的演变与实践
在软件开发的长河中,微服务架构如同一股清流,它改变了我们构建和部署应用的方式。本文将深入探讨微服务架构从诞生到成熟的发展历程,分析其核心价值与面临的挑战,并分享实践中的经验教训。通过具体案例,我们将揭示如何在不断变化的技术生态中有效运用微服务架构,以及如何克服实施过程中的障碍。
|
1月前
|
边缘计算 人工智能 Cloud Native
云原生架构的演变与未来展望
在数字化转型的浪潮中,云原生技术成为企业IT战略的核心。本文深入探讨了云原生架构从起步到成熟的发展脉络,分析了容器化、微服务和持续交付等关键技术如何推动应用现代化,并预测了云原生技术的未来趋势,如边缘计算、AI增强和多云管理。同时,文章也对云原生实践过程中可能遇到的安全挑战、技术复杂性以及人才缺口问题提出了见解,旨在为读者提供一份全面的云原生技术指南。
|
10天前
|
运维 监控 持续交付
探索微服务架构的演变与实践
在数字化浪潮推动下,微服务架构如同细胞分裂般不断演化,孕育出更灵活、高效的系统设计哲学。本文将带你穿梭于微服务的发展历程,解锁其背后的技术密码,并分享构建和部署微服务的实践智慧。从理论到实战,我们将一同见证微服务如何重塑现代应用开发的面貌。
19 2
|
14天前
|
运维 负载均衡 数据管理
探索微服务架构的演变与实践
本文将深入探讨微服务架构的概念、发展及其在现代软件开发中的应用。通过分析微服务架构的核心优势和面临的挑战,结合实际案例,揭示如何有效实施微服务以提升系统性能和可维护性。文章旨在为读者提供一套清晰的微服务采用指南,帮助团队做出更明智的技术选择。
|
15天前
|
机器学习/深度学习 敏捷开发 运维
探索后端架构的演变与未来趋势
【8月更文挑战第5天】在数字化时代的浪潮下,后端架构作为支撑现代网络应用的骨架,经历了从单体应用到微服务、再到无服务器计算的转变。每一次技术的跃进不仅提升了开发效率,也带来了新的挑战和思考。本文将深入探讨后端架构的演变路径,分析当前面临的主要问题,并展望未来可能的发展方向。
|
20天前
|
运维 Cloud Native Devops
云原生架构的演变与实践
【7月更文挑战第31天】本文将深入探讨云原生技术如何从概念走向成熟,并分析其对企业IT架构的影响。我们将从云原生的基本概念出发,逐步剖析其在现代软件开发和运维中的关键作用,以及如何通过实践案例来理解云原生架构的优势和挑战。文章旨在为读者提供一套实用的云原生应用指南,帮助他们在数字化转型的浪潮中乘风破浪。
26 4
|
25天前
|
运维 Cloud Native 持续交付
探索云原生架构的演变与实践
随着企业数字化转型的步伐加快,云原生技术成为推动这一进程的核心动力。本文将深入探讨云原生架构的发展历程,解析其核心技术组件,并通过实际案例展现云原生在现代IT架构中的应用与挑战。从容器化、微服务到自动化运维,我们将一窥云原生如何重塑软件开发与运维模式,并预见其对未来技术生态的影响。
|
4天前
|
边缘计算 安全 物联网
未来互联网架构的演变
【8月更文挑战第16天】随着科技的不断进步,互联网作为现代社会不可或缺的基础设施,其架构也在不断地发展与演变。本文将探讨未来互联网架构可能的变化方向,包括边缘计算、软件定义网络(SDN)、网络功能虚拟化(NFV)等技术趋势,以及这些技术如何影响互联网的稳定性、安全性和效率。同时,文章还将讨论这些变革对用户隐私保护和数据治理的潜在影响,并展望互联网架构的未来发展趋势。
|
14天前
|
机器学习/深度学习 Kubernetes Cloud Native
云原生架构的演变与未来展望
【8月更文挑战第6天】云原生技术正以前所未有的速度重塑着软件开发和运维领域,它不仅仅是一种技术革新,更是一种思维方式的转变。从最初的容器化技术到如今复杂的服务网格和无服务器架构,云原生不断演进,推动着企业IT架构的现代化。本文将探讨云原生架构的关键组成部分、它们是如何协同工作的,以及这些技术如何促进企业的数字化转型。我们还将展望未来云原生技术的发展趋势,以及它们可能带来的行业变革。
22 0