6.5 监控和日志 架构模式和应用实践

news2024/10/4 22:56:18

6.5 监控和日志 架构模式和应用实践

  • 目录
    • 概述
      • 需求:
    • 设计思路
    • 实现思路分析
      • 1.集中式监控
      • 2.分布式监控
      • 3.边缘监控
      • 4.集中式日志管理
      • 5.分布式日志管理
      • 6.实时日志流处理
    • 监控工具
    • 最佳实践
  • 参考资料和推荐阅读

Survive by day and develop by night.
talk for import biz , show your perfect code,full busy,skip hardness,make a better result,wait for change,challenge Survive.
happy for hardess to solve denpendies.

目录

在这里插入图片描述

概述

本文重点讲述一下监控和日志的架构模式的分类和实践,供大家参考,基于SpringBoot实现了日志的概述系统,供大家参看。至此微服务的架构模式 和用基本的Springboot 技术实现思路讲述完毕。

需求:

设计思路

实现思路分析

1.集中式监控

集中式监控是一种通过集中管理和控制的方式对多个监控设备或系统进行管理和监控的方法。它通过将各个监控设备或系统连接到一个中心控制台,实现对这些设备或系统的集中管理和监控。

集中式监控的优点包括:

  1. 简化管理:集中式监控可以将多个监控设备或系统的管理和监控集中在一个控制台上,减少了管理人员需要操作的设备数量,简化了管理的难度。

  2. 效率提升:集中式监控可以通过自动化和智能化的方式对多个设备或系统进行监控和管理,提高了工作效率,减少了人工操作的繁琐。

  3. 数据集中存储:集中式监控可以将多个设备或系统的监控数据集中存储,方便后续查询和分析,对于安全监控和故障排查有着重要的意义。

  4. 统一标准和规范:集中式监控可以通过统一标准和规范,对多个设备或系统进行集中管理和监控,提高了管理的一致性和规范性。

集中式监控的缺点包括:

  1. 单点故障:如果中心控制台出现故障,可能导致整个监控系统无法正常工作,造成监控的中断和数据丢失。

  2. 依赖网络:集中式监控需要依赖网络进行设备之间的连接和数据传输,如果网络出现问题,可能会影响监控的正常运行。

  3. 成本高昂:集中式监控需要建立一个中心控制台,并且需要连接和管理多个监控设备或系统,需要投入大量的人力、物力和财力。

集中式监控适用于以下场景:

  1. 大型企业或组织:对于拥有多个分支机构或多个监控系统的大型企业或组织来说,集中式监控可以实现对所有设备或系统的集中管理和监控。

  2. 安全监控:集中式监控可以实现对多个安全监控设备(如摄像头、门禁系统等)的集中管理和监控,提升安全监控的效果和效率。

  3. 系统运营监控:集中式监控可以实现对多个系统(如服务器、网络设备等)的集中管理和监控,提供系统运营状态的实时监控和故障排查。

总的来说,集中式监控在大型场所、多设备或系统的管理和监控、安全监控等方面具有一定的优势,但也需要考虑到其带来的单点故障和依赖网络的问题。

2.分布式监控

分布式监控是指通过在多个节点之间分配监控任务和数据处理的一种监控方案。它的优点包括:

  1. 可扩展性:分布式监控可以根据需要增加或减少监控节点,以适应监控系统的规模变化。这种灵活性可以帮助系统管理员更好地管理监控工作负载。

  2. 容错性:分布式监控可以通过在多个节点上执行监控任务,从而提高监控系统的可靠性。当一个节点发生故障时,其他节点仍可以继续监控工作,确保系统的连续性。

  3. 数据处理效率:由于分布式监控可以将监控任务和数据处理分布在多个节点上,因此可以充分利用节点的计算资源,提高数据处理效率。

但是,分布式监控也存在一些缺点:

  1. 复杂性:分布式监控需要管理多个节点和处理节点之间的通信和协调,因此需要更复杂的系统设计和实施。

  2. 网络通信开销:由于分布式监控需要节点之间的数据交换和通信,可能会增加网络通信的开销,对网络负载和延迟产生影响。

  3. 数据一致性:由于分布式监控涉及多个节点,各节点之间的数据一致性可能会成为一个挑战。确保各节点间的数据同步和一致性需要额外的工作和机制。

