运维管理数智化:数据与智能运维场景实践

本文来自腾讯蓝鲸智云社区用户:CanWay

摘要:笔者根据自身的技术和行业理解,分享嘉为蓝鲸数据与智能运维场景实践。

涉及关键字:一体化运维、平台化运维、数智化运维、AIOps、运维PaaS、运维工具系统、蓝鲸等。

本文作者:嘉为蓝鲸运维产品及解决方案负责人 张敏、嘉为蓝鲸平台产品线总经理 周宗沛

全文共计6500字,预计阅读时间14min。

数据与智能技术在运维业务中的定位

数据与智能技术在运维业务中的应用近几年进入“实用化提升阶段”,无论从供给方,还是需求方,都逐步认识到,“数据与智能”运维有其边界和条件,“AI加持运维”比“AI颠覆运维”有了更广泛的声音;我们乐于看到甲乙方更为聚焦在实用化业务场景上:基于数据与智能的技术手段,补足和提升一体化运维。

回归业务本质,运维复杂度是由管理场景和技术对象共同来影响的,所以回到一体化运维的定义中:基于运维业务视角的角色、流程、活动(对象)、工具系统的整合,业务运转顺畅、流程运行高速、工具支撑高效是对运维一体化的核心验证,运维一体化不仅仅是工具全面和单一工具技术功能完备,而是要融入业务设计和整个体系中。因而数据和智能是一种生产力,尤其是在数据整合、高阶分析场景上,带来整体的提升。

运维大数据在运维的定位:跨多数据源系统,实现配置、运行、操作、流程等维度数据源分析,提升性能容量、观测整合、运营分析等的运维能力。例如:在一站式数据和功能闭环的可观测架构设计下,数据采集、清洗、存储、检测、消费均自行闭环,产品内置大数据能力。然而,由于数据源来自不同的专业监控工具,对数据接入、统一元数据和数据标签的要求变得更高。因此,需要运维大数据进行管理和处理。

AI技术在运维中的定位:通过机器学习、自然语言处理、大语言模型和其他AI技术,AI in All来对原有运维系统的能力加持,提升故障管理、服务优化、成本节省、安全提升等运维能力。例如:在一体化运维的告警事件中心里,核心是告警接入、标准化与丰富、告警收敛、屏蔽、委派、生成事件、自动化处置,而在规模到达一定量级的告警数,则需要文本相似度等算法来做告警的智能聚合,或基于图谱的智能聚合,这样能在原有基础上进一步升级。

概要设计:运维大数据及AI是技术能力,核心是应用到运维业务场景中;有三个核心基础:基础运维系统提供数据和能力、数据及AI平台提供数据处理和模型训练能力、运维数据分析及算法工程师和团队提供组织支撑。

--b3bdda620e541301e9047a0c56f1c02d.png

图1:数据与智能业务架构

大数据分析运维场景实践

首先初步定义运维数据域,可以大致划分成5个域:

1、配置域:IT资产管理系统、配置管理中各类电子信息设备的基本信息、技术参数及关联关系等信息,包括PC机、服务器、存储设备、网络设备、安全设备、辅助设备、机房环境设备、套装软件及应用系统软件等。

2、状态域:IT监控、自动化运维、安全监测等采集的设备软硬件性能、状态、事件、日志、告警及实用化数据等。

3、流程域:运维流程管理中执行一个业务流程所产生的相关记录数据。

4、作业域:自动化作业、故障自愈、编排处置步骤等作业执行流程数据和操作审计数据。

5、知识域:故障事件处理经验,其他相关知识库,以知识主题、关键字索引、内容等形式存在。

数据治理框架核心要定义几个问题:

运维数据之间的逻辑和关联设计如何做?
运维大数据平台的定位?
数据消费场景如何持续建设?
数据与AI如何统一建设?
关键逻辑为:

--3e6dfcd4db9464d70b3b371e4bbfdea9.png

图2:基于运维数据的管理架构

这里有几个实践建议:

1、消费场景聚焦在提升性能容量、观测整合、运营分析的高阶运维能力;尤其是在观测整合上,当前可观测主要围绕故障分析和定位展开,基于数据管理框架,则可以完成数据标签统一、数据聚合计算、数据关联信息平面、AI模型应用等,例如其中一个观测场景可以基于告警视角,展开Trace、Log、Metric、场景视图、知识库关联、变更事件关联分析等,来形成初步的观测整合分析场景:

--595cce69844361485278741b95109702.png

图3:告警视角的观测场景示例

