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

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

相关文章

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛

github打不开的问题分析及解决

《github打不开的问题分析及解决》:本文主要介绍github打不开的问题分析及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、找到github.com域名解析的ip地址二、找到github.global.ssl.fastly.net网址解析的ip地址三

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Java中的登录技术保姆级详细教程

《Java中的登录技术保姆级详细教程》:本文主要介绍Java中登录技术保姆级详细教程的相关资料,在Java中我们可以使用各种技术和框架来实现这些功能,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录1.登录思路2.登录标记1.会话技术2.会话跟踪1.Cookie技术2.Session技术3.令牌技

java -jar命令运行 jar包时运行外部依赖jar包的场景分析

《java-jar命令运行jar包时运行外部依赖jar包的场景分析》:本文主要介绍java-jar命令运行jar包时运行外部依赖jar包的场景分析,本文给大家介绍的非常详细,对大家的学习或工作... 目录Java -jar命令运行 jar包时如何运行外部依赖jar包场景:解决:方法一、启动参数添加: -Xb

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

Linux中的more 和 less区别对比分析

《Linux中的more和less区别对比分析》在Linux/Unix系统中,more和less都是用于分页查看文本文件的命令,但less是more的增强版,功能更强大,:本文主要介绍Linu... 目录1. 基础功能对比2. 常用操作对比less 的操作3. 实际使用示例4. 为什么推荐 less?5.

spring-gateway filters添加自定义过滤器实现流程分析(可插拔)

《spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔)》:本文主要介绍spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔),本文通过实例图... 目录需求背景需求拆解设计流程及作用域逻辑处理代码逻辑需求背景公司要求,通过公司网络代理访问的请求需要做请

如何关闭Mac的Safari通知? 3招教你关闭Safari浏览器网站通知的技巧

《如何关闭Mac的Safari通知?3招教你关闭Safari浏览器网站通知的技巧》当我们在使用Mac电脑专注做一件事情的时候,总是会被一些消息推送通知所打扰,这时候,我们就希望关闭这些烦人的Mac通... Safari 浏览器的「通知」功能本意是为了方便用户及时获取最新资讯,但很容易被一些网站滥用,导致我们