适用场景包括:

  1. 大规模系统监控:当监控范围较大,需要监控大量的设备、服务或节点时,分布式监控可以帮助分散监控工作负载,提高监控效率。

  2. 高可用性要求:对于要求高可用性的应用或服务,分布式监控可以通过在多个节点上执行监控任务来提高系统的可靠性,确保监控的连续性。

  3. 数据处理密集型应用:如果监控任务需要处理大量的数据,分布式监控可以利用多个节点的计算资源,提高数据处理效率。

总之,分布式监控适用于大规模系统监控、高可用性要求和数据处理密集型应用等场景,能够提高监控系统的效率和可靠性。

3.边缘监控

边缘监控是指将监控功能从传统的中心化架构转移到网络边缘节点上的一种监控方式。边缘节点可以是物理设备、传感器、摄像头等,具备一定的计算和存储能力。

边缘监控的优点包括:

  1. 低延迟:由于边缘监控将监控功能放置在离用户更近的边缘节点上,可以减少数据传输的延迟,提高实时性。

  2. 带宽节省:边缘监控可以在边缘节点上对数据进行预处理和过滤,只将重要的数据传输到中心服务器,有效减少了网络带宽的占用。

  3. 高可靠性:边缘节点可以独立运行,即使网络连接中断或中心服务器出现故障,边缘监控仍然可以正常运行,确保监控的连续性。

  4. 隐私保护:边缘监控可以将敏感数据在边缘节点上进行处理,只传输匿名化的结果到中心服务器上,保护用户隐私。

边缘监控的缺点包括:

  1. 有限的计算和存储资源:边缘节点的计算和存储能力有限,可能无法处理大规模的监控数据或进行复杂的分析任务。

  2. 安全性风险:边缘节点可能面临更大的安全性风险,如被攻击、窃听或篡改数据等。

边缘监控适用于以下场景:

  1. 物联网监控:边缘监控可以将传感器数据在边缘节点上进行处理和分析,减少数据传输和云端计算的负担。

  2. 实时视频监控:边缘监控可以将摄像头数据在边缘节点上进行实时处理,减少视频传输延迟。

  3. 边缘计算环境:边缘监控可以对边缘计算环境的状态、性能进行监控和管理,提高系统的可靠性和效率。

综上所述,边缘监控具有低延迟、带宽节省、高可靠性和隐私保护等优点,适用于物联网监控、实时视频监控和边缘计算环境等场景。然而,仍需注意边缘节点的计算和存储能力限制以及安全性风险。

4.集中式日志管理

在Spring Boot中实现集中式日志管理可以通过以下步骤进行操作:

  1. 配置日志输出格式:在application.propertiesapplication.yml中配置日志输出格式,可以选择格式如jsonlogstash等。

  2. 添加相关依赖:引入Spring Boot的日志依赖,例如spring-boot-starter-logging,并根据需要添加其他依赖,例如logbacklog4j2

  3. 添加日志组件:根据选择的日志输出格式,添加相应的日志组件。例如,如果选择使用logstash格式,可以添加logstash-logback-encoder作为日志组件。

  4. 配置日志输出:在application.propertiesapplication.yml中配置日志输出的目标和日志级别。可以将日志输出到控制台、文件或其他目标。

  5. 配置日志收集:将日志发送到日志收集系统,例如ELK(Elasticsearch、Logstash和Kibana)或Fluentd等。

  6. 集中式日志查询和监控:使用日志收集系统提供的工具,如Elasticsearch和Kibana,可以进行日志查询和监控。

以上是实现集中式日志管理的一般步骤,具体操作可以根据需求和技术栈的不同进行调整。

5.分布式日志管理

