本文介绍如何使用Logtail采集Node.js日志。
背景信息
log4js是一个Node.js日志管理工具,您可以通过log4js把Node.js日志打印到文件中,并自定义日志格式,便于日志采集和整理。 log4js分为6个输出级别,从低到高分别为trace、debug、info、warn、error、fatal。 log4js配置示例如下所示:
var log4js = require('log4js');
log4js.configure({
appenders: [
{
type: 'file', //文件输出
filename: 'logs/access.log',
maxLogSize: 1024,
backups:3,
category: 'normal'
}
]
});
var logger = log4js.getLogger('normal');
logger.setLevel('INFO');
logger.info("this is a info msg");
logger.error("this is a err msg");
操作步骤
日志服务提供配置向导,帮助您快速完成Logtail采集配置。本文以通过完整正则模式采集Node.js日志为例。
登录日志服务控制台。
- 在接入数据区域,选择正则-文本日志。
- 选择目标Project和Logstore,单击下一步。
创建机器组。
如果您已有可用的机器组,请将该机器组添加到应用机器组。
如果您还没有可用的机器组,请执行以下操作(以ECS为例)。
使用场景选择主机场景。
安装环境选择ECS。
选择机器组单击创建机器组。
在创建机器组页签中,选中目标ECS实例,单击安装并创建为机器组。
具体操作,请参见安装Logtail(ECS实例)。
页面中Logtail安装情况提示成功,则表示安装成功。
在创建机器组页面,输入机器组名称,其他参数均可保持默认配置,然后单击确定。
更多信息,请参见创建IP地址机器组。
确认目标机器组已在应用机器组区域,单击下一步。
重要创建机器组后立刻应用,可能因为连接未生效,导致心跳为FAIL,您可单击自动重试。如果还未解决,请参见Logtail机器组无心跳进行排查。
在Logtail配置页签中,创建Logtail配置。
重要参数配置如下所示。其他参数说明,请参见使用完整正则模式采集日志。
日志样例:
[2022-02-24 17:42:38.946] [INFO] normal - this is a info msg
正则:
\[([^]]+)]\s\[(\w+)]\s(\w+)\s-\s(.*)
日志抽取内容:日志服务会根据您输入的日志样例和正则表达式,自动提取日志内容。您需要为该内容设置对应的Key。
预览数据及创建索引,然后单击下一步。索引的更多信息,请参见创建索引。
单击查询日志,系统将跳转至Logstore查询分析页面。
您需要等待1分钟左右,待索引生效后,才能在原始日志页签中,查看已采集到的日志。更多信息,请参见查询和分析日志。