设计新的 Kibana 仪表板布局以支持可折叠部分等

作者:来自 Elastic Teresa Alvarez Soler, Hannah Mudge 及 Nathaniel Reese

在 Kibana 中构建可折叠仪表板部分需要彻底改造嵌入式系统并创建自定义布局引擎。这些更新改进了状态管理、层次结构和性能,同时为新的高级仪表板功能奠定了基础。

我们正在开发可折叠部分,以隐藏和显示 Kibana 仪表板中的面板,以帮助组织内容并提高性能。这是一个经典的软件开发故事:有时要前进,就必须……走下坡路?阅读有关如何构建看似简单的热门功能有时会导致比你预期的更大的简化的信息!😅

可折叠部分

背景介绍:Kibana 中的仪表板可以包含许多可视化内容,站点可靠性工程师 (SRE) 使用这些可视化内容来保持系统运行,或安全分析师在调查中使用它们。这些仪表板可能很长且加载速度很慢。用户希望更好地组织仪表板内容,以避免性能陷阱并使其更易于扫描。今天,实现此目的的最佳方法是将仪表板内容拆分为多个仪表板,然后使用仪表板链接面板链接它们以方便导航。不幸的是,这不允许你并排查看内容,并且使仪表板作者需要付出大量努力才能进行更新和维护。为了解决这一需求,我们正在开发可折叠部分以隐藏和显示 Kibana 仪表板中的面板 - 这些部分有助于组织内容,并且不会加载折叠的内容以提高性能。

这些新部分将允许你对主题相关的仪表板面板和数据可视化进行分组,从而更轻松地找到你要查找的信息。最重要的是,你可以轻松隐藏和展开这些部分,从而仅加载所需的数据。这将帮助你创建图表的并排比较并简化仪表板性能。

规划工程方法

一开始,当我们审视客户对该功能的需求时,它看起来像是一个常规规模的工程工作:仪表板包含面板(稍后会详细说明),需要将它们组织到不同的部分中,并且产品需求要求仅在某个部分打开时渲染相关面板。此外,还需要一个拖放系统来布局仪表板,该系统必须考虑这些部分,并能处理各种 “在部分之间移动内容” 类型的用例。看起来像是对现有代码的一次增强,对吧?

不幸的是,经过短暂的概念验证后,我们发现答案是否定的。事情没那么简单。Kibana 使用 “可嵌入” 框架,而该框架缺乏不在仪表板上呈现某些嵌入对象所需的特性。让我们来看看为什么……

什么是 “可嵌入”?

尽管 “可嵌入” 未出现在 “Discover” 和 “Dashboard" 旁边的导航菜单中,但你仍可以在整个 Kibana 中与可嵌入内容进行交互。Discover 中的直方图、仪表板中的每个面板、面板的上下文菜单、可观察性中的镜头图表或安全性中的地图 - 所有这些都可以通过可嵌入内容实现。

可嵌入内容是 React 组件,可提供与 Kibana 深度集成的 API。此 API 允许它们由任何页面持久保存和恢复,使它们能够访问当前搜索上下文,允许它们定义编辑 UI,并且可扩展,以便工程师可以定义组件如何相互交互。它们位于注册表中,注册表将它们的行为与编写代码的位置分开。因此,许多工程师可以同时处理不同的可嵌入内容,而不会互相干扰。

对新嵌入式系统的需求

我们当时正在研究的旧式嵌入式系统可以追溯到 2018 年。嵌入式功能通过自定义用户体验组件抽象来公开。当时,Kibana 正在从 Angular 1 过渡到 React,因此嵌入式系统被设计为与框架无关,这可以顺利实现从 React 的理论过渡。虽然当时需要这种架构,但自那时以来,Kibana 已经发生了很大变化,并且不太可能脱离 React。现在,不灵活且不可知的嵌入式架构是一个日益严重的摩擦点。一些痛点是:

  • 复杂的状态管理:嵌入式中的所有状态都要经过两个可观察对象(输入、输出)之一才能被继承、设置或读取。这要求消费者设置复杂的双向同步管道。
  • 有限的继承:嵌入式只能有一个父级,将继承限制在一个层次结构中。此外,可嵌入状态从父级流向子级,如果已定义,子级状态将覆盖父级状态。
  • 手动渲染:可嵌入需要繁琐的手动渲染过程和 Kibana 其余部分之间的兼容层,后者通过 React 进行渲染。