在Spring Boot项目中实现分布式日志管理可以使用以下方法:

  1. 使用ELK Stack:ELK Stack是Elasticsearch, Logstash和Kibana的组合。Elasticsearch是一个分布式搜索和分析引擎,可用于存储和搜索日志数据。Logstash是一个用于收集、过滤和传输日志数据的工具。Kibana是一个可视化的日志分析工具,可以通过图表和图形直观地展示日志数据。在Spring Boot项目中,可以使用Logstash将日志数据发送到Elasticsearch进行存储和检索,然后使用Kibana进行日志的可视化和分析。

  2. 使用分布式日志收集工具:可以使用一些专门的分布式日志收集工具,例如Apache Kafka、Apache Flume或者RabbitMQ。这些工具可以在分布式系统中收集和传输日志数据,并存储在中心化的日志服务器中。在Spring Boot项目中,可以使用相应的客户端库将日志数据发送到这些工具,并通过日志服务器进行集中管理和分析。

  3. 自定义日志输出:在Spring Boot项目中,可以通过自定义日志输出来实现分布式日志管理。可以编写一个自定义的Appender来将日志数据发送到远程的日志服务器。可以选择使用SocketAppender、HTTPAppender或者其他适合的协议来发送日志数据。在远程的日志服务器中,可以将接收到的日志数据进行存储和分析。

无论选择哪种方法,都需要在Spring Boot项目中配置相应的依赖和配置文件。具体的实现方式可以根据项目的需求和环境来选择。

6.实时日志流处理

要在Spring Boot中实现实时日志流处理,您可以使用Spring Cloud Stream和Apache Kafka等技术栈。

首先,您需要在pom.xml文件中添加相关依赖项:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-stream-kafka</artifactId>
</dependency>

接下来,您需要创建一个Spring Boot应用程序,并在主要Java类上添加@EnableBinding注解来启用消息绑定功能:

@SpringBootApplication
@EnableBinding(Sink.class)
public class LogStreamApplication {

    public static void main(String[] args) {
        SpringApplication.run(LogStreamApplication.class, args);
    }

    @StreamListener(Sink.INPUT)
    public void processLog(String log) {
        // 处理日志数据
        System.out.println("Received log: " + log);
    }
}

在上面的代码中,@EnableBinding(Sink.class)注解启用了消息绑定,并将日志数据传递给名为processLog的方法进行处理。

最后,您需要在application.properties文件中配置Kafka服务器的连接信息:

spring.cloud.stream.bindings.input.destination=log-topic
spring.cloud.stream.bindings.input.contentType=application/json
spring.cloud.stream.bindings.input.group=logs-group
spring.cloud.stream.kafka.binder.brokers=localhost:9092

上面的配置将日志数据绑定到名为log-topic的Kafka主题,并设置日志消费者组为logs-group

一旦您的应用程序启动,并且日志数据被发送到Kafka主题,它就会被传递给processLog方法进行处理。

监控工具

监控工具是用来监视和测量系统的工具,用于收集、存储、分析和可视化系统的性能数据。以下是几个常见的监控工具:

  1. Prometheus:一个开源的监控和警报工具,专注于可观察性和时间序列数据。它具有强大的多维数据模型、灵活的查询语言和可扩展的警报机制。

  2. Grafana:一个开源的数据可视化和监控平台,可以与多种数据源集成,包括 Prometheus、Zabbix 等。它提供了丰富的仪表板和可视化工具,方便用户通过图表和仪表板来展示和分析监控数据。

  3. Zabbix:一个开源的企业级监控工具,支持多种监控方式,包括代理、SNMP、IPMI 等。它可以监控系统的性能、网络的可用性、应用程序的运行状态等,并提供了灵活的警报机制和报告功能。

最佳实践

监控和日志架构模式和最佳实践有很多,以下是其中一些常见的模式和实践:

1.中心化日志集中存储:将所有系统的日志集中存储在一个中心化的存储系统中,例如使用ELK(Elasticsearch,Logstash和Kibana)或Splunk等工具。这样可以让开发人员和运维人员更方便地搜索和分析日志。

2.分布式追踪:在分布式系统中,使用分布式追踪工具(例如Zipkin或Jaeger)来跟踪请求的流向,以便识别性能瓶颈和故障,并进行优化和排查。

3.指标监控:使用指标监控工具(例如Prometheus或Grafana)来收集系统的关键指标数据,例如CPU使用率、内存使用率、网络流量等,以便及时发现系统的异常情况和进行容量规划。

4.日志聚合和报警:使用日志聚合和报警工具(例如Graylog或Splunk)来自动收集和分析日志,并设置报警规则以便及时发现系统的异常情况和故障。

5.事件驱动架构:使用事件驱动架构将系统内的各个组件解耦,从而实现更可靠、可伸缩和容错的监控和日志处理。

6.日志分级:根据日志的重要程度和紧急程度,将日志分为不同的级别(例如debug、info、warn、error等),并根据不同级别设置适当的日志输出方式和存储策略。

