是什么使BackgroundService.ExecuteAsync方法无法完成?

问题描述

我刚刚使用标准Visual Studio模板创建了一个Worker Service。在Worker类中,如果删除while (!stoppingToken.IsCancellationRequested){...}包装程序并运行应用程序,则ExecuteAsync永远不会完成。如果我在方法的末尾添加return,那么它又不会完成。

任何人都可以解释使该方法存活的原因吗?

我想知道为什么在下面的代码ExecuteAsync不仅会完成并拆除我的FileSystemWatcher?我可以一直触发观察程序,直到按Ctrl + C会取消令牌并停止整个应用程序。

protected override async Task ExecuteAsync(CancellationToken stoppingToken) =>
            await Task.Run(async () =>
            {
                try
                {
                    _logger.Log@R_739_4045@ion("Worker running at: {time}",DateTimeOffset.Now);

                    _watcher = new FileSystemWatcher(_settings.Value.FolderToWatch,"Transactions_????????.xml")
                    {
                        NotifyFilter = NotifyFilters.FileName
                    };
                    _watcher.Created += FileCreated;
                    _watcher.EnableRaisingEvents = true;

                    _logger.Log@R_739_4045@ion("Monitoring folder '{watchedFolder}' for file drops...",_settings.Value.FolderToWatch);
                }
                catch (Exception e) when (False(() => _logger.LogCritical(e,"Fatal error.")))
                {
                    throw;
                }

            });

解决方法

BackgroundService不在乎您的ExecuteAsync方法是否在关闭前完成。在服务器停止之前,它只关心服务停止。

我建议您实现一个作业队列,在jar cvf MyJarFile.jar !(file1) jar cvf MyJarFile.jar !(file1|folder1) 方法中添加到队列,并在ExecuteAsync方法中处理该队列。取消stopToken时返回。这样,您可以阻止服务器关闭,直到处理完当前文件更改为止,或者传递取消令牌。

并且不要忘了Dispose()FileSystemWatcher。