当需要输出的日志很多的时候,每次修改config都很麻烦,于是想可不可以动态生成。

网上找的案例都是获取单个appender/logger的,此处例子是任意logger,appender相同

log4net的pattern里面关于线程的显示规则是,有线程名用名字,无线程名用线程号。Nlog 可以分别指定

例子如下

 1         public static ILog GetLoggerByName(string name)
2 {
3 if (LogManager.Exists(name) == null)
4 {
5
6 // Pattern Layout defined
7 PatternLayout patternLayout = new PatternLayout();
8 patternLayout.ConversionPattern = "%date %thread %level %logger - %message%newline";
9 patternLayout.ActivateOptions();
10
11 // configurating the RollingFileAppender object
12 RollingFileAppender appender = new RollingFileAppender();
13 appender.Name = name;
14 appender.AppendToFile = true;
15 appender.File = $"Log\\{name}.log";
16 appender.StaticLogFileName = true;
17 appender.PreserveLogFileNameExtension = true;
18 appender.LockingModel = new FileAppender.MinimalLock();
19 appender.Layout = patternLayout;
20 appender.MaxSizeRollBackups = 512;
21 appender.MaximumFileSize = "150MB";
22 appender.RollingStyle = RollingFileAppender.RollingMode.Composite;
23 appender.ActivateOptions();
24
25 Hierarchy hierarchy = (Hierarchy)LogManager.GetRepository();
26
27 var loger = hierarchy.GetLogger(name, hierarchy.LoggerFactory); //!!! 此处写法是重点,不容更改
28 loger.Hierarchy = hierarchy;
29 loger.AddAppender(appender);
30 loger.Level = Level.All;
31
32 BasicConfigurator.Configure();//!!! 此处写法是重点,不容更改
33
34 var appname = Assembly.GetEntryAssembly().GetName().Name;
35 var version= Assembly.GetEntryAssembly().GetName().Version;
36 loger.Log(Level.Info, $"Log name {name} created for Application: {appname} Version: {version}", null);
37 }
38 var log = LogManager.GetLogger(name);
39 return log;
40 }
 1        public static void SetMinLogLevel(Level level,string name="")
2 {
3 if(string.IsNullOrEmpty(name))
4 {
5 Hierarchy hierarchy = (Hierarchy)LogManager.GetRepository();
6 hierarchy.Threshold = level;
7 }
8 else
9 {
10 Hierarchy hierarchy = (Hierarchy)LogManager.GetRepository();
11 if(hierarchy.Exists(name) is Logger loger)
12 {
13 loger.Level = level;
14 }
15 }
16 }

最新文章

  1. SQL Server代理(8/12):使用SQL Server代理外部程序
  2. 海王星给你好看!FineUI v4.0公测版发布暨《你找BUG我送书》活动开始(活动已结束!)
  3. 【转载】Visual Studio 2015 for Linux更好地支持Linux下的开发
  4. perform-two-phase-commits/
  5. angular $apply()以及$digest()讲解1
  6. hdu 4764 Stone (巴什博弈,披着狼皮的羊,小样,以为换了身皮就不认识啦)
  7. js的for in循环和java里的foreach循环的差别
  8. URL参数中有 特殊符号或加密数据 的问题解决
  9. IIS Express添加MIME映射
  10. Android使用 startActivityForResult 、 onActivityResult 时的注意事项
  11. numpy C语言源代码调试(二)
  12. css清除浮动方式总结
  13. DataGridView的单元格如何嵌入多个按钮控件
  14. Java 的 Api 文档生成工具 JApiDocs 程序文档工具
  15. 买了第一台mac
  16. STL整理之map
  17. 使用 AngularJS & NodeJS 实现基于 token 的认证应用
  18. Netty源码分析之NioEventLoop(二)—NioEventLoop的启动
  19. redux+react-redux+示例的快速上手体验
  20. zabbix监控之自定义item

热门文章

  1. 基于伪分布式Hadoop搭建Hive平台详细教程
  2. Serializers组件详解
  3. 《神经网络的梯度推导与代码验证》之vanilla RNN的前向传播和反向梯度推导
  4. Fibonacci and Counting(水题)
  5. observeParents的使用
  6. Beware of the encrypted VM
  7. PHP + Redis 生成自定义订单编号
  8. Spring Boot入门,源码解析
  9. C#开发PACS医学影像处理系统(二):界面布局之菜单栏
  10. Ubuntu查看并修改主机名的方法