7.数据可视化:使用数据可视化工具(例如Grafana或Kibana)将监控和日志数据转化为可视化的仪表盘,方便用户直观地了解系统的运行状态和性能指标。

8.日志保留和归档:根据业务需求和法规要求,制定合理的日志保留和归档策略,以确保日志数据的安全性和完整性,同时节约存储资源。

9.自动化监控和报警:使用自动化工具和脚本来配置和管理监控和报警规则,以便及时发现和解决系统的异常情况和故障。

10.日志安全性和权限控制:确保只有授权的用户可以访问系统的监控和日志数据,并采取适当的安全措施(例如加密、身份验证等)保护日志数据的机密性和完整性。

参考资料和推荐阅读

参考资料
官方文档
开源社区
博客文章
书籍推荐

欢迎阅读,各位老铁,如果对你有帮助,点个赞加个关注呗!同时,期望各位大佬的批评指正~,如果有兴趣,可以加文末的交流群,大家一起进步哈

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

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

相关文章

基于元神操作系统实现NTFS文件操作(六)

1. 背景 本文主要介绍$Root元文件属性的解析。先介绍元文件各属性的属性体构成&#xff0c;然后结合读取到的元文件内容&#xff0c;对测试磁盘中目标分区的根目录进行展示。 2. $Root元文件属性的解析 使用每个属性头偏移0x04-0x07处的值可以从第一个属性开始依次定位下一个…

Jupyter | jupyter notebook 使用 conda 环境

博客使用更佳 点我进入博客 创建虚拟环境 在 Anaconda Prompt 里面输入&#xff1a; conda create -n env-name并且输入 y 确认。例如我们创建环境名为 jupyter 激活环境 conda activate env-name激活之后发现环境从 base 变为 jupyter(笔者用的 env-name 为 jupyter) …

python-求一个整数的质因数/字符串的镜像/加数

一:求一个整数的质因数 题目描述 编写一个程序&#xff0c;返回给定整数的质因数。 定义函数get_prime_factors()&#xff0c;该函数接受一个参数num&#xff08;正整数&#xff09;。 该函数应返回传入参数的质因数列表&#xff0c;且从小到大排序。 比如150的质因数分解如…

Spring MVC__HttpMessageConverter、拦截器、异常处理器、注解配置SpringMVC、SpringMVC执行流程

目录 一、HttpMessageConverter1、RequestBody2、RequestEntity3、ResponseBody4、SpringMVC处理json5、SpringMVC处理ajax6、RestController注解7、ResponseEntity7.1、文件下载7.2、文件上传 二、拦截器1、拦截器的配置2、拦截器的三个抽象方法3、多个拦截器的执行顺序 三、异…

数据结构——计数、桶、基数排序

目录 引言 计数排序 1.算法思想 2.算法步骤 3.代码实现 4.复杂度分析 桶排序 1.算法思想 2.算法步骤 3.代码实现 4.复杂度分析 基数排序 1.算法思想 2.算法步骤 3.代码实现 4.复杂度分析 排序算法的稳定性 1.稳定性的概念 2.各个排序算法的稳定性 结束语 引…

初识Linux · 自主Shell编写

目录 前言&#xff1a; 1 命令行解释器部分 2 获取用户命令行参数 3 命令行参数进行分割 4 执行命令 5 判断命令是否为内建命令 前言&#xff1a; 本文介绍是自主Shell编写&#xff0c;对于shell&#xff0c;即外壳解释程序&#xff0c;我们目前接触到的命令行解释器&am…

基于vue框架的大学生四六级学习网站设计与实现i8o8z(程序+源码+数据库+调试部署+开发环境)系统界面在最后面。

系统程序文件列表 项目功能&#xff1a;学生,训练听力,学习单词,单词分类,阅读文章,文章类型,学习课程 开题报告内容 基于Vue框架的大学生四六级学习网站设计与实现开题报告 一、研究背景与意义 随着全球化进程的加速和国际交流的日益频繁&#xff0c;英语作为国际通用语言…

22.3 解读k8s服务发现源码

本节重点介绍 : discovery.Manager服务发现管理员 注册各个服务发现源启动各个服务发现源处理服务发现的结果 k8s服务发现 k8s-client informer机制 架构图补充 注册各个服务发现源 位置 D:\go_path\src\github.com\prometheus\prometheus\discovery\manager.go去掉部分细节…

