插件窝 干货文章 构建可扩展的 Azure 静态 Web 应用程序来处理高流量网站

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

应用程序 azure strong 静态 953    来源:    2024-10-21

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 静态 web 应用程序以服务高流量网站,您可以在应用程序级别或 azure 级别进行优化。

应用级优化

首先,让我们看看您可以在整个应用程序中进行哪些更改,以确保它准备好服务高流量。在应用程序级别,您可以执行三项主要操作。

最小化和压缩资产

首先,您可以最小化和压缩应用程序的资源。例如,您可能有一个包含大量静态内容(例如图标和图像)的公共目录。当项目数量增加时,应用程序的整体大小会以兆字节为单位增加,这可能会对网络性能产生负面影响。

优化:

  • 清除未使用的文件以保持您的应用程序精简。
  • 确保图像和其他资源被压缩。例如,目标是将图像保持在 300kb 以下,以优化网络加载时间。

优化图像

接下来,您可以优化应用程序中加载图像的方式。例如,通过网络加载 1,000 张图像是没有用的,因为您无法一次显示 1,000 张图像。相反,建议当用户向下滚动您的网站时按需加载这些图像。

这可以节省网络操作并保持应用程序平稳运行,从而帮助您的应用程序服务更多的 azure 用户。此外,这可以通过使用图像标签在 next.js 等框架中实现。

import Image from 'next/image'

function HomePage() {
  return (
    <div>
      <image src="" 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 应用计划升级到 标准 计划。这确保您的应用程序可以处理高流量,同时提高性能和安全性。构建可扩展的 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 服务