可折叠部分无法通过单一层次结构实现。可折叠部分需要多个层次结构,以允许面板属于仪表板和可折叠部分。否则,你将无法将面板放入可折叠部分。

新的可嵌入系统

因此,为了实现此功能,我们实际上必须 “深入” 可嵌入系统本身,并现代化管理可嵌入项的方式:我们必须设计一个新的可嵌入系统。很有趣!但同时……范围也很大!

新的可嵌入功能通过普通的旧 JavaScript 对象公开,并且可以通过实现接口来组合其功能。例如,可嵌入可以通过实现 PublishesDataLoading 接口来传达数据加载。这提供了以下好处:

  • 干净的状态管理:每个状态都作为只读可观察对象公开。可以为可变状态公开 Setter 方法。
  • 灵活的继承:可嵌入可以有一个父级链,允许根据需要设置尽可能多的层次结构。每一层都保留自己的状态,以便在使用时决定使用哪个状态。

有了可以容忍我们所需的继承的系统,现在可以构建可折叠部分。

但是,像任何好的重构一样,也有一个问题:可嵌入在 Kibana 中无处不在,为了在不导致回归的情况下实现这一变化,我们需要在 Elastic 的整个体验中迁移到新的可嵌入系统 —— 从 Elastic Security 中的 Alerts 页面到 Elastic Observability 中的 Service Inventory,以及介于两者之间的几乎所有内容。这花费了我们一些时间,但却带来了一些令人兴奋的新可能性。

新的布局引擎

任何仪表板背后的驱动力都是布局引擎,它允许面板被拖动和调整大小 —— 没有它,仪表板将完全是静态的(和无聊的)!

目前,Kibana 使用外部 react-grid-layout 包来驱动我们的仪表板,这是一个由一小群志愿者管理的开源布局引擎。到目前为止,这个布局引擎对我们的仪表板非常有用;然而,不幸的是,它缺少一些关键功能,这些功能可以使可折叠部分开箱即用:要么是 “面板内的面板”,要么是将面板拖到布局的两个独立实例上。

由于 react-grid-layout 背后的团队很小,因此对包的更新很少 —— 这意味着,即使我们开始直接为 react-grid-layout 做出贡献以添加我们需要的功能,将这些更改纳入 Kibana 仪表板也会很慢且不可靠。虽然我们曾短暂考虑过制作一个特定于 Kibana 的 react-grid-layout 分支,以便以与我们的发展相匹配的速度发布更新,但维护成本和不灵活性最终导致我们放弃了这个想法。

在研究了替代的布局引擎包后,我们决定最好的前进道路是开发我们自己的内部布局引擎 —— 一个专门为 Kibana Dashboard 用例而构建的引擎!这个新布局引擎(我们称之为 kbn-grid-layout)的开发工作已经开始。据我们所知,这是第一个利用原生 CSS 网格来定位其面板的布局引擎 —— 我们在研究中发现的所有其他布局引擎都依赖于像素级变换或绝对定位。这使得理解面板在仪表板上的放置方式变得容易得多。

kbn-grid-layout 对所有拖动和调整大小事件使用被动事件处理程序,重点是将这些操作期间的重新渲染次数减少到最低限度,以提高性能。由于我们可以控制这些事件处理程序,因此我们可以比以前更加专注于用户体验,并且我们添加了一些功能,例如在屏幕顶部或底部附近拖动时自动滚动,以及在调整大小事件期间锁定网格高度,以防止浏览器在调整大小事件完成之前响应高度变化而导致的意外行为。

我们目前正在完善实施,包括改进可折叠部分的管理、添加用于拖动和调整大小的键盘支持(Kibana 仪表板目前不支持此功能)等等。这个新的布局引擎不仅能够解锁添加可折叠部分的功能,而且在构建时还以可访问性和效率为首要考虑 — 这意味着一旦我们将最终布局引擎从 react-grid-layout 切换到 kbn-grid-layout,整个仪表板体验就会得到改善!

react-grid-layout

<ResponsiveReactGridLayoutcols={{lg: 48,sm: 1,}}layouts={layouts}className={classes}width={viewportWidth}breakpoints={breakpoints}onLayoutChange={onLayoutChangeCallback}isResizable={!expandedPanel && !focusedPanel}isDraggable={!expandedPanel && !focusedPanel}rowHeight={20}margin={useMargins ? [8, 8] : [0, 0]}draggableHandle={'.embPanel--dragHandle'}useCSSTransforms={false}
>{panelComponents}
</ResponsiveReactGridLayout>