ConcurrentHashMap 中的并行性

ConcurrentHashMap 在多线程应用程序中被广泛使用。多线程应用程序的示例包括在线游戏应用程序、聊天应用程序&#xff0c;它为应用程序增加了并发性的好处。为了使应用程序本质上更具并发性&#xff0c;ConcurrentHashMap 引入了一个名为“并行性”的概念。 在本文中&#xf…

飞机导航数据库资料

以上是从网上收集的飞机导航数据库的一些资料。现在放在百度网盘中。 链接&#xff1a;https://pan.baidu.com/s/1fDYuaB0DuyKmYt6C_lXvZQ?pwdkcqj 提取码&#xff1a;kcqj

ZTE RRC重建优化案例

ZTE RRC重建优化案例 随着移动通信网络的不断发展&#xff0c;用户对网络的稳定性和覆盖质量提出了更高的要求。尤其在LTE网络中&#xff0c;RRC&#xff08;Radio Resource Control&#xff09;连接的稳定性直接影响用户体验和业务连续性。然而&#xff0c;在实际网络环境中&a…

案例-表白墙简单实现

文章目录 效果展示初始画面提交内容后画面&#xff08;按键按下&#xff09; 代码区 效果展示 初始画面 提交内容后画面&#xff08;按键按下&#xff09; 代码区 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8">…

C++输⼊输出

1.<iostream> 是 Input Output Stream 的缩写&#xff0c;是标准的输⼊、输出流库&#xff0c;定义了标准的输⼊、输 出对象 2.std::cin 是 istream 类的对象&#xff0c;它主要⾯向窄字符&#xff08;narrow characters (of type char)&#xff09;的标准输 ⼊流。 3…

STL之priority_queue篇——深入剖析C++中优先队列的实现原理、核心特性及其底层机制

文章目录 前言一、补充内容&#xff1a;堆1.1 什么是堆1.2 堆的分类与性质1.3 堆的向下调整算法&#xff08;小根堆&#xff09;实现流程&#xff1a;代码&#xff1a; 1.4 堆的向上调整算法&#xff08;小根堆&#xff09;实现流程&#xff1a;代码&#xff1a; 1.5 数组建堆算…

eclpsexxx

Copyright?2001-2004 International Business Machines Corp. Guidelines Eclipse 用户界面指南 2.1 版 查看目录 作者&#xff1a;Nick Edgar, Kevin Haaland, Jin Li , Kimberley Peter 译者&#xff1a;Bobbie Wang&#xff0c;Qi Liang 最新更新: 2004年2月 注意 您…

kaggle实战2信用卡反欺诈逻辑回归模型案例1

信用卡欺诈案例 数据集下载地址 https://storage.googleapis.com/download.tensorflow.org/data/creditcard.csv 参考不平衡数据的分类 文章目录 只进行特征衍生&#xff0c;未进行数据标准化、上才样处理数据不平衡问题&#xff0c;得到的准确率和召回率居然很高如果不处理数据…

李宏毅 X 苹果书 自注意力机制 学习笔记上

self attention 是一种network架构使用场景&#xff1a;输入一组向量&#xff0c;这组向量的性质&#xff1a;数量有变化&#xff0c;序列长度不一 模型输入 文字处理&#xff1a; 模型输入&#xff1a;句子&#xff08;句子的长度&#xff0c;单词都不一样&#xff09;&am…

qt QMainWindow 自定义标题栏

可以使用setMenuWidget 来将自定义的标题栏 QWidget 设置进去就可以&#xff0c; 用来替代setMenu 菜单栏单一&#xff0c;自定义不高的问题

node_exporter使用textfile collector收集业务数据

上一篇文章讲了使用Pushgateway收集业务数据的方法&#xff0c;今天讲另外一种方式textfile collector The textfile collector is similar to the Pushgateway, in that it allows exporting of statistics from batch jobs. The Pushgateway should be used for service-leve…

解决ModuleNotFoundError: No module named ‘torchcrf‘

运行深度学习程序时候&#xff0c;出现报错&#xff1a;ModuleNotFoundError: No module named torchcrf 将 from torchcrf import CRF 改为 from TorchCRF import CRF