您现在的位置是:亿华云 > 数据库
如何使用第三方日志记录提供程序替代.NET Core中的内置程序
亿华云2025-10-09 01:19:21【数据库】3人已围观
简介本文转载自微信公众号「UP技术控」,作者 conan5566。转载本文请联系UP技术控公众号。.NET Core 支持适用于各种内置和第三方日志记录提供程序的日志记录 API。 先来看下如何将日志记录
本文转载自微信公众号「UP技术控」,何使作者 conan5566。用第转载本文请联系UP技术控公众号。志记中
.NET Core 支持适用于各种内置和第三方日志记录提供程序的录提日志记录 API。 先来看下如何将日志记录 API 与内置提供程序一起使用。服务器租用供程
调用 CreateDefaultBuilder,序替这将添加以下日志记录提供程序:
控制台
调试
EventSource
EventLog:仅限 Windows
public class Program { public static void Main(string[] args) { CreateHostBuilder(args).Build().Run(); } public static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .ConfigureWebHostDefaults(webBuilder => { webBuilder.UseStartup<Startup>(); }); }若要替代Host.CreateDefaultBuilder 添加的内置默认日志记录提供程序集,请调用 ClearProviders 并添加所需的程序日志记录提供程序。高防服务器 例如,何使以下代码:
调用 ClearProviders 以从生成器中删除所有 ILoggerProvider 实例。用第
添加控制台日志记录提供程序。志记中
public static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .ConfigureLogging(logging => { logging.ClearProviders(); logging.AddConsole(); }) .ConfigureWebHostDefaults(webBuilder => { webBuilder.UseStartup<Startup>(); });使用第三方替代,录提以Nlog为例
修改 program.cs
using System; using NLog.Web; using Microsoft.AspNetCore.Hosting; using Microsoft.Extensions.Logging; using Microsoft.Extensions.Hosting; public static void Main(string[] args) { var logger = NLog.Web.NLogBuilder.ConfigureNLog("nlog.config").GetCurrentClassLogger(); try { logger.Debug("init main"); CreateHostBuilder(args).Build().Run(); } catch (Exception exception) { //NLog: catch setup errors logger.Error(exception,供程 "Stopped program because of exception"); throw; } finally { // Ensure to flush and stop internal timers/threads before application-exit (Avoid segmentation fault on Linux) NLog.LogManager.Shutdown(); } } public static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .ConfigureWebHostDefaults(webBuilder => { webBuilder.UseStartup<Startup>(); }) .ConfigureLogging(logging => { logging.ClearProviders(); logging.SetMinimumLevel(Microsoft.Extensions.Logging.LogLevel.Trace); }) .UseNLog(); // NLog: Setup NLog for Dependency injection写日志
using Microsoft.Extensions.Logging; public class HomeController : Controller { private readonly ILogger<HomeController> _logger; public HomeController(ILogger<HomeController> logger) { _logger = logger; _logger.LogDebug(1, "NLog injected into HomeController"); } public IActionResult Index() { _logger.LogInformation("Hello, this is the index!"); return View(); } 云南idc服务商很赞哦!(4142)
相关文章
- 3.dns修改成功后,点击“域名解析”,按提示进行操作。解析格式一般如下:
- 外媒速递:AWS生产环境下十大MongoDB部署最佳实践
- Facebook开源相似性搜索类库Faiss,超越已知最快算法8.5倍
- 聊聊C语言中使用频率较高的指针与数组
- 如果你的潜在终端必须是这个米(域名),那么潜在终端并不多,也没有硬通货,那么你的域名应该在终端有兴趣购买时出售。否则,你可能得自己留着吃。
- 一文读懂汽车域控制器集成化架构的背景、优点及设计
- 关系数据库迈入新时代,这个标题是认真的!
- 数据库中间件 MyCAT源码分析 —— PreparedStatement 重新入门
- 什么样的邮箱才是安全的电子邮件地址?
- 你的数据库索引是否真的起作用了?