2、技术价值主要体现在复杂和大规模的数据清洗、开发和存储需求;跨数据源的数据关联计算;联动MLOps实现数据样本和数据源的关联,实现AIOps模型开发和应用。

3、数据管理采用专业分散,消费驱动的模式管理,专业分散是指如CMDB、Metric、Trace、Log等都在专业管理工具里,消费驱动则是基于场景调用时,再去做数据接入、标签、关联计算等,支撑数据之上的场景应用。

而到运维数据平台自身的应用架构,运维数据平台应该具备的核心功能包括数据采集接入、数据清洗加工、数据入库存储、数据开发、数据探索、数据集市等,并且要具备元数据、数据质量和安全等管理能力和自运维能力。在运维数据管理过程中不仅要关注“稳定”“安全”“可靠”,更要关注“体验”“效率”“效益”。

--8288a5760d85642c153dc80e1685e4d9.png

图4:运维大数据平台功能架构

AI运维场景实践

数据+算法驱动的分析决策能力是AIOps场景落地的核心能力。基于运维数据平台提供的高质量、低延迟的统一运维数据,智能分析决策平台可以根据不同场景需求采用适合的AI算法和模型做出合理判断或结论,并驱动自动管控平台执行运维操作。

因此,智能分析决策平台最核心的模块是人工智能/机器学习平台。类似于行业通用的机器学习平台,它需要具备数据集成和计算、模型开发和训练、模型部署和推理等基础功能。然而,为了支撑AIOps场景,该平台需要在运维领域中加入一些特性,高效地孵化出适配各种智能运维场景的算法和模型。

首先,智能分析决策平台需要建立运维数据模型、指标体系和知识图谱。该功能面向可扩展的AI场景,依托于运维数据平台,采用“采集、治理、应用、采集”的循环迭代方法。通过不断尝试落地AIOps场景,发现数据质量问题,并进行补充完善。

其次,智能分析决策平台最终的用户是运维人员。因此,它需要具备流程化的低门槛场景建模能力,采用向导式的图形化建模。这样可以将运维人员难以理解的算法变成“组件”,将模型训练过程中的复杂调参过程变成“灵敏度调整”,从而更快地将成熟的AI场景普及到更多的业务中。

最后,可以将运维领域的DevOps理念引入到算法和模型开发过程中,以加速AI场景的开发。

--b2ded430e9dee6aad18f0ff94ef82627.png

图5: AI平台功能架构

指标异常检测

指标异常检测是其他智能运维场景建设的基础,属于单场景,异常检测的结果将为后续的告警收敛、故障定位、故障自愈等场景提供重要输入。指标一般分为业务指标(如访问量、响应率、响应时间等)、性能指标(CPU、内存、IO、网络流量等),并且汇总多个独立的或关系型的指标可以组成不同的多指标异常检测。这里详细介绍一下性能单指标异常检测。

性能指标异常检测可以采用了时间序列特征提取和深度贝叶斯学习的通用异常检测方案,它考虑了不同类型曲线(周期型、稳定型、稀疏型)的特征,可以满足机器指标、业务指标等时序数据的异常检测需求。

通用单指标异常检测的检测流程分为异常模式提取和有监督异常检测两部分:

①在异常模式提取阶段,基于概率论、极值理论、残差理论等,从时序数据中提取能多方面表征数据异常模式的特征。

②在有监督异常检测阶段,采用基于主动学习的深度贝叶斯模型,能够在异常检测的同时,根据用户反馈学习未知的异常模式和部分用户偏好。

--098a7e318befef5fb56d11b7b7d4ab7e.png

图6: 异常检测模型

单指标异常检测可以集成应用到监控产品中,当CPU使用率突降和磁盘使用率突降时,通用单指标异常检测算法可检测出异常点,并在告警中心可以展示告警详情。包括告警内容,以及关联的维度。如下图所示,其中检测出异常时刻,会进行标注(红色框)。

--dd99c31438ca9eabbee52434572eaae3.png

图7: 异常检测模型应用

时序数据预测

在IT运维领域,对信息系统进行检测,会产生大量多类型的时间序列数据,如用户在线数、主机CPU使用率等。时序数据预测利用历史时间,序列数据预测未来一段时间数据的变化趋势,可以满足如CPU、磁盘使用率、在线人数等各类大型在线业务的时序预测需求,为用户做出重要决策(如资源管理、异常告警等)提供准确有力的数据支撑。

