zoukankan      html  css  js  c++  java
  • 浅入 ABP系列(3):增加日志组件、依赖注入服务

    版权护体©作者:痴者工良,微信公众号转载文章需要 《NCC开源社区》同意。

    前面两篇我们搭建了一个基础的、简单的,具有统一响应格式的 Web 程序,这一篇内容不多,继续增加一些需要的组件功能。

    前面两篇已经搭建好基架,所以我们可以直接使用基架来逐渐增加功能,本系列后面的篇章会针对多方面的内容来逐渐讲解。

    源码地址:https://github.com/whuanle/AbpBaseStruct

    基架项目位置在 src/2/AbpBase 里面。

    自动依赖注入

    AbpBase.WebAbpBaseWebModule 中,添加一个函数:

    此函数用于扫描模块中的服务,自动将其加入容器中,这样就不需要收到加入了。

            /// <summary>
            /// 自动扫描所有的服务并进行依赖注入
            /// </summary>
            /// <param name="context"></param>
            private void ConfigureAutoIoc(ServiceConfigurationContext context)
            {
                context.Services.AddAssemblyOf<IoTCenterApplicationModule>();
                context.Services.AddAssemblyOf<IoTCenterWebModule>();
            }
    

    然后在 ConfigureServices 里面,加上

                // 配置依赖注入服务
                ConfigureAutoIoc(context);
    

    这些模块中继承了 ITransientDependency 接口的类型都会被自动注入到 DI 容器中。

    添加日志依赖

    ABP 中,封装了 Serilog 作为日志组件,大家可以在 AbpBase.Web 项目 中使用 Nuget 安装 Volo.Abp.AspNetCore.Serilog 包,版本为 3.1.2。

    因为 Web 是最上层部分,Volo.Abp.AspNetCore.Serilog 已经封装好了,但是功能还不够多,所以我们还需要需要继续添加 Serilog 提供的拓展。

    由于 AbpBase.Application 模块是服务提供模块,也是要使用到日志功能的,所以我们需要在 AbpBase.Application 中,用 Nuget 添加 两个包:

    Serilog.AspNetCore 包,版本 3.4.0;

    Serilog.Sinks.Async 包,版本 1.4.0

    然后在 AbpBaseApplicationModule 中,增加一个注入:

            public override void ConfigureServices(ServiceConfigurationContext context)
            {
                context.Services.AddSingleton<Serilog.ILogger>(Serilog.Log.Logger);
            }
    

    添加日志功能

    日志往往要分级、按日期记录等,因此我们这里配置一个简单的分级日志配置。

    Program.cs 中,添加一个函数:

            private static void ConfigLog()
            {
                Serilog.Log.Logger = new LoggerConfiguration()
    #if DEBUG
                    .MinimumLevel.Debug()
    #else
                    .MinimumLevel.Information()
    #endif
                    .MinimumLevel.Override("Microsoft", LogEventLevel.Information)
                    .MinimumLevel.Override("Microsoft.EntityFrameworkCore", LogEventLevel.Warning)
                    .Enrich.FromLogContext()
                    .WriteTo.Async(c => c.File($"Logs/{DateTime.Now.ToString("yyyy-MM-dd", System.Globalization.CultureInfo.CurrentCulture)}-logs.txt"))
                    .WriteTo.Logger(log =>
                            log.Filter.ByIncludingOnly(evt => evt.Level == LogEventLevel.Fatal)
                                .WriteTo.File(
                                    $"Logs/{(DateTime.Now.ToString("yyyy-MM-dd", System.Globalization.CultureInfo.CurrentCulture) + "-Fatal.txt")}",
                                    fileSizeLimitBytes: 83886080),
                        LogEventLevel.Fatal)
                    .WriteTo.Logger(log =>
                            log.Filter.ByIncludingOnly(evt => evt.Level == LogEventLevel.Error)
                                .WriteTo.File(
                                    $"Logs/{(DateTime.Now.ToString("yyyy-MM-dd", System.Globalization.CultureInfo.CurrentCulture) + "-Error.txt")}",
                                    fileSizeLimitBytes: 83886080),
                        LogEventLevel.Fatal)
                    .WriteTo.Console()
                    .CreateLogger();
            }
    

    这个函数中配置了 Seriolg 日志输出,我们将日志分成 Error.txtFatal.txtlogs.txt 三个等级,还设置按日期新建日志文件,并且每个日志文件最大为 8 MB。

    读者可以根据情况自行调整。

    然后在 CreateHostBuilder 后面加上:

            public static IHostBuilder CreateHostBuilder(string[] args) =>
                Host.CreateDefaultBuilder(args)
                    .ConfigureWebHostDefaults(webBuilder =>
                    {
                        webBuilder.UseStartup<Startup>();
                    })
                .UseAutofac()
                .UseSerilog();
    

    再将 Main 方法改成:

            public static int Main(string[] args)
            {
                try
                {
                    ConfigLog();
                    Serilog.Log.Information("Starting web host.");
                    CreateHostBuilder(args).Build().Run();
                    return 0;
                }
                catch (Exception ex)
                {
                    Serilog.Log.Fatal("Host terminated unexpectedly!");
                    return 1;
                }
                finally
                {
                    Serilog.Log.CloseAndFlush();
                }
            }
    

    之后我们将可以获得一个带有日志功能的 Web 程序了。

    依赖注入

    如果你需要使用日志服务,则可以引用 using Serilog;

    然后使用以下格式使用注入服务:

            private readonly ILogger _ILogger;
    
            public CustomerExceptionHandler(ILogger logger)
            {
                _ILogger = logger;
            }
    
    

    完成后,源码可以参考 https://github.com/whuanle/AbpBaseStruct/tree/master/src/3/AbpBase

  • 相关阅读:
    阿里云服务器搭建之绑定多个域名
    centos7下yum安装mysql
    Mac 升级之后 无法通过域名 SSH 连接
    【课程章节更新】突破 没有支付权限的小程序 完成支付闭环
    每次sudo su切换root用户,都要source /etc/profile
    那些让你震惊的网站
    bootstrap select2使用模态框,搜索框无法输入问题解决
    新浪图片停止外链后的一些解决办法
    Yii2 报错 Headers already sent in
    使用Python Flask 开发微信机器人
  • 原文地址:https://www.cnblogs.com/whuanle/p/13679979.html
Copyright © 2011-2022 走看看