kbn-grid-layout

<GridLayoutlayout={currentLayout}gridSettings={{gutterSize: useMargins ? 8 : 0,rowHeight: 20,columnCount: 48,}}renderPanelContents={renderPanelCallback}onLayoutChange={onLayoutChangeCallback}expandedPanelId={expandedPanel}accessMode={accessMode}
/>

在发布之前查看

我们即将走出可嵌入的困境,并准备与所有客户一起享受我们的劳动成果,从每周发布的 Elastic Serverless 到我们的自托管用户。我们的客户将能够设计一个包含许多部分的仪表板,默认情况下可以折叠这些部分,从而允许调查仅加载所需的面板内容,同时保持冗长的仪表板整洁。如果你想向我们提供反馈或注册早期测试,请告诉我们!我们将在未来几个月内宣布此功能何时可供使用。敬请期待!

Elasticsearch 包含许多新功能,可帮助你为你的用例构建最佳搜索解决方案。深入了解我们的示例笔记本以了解更多信息,开始免费云试用,或立即在你的本地机器上试用 Elastic。

原文:Engineering a new Kibana dashboard layout to support collapsible sections & more - Elasticsearch Labs

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

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

相关文章

怎么样把pdf转成图片模式(不能复制文字)

贵但好用的wps&#xff0c; 转换——转为图片型pdf —————————————————————————————————————————— 转换前&#xff1a; 转换后&#xff1a; 肉眼可见&#xff0c;模糊了&#xff0c;且不能复制。 其他免费办法&#xff0c;参考&…

PAT甲级-1023 Have Fun with Numbers

题目 题目大意 一个数乘以2倍后&#xff0c;仍由原来的数字组成&#xff0c;只不过顺序发生变化&#xff0c;就输出Yes&#xff0c;否则输出No。并输出乘以2部后的数。 思路 题目说数字不超过20位&#xff0c;long long最多只能表示19位&#xff0c;93....&#xff0c;超过其…

系统架构设计师教材:信息系统及信息安全

信息系统 信息系统的5个基本功能&#xff1a;输入、存储、处理、输出和控制。信息系统的生命周期分为4个阶段&#xff0c;即产生阶段、开发阶段、运行阶段和消亡阶段。 信息系统建设原则 1. 高层管理人员介入原则&#xff1a;只有高层管理日恩怨才能知道企业究竟需要什么样的…

CNN-BiLSTM卷积双向长短期记忆神经网络时间序列预测(Matlab完整源码和数据)

CNN-BiLSTM卷积双向长短期记忆神经网络时间序列预测&#xff08;Matlab完整源码和数据&#xff09; 目录 CNN-BiLSTM卷积双向长短期记忆神经网络时间序列预测&#xff08;Matlab完整源码和数据&#xff09;预测效果基本介绍 CNN-BiLSTM卷积双向长短期记忆神经网络时间序列预测一…

我谈区域偏心率

偏心率的数学定义 禹晶、肖创柏、廖庆敏《数字图像处理&#xff08;面向新工科的电工电子信息基础课程系列教材&#xff09;》P312 区域的拟合椭圆看这里。 Rafael Gonzalez的二阶中心矩的表达不说人话。 我认为半长轴和半短轴不等于特征值&#xff0c;而是特征值的根号。…

每日进步一点点(网安)

1.1 level5 查看源码关键部分 $str strtolower($_GET["keyword"]); $str2str_replace("<script","<scr_ipt",$str); $str3str_replace("on","o_n",$str2);<input namekeyword value".$str3.">关键…

centos操作系统上以service形式运行blackbox_exporter监控网页端口

文章目录 前言一、blackbox_exporter是什么二、使用步骤1.获取二进制文件2.准备部署脚本3.执行命令&#xff0c;进行部署4.prometheus中增加需要监控页面的job信息 三、查看部署结果四、配置到grafana中总结 前言 记录一下centos操作系统上以简单的service形式运行blackbox_ex…

【阅读笔记】基于图像灰度梯度最大值累加的清晰度评价算子

本文介绍的是一种新的清晰度评价算子&#xff0c;基于图像灰度梯度最大值累加 一、概述 目前在数字图像清晰度评价函数中常用的评价函数包括三类&#xff1a;灰度梯度评价函数、频域函数和统计学函数&#xff0c;其中灰度梯度评价函数具有计算简单&#xff0c;评价效果好等优…

