当前位置: 首页 > news >正文

【成神之路】Ambari实战-050-UI-如何通过配置修改ambari样式

在Ambari中,通过自定义UI控件(Widget),你可以灵活调整配置项的展现形式,使其更符合实际需求。这篇文章将详细介绍各种控件的使用,并提供代码示例和实际应用场景,帮助你成为UI配置的行家!💻✨

在这里插入图片描述

1. 配置说明

1.1 Ambari 配置中的 Widget 和 Metadata 结构

WidgetMetadata Used (元数据使用)解释 (Explanation)
Slider(滑块)<value-attributes>
<type>int</type>
<minimum>1073741824</minimum>
<maximum>17179869184</maximum>
<unit>B</unit>
<increment-step>1073741824</increment-step>
</value-attributes>
滑块控件用于调整数值范围,适合设置内存或磁盘大小等配置项。用户可以通过滑动条来选择一个范围,比如1GB到16GB。🎚️
Combo(下拉菜单)<value-attributes>
<type>value-list</type>
<entries>
<entry><value>2</value></entry>
<entry><value>4</value></entry>
<entry><value>8</value></entry>
</entries>
<selection-cardinality>1</selection-cardinality>
</value-attributes>
下拉菜单适合选择固定选项的配置,比如从多个调度器中选择一个。⬇️
List(列表)<value-attributes>
<type>value-list</type>
<entries>
<entry><value>2</value></entry>
<entry><value>4</value></entry>
<entry><value>8</value></entry>
</entries>
<selection-cardinality>2+</selection-cardinality>
</value-attributes>
列表控件允许用户选择多个值,适合配置多个路径或选项的场景,比如磁盘路径的选择。📋
Time Interval Spinner(时间间隔选择器)<value-attributes>
<type>int</type>
<minimum>0</minimum>
<maximum>2592000000</maximum>
<unit>milliseconds</unit>
</value-attributes>
时间选择器用于设置时间间隔,支持从毫秒到天的配置。⏳
Toggle, Checkbox(切换按钮、复选框)<value-attributes>
<type>value-list</type>
<entries>
<entry>
<value>true</value>
<label>Enabled</label>
</entry>
<entry>
<value>false</value>
<label>Disabled</label>
</entry>
</entries>
<selection-cardinality>1</selection-cardinality>
</value-attributes>
适合启用或禁用某项功能的场景,例如开关某个服务。🔘
Directory, Directories, Password, Text Field, Text Area无需特定的 <value-attributes> 元素。
用户直接输入路径、密码或其他文本内容。
这些控件适用于需要手动输入的场景,例如目录路径、密码或大段文本。📂🔑
Radio-Buttons(单选按钮)<value-attributes>
<type>value-list</type>
<entries>
<entry><value>1</value><label>Option 1</label></entry>
<entry><value>2</value><label>Option 2</label></entry>
</entries>
<selection-cardinality>1</selection-cardinality>
</value-attributes>
单选按钮用于让用户在多个选项中选择一个,适合互斥选项的配置场景。🔘

2. HBase为例,配置的UI控件详细解析

2.1 Slider(滑块)

适用于数值范围的配置

应用场景
滑块(Slider)控件非常适合那些需要调整数值的配置,用户可以通过滑动来选择值,例如内存大小、文件大小或超时时间等。滑动条让数值调节变得简单直观。

在这里插入图片描述

  • 配置项:HBase Master Maximum Memory

    • 配置文件: hbase-env.xml
    • 描述: 该配置用于设置 HBase Master 进程的最大堆内存,默认值为 4096MB。Master 进程是 HBase 中的管理节点,负责管理 RegionServer 及集群的健康状态。适合用滑块来方便地调整内存大小。
    <property><name>hbase_master_heapsize</name><value>4096</value><description>Maximum amount of memory each HBase Master can use.</description><display-name>HBase Master Maximum Memory</display-name><value-attributes><type>int</type><minimum>0</minimum><maximum>16384</maximum><unit>MB</unit><increment-step>256</increment-step></value-attributes><on-ambari-upgrade add="false"/>
    </property>
    
    • UI展现: 🎚️ 滑块可让用户在 0 到 16GB 范围内调整 HBase Master 的最大内存大小,用户可以通过拖动滑块来分配更多或更少的内存资源,适用于集群扩展时。

⬇️⬇️⬇️查看全部内容⬇️⬇️⬇️


更多详细内容请关注我们的微信公众号:发送"文章"关键字获取

或加入QQ1群,了解版本动向,解答大数据问题。


⬆️⬆️⬆️查看全部内容⬆️⬆️⬆️

2.7 Radio-Buttons(单选按钮)

适用于互斥的配置选项

应用场景
Radio-Buttons(单选按钮) 控件适用于那些互斥的配置选项,用户只能从多个选项中选择一个。这种控件用于模式选择、日志级别等,确保用户只能选择一个值,且每个选项都有对应的说明标签。

注意首先根据官方文档配置,entry 个数 > 3 , 有label ,单选才会触发 radiobox 。但是目前页面上没看到,不知道是不是卡bug了

注意首先根据官方文档配置,entry 个数 > 3 , 有label ,单选才会触发 radiobox 。但是目前页面上没看到,不知道是不是卡bug了

注意首先根据官方文档配置,entry 个数 > 3 , 有label ,单选才会触发 radiobox 。但是目前页面上没看到,不知道是不是卡bug了

