一个无所不能框架,基于模块化注入的介绍

作者: 单机游戏资讯  发布:2019-06-08

相关模块

  1. 一个无所不能框架,基于模块化注入的介绍。全局都是依赖DI
  2. 一个无所不能框架,基于模块化注入的介绍。消息队列
  3. NoSql
  4. Caching
  5. 一个无所不能框架,基于模块化注入的介绍。仓储
  6. 服务总线
  7. Solr
  8. 调度
  9. 一个无所不能框架,基于模块化注入的介绍。日志
  10. Asspect拦截组件
  11. UAA授权
  12. 各种组件环境的搭建
  13. 各模块单元测试编写

    #### DI统一战线

    一个无所不能框架,基于模块化注入的介绍。LindDotNet框架同样采用了全局DI注入的方式来使用模块对象的,这种松耦合的设计对于单元测试
    一个无所不能框架,基于模块化注入的介绍。是很方便人。

    services.AddLog4Logger(o =>
    {
    o.Log4ConfigFileName = "log4.config";
    o.ProjectName = "test";
    });
    services.UseDapper(o =>
    {
    o.ConnString = $"Data Source=/Data/intergratetest.db";
    o.DbType = Lind.DotNetCore.Repository.DbType.SqlLite;
    });
    

    #### 消息队列

    一个无所不能框架,基于模块化注入的介绍。消息队列主要使用'rabbitmq,kafka'实现的,用来解耦项目,处理高并发任务和耗时任务,生产者
    不需要关心是谁来消费,它只管把消息发到队列中;而消费者不关心消息如何产生,只把消费按着
    业务逻辑去处理掉!

    services.AddRabbitMQ(o =>
    {
    o.ExchangeName = "zzl";
    o.MqServerHost = "192.168.200.214";
    o.VirtualHost = "/";
    o.ExchangeType = "topic";
    });
    

    #### NoSql

    目前框架的NoSql部分由redis和mongodb一个无所不能框架,基于模块化注入的介绍。组成,之所有选择这两种框架最大的原因就是它们覆盖了
    NoSql所有的使用场景,像redis用来存储k/v键值对,支持5大数据结构;而mongodb用来存储文档
    型数据,支持复杂的查询,嵌套查询等。

    services.AddRedis(o =>
    {
    o.Host = "localhost:6379";
    o.AuthPassword = "";
    o.IsSentinel = 1;
    o.ServiceName = "mymaster";
    o.Proxy = 0;
    });
    

    #### Caching

    数据缓存是比较重要的部分,用来存储一些热数据,目前分布式环境使用redis,单机可以直接使用
    运行时缓存。

    services.AddRuntimeCache(o =>
    {
    o.CacheKey = "lindCache";
    o.ExpireMinutes = 5;
    });
    

    #### 仓储

    仓储主要简化数据持久化的操作,对外提供简单的CURD操作接口,使用者直接调用即可,不需要干预SQL语句,
    从这点上来说,开发效率确实提升了不少。目前大叔框架里集成了ef,dapper,mongodb,redis,elastic等仓储,其中
    EF和Dapper可以操作sqlserver,mysql,sqllite等数据库。

    services.UseDapper(o =>
    {
    o.ConnString = $"Data Source={Directory.GetCurrentDirectory()}/intergratetest.db";
    o.DbType = Lind.DotNetCore.Repository.DbType.SqlLite;
    });
    

    #### 服务总线

    服务总线主要是用来解耦项目的层与层之间的调用,让程序员把关注点放在业务上,目前框架提供了IOC模式的事件,
    基于简单内存字典存储的事件等。

    services.AddIocBus();
    services.AddInMemoryBus();
    

    #### Solr

    Solr是在Lucene基础之前开发的,使用java编写,一般部署在tomcat上,有自己的图像管理界面,可以用来管理core,
    一般地,我们在设计一个core时,需要为它建立对应的实体,与它的core里的属性对应起来;solr有丰富的插件,像一些
    中文分词包,索引包等。

    services.AddSolrNet(o =>
    {
    o.ServerUrl = "http://192.168.200.214:8081/solr/system_companysubject";
    o.UserName = "sa";
    o.Password = "sa";
    });
    

    #### 调度服务

    调度服务是以quartz为核心,并对它的功能进行了封装,支持实时添加的任务,这一点使用了windows/linux的目录监控事件
    ,也是.netcore帮我们实现的,我们只需要订阅相关事件即可。

    var watcher = new FileSystemWatcher
    {
    Path = AppDomain.CurrentDomain.BaseDirectory,
    NotifyFilter = NotifyFilters.Attributes |
                   NotifyFilters.CreationTime |
                   NotifyFilters.DirectoryName |
                   NotifyFilters.FileName |
                   NotifyFilters.LastAccess |
                   NotifyFilters.LastWrite |
                   NotifyFilters.Security |
                   NotifyFilters.Size,
    Filter = "*.dll"
    };
    // quartz运行时,可以添加新job,但不能覆盖,删除等
    watcher.Created  = new FileSystemEventHandler((o, e) =>
    {
    foreach (var module in Assembly.LoadFile(e.FullPath).GetModules())
    {
        foreach (var type in module.GetTypes().Where(i => typeof(ISchedulingJob).IsAssignableFrom(i)))
        {
            JoinToQuartz(type, DateTimeOffset.Now);
        }
    }
    });
    //Start monitoring.
    watcher.EnableRaisingEvents = true;
    

    #### 日志

    日志框架与之前的Lind框架里日志差别不大,只是把对象的生命周期移到了DI容器去统一管理,都采用单例方式,目前日志框架提供了
    对log4net的支持,同时轻量级日志可以使用lindlogger来实现。

    services.AddLog4Logger(o =>
    {
    o.Log4ConfigFileName = "log4.config";
    o.ProjectName = "test";
    });
    

    #### Asspect拦截组件

    方法拦截在微软mvc,api框架里应用十分广泛,可以在方法执行前与执行后动态添加一切逻辑,而不需要关注方法细节,实现拦截行为
    的开发人员不需要去关注方法细节,这利用了面向对象的封装特性,而也符合开闭原则,因为你可以在不修改原来代码的情况下,动态
    为它添加行为。

    [Fact]
    public void FuncInvoke()
    {
    var obj = ProxyFactory.CreateProxy<AspectTest, AspectTest>();
    Assert.Equal("OK", obj.GetHello());
    }
    [Fact]
    public void ActionInvoke()
    {
    var obj = ProxyFactory.CreateProxy<AspectTest, AspectTest>();
    obj.SetHello();
    Assert.Equal(1, 1);
    }
    

    待续...
    回到目录

