gpt4 book ai didi

c# - 如何在 Blazor 服务器应用程序中正确计算 SignalR 消息?

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

我有一个托管在 Azure 应用服务上的 Blazor 服务器应用程序,该应用程序似乎非常“健谈”,因为它正在处理浏览器上的一些 UI 事件(例如拖放事件)。我添加了跟踪日志,以对正在使用的 SignalR 消息数量及其大小进行某种估计。

我的 Program.cs 中有以下内容

public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureLogging(logging =>
{
logging.ClearProviders();
logging.AddConsole();
// Logs to trace Blazor SignalR traffic.
logging.AddFilter("Microsoft.AspNetCore.SignalR", LogLevel.Trace);
logging.AddFilter("Microsoft.AspNetCore.Http.Connections", LogLevel.Trace);
})

.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
});
}

这给了我一个相当广泛的日志输出,看起来像这样:

trce: Microsoft.AspNetCore.Http.Connections.Internal.Transports.WebSocketsTransport[9]
Message received. Type: Binary, size: 319, EndOfMessage: True.
dbug: Microsoft.AspNetCore.SignalR.Internal.DefaultHubDispatcher[1]
Received hub invocation: InvocationMessage { InvocationId: "", Target: "DispatchBrowserEvent", Arguments: [ {"browserRendererId":0,"eventHandlerId":366,"eventArgsType":"mouse","eventFieldInfo":null}, {"type":"click","detail":1,"screenX":386,"screenY":-443,"clientX":700,"clientY":514,"offsetX":70,"offsetY":21,"button":0,"buttons":0,"ctrlKey":false,"shiftKey":false,"altKey":false,"metaKey":false} ], StreamIds: [ ] }.
trce: Microsoft.AspNetCore.Http.Connections.Internal.Transports.WebSocketsTransport[11]
Sending payload: 1078 bytes.
trce: Microsoft.AspNetCore.SignalR.Internal.DefaultHubDispatcher[7]
InvocationId (null): Sending result of type 'System.Void'.
trce: Microsoft.AspNetCore.Http.Connections.Internal.Transports.WebSocketsTransport[9]
Message received. Type: Binary, size: 28, EndOfMessage: True.
dbug: Microsoft.AspNetCore.SignalR.Internal.DefaultHubDispatcher[1]
Received hub invocation: InvocationMessage { InvocationId: "", Target: "OnRenderCompleted", Arguments: [ 1237, ], StreamIds: [ ] }.
trce: Microsoft.AspNetCore.SignalR.Internal.DefaultHubDispatcher[7]
InvocationId (null): Sending result of type 'System.Void'.
trce: Microsoft.AspNetCore.Http.Connections.Internal.Transports.WebSocketsTransport[11]
Sending payload: 13216 bytes.

我可以看到那里正在发送大消息,我认为这是由于在服务器大小(从数据库)上加载初始数据并传递到组件以呈现信息而引起的。较小的 UI 事件会产生大量较小的 75 字节消息(显然)。

我正在应用一些正则表达式工作来从这些日志中获取我需要的信息,但不确定所收集信息的准确性。

计算 SignalR 消息的最佳/正确方法是什么(消息数量和每条消息的大小)?

我想估计使用 Azure SignalR 服务是否是扩展我的应用程序的可行解决方案。

描述了如何对 Azure SignalR 消息进行计费计数 here .

到目前为止,我对 SignalR 免费层的测试显示,每天几分钟内就超过了 20,000 条免费消息。当测试每天 100 万条免费消息的标准层时,我可以看到一小时内已经使用了数十万条消息。

我已经找到了在我的应用程序上产生不需要的(或非常大的)消息的东西,但有些东西似乎失去了控制;我需要正确地测量这个。

最佳答案

谢谢SnehaAgrawal-MSFT发布您的suggestion作为帮助其他社区成员的答案。

“您可以引用此 Doc on resource logs for Azure SignalR Service 以及如何设置它们,以及如何使用它们进行故障排除。

要添加到免费套餐实例中的 SignalR 资源,每天的消息限制为 20000 条。

请检查此Microsoft document关于 SignalR 服务中消息的计数方式。

如果大消息分成较小的消息并计为多条消息,在这种情况下连接会受到限制。

如果消息计数是预期的,那么唯一的解决方案是将实例扩展到没有硬性消息计数限制的标准层。”

请参阅此 Microsoft 文档以获取更多信息:。 Evaluation for complex use cases for Azure SignalR Service

关于c# - 如何在 Blazor 服务器应用程序中正确计算 SignalR 消息?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69277202/

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