在这里插入图片描述

  • 配置项:Hive Log Level

    • 配置文件: hive-env.xml
    • 描述: 用户可以通过此单选按钮选择 Hive 的日志级别(INFODEBUGWARNERROR)。该配置控制 Hive 的日志输出级别,用户可以根据需求选择合适的级别。
    <property><name>hive.log.level</name><description>Hive Log level to control log4j - Options are INFO, DEBUG, WARN, ERROR</description><value>INFO</value><display-name>Hive Log Level</display-name><value-attributes><type>value-list</type><entries><entry><value>INFO</value><label>INFO (Recommended)</label></entry><entry><value>DEBUG</value><label>DEBUG (Most Verbose)</label></entry><entry><value>WARN</value><label>WARN</label></entry><entry><value>ERROR</value><label>ERROR (Least Verbose)</label></entry></entries><selection-cardinality>1</selection-cardinality></value-attributes><on-ambari-upgrade add="false"/>
    </property>
    
    • UI展现: 🔘 用户可以通过单选按钮选择日志输出级别,INFO 为推荐选项,DEBUG 输出最详细的日志,WARNERROR 适合过滤不必要的信息,保证系统运行日志的简洁性。

3. 控件样式的区别(基于 value-attributes 关键字段)

条件页面样式解释示例配置
entries 个数 <= 2 且 无 labelToggle 切换开关entries 少于等于 2 且没有 label 时,页面会显示为切换开关,用于简单启用/禁用功能。hbase.security.authorization
entries 个数 <= 2 且 带有 labelToggle 切换开关尽管带有 label,但因为选项少于等于 2,依旧会显示为切换开关。hbase.security.authentication
entries 个数 > 2 且 带有 labelRadio-Buttons(单选按钮)entries 大于 2 且每个选项带有 label 时,显示为单选按钮,用户只能选择一个选项。hive.log.level
entries 个数 > 2 且 无 labelCombo(下拉菜单)如果选项超过 2 且没有 label,页面会显示为下拉菜单,用户可以从中选择一个选项。hbase.security.authentication
selection-cardinality > 1 且 无 labelList(列表)selection-cardinality 大于 1 且没有 label 时,页面会显示为列表,用户可以选择多个选项。hbase.coprocessor.region.classes
type=directoryDirectory(目录选择器)typedirectory 时,页面展示为单个目录路径输入框。hbase.tmp.dir
type=directoriesDirectories(多目录选择器)typedirectories 时,页面展示为多个目录路径输入框,用户可以输入多个路径。yarn.nodemanager.log-dirs
type=passwordPassword(密码输入框)typepassword 时,输入的内容会被隐藏,适用于输入密码。javax.jdo.option.ConnectionPassword
type=textText Field(单行文本框)typetext 时,页面展示为单行文本输入框,适用于输入简短的字符串内容。hbase.master.info.bindAddress
type=contentText Area(多行文本区域)typecontent 时,页面展示为多行文本输入框,通常用于输入长文本或脚本内容。hbase-env.sh

关键字段解释

  1. entries 的个数

    • 如果 entries 的个数少于等于 2,并且没有 label,页面会显示为 Toggle 切换开关
    • 如果 entries 的个数大于 2 并且带有 label,页面会显示为 Radio-Buttons(单选按钮)
  2. 是否有 label 标签

    • 如果 entries 包含 label,表示每个选项有说明文字。对于 Radio-Buttons 控件来说,label 是必需的。
    • 如果没有 label,则视为没有选项说明。通常在下拉菜单或列表中不需要 label
  3. selection-cardinality 的值

    • selection-cardinality 的值大于 1 时,表示用户可以选择多个选项,页面通常会显示为 List(列表) 控件。
    • 如果 selection-cardinality 的值为 1,页面会显示为单选控件(ComboRadio-Buttons)。
  4. type 的值

    • typedirectory 时,页面显示为 Directory(目录选择器)
    • typedirectories 时,页面显示为 Directories(多目录选择器)
    • typepassword 时,输入的字符会被隐藏,页面显示为 Password(密码输入框)
    • typetext 时,页面显示为 Text Field(单行文本框)
    • typecontent 时,页面显示为 Text Area(多行文本区域)

http://www.mrgr.cn/news/45932.html

相关文章:

  • Docker镜像命令汇总笔记
  • python 实现Edmonds-Karp算法
  • 1.9 电子商城测试分析
  • 基于Python的自然语言处理系列(28):spaCy基础介绍
  • Apache Flume 启动报错及解决方法
  • Linux: debug: perf: report: --sort
  • 《系统架构设计师教程(第2版)》第17章-通信系统架构设计理论与实践-06-网络构建和设计方法
  • 应用UX体验标准
  • 一个适用于 ASP.NET Core 的轻量级插件框架
  • Spring 循环依赖
  • 数学建模算法与应用 第3章 非线性规划及其求解方法
  • MySQL的索引
  • 基于Springboot+Vue的公寓出租系统 (含源码数据库)
  • 缓存穿透 - 生成缓存的过程耗费大量时间和资源
  • SpringBoot开发——SpringSecurity安全框架17个业务场景案例(三)
  • 全网首发Windows Server 2019 AD 域控降级与退域的全面指南
  • ICM20948 DMP代码详解(70)
  • 通过GIS数据对比北京西城区和鹤岗工农区,数据解释为啥房价差异那么大
  • ORA-19815 db_recovery_file_dest_size 100%
  • html内嵌其他网页iframe