成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

.NET 8 的 IHostedLifecycleService 接口是雞肋功能嗎?

開發(fā) 前端
IHostedLifecycleService?是.NET 8中引入的一個新特性,它可以讓我們在使用多個IHostedService實現(xiàn)的時候,更加靈活和高效地控制它們的啟動和停止,避免出現(xiàn)不必要的依賴和沖突。

.NET 8 引入了一個新的接口,叫做IHostedLifecycleService,這個接口繼承自現(xiàn)有的 IHostedService 接口,它為 BackgroundService 提供了一些新的生命周期事件的方法:

  • StartingAsync:在 StartAsync 方法之前執(zhí)行,用于執(zhí)行一些初始化或預處理的邏輯。
  • StartedAsync:在 StartAsync 方法之后執(zhí)行,用于執(zhí)行一些后處理或檢查的邏輯。
  • StoppingAsync:在 StopAsync 方法之前執(zhí)行,用于執(zhí)行一些清理或釋放的邏輯。
  • StoppedAsync:在 StopAsync 方法之后執(zhí)行,用于執(zhí)行一些收尾或報告的邏輯。

這些方法都發(fā)生在現(xiàn)有的 StartAsync 和 StopAsync 方法之前或之后。

示例代碼

下面的示例演示如何使用新 API:

var builder = Host.CreateApplicationBuilder(args);
builder.Services.AddHostedService<MyIOWorker>();

var host = builder.Build();
host.Run();

public class MyIOWorker : BackgroundService, IHostedLifecycleService
{
    public async Task StartingAsync(CancellationToken cancellationToken)
    {
        Console.WriteLine($"{nameof(MyIOWorker)} Starting");//業(yè)務邏輯
    }
    public async Task StartedAsync(CancellationToken cancellationToken)
    {
        Console.WriteLine($"{nameof(MyIOWorker)} Started");//業(yè)務邏輯
    }
    public async Task StoppingAsync(CancellationToken cancellationToken)
    {
        Console.WriteLine($"{nameof(MyIOWorker)} Stopping");//業(yè)務邏輯
    }
    public async Task StoppedAsync(CancellationToken cancellationToken)
    {
        Console.WriteLine($"{nameof(MyIOWorker)} Stopped");//業(yè)務邏輯
    }
    protected override async Task ExecuteAsync(CancellationToken stoppingToken)
    {
        while (!stoppingToken.IsCancellationRequested)
        {
            Console.WriteLine($"{nameof(MyIOWorker)} Execute");//業(yè)務邏輯
            await Task.Delay(1000, stoppingToken);
        }
    }
}

輸出結果如下:

MyIOService Starting
MyIOService Execute
MyIOService Started

...

MyIOService Stopping
MyIOService Stopped

雞肋功能?

但是,直接使用 IHostedService 接口一樣可以實現(xiàn)相同功能:

public class MyIOWorker : BackgroundService
{ 
    public override async Task StartAsync(CancellationToken cancellationToken)
    {
        Console.WriteLine($"{nameof(MyIOWorker)} Starting");//業(yè)務邏輯
        await base.StartAsync(cancellationToken);
        Console.WriteLine($"{nameof(MyIOWorker)} Started");//業(yè)務邏輯
    }
     
    public override async Task StopAsync(CancellationToken cancellationToken)
    {
        Console.WriteLine($"{nameof(MyIOWorker)} Stopping");//業(yè)務邏輯
        await base.StopAsync(cancellationToken);
        Console.WriteLine($"{nameof(MyIOWorker)} Stopped");//業(yè)務邏輯
    }
    
    protected override async Task ExecuteAsync(CancellationToken stoppingToken)
    {
        while (!stoppingToken.IsCancellationRequested)
        {
            Console.WriteLine($"{nameof(MyIOWorker)} ExecuteAsync");//業(yè)務邏輯
            await Task.Delay(1000, stoppingToken);
        }
    }
}

那么,新特性IHostedLifecycleService的意義何在呢?

僅僅為了,方便放置不同邏輯的代碼嗎?

探究源碼

在dotnet/runtime源碼https://github.com/dotnet/runtime/blob/main/src/libraries/Microsoft.Extensions.Hosting/src/Internal/Host.cs中,我們找到了 IHostedLifecycleService 的使用邏輯:

// Call StartingAsync().
if (_hostedLifecycleServices is not null)
{
    await ForeachService(_hostedLifecycleServices, cancellationToken, concurrent, abortOnFirstException, exceptions,
        (service, token) => service.StartingAsync(token)).ConfigureAwait(false);

    // Exceptions in StartingAsync cause startup to be aborted.
    LogAndRethrow();
}

// Call StartAsync().
await ForeachService(_hostedServices, cancellationToken, concurrent, abortOnFirstException, exceptions,
    async (service, token) =>
    {
        await service.StartAsync(token).ConfigureAwait(false);

        if (service is BackgroundService backgroundService)
        {
            _ = TryExecuteBackgroundServiceAsync(backgroundService);
        }
    }).ConfigureAwait(false);

// Exceptions in StartAsync cause startup to be aborted.
LogAndRethrow();

// Call StartedAsync().
if (_hostedLifecycleServices is not null)
{
    await ForeachService(_hostedLifecycleServices, cancellationToken, concurrent, abortOnFirstException, exceptions,
        (service, token) => service.StartedAsync(token)).ConfigureAwait(false);
}

上面的代碼先遍歷執(zhí)行IEnumerable<IHostedLifecycleService>? _hostedLifecycleServices的StartingAsync方法,再遍歷執(zhí)行IEnumerable<IHostedService>? _hostedServices的StartAsync方法。

