【一】、.net core 3.1 创建windows服务并集成Serilog的步骤记录
1、新建项目
选择“Worker Service”,如下图:
2、添加nuget引用
Microsoft.Extensions.Hosting.WindowsServices
Serilog.Extensions.Hosting
Serilog.Sinks.Console
Serilog.Sinks.File
3、修改Program的Main方法
public static void Main(string[] args) { var baseDir = AppDomain.CurrentDomain.BaseDirectory; var logfile = Path.Combine(baseDir, "log", "log.txt"); Log.Logger = new LoggerConfiguration() .MinimumLevel.Override("Microsoft", LogEventLevel.Warning) .Enrich.FromLogContext() .WriteTo.Console(LogEventLevel.Information, theme: AnsiConsoleTheme.Literate) .WriteTo.File(logfile, LogEventLevel.Information, rollingInterval: RollingInterval.Day, retainedFileCountLimit: 90) .CreateLogger(); try { Log.Information("服务启动成功!" + DateTime.Now.ToString()); CreateHostBuilder(args).Build().Run(); } catch (Exception e) { Log.Fatal(e, "启动出错了!"); } finally { Log.CloseAndFlush(); } }
4、修改Program里的CreateHostBuilder
代码如下:
public static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .UseWindowsService() .ConfigureServices((hostContext, services) => { services.AddHostedService<Worker>(); }) .UseSerilog();
5、测试Worker里的日志记录功能
protected override async Task ExecuteAsync(CancellationToken stoppingToken) { while (!stoppingToken.IsCancellationRequested) { _logger.LogInformation("Worker running at: {time}", DateTimeOffset.Now); await Task.Delay(1000, stoppingToken); } }
上面的代码是visual在创建项目时自带的,直接运行,就会在log文件夹里新建日志文件,然后记下日志如下:
示例代码地址:https://download.csdn.net/download/jiancaixing/20629212
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?