记录日志
log
组件:记录日志组件。用于将消息内容格式化并记录到日志中,支持使用JavaScript脚本自定义日志格式。
JavaScript脚本支持ECMAScript 5.1(+) 语法规范和部分ES6规范,如:async/await/Promise/let。允许在脚本中调用Go自定义函数,请参考udf 。
# 配置
字段 | 类型 | 说明 | 默认值 |
---|---|---|---|
jsScript | string | 日志格式化脚本 | 无 |
jsScript
:用于格式化日志内容的JavaScript脚本。该字段作为以下函数的函数体:function ToString(msg, metadata, msgType) { ${jsScript} }
1
2
3函数参数说明:
- msg:消息内容
- 当dataType=JSON时,类型为
jsonObject
,可使用msg.field
方式访问字段 - 其他dataType时,类型为
string
- 当dataType=JSON时,类型为
- metadata:消息元数据,类型为
jsonObject
- msgType:消息类型
函数返回值必须是
string
类型,返回的字符串将作为日志内容记录。- msg:消息内容
提示
- 日志记录器可通过config.Logger配置
- 默认输出到控制台
- 支持配置日志级别、输出格式等
# Relation Type
- Success: 执行成功,把消息发送到
Success
链 - Failure: 执行失败,把消息发送到
Failure
链
# 执行结果
该组件不会改变msg.Data
和msg.Metadata
内容。
# 配置示例
{
"id": "s1",
"type": "log",
"name": "记录日志",
"configuration": {
"jsScript": "return 'Incoming message:\\n' + JSON.stringify(msg) + '\\nIncoming metadata:\\n' + JSON.stringify(metadata);"
}
}
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# 应用示例
在 GitHub 上编辑此页 (opens new window)
上次更新: 2024/12/22, 03:38:12