码迷,mamicode.com
首页 > 其他好文 > 详细

整合了一个命令行程序的框架

时间:2018-03-14 15:51:18      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:get   测试   interface   rri   message   相关   数据   err   nta   

背景

最近工作中写了N多个命令行程序跑数据.每新建一个项目就要引用各种包,各种配置.所以有了这个整合包.其实不能算是框架吧,没写什么代码,几乎就是引用一些包.

代码

GitHub: https://github.com/lun3322/Luna.Service

NuGet1: Install-Package Luna.Service

NuGet2: Install-Package Luna.Service.Nlog

  1. Luna.Service 代码几乎都在这个包里.Starter在程序启动的时候加载.主要功能是扫描程序集注册相关类型进IOC
  2. Luna.Service.Nlog 这里包含了我常用的nlog配置,和一个启动器

关于使用

  1. 如果你也使用nlog写日志的话可以直接引用 Luna.Service.Nlog 包.关于日志的一个配置会自动加载到项目中
  2. 设置NLog.config文件编译时复制到输出目录
  3. 在Main方法中新增代码

    using (var starter = Starter.Create<Runner>())
    {
        starter.Container.AddFacility<LoggingFacility>(f => f.LogUsing<NLogFactory>().WithConfig("NLog.config"));
    
        starter.Run();
    }
  4. 增加你的service像下面这样

    public interface IDemoService : ILunaService
    {
        string GetMessage();
    }
    
    public class DemoService : LunaServiceBase, IDemoService
    {
        public string GetMessage()
        {
            Logger.Info("GetMessage");
            return "测试";
        }
    }
    注意接口实现ILunaService才能被自动注册进IOC
  5. 修改Runner类的run方法

    public class Runner : LunaRunnerBase
    {
        private readonly IDemoService _demoService;
    
        public Runner(IDemoService demoService)
        {
            _demoService = demoService;
        }
    
        public override void Run()
        {
            var message = _demoService.GetMessage();
            Logger.Info(message);
            Logger.Info("ok");
        }
    }

如果不喜欢用nlog的话,可以查看Castle.Windsor文档修改第3步中AddFacility方法

项目约定: 你的程序命名必须遵循aaa.bb.c的方式

Demo.App <- 应用程序入口

Demo.Service <- 服务层

Demo.Entity <- 实体层

整合了一个命令行程序的框架

标签:get   测试   interface   rri   message   相关   数据   err   nta   

原文地址:https://www.cnblogs.com/huaface/p/8567904.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!