关于她

LindAgile是大叔在这两年里的新宠儿,它主推模块化,插件化,敏捷化,主要于LindAgile基础项目,LindAgile.Http项目,LindAgile.Modules项目和几个扩展模块项目组成,那几个扩展模块主要体现的AOP的特性,需要哪些模块,就在应用程序里注册哪些。

图片 1

回到目录

LindAgile目前的几大Modules

Modules通常在应用程序启动时被注册

#region 模块注册
   ModuleManager.Create()
                .UseAutofac()
                .UseLindLogger()
                .UseEfRepository()
                .UseRabbitMq()
                .UseESBIoC();
 #endregion

LindAgile.Repository-全能仓储

  1. EF仓储-支持mssql和mysql
  2. MongoDB仓储
  3. Redis仓储
  4. Dapper仓储-支持mssql和mysql
  5. 内存沙箱仓储

LindAgile.Caching-简单的数据缓存

  1. 运行时缓存
  2. Redis缓存

LindAgile.MQ-两大消息队列的适配

  1. .net集成的简单队列
  2. Kafka队列的适配
  3. RabbitMQ的适配

LindAgile.ServiceBus-大叔服务总线在项目中的解耦

  1. 运行时为存储介质
  2. Redis为存储介质
  3. IoC直接生产-通过事件与处理程序的字典(存在运行时或者redis)

 

感谢各位的阅读!

以后有时间将向大家介绍LindAgile框架!

 

本文由bg游戏资讯发布于单机游戏资讯,转载请注明出处:一个无所不能框架,基于模块化注入的介绍

关键词: 所有随笔 软件设计 .NET Core