也就是說,如果存在多個IHostedLifecycleService實現(xiàn),我們可以把初始化代碼放在StartingAsync方法實現(xiàn)中,保證了全部初始化邏輯執(zhí)行成功后才會執(zhí)行StartAsync方法中正式的業(yè)務邏輯。對于StopAsync方法也是同理。

使用場景

比如,如果直接使用 IHostedService 接口:

builder.Services.AddHostedService<AWorker>();
builder.Services.AddHostedService<BWorker>();

public class AWorker : BackgroundService
{ 
    public override async Task StartAsync(CancellationToken cancellationToken)
    {
        //初始化數(shù)據(jù)庫A表
    } 
    protected override async Task ExecuteAsync(CancellationToken stoppingToken)
    {
        //訪問數(shù)據(jù)庫A表和B表
    }
}

public class BWorker : BackgroundService
{ 
    public override async Task StartAsync(CancellationToken cancellationToken)
    {
        //初始化數(shù)據(jù)庫B表
    } 
    protected override async Task ExecuteAsync(CancellationToken stoppingToken)
    {
        //訪問數(shù)據(jù)庫A表和B表
    }
}

由于執(zhí)行有先后順序,初始化數(shù)據(jù)庫B表操作還沒有執(zhí)行,AWorker 就已經(jīng)開始執(zhí)行ExecuteAsync方法了,AWorker 的訪問數(shù)據(jù)庫A表和B表操作可能產生不可預料的結果。

現(xiàn)在使用IHostedLifecycleService,將初始化放在生命周期的早期:

public class AWorker : BackgroundService, IHostedLifecycleService
{
    public async Task StartingAsync(CancellationToken cancellationToken)
    {
        //初始化數(shù)據(jù)庫A表
    } 
    protected override async Task ExecuteAsync(CancellationToken stoppingToken)
    {
        //訪問數(shù)據(jù)庫A表和B表
    }
}

public class BWorker : BackgroundService, IHostedLifecycleService
{
    public async Task StartingAsync(CancellationToken cancellationToken)
    {
        //初始化數(shù)據(jù)庫B表
    } 
    protected override async Task ExecuteAsync(CancellationToken stoppingToken)
    {
        //訪問數(shù)據(jù)庫A表和B表
    }
}

現(xiàn)在,訪問數(shù)據(jù)庫A表和B表操作可以保證正常執(zhí)行了。

默認情況下,多個IHostedLifecycleService實現(xiàn)是按順序執(zhí)行的,我們還可以設置它們并發(fā)啟動和停止,節(jié)約整體啟動時間:

builder.Services.Configure<HostOptions>(options =>
{
    options.ServicesStartConcurrently = true;
    options.ServicesStopConcurrently = true;
});

總結

IHostedLifecycleService是.NET 8中引入的一個新特性,它可以讓我們在使用多個IHostedService實現(xiàn)的時候,更加靈活和高效地控制它們的啟動和停止,避免出現(xiàn)不必要的依賴和沖突。

責任編輯:武曉燕 來源: MyIO
相關推薦

2009-08-14 15:42:11

什么是.NET接口.NET抽象類

2024-08-29 08:02:32

2020-10-23 14:18:00

智慧社區(qū)互聯(lián)網(wǎng)科技

2025-02-18 01:00:00

Astro系統(tǒng)AI

2021-03-22 17:00:15

區(qū)塊鏈NFT數(shù)字資產

2017-09-13 16:46:38

敏捷站會團隊

2023-04-14 07:49:26

iOS安卓

2022-12-15 16:13:19

Windows11微軟

2011-11-17 14:05:47

筆記本常見問題

2023-07-09 23:55:16

C++RoslynILC

2015-09-18 09:49:50

3DTouch蘋果

2017-07-26 08:17:03

V4AppLaunchChApi

2024-12-17 08:51:55

2024-04-28 08:20:52

Controller接口URL

2021-08-28 06:03:42

5G 5G網(wǎng)絡5G商用

2024-11-07 12:33:47

2024-11-12 07:28:39

2009-02-13 09:26:43

心態(tài)職場工作

2021-11-28 06:37:12

Windows11系統(tǒng)小組件系統(tǒng)

2013-09-05 11:18:58

.NetWeb
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久九七| 国产精品一区二区三区免费观看 | 精品国产一区二区三区久久久蜜月 | 亚洲一区二区中文字幕 | 日韩电影免费在线观看中文字幕 | 日韩毛片免费看 | 欧美一区2区三区3区公司 | 综合中文字幕 | 亚洲精品一区在线观看 | www.日韩在线 | 午夜欧美一区二区三区在线播放 | 夜夜骑av| 97精品国产97久久久久久免费 | 中文字幕一区二区三区四区五区 | 国产中文字幕在线观看 | 懂色av色香蕉一区二区蜜桃 | 99爱在线观看 | 欧美a区 | 亚洲精彩免费视频 | 亚洲精品免费视频 | av一区二区三区四区 | 久久99精品国产 | 欧美日韩精品一区 | 亚洲免费在线观看 | 亚洲黄色视屏 | 国产精品久久久久久网站 | 91资源在线 | 国产一区二区三区色淫影院 | 国产精品久久在线 | 免费观看的av| 国产成人啪免费观看软件 | 91成人在线 | 亚洲综合精品 | 久久久久综合 | 国产欧美视频一区 | 亚洲国产精品一区二区第一页 | 欧美亚州| 99热精品在线观看 | 亚洲精品黄色 | 欧美爱爱视频 | 一级毛片免费完整视频 |