时序数据预测是一种基于Transformer的时间序列预测方法,Transformer是最成功的序列模型架构,在自然语言处理(NLP)、语音识别和计算机视觉等各方面有着非常显著的优势。基于Transformer的时间序列预测模型,广泛运用的相关场景包括交通流量估计、能源管理、金融等领域。在运维领域主要对长时时序数据进行预测,例如资源的容量预测(如服务器的CPU、Mem)、成本预测等。

时序数据预测方案设计了一套基于Transformer模型的融合迁移学习和增量学习的时间序列预测服务,它通过对不同频率下的时间序列指标进行归一化,以确保模型能在多源系统之间实现共享,采用基于贝叶斯估计的Transformer模型来生成预测边缘分布,同时将迁移学习和增量学习引入到模型训练过程中以避免概念漂移风险,确保模型的长期预测性能。

--e293efe7f87baf25ebde0cbb0c3ee96c.png

图8: 时序数据检测模型

时序数据预测算法可以集成应用在配置管理平台的资产盘点分析和容量管理平台的容量分析预测等场景,分析和预测IT系统的关键应用未来的容量情况,支撑报表展示和辅助客户进行资源规划。下图是在容量管理平台里的一个业务弹性扩缩容场景,应用时序数据预测AI模型对某业务服务器集群CPU使用量进行预测分析,并结合自动化系统执行扩缩容任务,在保障业务稳定的情况下,降低了30%的成本。

--acc0fd9dbab4651bd020f04d5fd68cb3.png

图9: 时序数据检测模型应用

多维下钻

业务系统的管理人员需要监控大量的指标来了解和维护系统的可用性,通常这些指标会包含一些维度,例如,一个微服务调用数相关的指标可能会包含服务供应方(Internet Service Provider,ISP)、服务所属业务信息等维度。通过组合不同维度来汇总指标,可以从不同粒度,不同角度来充分展示系统的实时状态。然而,由于维度的组合爆炸问题,系统管理人员通常需要筛选并重点关注某些维度组合下的指标汇总值;这些指标的汇总方式可以是求和,求均值等。经过筛选出来的指标汇总值又称为SLI (Service Level Indicator)。当从SLI中检测出异常时,为了诊断异常,就需要找出实际上导致SLI出现异常的维度与这一维度下的元素组合,这一过程又称为多维下钻。

基于多维下钻和贝叶斯网络的多维指标异常根因维度定位方法流程如下图所示,由检测出的SLI异常触发。多维下钻算法包含维度映射构造和维度下钻两个核心步骤。维度映射构建旨在指定各个最细粒度指标与聚合形成的SLI之间的计算公式。这一计算公式可由用户配置的,用户可基于业务自身需要定制任意SLI指标计算方式。用户对SLI指标计算方法的需求包含但不限于计数型,求和型,求均值型,求最值型,求分位数型和求比例型。异常维度下钻,就是要利用各个最细粒度指标的值作为输入,最终找出真正导致汇总形成的SLI指标出现异常的维度和对应的元素组合。由于组合爆炸问题,需要充分挖掘异常维度的特征,以设计启发式搜索的方法来实现这一目的。

--81b5db1d488241fd816b8402bc39cfb8.png

图10: 多维下钻模型逻辑

在某些情形中,在下钻出具体的异常维度后,需要更进一步地明确这些异常维度之间的因果关系。最终识别的异常维度及其因果关系会提供给用户,辅助其对系统中出现的故障进行根因分析,做出快速响应与恢复。

在监控场景的单指标告警策略,如果没有配置完整的维度信息,可能在告警时无法准确判断当前异常是由哪个维度导致的。维度下钻功能可以自动分析异常的维度信息,辅助定位问题。如某业务的在线人数检测到异常,通过下钻该时间点的异常,给出具体异常的维度(比如用户所属省份、客户端版本等),以及最有可能异常的具体维度值 (含排序)。

指标关联推荐

在生产环境下,在线系统的系统管理人员需要管理大量的运维对象(例如,关键绩效指标等描述应用服务能力的指标,服务器、公共和自定义组件等基础物理设施)来维护系统的可用性。其中,每个运维对象会暴露大量的监控指标,供系统管理人员从各个方面来监视系统的实时状态。通常,这些监控指标的数量可达成百上千个,并且,随着系统可观测性的发展,这一数量只会越来越大。大量的监控指标使得系统管理人员疲于观察和分析,极大地影响了故障发现和诊断的效率。

