15

我正在尝试使用 Topshelf 和 Serilog(分别为 Serilog.Extras.Topshelf 包)为我的 Windows 服务设置一个简单的日志记录配置。

HostLogger.UseLogger(new SerilogHostLoggerConfigurator(new LoggerConfiguration()
                .WriteTo.RollingFile(AppDomain.CurrentDomain.BaseDirectory + "\\logs\\app-{Date}.log")
                .WriteTo.ColoredConsole()
                .MinimumLevel.Debug()
                .CreateLogger()));
HostFactory.Run(x => {
            x.UseSerilog();
            ...

该服务运行良好,但是没有输出到控制台和指定的日志文件(我可以看到正在创建一个,但它仍然是空的)。有没有人使用这两个框架的经验?

4

1 回答 1

16

第二次调用“x.UseSerilog()”将 TopShelf 的 HostLogger 重置为使用您尚未配置的 Serilog 的全局实例 (Log.Logger)。

删除第二个调用,日志记录应该开始工作。

另一种选择是配置全局记录器:

Log.Logger = new LoggerConfiguration()
            .WriteTo.RollingFile(AppDomain.CurrentDomain.BaseDirectory + "\\logs\\app-{Date}.log")
            .WriteTo.ColoredConsole()
            .MinimumLevel.Debug()
            .CreateLogger();

HostFactory.Run(x => {
        // configure TopShelf to use Serilog's global instance.
        x.UseSerilog();
}
于 2015-05-09T02:46:56.310 回答