日志记录

AEM使您能够配置:

  • 中央日志记录服务的全局参数
  • 请求数据记录;请求信息的专用记录配置
  • 各个服务的特定设置;例如,单个日志文件以及日志消息的格式

这些都是 OSGi配置.

注意

AEM中的日志记录基于Sling原则。 参见 Sling日志记录 以进一步了解。

全局日志记录

Apache Sling日志记录配置 用于配置根记录器。 这将定义用于在AEM中登录的全局设置:

  • 日志记录级别
  • 中央日志文件的位置
  • 要保留的版本数
  • 版本轮换;最大大小或时间间隔
  • 写入日志消息时要使用的格式
注意

知识库文章 介绍如何轮换request.log和access.log文件。

用于单独服务的记录器和写入程序

除了全局日志记录设置之外,AEM还允许您为单个服务配置特定设置:

  • 特定的日志记录级别
  • 单个日志文件的位置
  • 要保留的版本数
  • 版本轮换;最大大小或时间间隔
  • 写入日志消息时要使用的格式
  • 日志程序(提供日志消息的OSGi服务)

这样,您就可以将单个服务的日志消息引导到一个单独的文件中。 这在开发或测试期间特别有用;例如,当您需要提高特定服务的日志级别时。

AEM使用以下方法将日志消息写入文件:

  1. An OSGi服务 (logger)写入日志消息。
  2. A 日志记录器 会采用此消息,并根据您的规范设置格式。
  3. A 日志记录作者 将所有这些消息写入您定义的物理文件。

这些元素由相应元素的以下参数链接:

  • Logger (日志记录器)

    定义生成消息的服务。

  • 日志文件(日志记录器)

    定义用于存储日志消息的物理文件。

    用于将日志记录器与日志记录器链接。 该值必须与日志记录编写器配置中的相同参数相同,才能建立连接。

  • 日志文件(日志记录程序)

    定义日志消息将写入到的物理文件。

    这必须与日志记录编写器配置中的相同参数相同,否则将不会进行匹配。 如果没有匹配项,将使用默认配置(每日日志轮换)创建隐式编写器。

标准记录器和写入程序

标准AEM安装中包含某些记录器和写入程序。

第一种情况比较特殊,因为它同时控制了 request.logaccess.log 文件:

  • 记录器:

    • Apache Sling可自定义请求数据记录器

      (org.apache.sling.engine.impl.log.RequestLoggerService)

    • 将有关请求内容的消息写入 request.log.

  • 链接到:

    • Apache Sling请求记录器

      (org.apache.sling.engine.impl.log.RequestLogger)

    • 将消息写入 request.logaccess.log.

虽然标准配置适用于大多数安装,但是如果需要,可以自定义这些配置。

其他对将遵循标准配置:

  • 记录器:

    • Apache Sling日志记录器配置

      (org.apache.sling.commons.log.LogManager.factory.config)

    • 写入 Information 消息发送至 logs/error.log.

  • 指向作者的链接:

    • Apache Sling日志记录编写器配置

      (org.apache.sling.commons.log.LogManager.factory.writer)

  • 记录器:

    • Apache Sling日志记录器配置(org.apache.sling.commons.log.LogManager.factory.config.649d51b7-6425-45c9-81e6-2697a03d6be7)

    • 写入 Warning 消息发送至 ../logs/error.log 服务 org.apache.pdfbox.

  • 未链接到特定的Writer,因此将创建并使用具有默认配置(每日日志轮换)的隐式Writer。

创建自己的记录器和作者

您可以定义自己的记录器/写入器对:

  1. 创建工厂配置的新实例 Apache Sling日志记录器配置.

    1. 指定日志文件。
    2. 指定记录器。
    3. 根据需要配置其他参数。
  2. 创建工厂配置的新实例 Apache Sling日志记录编写器配置.

    1. 指定日志文件 — 该文件必须匹配为日志程序指定的日志文件。
    2. 根据需要配置其他参数。
注意

在某些情况下,您可能希望创建 自定义日志文件.

在此页面上