本文介绍JSON模式及通过日志服务控制台配置JSON模式采集日志的步骤。
简介
JSON日志建构于两种结构:
- Object类型:键/值对的集合。
- Array类型:值的有序列表。
Logtail支持采集Object类型的JSON日志,自动提取Object首层的键作为字段名称,Object首层的值作为字段值。字段值的数据类型可以为Object、Array或基本类型(例如:String、Number)。
logtail不支持自动解析Array类型的JSON日志,请使用完整正则模式或者极简模式采集日志,详情请参见极简模式或完整正则模式。
JSON日志使用\n
进行分割日志,每行为一条日志。
JSON日志示例如下所示。
{"url": "POST /PutData?Category=YunOsAccountOpLog&AccessKeyId=U0Ujpek********&Date=Fri%2C%2028%20Jun%202013%2006%3A53%3A30%20GMT&Topic=raw&Signature=pD12XYLmGxKQ%2Bmkd6x7hAgQ7b1c%3D HTTP/1.1", "ip": "10.200.98.220", "user-agent": "aliyun-sdk-java", "request": {"status": "200", "latency": "18204"}, "time": "05/May/2016:13:30:28"}
{"url": "POST /PutData?Category=YunOsAccountOpLog&AccessKeyId=U0Ujpek********&Date=Fri%2C%2028%20Jun%202013%2006%3A53%3A30%20GMT&Topic=raw&Signature=pD12XYLmGxKQ%2Bmkd6x7hAgQ7b1c%3D HTTP/1.1", "ip": "10.200.98.210", "user-agent": "aliyun-sdk-java", "request": {"status": "200", "latency": "10204"}, "time": "05/May/2016:13:30:29"}
操作步骤
- 登录日志服务控制台。
- 在接入数据区域,选择JSON-文本日志。
- 在选择日志空间页签中,选择目标Project和Logstore,单击下一步。
您也可以单击立即创建,重新创建Project和Logstore,详情请参见步骤1:创建Project和Logstore。
- 在创建机器组页签中,创建机器组。
- 如果您已有可用的机器组,请单击使用现有机器组。
- 如果您还没有可用的机器组,请执行以下操作(以ECS为例)。
- 选择ECS实例安装Logtail,详情请参见安装Logtail(ECS实例)。
如果已在ECS上安装Logtail,可直接单击确认安装完毕。
说明 如果是自建集群、其他云厂商服务器,需要手动安装Logtail,详情请参见安装Logtail(Linux系统)或安装Logtail(Windows系统)。 - 安装完成后,单击确认安装完毕。
- 创建机器组,详情请参见创建IP地址机器组或创建用户自定义标识机器组。
- 选择ECS实例安装Logtail,详情请参见安装Logtail(ECS实例)。
- 在机器组配置页签中,应用机器组。选择一个机器组,将该机器组从源机器组移动到应用机器组。
- 在Logtail配置页签中,创建Logtail配置。
配置项 详情 配置名称 Logtail配置的名称,设置后不可修改。 您也可以单击导入其他配置,导入其他Project中已创建的Logtail配置。
日志路径 指定日志的目录和文件名。 日志文件名支持完整文件名和通配符两种模式,文件名规则请参见Wildcard matching。日志文件查找模式为多层目录匹配,即指定目录(包含所有层级的目录)下所有符合条件的文件都会被查找到。例如:- /apsara/nuwa/ … /*.log表示/apsara/nuwa目录(包含该目录的递归子目录)中后缀名为.log的文件。
- /var/logs/app_* … /*.log*表示/var/logs目录下所有符合app_*模式的目录(包含该目录的递归子目录)中包含.log的文件。
说明- 一个文件只能被一个Logtail配置采集。
- 目录通配符只支持星号(*)和问号(?)。
设置采集黑名单 开启该功能后,可设置黑名单配置。黑名单配置可在采集时忽略指定的目录或文件,目录和文件名支持完整匹配,也支持通配符模式匹配。例如: - 选择按目录路径,路径为/tmp/mydir,则在采集时过滤掉该目录下的所有文件。
- 选择按文件路径,路径为/tmp/mydir/file,则在采集时过滤掉该文件。
是否为Docker文件 如果是Docker文件,可以直接配置内部路径与容器Tag,Logtail会自动监测容器创建和销毁,并根据Tag进行过滤采集指定容器的日志。关于容器文本日志采集请参见通过DaemonSet-控制台方式采集Kubernetes文件。 模式 默认为JSON模式,可修改为其它模式,其他模式的配置请参见概述。 使用系统时间 - 开启使用系统时间,则日志时间为采集日志时,Logtail所在主机的系统时间。
- 关闭使用系统时间,您需要指定一个时间字段的Key名称和时间转换格式,关于时间转换格式的详细信息请参见时间格式。
丢弃解析失败日志 - 开启丢弃解析失败日志,解析失败的日志不上传到日志服务。
- 关闭丢弃解析失败日志,日志解析失败时上传原始日志。
最大监控目录深度 设置日志目录被监控的最大深度。最大深度范围:0~1000,0代表只监控本层目录。 请根据您的需求选择高级配置。如没有特殊需求,建议保持默认配置。参数 详情 启用插件处理 请选择是否启用Logtail处理。开启该功能后,使用Logtail插件处理日志,具体配置请参见处理数据。 上传原始日志 开启该功能后,原始日志内容作为__raw__字段与解析过的日志一起上传到日志服务。 Topic生成方式 - 空-不生成Topic:默认选项,表示设置Topic为空字符串,在查询日志时不需要输入Topic即可查询。
- 机器组Topic属性:设置为机器组Topic属性,用于明确区分不同服务器产生的日志数据。
- 文件路径正则:设置为文件路径正则,则需要配置自定义正则,用正则表达式从路径里提取一部分内容作为Topic。用于区分不同用户或实例产生的日志数据。
日志文件编码 - utf8:指定使用UTF-8编码。
- gbk:指定使用GBK编码。
时区属性 设置采集日志时,日志时间的时区属性。 - 机器时区:默认为机器所在时区。
- 自定义时区:手动选择时区。
超时属性 如果一个日志文件在指定时间内没有任何更新,则认为该文件已超时。 - 永不超时:持续监控所有日志文件,永不超时。
- 30分钟超时:如果日志文件在30分钟内没有更新,则认为已超时,并不再监控该文件。
选择30分钟超时时,还需配置最大超时目录深度,范围为1~3。
过滤器配置 只采集完全符合过滤器中的条件的日志。例如: - 满足条件即采集:配置Key:level Regex:WARNING|ERROR,表示只采集level为WARNING或ERROR类型的日志。
- 过滤不符合条件的数据:
- 配置为Key:level Regex:^(?!.*(INFO|DEBUG)).*,表示不收集level为INFO或DEBUG类型的日志。
- 配置为Key:url Regex:.*^(?!.*(healthcheck)).*,表示不采集URL中带有healthcheck的日志,例如key为url,value为/inner/healthcheck/jiankong.html的日志将不会被采集。
- 在查询分析配置页签中,设置索引。默认已设置索引,您也可以根据业务需求,重新设置索引,具体请参见开启并配置索引。说明
- 全文索引和字段索引属性必须至少启用一种。同时启用时,以字段索引属性为准。
- 索引类型为long、double时,大小写敏感和分词符属性无效。
配置完成后,日志服务开始采集日志。