c# - 如何在作为窗口服务运行的 .NET Core WorkerService 中启用事件日志记录
问题描述
我正在尝试构建一个作为 Windows 服务运行并能够记录到应用程序事件日志的 .NET Core WorkerService。
我没有收到任何错误或服务使用 sc create then sc start 运行的任何内容,但我在事件应用程序事件日志中没有得到任何预期。
我错过了什么?
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Logging.EventLog;
namespace FreshIQPrinterProxy
{
public class Program
{
public static void Main(string[] args)
{
CreateHostBuilder(args).Build().Run();
}
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.UseWindowsService()
.ConfigureLogging((context, logging) =>
{
logging.AddEventLog(new EventLogSettings()
{
SourceName = "MyApp"
});
})
.ConfigureServices((hostContext, services) =>
{
services.AddHostedService<Worker>();
});
}
}
这是我的 Worker.cs 文件
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Logging.EventLog;
namespace FreshIQPrinterProxy
{
public class Worker : BackgroundService
{
private readonly ILogger<Worker> _logger;
public Worker(ILogger<Worker> logger)
{
_logger = logger;
}
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
while (!stoppingToken.IsCancellationRequested)
{
_logger.LogInformation("Worker running at: {time}", DateTimeOffset.Now);
await Task.Delay(1000, stoppingToken);
}
}
}
}
这是我的 appsettings.json 文件
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft": "Warning",
"Microsoft.Hosting.Lifetime": "Information"
}
},
"EventLog": {
"LogLevel": {
"Default": "Information",
"Microsoft.Hosting.Lifetime": "Information"
}
}
}
解决方案
在您的appsettings.json
中,EventLog
节点需要位于Logging
节点下方,例如:
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft": "Warning",
"Microsoft.Hosting.Lifetime": "Information"
},
"EventLog": {
"LogLevel": {
"Default": "Information",
"Microsoft.Hosting.Lifetime": "Information"
}
}
}
}
推荐阅读
- json - 如何在 Apache Nifi 中合并分区的 Json
- xamarin.forms - 在 Xamarin Forms App 中集成 Twilio 聊天功能
- php - 警告:stripos() 在 php 中至少需要 2 个参数
- javascript - jQuery.datepicker 在第二次调用时未定义
- python - 我尝试使用 nltk.download("stopwords") 为 NLP 模型下载 nltk 'stopwords'。显示错误
- javascript - 如何确定元素是否在视口上方?
- javascript - 从其他对象返回对象数组
- java - Hibernate:按内部列表的值过滤实体的结果列表
- powershell - 将 JPG 转换为 base64 并返回
- python - 当迭代器在Python中为空时如何获取None