写点什么

智能运维基础-运维知识库之 ETL

  • 2019-09-10
  • 本文字数:2228 字

    阅读完需:约 7 分钟

智能运维基础-运维知识库之ETL

在百度智能化运维的持续演进过程中,我们在逐步建设以智能运维机器人为核心的运维能力,将其应用于故障自愈、根因定位、智能变更等运维场景中。而建设以智能运维机器人为核心的运维能力,最基础的工作是要先建立运维的世界观(环境模型),以机器人的视角来理解运维世界、感知系统状态、获取环境变化等。


在传统运维模式中,运维数据分散在不同的系统中,这些运维数据存在几个问题:访问方式不一致;数据术语、概念、模型不一致;系统间没有数据关联。


这些问题使得我们日常的运维工作,经常需要理解、处理各种不同的数据,导致运维成本高,效率难以提升。因此希望建立运维知识库统一运维工作中的语言,对运维工作中的对象进行统一建模,收集并转录日常运维工作的资源与操作,为日常运维工作提供一种『书同文,车同轨,行同伦』的基础。(PS:借鉴自秦始皇)


本文主要介绍百度云 Noah 智能运维产品,在构建运维知识库过程中的思考。

运维知识库中的数据

运维知识库中包含了元数据(Meta)、状态数据(Status)、事件数据(Event):


  • 运维元数据(Meta)对运维实体世界进行建模,包括运维实体的属性、组成以及关联关系等;

  • 状态数据(Status)反应系统的状态,表征服务的存活性、资源消耗或能力等;

  • 事件数据(Event)描述对系统做的变更、服务状态的异常等事件。


ETL 系统架构

运维元数据、状态数据、事件数据分布在几十个不同的系统中,随着业务的增长和相关系统的不断增加暴露出了以下几个问题:


  • 数据分散,访问方式不一致:同一类型的数据分散在多个不同的系统,各系统提供不同的访问入口;

  • 数据术语、概念、模型不一致:各系统使用的术语、概念、模型各不相同,例如“应用”这个概念,每个系统或工具对于 Application 的理解都不尽相同;

  • 系统间数据没有建立关联:例如部署、监控和路由服务等核心场景在运维数据上没有打通,表现为部署平台、路由服务、监控系统所使用的服务管理机制各不相同,三个系统间的数据难以关联,且无联动性。


因此,依托『书同文』的理念建立运维知识库,提供一个统一的运维数据管理系统,来管理运维工作中的公共基础数据,打通系统间的数据关联,使这些数据能够遵循统一的模型被共享和使用。


为了使这些数据能够遵循统一模型,我们制定了各类数据的模型(Schema),采用 ETL 机制从各系统获取(Extract)数据、转换(Transform)成统一的模型、并存储(Load)在知识库中,其架构如图所示。



这些运维数据在建设时根据业务对数据时效性要求的不同,分为以下三种:


  • 离线数据建设,例如用于运维变更效率指标统计等相关的数据;

  • 近线数据建设,例如故障诊断过程中依赖的数据;

  • 实时数据建设,例如智能故障自愈、智能流量调度相关的路由数据等。


对于上述不同的数据我们采用不同的 ETL 方式,分别是:


  • 拉 (Pull ETL),周期性从数据源拉取数据,适用于离线数据的建设;

  • 推 (Push ETL),数据源主动推送变更的数据,适用于时效性较高的近线数据建设;

  • Federation (Lazy ETL),在查询时从数据源获取数据、按照 Schema 转换后并返回,适用于实时数据建设。

1Pull ETL

Pull ETL 提供了两种数据接入方式:自适应 ETL、基于 SDK 的自定义 ETL。


自适应 ETL,是我们针对适用范围较广的数据源(如百度名字服务 BNS、Noah 监控平台、Noah 部署平台等)开发的,用户仅需配置好 ETL 规则,自适应调度器会自动解析规则,并将数据按规则接入运维知识库。


基于 SDK 的自定义 ETL,是我们为其他数据源提供的 ETL 方式,用户基于我们提供的 SDK 可以开发各种数据源的 ETL 脚本,配置好调度策略,通用调度器根据调度策略执行 ETL 脚本,即可将数据接入运维知识库。


2Push ETL

Push ETL 采用消息队列(MQ),来支持时效性高的数据建设。数据源发生变更时,需要将变更消息推送至 MQ,运维知识库订阅、消费这些消息,并转换、存储数据。


如下图所示,用户基于 SDK 开发 Push ETL 脚本,调度器执行脚本并保证其一直处于执行状态。数据源推送变更消息至 MQ,Push ETL 脚本订阅 MQ 中的变更消息,将变更的数据转换成统一的模型并存储在知识库中。


3Lazy ETL

Lazy ETL 是为实时数据查询而提供的 ETL 模式。在运维领域我们需要看到系统的某些元数据/状态的实时变化,比如实时路由数据、监控系统的时序数据等。Pull ETL 由于是周期性的执行,因此在时效性上无法满足需求;Push ETL 需要数据源进行改造,有一定的成本,且变更消息传输存在一定的延迟,无法实时查询到最新数据。


