【面试题】技术场景 5、日志采集ELK

日志采集的重要性与采集方式

  • 重要性:在项目开发、测试及生产环境中,日志是定位系统问题的关键手段,对系统维护与问题排查至关重要。
  • 采集方式
    • 常规采集:按天保存日志文件至专门目录,文件名包含项目名、端口及日期,操作简单。
    • ELK 采集:由 Elasticsearch(es)、Logstash、Kibana 三个组件协同工作,在项目中应用广泛但相对复杂。

在这里插入图片描述

ELK 组件及工作流程

  • Logstash:部署于项目中,从 Logback 框架收集系统日志数据,其配置在 resource 下的日志框架配置文件中,可设置日志级别与服务地址,收集并格式化数据后传输给 es。
  • Elasticsearch:用于存储、搜索和分析日志数据,通常按日期存储。
  • Kibana:可视化平台,能以图表展示日志信息,可搜索分析日志,如按端口、日志级别、时间戳等字段搜索,还能区分 error 和 info 等不同类型日志数据。

在实际项目中,ELK 日志采集系统可能会遇到以下问题及对应的解决方法:

  1. Logstash 性能瓶颈问题
    • 问题表现:随着日志数据量的快速增长,Logstash 可能出现处理速度跟不上数据产生速度的情况,导致数据积压、传输延迟。例如在高并发的大型分布式系统中,大量的日志信息同时涌入 Logstash,使其 CPU、内存资源占用过高,影响数据收集和转发效率。
    • 解决方法:可以对 Logstash 进行配置优化,如增加工作线程数、调整批处理大小等,合理利用系统资源来提升处理能力。同时,考虑采用分布式架构部署多个 Logstash 实例,实现负载均衡,分摊数据处理压力。还可以结合消息队列(如 Kafka),让 Logstash 从消息队列中获取数据,利用消息队列的缓冲和异步处理机制,缓解数据洪峰对 Logstash 的冲击。
  2. Elasticsearch 存储与查询性能问题
    • 问题表现:大量的日志数据存储会使 Elasticsearch 集群的磁盘空间紧张,并且查询响应时间可能变长。尤其是在进行复杂查询或跨长时间范围查询时,可能会出现查询超时或性能急剧下降的情况。
    • 解决方法:优化 Elasticsearch 的索引设置,根据日志数据的特点合理选择索引字段、设置分片数量和副本数量等。定期对 Elasticsearch 进行数据清理和归档,删除过期或不再需要的日志数据,释放磁盘空间。对于频繁查询的字段,可以设置合理的缓存策略,提高查询性能。也可以考虑对 Elasticsearch 集群进行横向扩展,增加节点数量,提升整体的存储和计算能力。
  3. Kibana 可视化与数据展示问题
    • 问题表现:在展示大规模日志数据时,Kibana 可能出现图表加载缓慢、界面卡顿等现象,影响用户对数据的分析和理解。例如在同时展示多个维度的日志数据图表或进行实时数据更新时,浏览器可能会出现内存占用过高甚至崩溃的情况。
    • 解决方法:在 Kibana 端优化图表配置,减少不必要的数据展示维度和细节,避免一次性加载过多数据。可以采用数据抽样的方式,在不影响整体数据分析结果的前提下,降低数据展示的粒度。同时,升级硬件设备,提高浏览器的性能和内存资源,确保能够流畅地展示 Kibana 可视化界面。还可以对 Kibana 进行缓存设置,减少重复数据的加载和渲染。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/66840.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数据库】三、SQL语言

文章目录 三、SQL语言1 概述2 数据定义(DDL)2.1 定义数据库2.2 定义基本表2.3 修改基本表2.4 删除基本表 3 数据操作(DML)3.1 数据查询3.1.1 单表查询3.1.2 连接查询3.1.3 嵌套查询3.1.4 集合查询 3.2 数据更新3.2.1 插入数据3.2.2 修改数据3.2.3 删除数据 4 数据控制(DCL)5 视…

Unity中 Xlua使用整理(二)

