大型网站技术架构案列分析笔记

2024-05-13 08:08

本文主要是介绍大型网站技术架构案列分析笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

  • 特点
  • 大型互联网应用系统有以下特点
    高并发,大流量

    1. 高可用,系统7X24小时不间断服务
    2. 海量数据
    3. 用户分布广泛,网络情况复杂
    4. 由于互联网的开放性,安全环境恶劣
    5. 需求快速变更,发布频繁
    6. 渐进式发展

发展历程

  • 初始阶段的网站架构都是一台服务器部署所有模块

输入图片说明

  • 应用服务器和数据服务分离,不同特性的服务器承担不同的角色,网站的并发处理能力和数据存储空间得到很大改善
    输入图片说明

  • 随着用户的增多,网站又一次面临挑战,数据库压力太大导致访问延迟,进而影响这个性能

  • 网站访问的特点和现实世界的财富分配一样遵循二八定律,80%的业务访问集中在20%的数据上,这个时候使用缓存可以有效的改善网站性能

网站使用的缓存可以分为两种

  1. 缓存在应用服务器上的本地缓存,本地缓存访问速度更快,但是受限于服务内存大小,且会出现和应用程序争内存的情况
  2. 缓存在专门服务器上的远程缓存,可以使用集群的方式部署大内存的服务器作为专门的缓存服务器,理论上可以做到不受内存容量限制

输入图片说明

使用缓存后,访问数据库压力可以得到有效缓解,但是单一的应用服务器处理的请求连接有限,在网站高峰访问时期,应用服务器会成为整个网站的瓶颈

使用应用服务器集群改善网站的 并发处理能力

集群是网站解决高并发,海量数据的常用手段,当一台服务器的处理能力,存储空间不足时,不要企图去更换更大的服务器,对大型网站而言,不管多强大的服务器,都满足不了网站持续增长的业务,更有效的做法是增加一台服务器来分摊压力

输入图片说明

应用服务器性能优化

  1. 分布式缓存

    • 网站性能优化第一定律:优先考虑使用缓存优化性能
  2. 异步操作

    • 使用消息队列将调用异步化,可改善网站的性能,消息队列具有很好的消峰作用
  3. 使用集群

  4. 代码优化

    • 使用多线程
    • 将对象设计为无状态对象,无状态对象本省不存储状态信息,多线程并发访问时就不会出现状态不一致
    • 使用局部对象
    • 并发访问时使用资源锁

网购秒杀系统架构设计

  1. 技术挑战

    • 对现有业务网站造成冲击
    • 高并发应用下,数据库负载
    • 突然增加的网落及服务带宽
  2. 应对策略

    • 独立部署秒杀系统和分配独立域名与现有业务网站完全隔离,避免拖垮整个业务网站
    • 秒杀页面静态化,不使用原有的商品详情页,将商品参数,详情写入一个静态页面,可以减少数据库的访问
    • 动态生成下单页面的url,
    • 由于秒杀的特性,库存和用户的参与数差别很大,可以限制用户的请求数,拦截大部分请求跳转至秒杀结束页面

输入图片说明

这篇关于大型网站技术架构案列分析笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/985140

相关文章

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

nginx部署https网站的实现步骤(亲测)

《nginx部署https网站的实现步骤(亲测)》本文详细介绍了使用Nginx在保持与http服务兼容的情况下部署HTTPS,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录步骤 1:安装 Nginx步骤 2:获取 SSL 证书步骤 3:手动配置 Nginx步骤 4:测

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

C#使用DeepSeek API实现自然语言处理,文本分类和情感分析

《C#使用DeepSeekAPI实现自然语言处理,文本分类和情感分析》在C#中使用DeepSeekAPI可以实现多种功能,例如自然语言处理、文本分类、情感分析等,本文主要为大家介绍了具体实现步骤,... 目录准备工作文本生成文本分类问答系统代码生成翻译功能文本摘要文本校对图像描述生成总结在C#中使用Deep

微服务架构之使用RabbitMQ进行异步处理方式

《微服务架构之使用RabbitMQ进行异步处理方式》本文介绍了RabbitMQ的基本概念、异步调用处理逻辑、RabbitMQ的基本使用方法以及在SpringBoot项目中使用RabbitMQ解决高并发... 目录一.什么是RabbitMQ?二.异步调用处理逻辑:三.RabbitMQ的基本使用1.安装2.架构

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re