Eclipse Che Dashboard 支持基于 CR 属性的 Airgap 模式样本管理
背景与需求分析
在现代云原生开发环境中,Eclipse Che 作为一个开源的云 IDE 平台,其 Dashboard 组件承担着用户交互的重要角色。在实际企业部署场景中,由于安全合规或网络隔离要求,经常需要支持"airgap"(空气隔离)模式,即在完全离线或受限网络环境中运行。
本文探讨了如何扩展 Eclipse Che Dashboard 功能,使其能够基于自定义资源(CR)属性来管理并提供 airgap 模式下的样本(samples)资源。这一功能对于企业级部署尤为重要,特别是在金融、政府等对网络安全有严格要求的行业。
技术实现方案
样本定义与存储
Dashboard 将通过一个特定格式的 JSON 文件来定义 airgap 模式下支持的样本列表。这个文件将被命名为 .airgap-samples.json 或类似名称,存储在代码仓库中。每个样本条目包含以下关键信息:
- displayName:样本显示名称
- description:详细描述
- tags:分类标签
- url:原始资源位置
- icon:可选的图标信息(支持 base64 编码)
{
"displayName": "JBoss EAP 8",
"description": "Java stack with EAP 8, OpenJDK 17 and Maven 3.9",
"tags": ["jboss", "eap"],
"url": "https://github.com/jbossas/eap-devfile-examples/tree/eap-8.0.x"
}
构建时处理
在 Dashboard 的构建过程中,系统将:
- 解析
.airgap-samples.json文件 - 下载并预处理所有定义的样本资源
- 将这些资源打包为可部署的格式
- 确保它们在运行时可以高效地被访问
这种构建时处理的方式确保了部署包的自包含性,满足 airgap 环境的要求。
运行时配置
关于如何在 CR (Custom Resource) 中配置 airgap 模式,社区提出了两种主要方案:
- Dashboard 级别配置
dashboard:
airgap: true
branding:
deployment:
containers:
- Devfile Registry 级别配置
devfileRegistry:
airgap: true
disableInternalRegistry: true
externalDevfileRegistries:
- url: 'https://registry.devfile.io/'
经过技术评估,推荐采用 Dashboard 级别的配置方案,原因如下:
- 随着
che-devfile-registry的逐步弃用,相关配置已趋于简化 - Dashboard 作为用户交互入口,更直接管理样本展示逻辑
- 配置语义更加清晰,便于运维理解
技术实现细节
样本服务机制
在运行时,Dashboard 将:
- 检查 CR 中的 airgap 配置标志
- 根据标志决定是否启用内置样本服务
- 从预打包的资源中提供样本内容
- 确保与常规模式的用户体验一致
缓存与更新策略
考虑到 airgap 环境的特殊性,系统实现了高效的缓存机制:
- 样本资源在构建时静态打包
- 支持通过配置更新触发重新构建
- 提供版本控制机制确保一致性
企业级考量
这一功能的实现特别考虑了企业级部署的需求:
- 安全性:所有样本资源经过预审查和验证
- 可审计性:提供样本来源和版本的完整追踪
- 性能:优化资源打包格式,减少运行时开销
- 兼容性:确保与现有配置和工作流无缝集成
未来演进方向
随着云原生技术的不断发展,这一功能可能会进一步扩展:
- 支持动态样本更新机制
- 增强样本的元数据管理
- 提供更细粒度的访问控制
- 集成更丰富的样本验证机制
总结
Eclipse Che Dashboard 对 airgap 模式样本的支持,为企业用户提供了在受限网络环境中使用云 IDE 的完整解决方案。通过构建时预处理和灵活的运行时配置,这一功能在保证安全性的同时,也兼顾了用户体验的一致性。随着功能的不断演进,它将成为 Eclipse Che 在企业级市场的重要竞争力之一。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust099- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
MiMo-V2.5-ProMiMo-V2.5-Pro作为旗舰模型,擅⻓处理复杂Agent任务,单次任务可完成近千次⼯具调⽤与⼗余轮上 下⽂压缩。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
Kimi-K2.6Kimi K2.6 是一款开源的原生多模态智能体模型,在长程编码、编码驱动设计、主动自主执行以及群体任务编排等实用能力方面实现了显著提升。Python00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00