1.Xlua的配置应用 xLua所有的配置都支持三种方式:打标签;静态列表;动态列表。配置要求: 列表方式均必须是static的字段/属性 列表方式均必须放到一个static类 建议不用标签方式 建议列表方式配置放Editor目录(如果是H…

Python Matplotlib教程-Matplotlib 多子图布局

Python Matplotlib 多子图布局 Matplotlib 是 Python 中最常用的数据可视化库,它提供了强大的功能来绘制不同类型的图表。在实际应用中,通常需要将多个图表绘制在同一个画布上,这就需要用到 多子图布局。本篇文章将详细介绍如何使用 Matplot…

全方位解读消息队列:原理、优势、实例与实践要点

全方位解读消息队列:原理、优势、实例与实践要点 一、消息队列基础认知 在数字化转型浪潮下,分布式系统架构愈发复杂,消息队列成为其中关键一环。不妨把消息队列想象成一个超级“信息驿站”,在古代,各地的信件、物资运…

Photon最新版本PUN 2.29 PREE,在无网的局域网下,无法连接自己搭建的本地服务器

1.图1为官方解答 2.就是加上这一段段代码:PhotonNetwork.NetworkingClient.SerializationProtocol SerializationProtocol.GpBinaryV16; 完美解决 unity 商店最新PUN 2 插件 不能连接 (环境为:本地局域网 无外网情况 ) …

消息中间件类型介绍

消息中间件是一种在分布式系统中用于实现消息传递的软件架构模式。它能够在不同的系统或应用之间异步地传输数据,实现系统的解耦、提高系统的可扩展性和可靠性。以下是几种常见的消息中间件类型及其介绍: 1.RabbitMQ 特点: • 基于AMQP&#…

51单片机(二)中断系统与外部中断实验

中断即单片机因为某些原因E暂定现在的工作P0,转去做其他的工作P1,完了之后继续之前的事P0,其他工作P1就是中断程序,原因E就是中断事件,原因由外部发生,程序不能预测到的是硬中断,可以由程度触发…

python-42-使用selenium-wire爬取微信公众号下的所有文章列表

文章目录 1 seleniumwire1.1 selenium-wire简介1.2 获取请求和响应信息2 操作2.1 自动获取token和cookie和agent2.3 获取所有清单3 异常解决3.1 请求url失败的问题3.2 访问链接不安全的问题4 参考附录1 seleniumwire Selenium WebDriver本身并不直接提供获取HTTP请求头(header…

汽车信息安全 -- S32K1如何更新BOOT_MAC

目录 1.安全启动模式回顾 2.为什么要讨论BOOT_MAC 3.S32K1如何更新? 1.安全启动模式回顾 之前提到过,S32K1系列提供了Crypto Service Engine硬件加密模块(简称CSEc),大家可以通过该芯片系统寄存器SDID.FEATURES(System Device Identification Register)来判断自己的片子…

【Python】Python与C的区别

文章目录 语句结束符代码块表示变量声明函数定义注释格式Python的标识符数据输入input()函数数据输出print()函数 语句结束符 C 语言 C 语言中每条语句必须以分号;结束。例如,int a 10;、printf("Hello, World!");。分号是语句的一部分,用于…

理解Unity脚本编译过程:程序集

https://docs.unity3d.com/Manual/script-compilation.html 关于Unity C#脚本编译的细节,其中一个比较重要的知识点就是如何自定义Assembly。 预定义的assembly 默认情况下,Unity会按照这个规则进行编译。 PhaseAssembly nameScript files1Assembly-…

Linux内核TTY子系统有什么(6)

接前一篇文章:Linux内核TTY子系统有什么(5) 本文内容参考: Linux TTY子系统框架-CSDN博客 一文彻底讲清Linux tty子系统架构及编程实例-CSDN博客 linux TTY子系统(3) - tty driver_sys tty device driver-CSDN博客 Linux TTY …

《代码随想录》Day31打卡!

《代码随想录》贪心算法:合并区间 本题的完整题目如下所示: 本题的完整思路如下所示: 1.本题依然是先对数组的左边界进行排序。将数组的第一个元素赋值给current。 2.遍历数组,判断current中的右边界和当前元素的左边界是否有重叠…

KL 散度:多维度解读概率分布间的隐秘 “距离”

深入理解KL散度:从多维度全面剖析 损失函数相关文章(置顶) 1. KL 散度:多维度解读概率分布间的隐秘 “距离” 2. 熵与交叉熵:从不确定性角度理解 KL 散度 3. 机器学习、深度学习关于熵你所需要知道的一切 引言 KL散即…

node-sass@4.14.1报错的最终解决方案分享

输入npm i全安装文件所需的依赖的时候,博主是使用sass去书写的,使用的是node-sass4.14.1和sass-loader7.3.1的版本的,安装的时候老是出现错误, node-sass4.14.1版本不再被支持的原因 node-sass 是一个基于 LibSass 的 Node.js 绑…

设计模式(观察者模式)

设计模式(观察者模式) 第三章 设计模式之观察者模式 观察者模式介绍 观察者模式(Observer Design Pattern) 也被称为发布订阅模式 。模式定义:在对象之间定义一个一对多的依赖,当一个对象状态改变的时候…

PyCharm 的安装与使用(Window)

1 PyCharm 简介 PyCharm 是一款由 JetBrains 公司开发的专门用于 Python 语言开发的集成开发环境(IDE)。以下是其相关介绍: 1.1 特点与功能 智能代码编辑:提供高度智能化的代码编辑器,支持语法高亮、自动补全、代码重…

(vue)el-table-column type=“selection“表格选框怎么根据条件添加禁选

(vue)el-table-column type"selection"表格选框怎么根据条件添加禁选 html <el-table:data"tableData"style"width: 100%"><el-table-columntype"selection"width"55":selectable"checkSelectable">…

C# 之某度协议登录,JS逆向,手机号绑定,获取CK

.NET兼职社区 .NET兼职社区 .NET兼职社区 .NET兼职社区 有需要指导&#xff0c;请私信我留言V或者去社区找客服。