数据库设计

七、存储管理 1、存储介质 存储层次 存储分类 访问速度分类&#xff1a;主存储器、二级存储器、三级存储器操作分类&#xff1a;读操作、写操作联机分类&#xff1a;联机、脱机访问方式分类&#xff1a;随机访问、顺序访问读写单位分类&#xff1a;字节、块 存储介质分类 易…

到华为考场考HCIE的注意事项和考试流程

大家好&#xff0c;我是张同学&#xff0c;来自成都职业技术学院2021级计算机网络专业。最近成功通过了 Datacom HCIE 考试&#xff0c;在这里和大家分享一下我的经验。 考证契机 在母校的培养下&#xff0c;我接触到ICT这个行业&#xff0c;打好了基础&#xff0c;开始了成…

海外问卷调查如何影响企业的经营?在品牌建设中有何指导意义?

市场调查的定义&#xff1a;通过科学的方法&#xff0c;有目的地、系统地搜集整理一些市场信息&#xff0c;其目的在于了解当下市场现状和发展前景&#xff0c;为企业生产和品牌打造提供一些科学的指导意见&#xff0c;这是任何大企业、中小企业、初创企业都必须重视的一个重要…

hedfs和hive数据迁移后校验脚本

先谈论校验方法&#xff0c;本人腾讯云大数据工程师。 1、hdfs的校验 这个通常就是distcp校验&#xff0c;hdfs通过distcp迁移到另一个集群&#xff0c;怎么校验你的对不对。 有人会说&#xff0c;默认会有校验CRC校验。我们关闭了&#xff0c;为什么关闭&#xff1f;全量迁…

Unity3D仿星露谷物语开发25之创建时钟界面

1、目标 在时钟界面显示当前时钟信息&#xff0c;同时设置特殊按钮可以快速推进时间用于测试。 2、创建GameClock.cs脚本 在Assets -> Scripts -> TimeSystem目录下创建GameClock.cs脚本。 代码如下&#xff1a; using System.Collections; using System.Collections…

使用Vue3实现可拖拽的九点导航面板

开篇 本文使用Vue3实现了一个可拖拽的九宫导航面板。这个面板在我这里的应用场景是我个人网站的首页的位置&#xff0c;九宫导航对应的是用户最后使用或者最多使用的九个功能&#xff0c;正常应该是由后端接口返回的&#xff0c;不过这里为了简化&#xff0c;写的是固定的数组数…

小利特惠源码/生活缴费/电话费/油卡燃气/等充值业务类源码附带承兑系统

全新首发小利特惠/生活缴费/电话费/油卡燃气/等充值业务类源码附带U商承兑系统 安装教程如下 图片:

FlinkSql使用中rank/dense_rank函数报错空指针

问题描述 在flink1.16(甚至以前的版本)中&#xff0c;使用rank()或者dense_rank()进行排序时&#xff0c;某些场景会导致报错空指针NPE(NullPointerError) 报错内容如下 该报错没有行号/错误位置&#xff0c;无法排查 现状 目前已经确认为bug&#xff0c;根据github上的PR日…

C语言精粹:深入探索字符串函数

大家好&#xff0c;这里是小编的博客频道 小编的博客&#xff1a;就爱学编程 很高兴在CSDN这个大家庭与大家相识&#xff0c;希望能在这里与大家共同进步&#xff0c;共同收获更好的自己&#xff01;&#xff01;&#xff01; 本文目录 引言正文&#xff08;1&#xff09;常见字…

微信阅读网站小程序的设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

RabbitMQ 死信队列

文章目录 前言1、死信交换机 DLX 与死信队列 DLQ2、死信队列的实现2.1、声明原队列信息2.2、声明死信队列信息2.3、完整示例 3、死信消息流转原理 前言 消息过期以后&#xff0c;如果没有任何配置&#xff0c;是会直接丢弃的。我们可以通过配置让这样的消息变成死信&#xff0…

《边界感知的分而治之方法:基于扩散模型的无监督阴影去除解决方案》学习笔记

paper&#xff1a;Boundary-Aware Divide and Conquer: A Diffusion-Based Solution for Unsupervised Shadow Removal 目录 摘要 1、介绍 2、相关工作 2.1 阴影去除 2.2 去噪扩散概率模型&#xff08;Denoising Diffusion Probabilistic Models, DDPM&#xff09; 3、方…