入门基础,入门基础

归来目录

回来目录

LindDotNetCore基础介绍

  1. 运作环境
  2. 配置文件
  3. 服务的注册
  4. 安排文件的登记
  5. 服务的应用
  6. 布置文件的利用

    #### 运行条件

    vs2017+.netcore2.0,vs需要升级到新型包

    #### 配置文件

    appsetting.json,我们提议了开发环境,测试环境和生育环境,分别对应不同的公文

  • 开发:Development,appsetting.Development.json
  • 测试:Staging,appsetting.Development.json
  • 生产:Producting,appsetting.Development.json

    #### 服务的注册

    在.net
    core里,包括在LindDotNetCore里,服务的登记是在startup里举行,你可以便宜的支配每个组件的生命周期。

  • 单例,整个经过使用同一个实例,像redis,mongodb,日志

  • 线程单例,在一个线程里它是绝无仅有的实例,在api环境下,你的一个http请求下来,一个目的只生育一回,像http请求链
  • 一晃,每回注入时,都会生产一个新的实业。像仓储对象,数据上下文

    public void ConfigureServices(IServiceCollection services)
    {
    
    //Lind.DotNetCore封装的一些模块
    services.AddLog4Logger(o =>
    {
        o.Log4ConfigFileName = "log4.config";
        o.ProjectName = "test";
    });
    services.UseDapper(o =>
    {
        o.ConnString = $"Data Source={Directory.GetCurrentDirectory()}/intergratetest.db";
        o.DbType = Lind.DotNet
    }
    }
    

    #### 配置文件的注册

    三伯封装了配置文件的流入和得到模式,注入需要借助环境变量,它在startup初始时被生产。

    public Startup(IConfiguration configuration, IHostingEnvironment env)
    {
    ConfigFileHelper.Set(env: env);
    Configuration = configuration;
    }
    

    #### 服务的行使

    咱俩的服务在startup里两遍性被注入,然后在各类控制器的构造方法里被选用,注意:咱俩的服务支撑依赖型注入
    这一点对大家任重而道远,比如一个劳务的生产依赖于另一个劳务,那么,这种涉及由core
    DI帮我们实现!

    [Route("api/[controller]")]
    public class ValuesController : Controller
    {
     ILogger _logger;
     public ValuesController(ILogger logger)
     {
    _logger = logger;
     }
    

    #### 配置文件的采纳

    大家得以间接使用Utils命名空间下的ConfigFileHelper对象,它里面有Get方法,用来得到具体的配置节点
    小心,大家的安排节点援助强类型和字符串二种,强类型务求你提供泛型,字符串只要输入名称就足以
    回来具体的值了。

    var options = new EFConfig();
    //装饰
    configure?.Invoke(options);
    //优先级控制
    ObjectMapper.MapperTo(options, ConfigFileHelper.Get<EFConfig>());
    

    待续…
    回去目录

LindDotNetCore基础介绍

  1. 运行条件
  2. 布置文件
  3. 劳动的登记
  4. 配备文件的注册
  5. 劳务的采纳
  6. 部署文件的使用

    #### 运行条件

    vs2017+.netcore2.0,vs需要升级到最新包

    #### 配置文件

    appsetting.json,我们指出了支付条件,测试环境和生产条件,分别对应不同的文件

  • 开发:Development,appsetting.Development.json
  • 测试:Staging,appsetting.Development.json
  • 生产:Producting,appsetting.Development.json

    #### 服务的登记

    在.net
    core里,包括在LindDotNetCore里,服务的登记是在startup里举办,你可以便宜的控制每个组件的生命周期。

  • 单例,整个过程使用同一个实例,像redis,mongodb,日志

  • 线程单例,在一个线程里它是绝无仅有的实例,在api环境下,你的一个http请求下来,一个目的只生育几次,像http请求链
  • 一时间,每一遍注入时,都会生产一个新的实业。像仓储对象,数据上下文

    public void ConfigureServices(IServiceCollection services)
    {
    
    //Lind.DotNetCore封装的一些模块
    services.AddLog4Logger(o =>
    {
        o.Log4ConfigFileName = "log4.config";
        o.ProjectName = "test";
    });
    services.UseDapper(o =>
    {
        o.ConnString = $"Data Source={Directory.GetCurrentDirectory()}/intergratetest.db";
        o.DbType = Lind.DotNet
    }
    }
    

    #### 配置文件的注册

    父辈封装了部署文件的流入和取得格局,注入需要倚重环境变量,它在startup起头时被生产。

    public Startup(IConfiguration configuration, IHostingEnvironment env)
    {
    ConfigFileHelper.Set(env: env);
    Configuration = configuration;
    }
    

    #### 服务的应用

    咱俩的劳务在startup里一回性被注入,然后在各种控制器的构造方法里被使用,注意:俺们的劳务帮忙依赖型注入
    这一点对我们根本,比如一个劳务的生产依赖于另一个劳动,那么,这种关联由core
    DI帮大家落实!

    [Route("api/[controller]")]
    public class ValuesController : Controller
    {
     ILogger _logger;
     public ValuesController(ILogger logger)
     {
    _logger = logger;
     }
    

    #### 配置文件的施用

    俺们可以直接行使Utils命名空间下的ConfigFileHelper对象,它里面有Get方法,用来赢得具体的部署节点
    在意,大家的布置节点襄助强类型和字符串两种,强类型渴求你提供泛型,字符串只要输入名称就足以
    回到具体的值了。

    var options = new EFConfig();
    //装饰
    configure?.Invoke(options);
    //优先级控制
    ObjectMapper.MapperTo(options, ConfigFileHelper.Get<EFConfig>());
    

    待续…
    再次来到目录

相关文章