gpt4 book ai didi

azure - 部署 Azure Web Apps 时最大限度减少停机时间的最佳实践

转载 作者:行者123 更新时间:2023-12-02 03:18:45 28 4
gpt4 key购买 nike

我有一个应用服务计划,在该计划中,我将解决方案的 5 个组件部署为 Web 应用程序。我使用 Azure DevOps 中的“发布管理”将代码部署到这些应用程序。

为了最大限度地减少部署期间的停机时间,我首先部署到暂存槽,然后将暂存槽切换到生产槽以完成部署。

我已配置应用服务预热(详细信息 here )来调用端点,该端点将在插槽交换过程中“预热”应用程序。

这似乎有效,但我有两个问题:

  1. 即使已运行预热,槽交换后向应用程序发出的第一个请求也需要很长时间。我怀疑这是由于生产插槽具有“粘性/插槽设置”,据我所知,这需要重新启动应用程序。为了测试这一点,我删除了插槽设置,但延迟仍然存在。

  2. 应用程序相互依赖,并且插槽交换(即使在 Azure DevOps 中并行启动)不能保证同时完成,这意味着较新的代码有可能与旧代码交互。虽然我们可以围绕这个进行设计,但这并不是最佳选择。

根据我迄今为止的调查,我能想到解决这些问题的唯一方法是启动第二个应用服务计划,并将流量管理器配置在两个服务计划之前。部署时,我将优先考虑其中一个服务计划,同时部署到另一个服务计划,完成后将流量转移到新部署的服务计划,同时升级另一个服务计划,然后在两者都完成后再次平衡两者之间的流量在相同的代码级别。

在 Azure 中使用 WebApps 时,当前零停机部署的“最佳实践”是什么?

与流量管理器重复的服务计划是一个可行的选择吗?如果不是,您有什么建议?

最佳答案

遵循这些更多最佳实践建议。

根据状态代码进行交换

在交换操作期间,通过向其根目录发出 HTTP 请求来预热暂存槽中的站点。有关该过程的更详细说明,请访问 How to warm up Azure Web App during deployment slots swap

默认情况下,只要站点响应任何状态代码,交换就会继续。但是,如果您希望在应用程序无法预热时不进行交换,则可以使用以下应用程序设置进行配置:

  • WEBSITE_SWAP_WARMUP_PING_PATH:发出预热请求的路径到。将其设置为以斜线开头的 URL 路径作为值。为了例如,“/warmup.php”。默认值为/。

  • WEBSITE_SWAP_WARMUP_PING_STATUSES:预期的 HTTP 响应代码预热操作。将其设置为以逗号分隔的 HTTP 列表状态代码。例如:“200,202”。如果返回的状态码为不在列表中,交换操作将无法完成。默认情况下,所有响应代码均有效。

最大限度地减少随机冷启动

  • WEBSITE_ADD_SITENAME_BINDINGS_IN_APPHOST_CONFIG:将此设置为“1”将阻止 Web 应用程序的工作进程和应用程序域回收当应用服务的存储基础架构重新配置时。

https://ruslany.net/2019/06/azure-app-service-deployment-slots-tips-and-tricks/#prevent-cold-start

控制槽粘性配置

但是,如果出于任何原因您需要恢复到交换这些设置的旧行为,那么您可以将应用设置 WEBSITE_OVERRIDE_PRESERVE_DEFAULT_STICKY_SLOT_SETTINGS 添加到应用的每个插槽,并将其值设置为“0”或“false”。

https://ruslany.net/2019/06/azure-app-service-deployment-slots-tips-and-tricks/#slot-sticky-config

关于azure - 部署 Azure Web Apps 时最大限度减少停机时间的最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58914514/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com