指标关联推荐算法设计了一种基于异常共现频率和随机游走的监控指标推荐方法。它由两个主要部分组成:指标关系构建和关键指标推荐。指标关系构建首先计算监控指标两两之间的异常共现频率和曲线相似度,然后基于异常共现频率确立指标间的关系,并使用曲线相似度剪枝,避免冗余推荐,最终确立指标间关系图。关键指标推荐则利用随机游走算法分析上一步骤得出的指标关系图,确定监控指标的推荐排名。

--585fd0c9adeb6fcbd322990ca2ca837b.png

图11: 指标关联推荐模型

监控配置的单指标告警策略,只能对单个指标的异常进行告警,在排查问题时可能需要结合关联指标进行人工的根因定位。关联指标推荐功能会根据是否同时异常、告警发生时的曲线形态来推荐关联指标。如下图所示,某服务器的磁盘空间使用率检测到异常,通过关联指标推荐,发现了【操作系统】层级的其他7个关联指标(仅展示3个示例),存在形状相似或同时异常。

--383f1ae2ee09ded206c904894bd8d5e6.png

图12: 指标关联推荐模型应用

日志聚类

日志聚类的主要流程是日志经过预处理后,通过计算日志间的相似度,将相似度高的日志聚在一起,通过模式识别生成日志模式,从而得到日志聚类模型,供日志检索和实时预测使用,降低运维人员查看海量异构日志的工作负担。

--7e861b08c6c9750805ac5178685fd2f3.png

图13: 日志聚类模型

聚类是找出日志分词和已有聚类簇的最大相似度,进行阈值判别,放入对应类/创建新类。

--8e5625d79665dacfd1fe6b5721c864a8.png

图14: 日志相似度模型

模式识别是从聚好的类簇中提取日志模式。模式识别包括日志对齐和模式生成两部分。

日志对齐:日志对齐的最佳方式是在合并后生成最小数量的通配符和变量。在对齐的过程中,分词之间可能会插入一些GAP。对齐算法确保插入GAP后同一类的日志长度相等。

模式生成:得到相同长度的日志后,遍历分词,将不一致的替换为通配符,并输出日志模式。

--71c8293462012862767f052b24dd5409.png

图15: 日志聚类模式识别

在蓝鲸日志平台,开启日志聚类后,可以高效查看日志聚类结果,了解新出现的日志模式。同时可以根据Pattern从少到多的不同档位,来灵活地选择不同粒度的聚类结果。

--57e530c5d535cfff45cb17b9bcef9dd5.png

图16: 日志聚类应用场景

日志异常检测

日志异常检测属于相对复杂的场景,本方案采用了离线冷启动训练和在线训练相结合的方式,依赖日志聚类单场景能力。离线冷启动训练,是将离线冷启动日志样本经过预处理后,计算日志间的相似度,将相似度高的日志聚在一起,通过模式识别生成日志模式,得到日志聚类模型,供在线训练作为冷启动模型使用;在线训练以流式方式实时解析日志,快速匹配到已有的日志模式,对未匹配到的日志即为新的日志模式,即为新类日志。

--4a5ee28d36227c1c9f3634b17e0dd597.png

图17: 日志异常检测模型

当使用日志模板模型检测出新的模板后,将会发出异常告警,可以在日志出现新的异常/错误模式时,第一时间收到告警,并查看对应的模式及日志内容。

--8b451878414aaf3ef9da38cafd7244eb.png

图18: 日志异常检测模型应用

告警收敛

在运维监控系统中,告警收敛是指对告警信息进行分析、合并和丢弃,以此来降低告警信息的规模,其对降低网络运维的压力意义重大。

在运维监控系统中,可以把告警分为噪声告警、事件告警、故障告警。根据告警出现的频繁程度和基于统计的方式,区分出噪声告警和非噪声告警,其中噪声告警指的是在历史上频繁出现的告警。再根据非噪声告警的数量和涉及的指标范围,区分为事件告警和故障告警,一个故障的重要告警更多,涉及的指标也更广。

聚集维度的告警收敛主要是基于频繁项集进行挖掘,找到告警聚集的维度,比如告警都聚集在某个服务上、某个主机上、某个Pod上,帮助用户快速定位告警的影响范围或者根因。层级分析的告警收敛使用有监督的方式,对告警进行分类,假设常见的告警类型有应用层、服务层、主机层、数据中心层等,由于一般来说,越偏低层告警数量越多,用户关心程度越低,因此采用高层级的告警收敛低层级的告警,将影响的最高层级通知用户。

--c4fabb852583b0a671e724c24cba7f2b.png

