首页 > 编程语言 >构建可扩展的 Azure 静态 Web 应用程序来处理高流量网站

构建可扩展的 Azure 静态 Web 应用程序来处理高流量网站

时间:2024-09-26 21:28:04浏览次数:7  
标签:Web web 静态 扩展 应用程序 azure 流量 Azure

tl;dr: azure static web apps 的免费托管计划可能无法满足高流量需求。通过最小化和压缩资产、优化图像加载、实施缓存、使用企业级边缘和自动缩放来扩展这些应用程序,以增强全球用户的性能、安全性和效率。在当今的软件开发世界中,您的应用程序不仅服务于本地社区,还覆盖来自全球各个角落的用户。您需要确保您的应用程序能够满足全球受众的需求。我们以亚马逊为例。仅 7 月份,亚马逊网站的访问量就达到了惊人的 34.1 亿次。每分钟约有 81,892 次访问!在传统的本地服务器上管理如此庞大的流量将非常昂贵且复杂,需要大量的硬件。但是有一个更好的方法来处理这个问题:使用基于云的服务,例如 azure static web apps。此托管服务消除了 web 应用程序部署和可扩展性的麻烦,使您的网站更轻松地有效处理全球流量。最好的部分?设置起来轻而易举。只需将版本控制工具(无论是 github 还是 azure devops)连接到 azure 静态 web 应用。从那里,azure 处理其余的事情,使用持续部署机制自动部署您的站点。这意味着您的应用程序始终是最新的,并准备好为全球用户提供服务,而无需您进行任何手动干预。 为什么 azure 静态 web 应用需要扩展?开箱即用的 azure static web apps 非常适合提供静态站点。但其默认设置是为小型项目设计的。例如,使用 azure 静态 web 应用程序的免费托管层查看此网站:使用免费计划,您会遇到一些限制。当应用程序扩展时,它们可能会遇到性能下降和效率降低的问题。 为高流量网站扩展 azure 静态 web 应用程序要扩展 azure 静态 web 应用程序以服务高流量网站,您可以在应用程序级别或 azure 级别进行优化。 应用级优化首先,让我们看看您可以在整个应用程序中进行哪些更改,以确保它准备好服务高流量。在应用程序级别,您可以执行三项主要操作。 最小化和压缩资产首先,您可以最小化和压缩应用程序的资源。例如,您可能有一个包含大量静态内容(例如图标和图像)的公共目录。当项目数量增加时,应用程序的整体大小会以兆字节为单位增加,这可能会对网络性能产生负面影响。优化:清除未使用的文件以保持您的应用程序精简。确保图像和其他资源被压缩。例如,目标是将图像保持在 300kb 以下,以优化网络加载时间。 优化图像接下来,您可以优化应用程序中加载图像的方式。例如,通过网络加载 1,000 张图像是没有用的,因为您无法一次显示 1,000 张图像。相反,建议当用户向下滚动您的网站时按需加载这些图像。这可以节省网络操作并保持应用程序平稳运行,从而帮助您的应用程序服务更多的 azure 用户。此外,这可以通过使用图像标签在 next.js 等框架中实现。import Image from 'next/image'function HomePage() { return ( <div> <image src="/path-to-your-image.jpg" alt="Description of image" width="{500}" height="{300}"></image></div> )}export default HomePage登录后复制next.js 中的图像标签可以原生处理这种延迟加载行为。 实施缓存您可以利用缓存控制标头来启用浏览器缓存。这可以包括诸如 max-age 之类的标头,以指示项目应缓存多长时间。这可以与 azure 级优化相结合,例如利用 cdn。 cdn 将读取此标头并将其缓存在其边缘位置上定义的时间。因此,所有请求都将从边缘位置提供服务,从而创建更快的响应。 azure 级优化接下来,让我们看看可以在 azure 静态 web 应用中进行的更改,以确保它可以处理高流量。此时您可以做三件事。 利用企业级边缘支持企业级边缘支持通过结合 azure 服务 front door、cdn 和 azure 静态 web 应用来创建单一、安全的云 cdn 平台,从而增强 web 应用的性能、安全性和可靠性。它具有以下功能:全球影响力: azure front door 提供遍布 100 个大都市的超过 118 个边缘站点的全球影响力,确保从更靠近用户的位置提供内容,减少延迟并缩短加载时间。边缘缓存: 在边缘(距离用户最近的点)缓存资源,最大限度地缩短数据传输距离并加快内容交付速度。ddos 防护: 此服务提供针对分布式拒绝服务 (ddos) 攻击的主动防护,保护您的网站免受恶意流量的侵害。ipv6 和 http/2 支持: 确保端到端 ipv6 连接并使用 http/2 协议实现更快、更高效的资源加载。优化文件压缩:自动压缩文件以减小大小并提高传输速度。要启用企业级边缘支持,您需要将 azure 静态 web 应用计划升级到 标准 计划。这确保您的应用程序可以处理高流量,同时提高性能和安全性。注意: 这不是免费升级。您必须为标准计划支付每个应用程序每月 17.52 美元才能利用企业级优势。 使用自动缩放后端功能自动扩展后端函数可确保您的无服务器函数可以通过自动扩展以满足需求来处理不同的负载。这可以使用 azure 函数来完成。azure 函数可以根据传入请求的数量自动扩展。这意味着在高流量期间,将运行更多函数实例来处理负载,从而确保平稳的性能。有两个版本:消费计划: 默认情况下,消费计划上的 azure 函数会根据需求自动扩展。这是不可预测的流量模式的理想选择,无需人工干预即可处理数百万个请求。高级计划: 对于更高级的场景,高级计划提供附加功能,例如 vnet 集成、无限执行持续时间和高级扩展选项。确保您的 azure 函数配置为使用适当的计划和扩展设置来满足您的应用程序的需求。这允许您的后端动态扩展和缩小,优化资源使用和成本。 设置主动监控随着您的应用为更多用户服务,需要进行监控。您需要了解世界不同地区的人们如何与您的应用互动。主动监控可帮助您跟踪应用程序的性能和运行状况,使您能够在问题影响用户之前识别并解决问题。为此,您可以利用以下方法:azure 监视器: 使用 azure 监视器收集和分析来自应用程序的指标和日志。这包括响应时间、请求率、错误率和资源利用率。应用程序见解: 将应用程序见解与 azure 静态 web 应用程序集成,以获得详细的遥测和诊断。应用程序洞察提供了用于监控应用程序性能、检测异常和诊断问题的强大工具。警报: 要收到潜在问题的通知,请根据特定指标或日志设置警报。例如,您可以针对高响应时间、错误率或异常流量模式设置警报。 结论性想法感谢您阅读此博客!我们探索了扩展 azure 静态 web 应用程序以处理高流量的基本策略。利用 azure static web apps 等服务是实现高效服务数百万用户的应用程序的关键,但需要注意的是,免费托管计划可能无法满足高流量需求。了解 azure 计划和功能,例如企业级边缘支持和自动缩放后端功能,可以显着提高应用程序的性能和可靠性。我希望您发现这篇文章对您的扩展需求富有洞察力和有用。 相关博客azure maps 作为 syncfusion 地图的来源如何在 azure 静态 web 应用程序上部署 react 应用程序如何使用 azure 应用程序网关解决 504 网关超时错误使用 azure key vault 和 syncfusion c# pdf 库创建 pdf 数字签名 web 服务以上就是构建可扩展的 Azure 静态 Web 应用程序来处理高流量网站的详细内容,更多请关注我的其它相关文章!

