欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 美景 > 【监控系列】ELK

【监控系列】ELK

2025/3/31 7:51:51 来源:https://blog.csdn.net/yunqi1215/article/details/146475200  浏览:    关键词:【监控系列】ELK

ELK Stack,现常称为Elastic Stack,是一个功能强大的开源工具组合,专为实时数据采集、存储、分析和可视化设计。以下是对其核心组件、工作流程、应用场景及挑战的详细解析:


​一、核心组件

  1. Elasticsearch

    • 角色:分布式搜索和分析引擎,基于Apache Lucene构建。
    • 功能
      • 存储大规模数据,支持近实时搜索。
      • 提供倒排索引、结构化查询、全文检索和聚合分析。
      • 分布式架构支持水平扩展和高可用性。
  2. Logstash

    • 角色:数据采集和处理管道。
    • 功能
      • 支持多种输入源(日志文件、Kafka、Beats等)。
      • 使用过滤器(如Grok、Mutate)解析、转换数据。
      • 输出到Elasticsearch、Kafka等存储或消息队列。
  3. Kibana

    • 角色:数据可视化和分析平台。
    • 功能
      • 创建交互式图表、仪表盘、地图等。
      • 提供开发工具(如Console)管理Elasticsearch。
      • 支持机器学习、APM(应用性能监控)等高级功能。
  4. Beats​(扩展组件)

    • 角色:轻量级数据采集器家族。
    • 常见工具
      • Filebeat:收集日志文件。
      • Metricbeat:采集系统和服务指标。
      • Packetbeat:网络流量分析。
      • Winlogbeat:Windows事件日志收集。

​二、典型工作流程

  1. 数据采集:Beats或Logstash从服务器、应用等来源收集日志或指标。
  2. 数据处理:Logstash解析、过滤数据(如提取字段、转换格式)。
  3. 数据存储:处理后的数据存入Elasticsearch,建立索引以便快速检索。
  4. 数据可视化:通过Kibana查询数据,生成图表和仪表盘,支持实时监控和分析。

三、部署ELK

1. 下载数据包
wget  https://artifacts.elastic.co/packages/7.x/yum/7.2.0/elasticsearch-7.2.0-x86_64.rpm
wget https://artifacts.elastic.co/packages/7.x/yum/7.2.0/logstash-7.2.0.rpm
wget https://artifacts.elastic.co/packages/7.x/yum/7.2.0/kibana-7.2.0-x86_64.rpm
2. 安装ES
rpm -ivh elasticsearch-7.2.0-x86_64.rpm
#vim /etc/elasticsearch/elasticsearch.ymlpath.data: /var/lib/elasticsearchpath.logs: /var/log/elasticsearchnetwork.host: 0.0.0.0http.port: 9200cluster.initial_master_nodes: ["127.0.0.1", "0.0.0.0"]
systemctl enable elasticsearch
systemctl start elasticsearch
systemctl status elasticsearch
netstat -tunlp
curl localhost:9200
3. 安装kibana
rpm -ivh kibana-7.2.0-x86_64.rpm
#vim /etc/kibana/kibana.ymlserver.port: 5601server.host: "0.0.0.0"elasticsearch.hosts: ["http://localhost:9200"]
systemctl enable kibana
systemctl start kibana
systemctl status kibana
netstat -tunlp
curl localhost:5601 -L
4. 安装logstash
rpm -ivh logstash-7.2.0.rpm
systemctl start logstash
systemctl enable logstash
systemctl status logstash
netstat -nlpt
5. 测试
/usr/share/logstash/bin/logstash -e 'input { stdin { } } output { stdout {} }'
直至出现 Successfully started Logstash API endpoint。输入“hello world”回车,即可打印出输出。
6. 创建instance,观察kibana
/usr/share/logstash/bin/logstash -f /etc/logstash/conf.d/test.conf --path.data=/var/lib/logstash/test &
/usr/share/logstash/bin/logstash -f /etc/logstash/conf.d/yun.conf --path.data=/var/lib/logstash/yun &#cat /etc/logstash/conf.d/yun.conf input {file {path => ["/tmp/yun.log"]sincedb_path => "/dev/null"start_position => "beginning"}}filter {}output {elasticsearch {hosts => ["http://localhost:9200"]}cat /tmp/yun.logyy01
7. 安装filebeat
rpm -ivh filebeat-1.3.0-x86_64.rpm 
# grep -Ev '^$|#' /etc/filebeat/filebeat.ymlfilebeat:prospectors:-paths:- /var/log/*.loginput_type: logregistry_file: /var/lib/filebeat/registryoutput:logstash:hosts: ["localhost:9600"]shipper:logging:files:
systemctl start filebeat
systemctl status filebeat# cat /etc/logstash/conf.d/file.conf input {beats {port => "9600"client_inactivity_timeout => 3000}stdin {}}output {elasticsearch {hosts => ["http://localhost:9200"]index => "%{[@metadata][beat]}-%{[@metadata][version]}-%{+YYYY.MM.dd}"}}
systemctl restart logstash
systemctl status logstash
netstat -tunlp
8. 查看索引
#查索引
curl http://192.168.88.23:9200/_cat/indices?v
#索引里搜索数据
curl http://192.168.88.23:9200/filebeat-test--2022.04.29/_search

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词