图19: 告警聚类逻辑示例

告警收敛后的降噪比如下图所示,整体降噪比达到98.4%,某个业务的降噪比84.6%。

--f263e7557700c86d3814a521ddce9988.png

图20: 告警聚类应用场景

大语言模型应用

大语言模型在运维领域对于我们来看,改变了人与运维系统的交互模式,其中场景就包括智能问答、故障解决建议、数据统计分析等。

提供了集中核心能力:

  • 语料管理系统:为用户提供语料撰写、语料管理、流程编排;
  • 高级编排中心:集成了语料、大模型、知识库、自动化等多种功能,提供了高度灵活的编排方式;
  • 模型训练中心:支持多次、批量训练,并提供了调参功能,提供了高效的模型训练方式,能够快速- 训练出高质量的机器人模型。
    接入运维沉淀的知识库文章→用户专业咨询→从知识库总结输出,自动获取告警、资产、日志等相关信息,综合分析,专业引导,最终辅助解决问题。

--e1223c4ce42a7d4afe5a8bf79a542cf2.png

图21: 故障智能问答交互

嘉为蓝鲸作为业内领先的平台化、一体化、数智化运维解决方案提供商,我们坚定地致力于把成熟的业务实践、领先的技术架构,赋能给我们的客户。

本期我们共同探讨了“数智化”相关内容,“一体化”、“平台化”相关内容请点击下方“系列推荐”。

--058efc0cfaf930fc35b31a81889a3b67.png

最后,欢迎随时与嘉为蓝鲸共同探讨!

总结:以上为笔者对数据与智能运维的剖析,欢迎探讨交流,谢谢!

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

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

相关文章

自动驾驶AVM环视算法–全景和标定全功能算法实现和exe测试demo

参考:全景和标定全功能算法实现和exe测试demo-金书世界 1、测试环境 opencv310vs2022 2、使用的编程语言 c和c 3、测试的demo的获取 更新:测试的exe程序,无需解压码就可以体验算法测试效果 百度网盘: 链接:http…

minio 获取预览地址

1.进入到 minio,并设置桶的权限。 2.获取预览地址代码如下: 注意: GetPresignedObjectUrlArgs.builder().method(Method.GET),这个地方一定要用 GET,我当时按照官网的例子写的,没注意这个,搞了…

深入解析公有IP与私有IP:地址分配与使用限制

IP地址在网络基础设施的建设和维护过程中起着至关重要的作用。作为IP地址的两大类型,公有IP和私有IP各自具有独特的分配机制和使用限制。本文将详细分析两者之间的区别,以帮助读者更好地理解和使用IP地址。 1. 公有IP与私有IP概述 IP地址是网络中的唯一…

库迪“夏日果咖季”打卡活动走样,联营商不想配合了?

库迪的“夏日果咖季”打卡活动,真是让人在这个炎炎夏日受一肚子气。 有大批不同IP的网友在社交媒体平台吐槽,特意前去门店打卡,却被告知门店没有这个活动。 一位广州的网友在小红书发帖表示,上班前特意坐地铁去门店参加活动&…

半自动辅助制作数据集【实例分割】

利用yoloV8的实例分割模型,半自动辅助制作数据集 引言:【主要步骤】 步骤1:无人机航拍,收集基础图片 步骤2:将收集到的图片,全部用yoloV8-seg.pt模型进行实例分割【预测之前,将配置文件default.…

什么是大模型?(超详细)从入门到精通 一文读懂大模型的基本概念

1. 大模型的定义 大模型是指具有大规模参数和复杂计算结构的机器学习模型。这些模型通常由深度神经网络构建而成,拥有数十亿甚至数千亿个参数。大模型的设计目的是为了提高模型的表达能力和预测性能,能够处理更加复杂的任务和数据。大模型在各种领域都有…

海外社媒矩阵为何会被关联?如何IP隔离?

在当今的数字时代,社交媒体已经成为人们日常生活中不可或缺的一部分。通过社交媒体,人们可以与朋友互动,分享生活,甚至进行业务推广和营销。然而,社交媒体账号关联问题逐渐受到广泛关注。社交媒体账号为何会关联&#…

力扣经典题目之->删除有序数组中的重复项讲解 的讲解与实现

一:题目 二:思路讲解 第一步:创建两个下标,一个是第一个元素的(start0),一个是第二个元素的(end1) 第二步: a:end移动,直到遇到不等…

Flowable-会签与或签

