Add links to Azure Service Bus where relevant (#33392)
parent
320c0482f0
commit
efb8a30df2
|
@ -37,6 +37,7 @@ A common performance problem in ASP.NET Core apps is blocking calls that could b
|
||||||
* **Do** call data access, I/O, and long-running operations APIs asynchronously if an asynchronous API is available.
|
* **Do** call data access, I/O, and long-running operations APIs asynchronously if an asynchronous API is available.
|
||||||
* **Do not** use <xref:System.Threading.Tasks.Task.Run%2A?displayProperty=nameWithType> to make a synchronous API asynchronous.
|
* **Do not** use <xref:System.Threading.Tasks.Task.Run%2A?displayProperty=nameWithType> to make a synchronous API asynchronous.
|
||||||
* **Do** make controller/Razor Page actions asynchronous. The entire call stack is asynchronous in order to benefit from [async/await](/dotnet/csharp/programming-guide/concepts/async/) patterns.
|
* **Do** make controller/Razor Page actions asynchronous. The entire call stack is asynchronous in order to benefit from [async/await](/dotnet/csharp/programming-guide/concepts/async/) patterns.
|
||||||
|
* **Consider** using message brokers like [Azure Service Bus](/azure/service-bus-messaging/service-bus-messaging-overview) to offload long-running calls
|
||||||
|
|
||||||
A profiler, such as [PerfView](https://github.com/Microsoft/perfview), can be used to find threads frequently added to the [Thread Pool](/windows/desktop/procthread/thread-pools). The `Microsoft-Windows-DotNETRuntime/ThreadPoolWorkerThread/Start` event indicates a thread added to the thread pool. <!-- For more information, see [async guidance docs](TBD-Link_To_Davifowl_Doc) -->
|
A profiler, such as [PerfView](https://github.com/Microsoft/perfview), can be used to find threads frequently added to the [Thread Pool](/windows/desktop/procthread/thread-pools). The `Microsoft-Windows-DotNETRuntime/ThreadPoolWorkerThread/Start` event indicates a thread added to the thread pool. <!-- For more information, see [async guidance docs](TBD-Link_To_Davifowl_Doc) -->
|
||||||
|
|
||||||
|
@ -132,7 +133,7 @@ Most requests to an ASP.NET Core app can be handled by a controller or page mode
|
||||||
Recommendations:
|
Recommendations:
|
||||||
|
|
||||||
* **Do not** wait for long-running tasks to complete as part of ordinary HTTP request processing.
|
* **Do not** wait for long-running tasks to complete as part of ordinary HTTP request processing.
|
||||||
* **Do** consider handling long-running requests with [background services](xref:fundamentals/host/hosted-services) or out of process with an [Azure Function](/azure/azure-functions/). Completing work out-of-process is especially beneficial for CPU-intensive tasks.
|
* **Do** consider handling long-running requests with [background services](xref:fundamentals/host/hosted-services) or out of process possibly with an [Azure Function](/azure/azure-functions/) and/or using a message broker like [Azure Service Bus](/azure/service-bus-messaging/service-bus-messaging-overview). Completing work out-of-process is especially beneficial for CPU-intensive tasks.
|
||||||
* **Do** use real-time communication options, such as [SignalR](xref:signalr/introduction), to communicate with clients asynchronously.
|
* **Do** use real-time communication options, such as [SignalR](xref:signalr/introduction), to communicate with clients asynchronously.
|
||||||
|
|
||||||
## Minify client assets
|
## Minify client assets
|
||||||
|
|
Loading…
Reference in New Issue