1

我有一个 C# Web 应用程序,它使用一个需要很长时间(2 分钟)才能初始化的组件(Progress Telerik Sitefinity CMS)。在此阶段访问该站点的用户将被重定向到每秒轮询状态的页面,直到初始化完成。(这是内置的 Sitefinity 行为)。

我在 Azure 应用服务中托管我的应用程序。如果我增加实例的数量(扩大规模),我的一些用户最终会在新节点仍在初始化时使用它。问题是,由于 Azure 添加的关联 cookie,它们停留在此节点上。

我想要亲和力,除非网站正在初始化。在这种情况下,我想删除 cookie 并进行投票。在那种情况下,我会被分配一个随机节点,因此会在几秒钟内找到一个初始化节点。

问题是:我如何实现这一目标?发生的大部分事情都是在 Sitefinity 中处理的,所以我求助于更改 global.asax 中的内容。它不起作用。我试图把它放在我的 global.asax.cs 中:

protected void Application_PreRequestHandlerExecute(object sender, EventArgs e)
{
    var path = HttpContext.Current.Request.Url.AbsolutePath;
    // "/sitefinity/status" is the page the client is redirected to
    // "/appstatus" is used to poll initialization status
    if (path == "/appstatus" || path == "/sitefinity/status")
    {
        // "ARRAffinity" is the Azure affinity cookie
        Response.Cookies.Remove("ARRAffinity");
        // just removing the cookie didn't work so i tried to override it
        Response.Cookies.Add(new HttpCookie("ARRAffinity", "-") { HttpOnly = true });
        // reportedly, this suppresses cookie adding by Azure
        Response.Headers.Add("ARR-Disable-Session-Affinity", "true");
    };
}

如何强制我的客户端到不同的节点?

编辑我想我在这里 找到了(部分)问题。

  • 首先,请求“/”。这将返回 302 重定向,但也返回 ARRAffinity cookie。
  • 然后,请求“/sitefinity/status”。ARR-Disable-Session-Affinity 和 cookie 都被剥离。这意味着,cookie 不会在客户端上清除。
  • 轮询时,客户端已经拥有 cookie。所以用户永远不会被重定向到另一个节点。

所以这可能是问题所在。现在要解决它...

编辑

我遵循了 Vesselin Vassilevs 的建议并将其添加到我的站点配置文件中:

<appSettings>
    <add key="sf:AppStatusPageResponseCode" value="503" />
</appSettings>

但是因为我仍然偶然到达了初始化节点,所以我还通过更改我的 global.asax.cs 来抑制 affinity cookie:

    protected void Application_EndRequest(object sender, EventArgs e)
    {
        var httpCode = Response.StatusCode;
        var isRedirectBackFromStatusPage = httpCode == 302 && Request.Url.AbsolutePath == "/sitefinity/status";
        var isFinalSitefinityStatusPoll = httpCode == 404 && Request.Url.AbsolutePath == "/appstatus";
        if (isRedirectBackFromStatusPage || isFinalSitefinityStatusPoll)
        {
            var cookie = Request.Cookies["ARRAffinity"];
            if (cookie != null) Response.Cookies.Add(cookie);
            return;
        }
        if (httpCode != 200 || !Response.ContentType.StartsWith("text/html"))
        {
            Response.Headers.Add("ARR-Disable-Session-Affinity", "true");
        };
    }
4

1 回答 1

1

为什么不完全禁用 arr 关联 cookie?Sitefinity 后端可以在没有 arr cookie 和多个实例的情况下正常工作。

编辑:我们需要告诉 Azure 在 Sitefinity 初始化期间该站点尚未准备好。问题在于,appStatus 页面(在初始化期间由 Sitefinity 显示)返回状态代码 302 甚至 200,这使 Azure 相信该站点运行正常。我在这里写过这个:https : //sitefinitydevelopment.com/blog/sitefinity's-application-status-page-can-cause-you-big-problems.html 根据您的 Sitefinity 版本,您可以实施自定义解决方案那里(在系统重新启动期间手动返回 http 代码 503)或在 web.config 中设置以下设置(Sitefinity 9+)

<add key="sf:AppStatusPageResponseCode" value="503" />
于 2018-04-06T22:54:10.343 回答