当前位置:首页 > 技术 > 正文内容

kbmMWLog日志框架实现多目标日志输出

访客 技术 2026年6月23日 1

kbmMWLog日志框架为开发者提供了丰富的日志管理器,以适应不同的应用场景需求:

  • TkbmMWStreamLogManager - 流式日志管理
  • TkbmMWLocalFileLogManager - 本地文件日志管理
  • TkbmMWSystemLogManager - 系统日志管理
  • TkbmMWStringsLogManager - 字符串列表日志管理
  • TkbmMWProxyLogManager - 代理日志管理
  • TkbmMWTeeLogManager - 组合日志管理
  • TkbmMWNullLogManager - 空日志管理

每种日志管理器都针对特定的输出目标进行优化,例如将日志写入文件、存储到TStrings、流式输出到系统控制台等。

当需要将日志同时输出到多个目标时,比如希望在保存日志文件的同时也能在系统控制台显示,并在界面的TMemo组件中实时查看日志内容,这时可以使用TkbmMWTeeLogManager来实现组合日志输出。以下是具体实现代码:

procedure TForm1.InitializeLogging;
var
  FileLogger: IkbmMWLocalFileLogManager;
  ConsoleLogger: IkbmMWSystemLogManager;
  MemoLogger: IkbmMWStringsLogManager;
  CombinedLogger: IkbmMWTeeLogManager;
begin
  // 创建文件日志管理器,指定主日志和审计日志路径
  FileLogger := TkbmMWLocalFileLogManager.Create('.\logs\app.log', '.\logs\audit.log');
  FileLogger.FileOptions := [mwlfoDeleteOldLog, mwlfoDeleteOldAudit];
  
  // 创建系统控制台日志管理器
  ConsoleLogger := TkbmMWSystemLogManager.Create;
  
  // 创建基于Memo控件的字符串日志管理器
  MemoLogger := TkbmMWStringsLogManager.Create(Memo1.Lines);
  
  // 使用Tee日志管理器组合多个日志目标
  CombinedLogger := TkbmMWTeeLogManager.Create(FileLogger, ConsoleLogger, MemoLogger);
  
  // 将组合日志管理器设置为全局日志管理器
  Log.LogManager := CombinedLogger;
  
  // 设置需要忽略的特定异常类型
  Log.LogManager.IgnoreException(EMyCustomException);
end;

上述代码演示了如何创建并组合三个不同的日志管理器。首先创建文件日志管理器用于持久化存储,然后创建系统日志管理器用于控制台输出,最后创建字符串日志管理器用于在界面组件中显示日志。通过Tee日志管理器的构造函数,将这三个管理器组合在一起,使其能够同时接收并处理日志消息。

根据实际需求,还可以对各个日志管理器进行独立配置。例如,可以设置文件日志记录所有级别的日志,而Memo组件中只显示调试、错误和致命级别的日志:

MemoLogger.LogTypeFilter := [mwltDebug, mwltError, mwltFatal];
标签: DelphikbmMW

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

linux screen 用法详情 (nohup 的替代方案)

一、screen 是什么?能干嘛?screen 是一个终端复用器,可以:在一个 SSH 会话中开多个“虚拟终端”SSH 断线后,程序仍然在后台运行随时重新连接到原来的会话特别适合:nohup 的替代方案跑脚本 / 爬虫 / 训练模型运维、远程开发二、安装 screen# CentOS / Rocky / Almayum install -y screen# Debian / Ubuntuapt i...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。