1.1. 基础概念
EFK不是一个软件,而是一套解决方案,开源软件之间的互相配合使用,高效的满足了很多场合的应用,是目前主流的一种日志系统。 EFK是三个开源软件的缩写,分别表示:Elasticsearch , Filebeat, Kibana , 其中Elasticsearch负责日志保存和搜索,Filebeat负责收集日志,Kibana 负责界面。
Elasticsearch 是一个实时的、分布式的可扩展的搜索引擎,允许进行全文、结构化搜索,它通常用于索引和搜索大量日志数据,也可用于搜索许多不同类型的文档。
Filebeat是数据采集的得力工具。将 Filebeat和您的容器一起置于服务器上,然后便可在 Elastisearch 中集中处理数据。
Kibana 核心产品搭载了一批经典功能:柱状图、线状图、饼图、旭日图,等等。不仅如此,您还可以使用 Vega 语法来设计独属于您自己的可视化图形。所有这些都利用 Elasticsearch 的完整聚合功能。
1.2. 日志排查
1.2.1. 如何在界面查看日志
日志在Discover模块:
data:image/s3,"s3://crabby-images/fbb77/fbb776ff9227032e7ab8e237ae18621601d3dd58" alt=""
可以通过修改索引模式来查看不同机器(集群)下的日志:
data:image/s3,"s3://crabby-images/5d061/5d061bea5bbd85716a7a12064f59fecb9f33599a" alt=""
添加日志需要展示的字段:
data:image/s3,"s3://crabby-images/bc1eb/bc1eb6cfa0c5a9be8d475b43364da98eaa8344b5" alt=""
data:image/s3,"s3://crabby-images/cc611/cc6112b0b1b8f93e5d7994c1c2497be55a18c839" alt=""
1.2.2. 查询某个服务的日志
1、选择集群环境
data:image/s3,"s3://crabby-images/45c1c/45c1c1b97d3b8fa7ea1f4bd4dda475646b26f780" alt=""
2、添加application 或者appname过滤条件,选择需要查看服务的日志
可以通过左侧字段筛选来选择想要查看的应用日志
data:image/s3,"s3://crabby-images/de412/de4121d21d4fe2b3ce2a7cb9a8b60c8c1f6a83ed" alt=""
也可以通过"添加筛选"来筛选应用日志
data:image/s3,"s3://crabby-images/46e87/46e8775573084a67c30c6a9ce8c585550cbc5e9c" alt=""
3、选择日志时间范围
data:image/s3,"s3://crabby-images/8b459/8b4598fe419ca3b592bc62cf17f14a6ef6a1570c" alt=""
1.2.3. 查询错误日志
1.2.3.1. 从前端搜索错误日志
1、浏览器报错时,点击F12。找到对应报错的请求,复制traceId
data:image/s3,"s3://crabby-images/aeab2/aeab273f786c6f5002a30fad6aa740158d6aa20c" alt=""
2、筛选traceId,查询日志
data:image/s3,"s3://crabby-images/f9bed/f9bed486cd20015fa6823988a46bba3f9166c590" alt=""
data:image/s3,"s3://crabby-images/b87e5/b87e592de005eac337ed855ac8d252ab3230fa45" alt=""
1.2.3.2 . 搜索任务错误日志
1、在"任务运行历史"页面找到失败的任务名称,复制溯源ID【】括号中的id内容
data:image/s3,"s3://crabby-images/3a26f/3a26fcc4aa6d325af4aa969b4011c7a69d5fb708" alt=""
2、在kibana中输入message: "8b8c755d6de44f8ea1f3105b56090cb3",复制得到的LUNA_TID
data:image/s3,"s3://crabby-images/50716/50716739f1353ca1ec8d93532e19439211f2c0f2" alt=""
3、搜索LUNA_TID
data:image/s3,"s3://crabby-images/f3fa8/f3fa80c10d44ffad46e7dc994c01d48b2c2bd7bd" alt=""
1.2.4. 搜索技巧
- 精确搜索
搜索框内输入message: "rowversion from t_bd_currencies"。针对message字段进行搜索,在搜索的时候不会区分大小写,也就是说,ROWVERSION FROM T_BD_CURRENCIES也是会被搜索出来的。上面的"rowversion from t_bd_currencies"使用了引号,这3个单词会被作为一个词进行查询,不会再进行分词,也就是说匹配的时候只会匹配rowversion from t_bd_currencies这样的顺序匹配,而不会匹配出rowversion,test from t_bd_currencies
data:image/s3,"s3://crabby-images/85162/85162150d9770c79c5fae4b893a677bc4f8ecbf4" alt=""
- 多字段匹配搜索
针对message搜索,输入message: rowversion from t_bd_currencies,去除上面例子中的双引号。搜索结果为message中包含rowversion或from或t_bd_currencies的结果。
data:image/s3,"s3://crabby-images/d0cc3/d0cc3914ef327994db114b71b4b91b997917ef9e" alt=""
- 连接词搜索
搜索时,可以用and or not三种连接词进行搜索。
搜索(application : "ats-usercore" and not level : "INFO") or message : "default"。可以得到application为ats-usercore且日志级别不为INFO的日志,或者得到message字段中包含default的日志。
data:image/s3,"s3://crabby-images/b8aaf/b8aaf4fd26e007627a21eb2dfd650c855a342e34" alt=""