一、会签 会签的意思是,在流程任务管理中,任务通常是由一个人或者多个人同时去处理的,这种任务叫做会签任务。类似于并行网关,会签任务一般需要任务候选人全部完成审批后,才能进入下一个审批环节。 (一) 会签类型 按…

持续集成06--Jenkins构建触发器

前言 在持续集成(CI)的实践中,构建触发器是自动化流程中不可或缺的一环。它决定了何时启动构建过程,从而确保代码变更能够及时地得到验证和反馈。Jenkins,作为业界领先的CI/CD工具,提供了多种构建触发器选项…

jeecgboot项目不知道什么原因启动出来8080端口后就不下去了,要等上10多分钟才出来接口地址等正常情况

因为这个项目license问题无法开源,更多技术支持与服务请加入我的知识星球。 1、项目中途不知道什么原因,就出现下面情况 具体如下: 2024-07-15 15:08:15.767 [main] [34mINFO [0;39m [36mliquibase.changelog:30[0;39m - Reading from jeec…

什么是鉴权开发框架?如何认证和限流

目录 一、鉴权开发框架介绍二、Django REST framework是什么三、如何实现认证、权限与限流功能四、Django REST framework的应用场景 一、鉴权开发框架介绍 鉴权开发框架是一种用于实现身份验证和授权的软件开发工具。它可以帮助开发者快速构建安全、可靠的身份验证和授权系统…

Spring Boot 中使用 Resilience4j 实现弹性微服务的简单了解

1. 引言 在微服务架构中,服务的弹性是非常重要的。Resilience4j 是一个轻量级的容错库,专为函数式编程设计,提供了断路器、重试、舱壁、限流器和限时器等功能。 这里不做过多演示,只是查看一下官方案例并换成maven构建相关展示&…

DNS查询过程

DNS(域名系统,Domain Name System)是一个用于将域名和IP地址相互映射的系统。当你在浏览器中输入一个网址时,浏览器会通过DNS查询过程来找到对应的IP地址,以便能够连接到目标服务器。其查询过程一般通过以下步骤&#…

Netgear WN604 downloadFile.php 信息泄露漏洞复现(CVE-2024-6646)

0x01 产品简介 NETGEAR WN604是一款由NETGEAR(网件)公司生产的无线接入器(或无线路由器)提供Wi-Fi保护协议(WPA2-PSK, WPA-PSK),以及有线等效加密(WEP)64位、128位和152位支持,保障网络安全。同时支持MAC地址认证、802.1x RADIUS以及EAP TLS、TTLS、PEAP等安全机制,…

【Flowable | 第四篇】flowable工作流多任务实例节点实现会签/或签

文章目录 5.flowable工作流多任务实例节点实现会签/或签5.1会签/或签概念5.2多实例配置说明5.3会签例子5.3.1用户候选人配置5.3.2多实例配置5.3.3执行监听器配置5.3.5测试 5.flowable工作流多任务实例节点实现会签/或签 5.1会签/或签概念 我们在本篇中,将使用多任…

【JavaEE】synchronized原理详解

本文使用的是JDK1.8 目录 引言 Java对象在JVM的结构 对象头 Mark Word Monitor Owner EntryList WaitSet 加锁过程 锁消除 偏向锁 偏向锁使用 重偏向 撤销偏向 轻量级锁 重量级锁 自旋优化 引言 对于synchronized原理讲解之前,我们需要知道Java对象…

C#学习

C#学习 1.B站丑萌气质狗C#的循环-判断泛型错误处理面向对象static的使用定义showInfo类和Hero类 在这里插入图片描述 然后在该解决方案add新建一个类库,点击rebuild,会在bin文件夹下生成.dll文件 ![在这里插入图片描述](https://i-blog.csdnimg.cn/direc…

SSE(Server Sent Event)实战(3)- Spring Web Flux 实现

上篇博客 SSE(Server Sent Event)实战(2)- Spring MVC 实现,我们用 Spring MVC 实现了简单的消息推送,并且留下了两个问题,这篇博客,我们用 Spring Web Flux 实现,并且看…

【北京迅为】《i.MX8MM嵌入式Linux开发指南》-第二篇 Linux系统编程篇-第三十一章 文件IO和标准IO

i.MX8MM处理器采用了先进的14LPCFinFET工艺,提供更快的速度和更高的电源效率;四核Cortex-A53,单核Cortex-M4,多达五个内核 ,主频高达1.8GHz,2G DDR4内存、8G EMMC存储。千兆工业级以太网、MIPI-DSI、USB HOST、WIFI/BT…