标签:Web,web,静态,扩展,应用程序,azure,流量,Azure
From: https://www.cnblogs.com/aow054/p/18434393

相关文章

  • 前端使用webpack本地实现编译时出现错误[cached] 1 asset ERROR in main Module not
    一:概述Webpack是一个现代JavaScript应用程序的静态模块打包工具。它主要用于将JavaScript代码、CSS、图片等资源模块化管理,并最终打包成一个或多个文件,方便在浏览器中使用。以下是对Webpack的详细介绍:主要特点模块化:Webpack支持ES6模块、CommonJS和AMD模块,能够将各种......
  • java使用webservice 调用天气预报接口
    市场上有许多免费的和付费的天气预报API,例如OpenWeatherMap、WeatherAPI、Weatherstack等。这里我们以OpenWeatherMap为例,因为它提供了广泛的天气数据和相对简单的API接口。访问OpenWeatherMap的官网(https://openweathermap.org/) ,注册一个账户,并创建一个API密钥(APIkey)。这个密钥将......
  • 掌握 GitHub Webhook:综合指南
    GitHubWebhooks提供了一种强大的方法来自动化工作流程并将GitHub与外部服务集成,根据存储库中的事件提供实时更新。无论您是想触发部署、发送通知还是跨平台同步数据,GitHubwebhooks都提供了灵活高效的解决方案。在本指南中,我们将探讨GitHubWebhooks是什么、它们如何工作以......
  • JavaWeb基础-学习笔记01
    01JavaWeb介绍一个Web的互联网系统可以分为三个主要部分:网页、JavaWeb程序、数据库网页:展现数据数据库:存储和管理数据javaWeb程序:逻辑处理因此,JavaWeb的学习内容对应以上三部分内容:数据库部分MySQL:一款主流的数据库产品(数据库管理系统),用结构化查询语言SQL操作数据库JD......
  • C# WebSocket Servers -- Fleck、SuperSocket、TouchSocke
    C#WebSocketServers--Fleck、SuperSocket、TouchSocke 最近在维护老项目,感觉内存一直都有问题,定位到问题是WebSocketServer的问题,了解了Fleck、SuperSocket、TouchSocke等开源项目,这里记录一下。可能今后都不会用些轮子了,.net5、.net6、.net7、.net8项目已经集成了We......
  • WEB服务器——Tomcat
    服务器是可以使用java完成编写,是可以接受页面发送的请求和响应数据给前端浏览器的,而在开发中真正用到的Web服务器,我们不会自己写的,都是使用目前比较流行的web服务器。如:Tomcat1.简介Tomcat是一个开源的轻量级Web服务器,主要用于运行JavaWeb应用。它支持Servlet和JS......
  • C# WebSocket Servers -- Fleck、SuperSocket、TouchSocke
    最近在维护老项目,感觉内存一直都有问题,定位到问题是WebSocketServer的问题,了解了Fleck、SuperSocket、TouchSocke等开源项目,这里记录一下。可能今后都不会用些轮子了,.net5、.net6、.net7、.net8项目已经集成了WebSocket,只要 app.UseWebSockets()代码就可以了,详情见 WebS......
  • Windows Server 2019 Web服务器之IIS的安装与基本配置
    准备工作:选择一台服务器作为WEB-IIS服务器在WindowsServer2019系统中,IIS角色是可选组件,默认情况下是没有安装的。1.在windows服务器中安装IIS1)打开【服务器管理器】,单击【添加角色和功能】。2)默认选择【基于角色或基于功能的安装】,点击【下一步】。3)默认选项,继续下一步。......
  • web开发人员必备的100个免费资源
    在这篇文章中,我将分享100多个免费的网页开发资源,包括API、托管平台、备忘单、图标、模板、字体、颜色资源、学习平台、CSS游戏、代码编辑器和JavaScript动画库。让我们直接开始吧!......
  • 命令执行篇3(web55-70)
    17.web55无字母数字的命令执行(ctfshowweb入门55)_ctfshowweb55-CSDN博客base64也是/bin目录下的可执行程序18.web56importrequestswhileTrue:url="http://2534e197-d33f-4743-857a-a32ba63fee72.challenge.ctf.show/?c=.+/???/????????[@-[]"r=re......