当前位置:   article > 正文

【详解】 ELK (ElasticStack) 实现日志监控_elk日志监控平台

elk日志监控平台

目录

ElasticStack 介绍:

Demo 实现

说在前面

案例实现流程图

创建Spring Boot 项目

项目部署、运行

Logstash配置

FileBeat配置

ES配置

Kibana配置

最终效果


前言

关于日志监控、日志管理,对于任何一个成型的系统来说都是必不可少的之前使用Commons-IO实现过日志监控功能,最终是数据存在MongoDB。实践告诉我们这个过程很繁琐,当然,这里并不是难实现的意思。 可是实际应用中一般没人选择这种方式。  听说使用ElasticStack 可以很好的达到实现我们的目的,于是决定尝试了一下,这里对做一个简单的记录,希望对你有一定的帮助。 

Commons-IO实现日志监控:【详解】日志监控_To Do.的博客-CSDN博客_监控日志简介:日志监控提供了针对日志内容的实时监控能力。通过云监控服务和云日志服务的结合,用户可以针对日志内容进行监控统计、设置告警规则等,降低用户监控日志的运维成本,简化用户使用监控日志的流程。前情提要:本文主要针对日志文件的监控、解析、入库,至于后续统计、警告等等操作,并没有明确说明,如果要完成整套的日志框架,建议使用ELK框架,而不是手动去写一个日志系统。ELK简介参见:【ELK学习笔记】ELK的简介_大龄码农生活的博客-CSDN博客_elk学习核心思路:利用Commons...https://blog.csdn.net/weixin_47255175/article/details/124055243

ElasticStack 介绍:

Elastic Stack 介绍_To Do.的博客-CSDN博客

Demo 实现

说在前面

 开始操作之前,请确保软件安装启动正常,以此结合如下配置和流程实现最终的效果。

分别启动fileBeat、logstash、es(单节点)、kibana,确保容器都启动成功,效果如下

使用Docker方式搭建ElasticStack:【图文详解】Docker搭建 ELK Stack (elk) [使用es-logstash-filebeat-kibana]_hah杨大仙的博客-CSDN博客

案例实现流程图

创建Spring Boot 项目

必要的依赖

  1. <dependency>
  2. <groupId>joda-time</groupId>
  3. <artifactId>joda-time</artifactId>
  4. <version>2.9.9</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.apache.commons</groupId>
  8. <artifactId>commons-lang3</artifactId>
  9. <version>3.12.0</version>
  10. </dependency>

 启动类

  1. import lombok.extern.slf4j.Slf4j;
  2. import org.apache.commons.lang3.RandomUtils;
  3. import org.joda.time.DateTime;
  4. import org.springframework.boot.SpringApplication;
  5. import org.springframework.boot.autoconfigure.SpringBootApplication;
  6. @Slf4j
  7. @SpringBootApplication
  8. public class ElkBwGenerateApplication {
  9. public static final String[] VISIT = new String[]{
  10. "浏览页面","评论商品","加入收藏","加入购物车","提交订单","使用优惠券","领取优惠券","搜索","查看订单"
  11. };
  12. public static void main(String[] args) throws Exception {
  13. SpringApplication.run(ElkBwGenerateApplication.class, args);
  14. while (true) {
  15. long sleep = RandomUtils.nextLong(200, 1000 * 5);
  16. Thread.sleep(sleep);
  17. Long maxUserId = 9999L;
  18. Long userId = RandomUtils.nextLong(1,maxUserId);
  19. String visit = VISIT[RandomUtils.nextInt(0,VISIT.length)];
  20. DateTime now = new DateTime();
  21. int maxHour = now.getHourOfDay();
  22. int maxMinutes = now.getMinuteOfHour();
  23. int maxSeconds = now.getSecondOfMinute();
  24. String date = now.plusHours(-(RandomUtils.nextInt(0, maxHour)))
  25. .plusMinutes(-(RandomUtils.nextInt(0, maxMinutes)))
  26. .plusSeconds(-(RandomUtils.nextInt(0, maxSeconds)))
  27. .toString("yyyy-MM-dd HH:mm:ss");
  28. String result = "DAU|" + userId + "|" +visit +"|"+date;
  29. log.info(result);
  30. }
  31. }
  32. }

日志框架使用LogBack,注意记录logBack的日志文件产出路径,后续需要用到。

项目部署、运行

========================================================================

 查看日志文件内容

Logstash配置

========================================================================

 logstash.conf

  1. input {
  2. beats {
  3. port => "5678"
  4. }
  5. }
  6. # 过滤器
  7. filter {
  8. # 对内容进行切割
  9. mutate {
  10. split => {"message"=>"|"}
  11. }
  12. # 将切割后的部分,分别添加成为字段
  13. mutate {
  14. add_field =>{
  15. "userId" => "%{[message][1]}"
  16. "visit" => "%{[message][2]}"
  17. "date" => "%{[message][3]}"
  18. }
  19. }
  20. # 字段添加类型
  21. mutate {
  22. convert => {
  23. "userId" => "integer"
  24. "visit" => "string"
  25. "date" => "string"
  26. }
  27. }
  28. }
  29. # 输出到控制台
  30. #output {
  31. # stdout { codec => rubydebug }
  32. #}
  33. # 输出到es
  34. output {
  35. elasticsearch {
  36. hosts => ["http://192.168.241.128:9200"]
  37. }
  38. }

 logstash.yml

FileBeat配置

========================================================================

 

ES配置

正常启动,并查看数据

 ========================================================================

Kibana配置

正常启动,访问 ip:5601

分别添加柱形图、饼图,并创建仪表盘

========================================================================

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

最终效果

 ========================================================================

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/442389
推荐阅读
相关标签
  

闽ICP备14008679号