因此,如下图所示,我们采用另一种经典方法 Federation(Lazy ETL)来实现数据集成:即运维知识库处理用户查询时,直接调用接口去访问原始数据源,按 schema 转换后,返回给用户。


总结

本文主要介绍了百度云 Noah 智能运维产品中的运维知识库之 ETL。针对不同业务场景使用的数据,提供不同的 ETL 方式。针对离线数据建设,采用 Pull ETL 周期性从数据源获取数据,此外综合考虑数据接入收益和成本,提供了自适应 ETL 以及基于 SDK 的自定义 ETL;针对时效性高的数据建设,采用 Push ETL,数据源主动推送变更到运维知识库中;针对实时数据建设,采用 Lazy ETL,在查询时回源获取数据并进行转换。有对运维知识库和 ETL 感兴趣的同学,欢迎留言探讨。


作者介绍:


H++,百度云高级研发工程师,负责百度云 Noah 智能运维产品元数据建设、时序数据存储相关研发工作,在分布式系统架构、高性能数据服务、数据清洗等方向有着较为广泛的实践经验。


本文转载自公众号 AIOps 智能运维(ID:AI_Ops)。


原文链接:


https://mp.weixin.qq.com/s/Py0lOZEHr2rdGwXbg2hnqw


2019-09-10 17:232839

评论

发布
暂无评论
发现更多内容

MestReNova 中文版:解析和解释核磁共振(NMR)和质谱(MS)数据

Rose

MestReNova软件 MestReNova14破解版 核磁共振 医学研究

Axure RP 9 与其他原型设计工具的比较:为何它是您的最佳选择?

Rose

原型设计 Axure RP 9汉化 Axure RP 9授权码

探索AIGC在腾讯自选股应用

ninetyhe

腾讯 AI 大模型 AIGC

【论文精读】| 综述:模糊测试的艺术、科学和工程(下)

云起无垠

Module2作业

大鹏

哪里有office2016安装包?office2016下载含激活工具

Rose

office办公套件 office2016

Solidity案例详解(四)投票智能合约

BSN研习社

区块链 Solidity

易点天下旗下出海应用数据分析与增长模型平台即将发布,一大波内测福利正在袭来!

新消费日报

软件测试管理进阶,快速掌握高效沟通的汇报技巧

测试人

软件测试 自动化测试 测试开发 测试管理

文心一言变身虚拟患者,助力医学生轻松开启「实践模式」

飞桨PaddlePaddle

百度 paddle 百度飞桨 开发者说 文心一言

英特尔x爱立信:以开放式移动网络加速未来关键领域数字化转型

E科讯

“智慧工程”助力房企突破发展瓶颈,精细化管理降本增效

Kyligence

大数据 数字化 解决方案 精细化管理

photoshop 2021 对显卡的要求 ps2021中文破解版安装包下载

Rose

ps2021破解版 Photoshop 2021 Photoshop 2021要求

马帮ERP与ETLCloud快速同步

RestCloud

数据同步 ETL 数据集成 ERP

把简单留给用户,把复杂交给 AI

Kyligence

大数据 AI 数据治理 指标平台

面试官:说说SSO单点登录的实现原理?

王磊

Java 面试

文心一言 VS 讯飞星火 VS chatgpt (205)-- 算法导论15.4 1题

福大大架构师每日一题

福大大架构师每日一题

常用的Linux命令;Linux常用命令用法及实现方式

小魏写代码

测试管理进阶 | 快速掌握高效沟通的汇报技巧

测吧(北京)科技有限公司

测试

软件测试学习笔记丨 k8s环境部署实战

测试人

软件测试 测试开发

WebSocket 连接保持方法详解

Apifox

程序员 前端 后端 websocket 长连接

Parallels Desktop 19 虚拟机如何安装?详细PD19图文安装教程 含激活版Windows镜像

Rose

Win11系统下载 Parallels Desktop 19 pd 19 虚拟机安装

VMware Workstation (VM电脑虚拟机)激活精简版

Rose

VMware Fusion破解版下载 虚拟机安装 VM虚拟机密钥

阿里云大降价后,与主流云厂商的价格对比,你选哪家?

NineData

数据库 阿里云 服务器 云厂商 阿里云降价

App应用程序(概念、开发步骤、技术要点介绍)

天津汇柏科技有限公司

定制软件开发 app定制开发 软件开发定制

运维一款月变更70+次的服务,是一种什么体验?

华为云开发者联盟

开发 华为云 华为云开发者联盟

Java实战1

thinkers

线程池、Lambda、Java实战

有道QAnything背后的故事---关于RAG的一点经验分享

有道技术团队

语言 & 开发 #开源

手把手带你快速上手香橙派AIpro

华为云开发者联盟

人工智能 华为云 昇腾 华为云开发者联盟 AI开发板

资深项目管理者教你快速掌握高效沟通的汇报技巧

霍格沃兹测试开发学社

智能运维基础-运维知识库之ETL_软件工程_H++_InfoQ精选文章