配置日志编辑

heartbeat.yml 配置文件中的 logging 部分包含用于配置日志输出的选项。日志系统可以将日志写入 syslog 或旋转日志文件。如果未显式配置日志,则使用文件输出。

logging.level: info
logging.to_files: true
logging.files:
  path: /var/log/heartbeat
  name: heartbeat
  keepfiles: 7
  permissions: 0640

除了在配置文件中设置日志选项外,还可以从命令行修改日志输出配置。请参阅 命令参考

当 Heartbeat 在带有 systemd 的 Linux 系统上运行时,它默认使用 -e 命令行选项,使其将所有日志输出写入 stderr,以便 journald 可以捕获它。其他输出被禁用。请参阅 Heartbeat 和 systemd 以了解有关如何更改此设置的更多信息。

配置选项编辑

您可以在 heartbeat.yml 配置文件中的 logging 部分指定以下选项

logging.to_stderr编辑

如果为 true,则将所有日志输出写入标准错误输出。这等效于使用 -e 命令行选项。

logging.to_syslog编辑

如果为 true,则将所有日志输出写入 syslog。

此选项在 Windows 上不受支持。

logging.to_eventlog编辑

如果为 true,则将所有日志输出写入 Windows 事件日志。

logging.to_files编辑

如果为 true,则将所有日志输出写入文件。当日志文件大小限制达到时,日志文件会自动旋转。

Heartbeat 仅在有日志输出时才创建日志文件。例如,如果您将日志 level 设置为 error,并且没有错误,则在为日志指定的目录中将没有日志文件。

logging.level编辑

最小日志级别。可以是 debuginfowarningerror。默认日志级别为 info

debug
记录调试消息,包括所有已刷新事件的详细打印输出。还会记录信息消息、警告、错误和严重错误。当日志级别为 debug 时,您可以指定 selectors 列表以显示特定组件的调试消息。如果未指定选择器,则使用 * 选择器以显示所有组件的调试消息。
info
记录信息消息,包括已发布事件的数量。还会记录任何警告、错误或严重错误。
warning
记录警告、错误和严重错误。
error
记录错误和严重错误。

logging.selectors编辑

不同 Heartbeat 组件使用的调试专用选择器标签列表。使用 * 启用所有组件的调试输出。使用 publisher 显示与事件发布相关的调试消息。

可用选择器列表可能在不同版本之间有所不同,因此请避免创建依赖于特定选择器的测试。

要查看哪些选择器可用,请以调试模式运行 Heartbeat(在配置中设置 logging.level: debug)。选择器名称出现在日志级别之后,并用方括号括起来。

要配置多个选择器,请使用以下 YAML 列表语法

logging.selectors: [ harvester, input ]

要覆盖命令行中的选择器,请使用 -d 全局标志(-d 还会设置调试日志级别)。有关更多信息,请参阅 命令参考

logging.metrics.enabled编辑

默认情况下,Heartbeat 会定期记录其在上一周期中发生变化的内部指标。对于每个发生变化的指标,都会记录其相对于周期开始时的值的增量。此外,在关闭时还会记录所有非零内部指标的总值。将此设置设为 false 以禁用此行为。默认值为 true。

以下是一个日志行示例

2017-12-17T19:17:42.667-0500    INFO    [metrics]       log/log.go:110  Non-zero metrics in the last 30s: beat.info.uptime.ms=30004 beat.memstats.gc_next=5046416

请注意,我们目前不提供对内部指标的向后兼容保证,因此它们也未在文档中记录。

logging.metrics.period编辑

记录内部指标的周期。默认值为 30 秒。

logging.metrics.namespaces编辑

要在日志中报告的指标命名空间列表。默认为 [stats]stats 包含通用 Beat 指标。 datasetinputs 可能存在于某些 Beat 中,并包含模块或输入指标。

logging.files.path编辑

写入日志文件的目录。默认值为日志路径。有关详细信息,请参阅 目录布局 部分。

logging.files.name编辑

写入日志文件的名称。默认值为 heartbeat

logging.files.rotateeverybytes编辑

日志文件的最大大小。如果达到限制,将生成一个新的日志文件。默认大小限制为 10485760(10 MB)。

logging.files.keepfiles编辑

要保留在磁盘上的最近旋转日志文件的数量。在日志旋转期间,将删除较旧的文件。默认值为 7。 keepfiles 选项必须在 2 到 1024 个文件之间。

logging.files.permissions编辑

在旋转日志文件时要应用的权限掩码。默认值为 0600。 permissions 选项必须是有效的 Unix 风格的文件权限掩码,以八进制表示法表示。在 Go 中,八进制表示法中的数字必须以 0 开头。

允许的最宽松掩码为 0640。如果通过此设置指定了更高的权限掩码,则它将受到 0027 的 umask 的限制。

此选项在 Windows 上不受支持。

示例

  • 0640:授予文件所有者读写访问权限,并授予与文件关联的组成员读取访问权限。
  • 0600:授予文件所有者读写访问权限,并拒绝所有其他人的访问权限。

logging.files.interval编辑

除了基于大小的旋转之外,还启用按时间间隔旋转日志文件。间隔必须至少为 1 秒。 1m、1h、24h、7*24h、30*24h 和 365*24h 的值与本地系统时钟报告的分钟、小时、天、周、月和年对齐。所有其他间隔都是从 unix 时间戳计算的。默认情况下禁用。

logging.files.rotateonstartup编辑

如果日志文件在启动时已存在,则立即将其旋转,并开始写入新文件,而不是追加到现有文件。默认值为 true。

logging.files.redirect_stderr [预览] 此功能处于技术预览阶段,可能在未来版本中更改或删除。Elastic 将努力解决任何问题,但技术预览中的功能不受正式 GA 功能支持 SLA 的约束。 编辑

如果为 true,则打印到 Heartbeat 标准错误输出的诊断消息也会记录到日志文件。这在 Heartbeat 意外终止(因为 Go 运行时检测到错误,但日志文件中没有诊断信息)的情况下很有用。此功能仅在将日志记录到文件(logging.to_files 为 true)时可用。默认情况下禁用。

日志格式编辑

日志格式通常对每个日志输出都是相同的。唯一的例外是 syslog 输出,其中时间戳未包含在消息中,因为 syslog 会添加它自己的时间戳。

每条日志消息包含以下部分

  • 以 ISO8601 格式表示的时间戳
  • 级别
  • 包含在方括号中的日志记录器名称(可选)
  • 调用者的文件名和行号
  • 消息
  • 以 JSON 编码的结构化数据(可选)

以下是一些示例

2017-12-17T18:54:16.241-0500 INFO logp/core_test.go:13 未命名全局日志记录器

2017-12-17T18:54:16.242-0500 INFO [example] logp/core_test.go:16 一些消息

2017-12-17T18:54:16.242-0500 INFO [example] logp/core_test.go:19 一些消息 {"x": 1}