从0到1搭建实时日志监控系统:基于WebSocket + Elasticsearch的实战方案

1. 背景与痛点

在开发分布式系统时,日志分散在多个服务节点中,传统轮询查询方式存在延迟高、资源浪费的问题。某次线上故障中,因未能实时发现错误日志,导致问题排查时间延长2小时。因此,决定自研一套低成本、实时性高的日志监控系统。

2. 技术选型
  • 数据存储:Elasticsearch(高效检索与聚合)
  • 实时推送:WebSocket(全双工通信,避免HTTP轮询)
  • 后端服务:Node.js + Express(轻量级,适合快速开发)
  • 前端展示:Vue.js + ECharts(可视化日志趋势)
3. 核心实现步骤(附代码片段与关键配置)
3.1 Elasticsearch索引设计

json

// 日志索引模板(按时间分片) PUT /log-template { "index_patterns": ["logs-*"], "settings": { "number_of_shards": 3 }, "mappings": { "properties": { "timestamp": { "type": "date" }, "level": { "type": "keyword" }, "message": { "type": "text", "analyzer": "ik_max_word" } } } }
3.2 WebSocket服务端实现

javascript

// Node.js WebSocket服务器 const WebSocket = require('ws'); const wss = new WebSocket.Server({ port: 8080 }); wss.on('connection', (ws) => { console.log('New client connected'); // 订阅Elasticsearch日志变更(通过_changes API或轮询模拟) setInterval(() => { // 模拟获取新日志(实际可通过ES的search_after或滚动查询) const newLogs = fetchNewLogsFromES(); ws.send(JSON.stringify(newLogs)); }, 1000); });
3.3 前端实时渲染优化

javascript

// Vue.js WebSocket客户端 const socket = new WebSocket('ws://localhost:8080'); socket.onmessage = (event) => { const logs = JSON.parse(event.data); // 使用虚拟滚动列表优化性能(避免DOM爆炸) this.logs.unshift(...logs); // 追加到列表顶部 if (this.logs.length > 1000) this.logs.pop(); // 限制数量 };
4. 性能优化与坑点
  • ES查询优化:使用search_after替代from/size,避免深度分页性能问题。
  • WebSocket断连重试:前端实现指数退避重连机制。
  • 数据压缩:对大文本日志启用Gzip压缩,减少带宽占用。
5. 最终效果
  • 实时性:日志从产生到展示延迟 < 1秒
  • 吞吐量:单WebSocket连接支持500条/秒日志推送
  • 成本:3节点ES集群(4C16G)可支撑日志量100GB/天
6. 扩展思考
  • 如何结合Prometheus实现告警阈值动态配置
  • 针对海量日志场景,是否需要引入Kafka作为消息队列

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

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

相关文章

协同过滤性能优化技巧:高并发场景应用

如何让协同过滤扛住百万QPS&#xff1f;高并发推荐系统的实战优化之路 你有没有遇到过这样的场景&#xff1a;双十一刚到&#xff0c;首页推荐接口突然响应变慢&#xff0c;P99延迟飙升到500ms以上&#xff0c;用户开始抱怨“怎么老是推我不感兴趣的东西”&#xff1f;后台监控…

零基础掌握AUTOSAR诊断协议栈(UDS over CAN)

零基础吃透AUTOSAR诊断协议栈&#xff1a;从UDS到CAN&#xff0c;拆解整车刷写与故障读取的底层逻辑 你有没有遇到过这样的场景&#xff1f; 产线上的ECU突然无法刷写&#xff0c;诊断仪反复提示“安全访问拒绝”&#xff1b; 售后反馈某车型OBD灯常亮&#xff0c;但用标准工…

医疗用AutoGluon自动建模

&#x1f4dd; 博客主页&#xff1a;jaxzheng的CSDN主页 医疗AutoGluon&#xff1a;自动化建模的潜力与伦理暗礁目录医疗AutoGluon&#xff1a;自动化建模的潜力与伦理暗礁 引言&#xff1a;自动化浪潮下的医疗AI新边疆 一、技术应用场景&#xff1a;从理论到临床的实践价值 1.…

通俗解释nmodbus4在.NET Framework与Core的区别

一文讲透 nModbus4 在 .NET Framework 和 .NET Core 中的真实差异工业现场的设备通信&#xff0c;从来不是“插上线就能跑”的简单事。当你在树莓派上部署一个 Modbus 网关服务&#xff0c;却发现串口打不开&#xff1b;或者把原本运行良好的上位机程序从 Windows 迁移到 Linux…

【图像隐写】基于matlab快速四元数通用极坐标复指数变换的彩色图像零水印【含Matlab源码 14889期】

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;欢迎来到海神之光博客之家&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49…

大规模数据检索优化:elasticsearch官网核心要点

如何让 Elasticsearch 在 PB 级数据下依然快如闪电&#xff1f;官方最佳实践全拆解你有没有遇到过这样的场景&#xff1a;凌晨三点&#xff0c;监控突然报警——Elasticsearch 集群 CPU 暴涨、查询延迟飙升到几秒甚至超时。翻看日志才发现&#xff0c;某个“看起来无害”的聚合…

【车辆控制】铰接重型车辆的稳健路径跟随控制【含Matlab源码 14890期】

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;Matlab武动乾坤博客之家&#x1f49e;…

AI全景之第十二章第三节:光子计算、量子计算与AI

12.3 新型计算范式:光子计算、量子计算与AI 当前AI技术的飞速发展,尤其是大模型的持续迭代,对算力提出了指数级增长的需求。传统电子计算基于电子的电荷特性进行信息处理,受限于摩尔定律的放缓、能耗过高、传输延迟等固有瓶颈,已难以支撑下一代AI的发展。 在此背景下,以光…

【气动学】最优控制理论的归导定律和撞击角控制【含Matlab源码 14887期】含报告

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;Matlab武动乾坤博客之家&#x1f49e;…

零基础掌握cp2102与Modbus协议的工业通信对接

用一根USB线直连工业设备&#xff1f;揭秘CP2102与Modbus的硬核通信实战 你有没有遇到过这样的场景&#xff1a;手头有一台老式温控仪、一台支持RS-485的电表&#xff0c;或者一个老旧PLC&#xff0c;想读点数据出来做监控或调试——但你的笔记本根本没有串口。插上USB转TTL模…

如何高效部署专业翻译模型?HY-MT1.5-7B镜像一键启动指南

如何高效部署专业翻译模型&#xff1f;HY-MT1.5-7B镜像一键启动指南 在多语言内容爆发式增长的今天&#xff0c;高质量、低延迟的翻译服务已成为全球化应用的核心基础设施。腾讯开源的混元翻译模型 HY-MT1.5-7B 凭借其在 WMT25 夺冠的技术底座和对混合语言、术语干预等复杂场景…

AVD无法运行?一文说清Intel HAXM安装全流程

AVD启动失败&#xff1f;别急&#xff0c;彻底搞懂Intel HAXM安装与避坑全指南 你有没有遇到过这样的场景&#xff1a;刚装好Android Studio&#xff0c;信心满满地创建了一个AVD准备调试应用&#xff0c;结果一点运行&#xff0c;弹出一条红色错误提示&#xff1a; “Intel …

Neo4j中的Cypher查询优化技巧

在Neo4j数据库中,Cypher查询语言是进行数据操作的核心工具。然而,面对复杂的查询条件,如何有效地组织查询语句以避免性能瓶颈是每个开发者需要面对的问题。今天,我们将通过一个具体的例子来讨论如何优化Cypher查询。 背景介绍 假设我们有以下Neo4j数据库模型: Actor(演…

工业机器人通信前的USB转232驱动安装准备指南

工业机器人通信前的USB转232驱动安装实战指南在工业自动化现场&#xff0c;你是否曾遇到这样的场景&#xff1a;调试软件已经打开&#xff0c;串口参数全部配置完毕&#xff0c;可点击“连接”按钮后却始终收不到机器人的回应&#xff1f;检查线缆、重启控制器、反复插拔USB——…

一文说清电路仿真circuits网页版中的反馈电路原理

从零搞懂反馈电路&#xff1a;用网页仿真玩转负反馈与正反馈 你有没有试过搭一个放大电路&#xff0c;结果输出不是信号被削了顶&#xff0c;就是莫名其妙地“自己振起来”&#xff1f;又或者想做个方波发生器&#xff0c;可电路死活不起振&#xff1f; 这些问题的根源&#…

【图像隐写】快速四元数通用极坐标复指数变换的彩色图像零水印【含Matlab源码 14889期】

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;Matlab武动乾坤博客之家&#x1f49e;…

解决NumPy ImportError问题的实践与思考

背景介绍 在使用Python进行数据科学或数值计算时,NumPy是一个不可或缺的库。然而,在某些情况下,尝试导入NumPy可能会遇到各种错误,其中一种常见的问题是ImportError。本文将结合一个实际案例,探讨如何在Windows WSL2 Ubuntu环境中解决这一问题。 问题描述 假设你在一个…

CANFD协议仲裁场解析:核心要点说明

CAN FD仲裁场深度解析&#xff1a;从原理到实战的完整指南在一辆现代智能汽车中&#xff0c;成百上千个电子控制单元&#xff08;ECU&#xff09;需要通过车载网络实时交换数据。当刹车指令、雷达点云、发动机扭矩和OTA升级包同时争抢总线时&#xff0c;谁该优先通行&#xff1…

实战案例:基于车载雷达模块的CANFD与CAN对比

实战案例&#xff1a;车载毫米波雷达通信&#xff0c;为什么CANFD正在取代传统CAN&#xff1f;在一辆智能汽车的“神经系统”中&#xff0c;传感器是感知世界的“眼睛”和“耳朵”&#xff0c;而通信总线就是传递信息的“神经纤维”。当77GHz毫米波雷达每秒输出数百个目标点时&…

零基础必看,1小时速通 从JavaSE到SpringBoot框架,搞定企业刚需技术!

零基础必看&#xff0c;1小时速通 从JavaSE到SpringBoot框架&#xff0c;搞定企业刚需技术&#xff01; 一、JavaSE 基础速览 (15分钟) 语法基础 变量与数据类型&#xff1a;int, String, boolean 等控制结构&#xff1a;if-else, for, while方法定义&#xff1a;public int ad…