首页
/ VMware Tanzu Educates 培训平台迁移指南:从 Learning Center 到 Educates 2.X

VMware Tanzu Educates 培训平台迁移指南:从 Learning Center 到 Educates 2.X

2025-06-19 07:06:26作者:卓炯娓

平台演进背景

VMware Tanzu Educates 培训平台是一个基于 Kubernetes 的交互式学习环境解决方案。在技术演进过程中,平台经历了从 Educates 1.X 分支到 Learning Center,再到当前 Educates 2.X 版本的发展路径。本文将详细介绍从 Learning Center 迁移到 Educates 2.X 版本时需要注意的关键变更点。

核心架构变更

1. API 组与资源定义变更

最显著的架构变化体现在 Kubernetes 自定义资源的 API 组定义上:

Learning Center 定义方式

apiVersion: learningcenter.tanzu.vmware.com/v1beta1
kind: Workshop

Educates 2.X 新规范

apiVersion: training.educates.dev/v1beta1
kind: Workshop

对应的资源类别别名也从 learningcenter/learningcenter-training 变更为 educates/educates-training。查询资源时需要使用新命令:

kubectl get educates

2. 工作坊基础镜像配置

镜像配置位置发生了重要调整:

旧版配置

spec:
  content:
    image: registry.example.com/org/image:tag

新版规范

spec:
  workshop:
    image: registry.example.com/org/image:tag

Educates 提供了更丰富的预置基础镜像选择:

  • base-environment:* - 基础环境镜像
  • jdk{8,11,17,21}-environment:* - 各版本JDK环境
  • conda-environment:* - Conda数据科学环境

注意:原有 Learning Center 的定制镜像需要基于 Educates 的基础镜像重新构建。

内容分发机制升级

3. 工作坊内容获取方式

内容获取机制从简单配置升级为基于 vendir 的声明式配置:

GitHub 内容源新配置

spec:
  workshop:
    files:
    - git:
        url: https://github.com/org/repo
        ref: origin/main
      includePaths:
      - /workshop/**
      - /exercises/**

HTTP 归档文件新配置

spec:
  workshop:
    files:
    - http:
        url: https://example.com/workshop.tgz

OCI 镜像新配置

spec:
  workshop:
    files:
    - image:
        url: $(image_repository)/workshop-files:latest

新机制提供了更精细的内容过滤控制,通过 includePathsexcludePaths 替代原有的 .eduk8signore 文件。

安全策略改进

4. 安全策略命名规范

安全策略名称遵循了 Kubernetes 最新的 Pod 安全标准:

Learning Center Educates 2.X
nonroot restricted
anyuid baseline
custom privileged

配置位置变更

spec:
  session:
    namespaces:
      security:
        policy: baseline

5. 资源配额调整

内存限制范围进行了优化调整:

新版默认值

| Budget    | Min  | Max  | Request | Limit |
|-----------|------|------|---------|-------|
| small     | 1M   | 1Gi  | 128Mi   | 256Mi |
| medium    | 1M   | 2Gi  | 128Mi   | 512Mi |
...

主要变化是将最小内存从 32Mi 调整为 1M,并统一了大型工作坊的内存限制为 512Mi。

网络与入口变更

6. Ingress 主机名规则

入口主机名生成规则从后缀式改为前缀式:

旧规则

$(session_namespace)-app.$(ingress_domain)

新规范

app-$(session_name).$(ingress_domain)

同时强化了安全策略,要求所有入口必须包含会话名称,防止跨工作坊干扰。

开发体验优化

7. 编辑器扩展管理

Educates 2.X 不再预装任何 VS Code 扩展,改为按需安装。可以通过工作坊的 setup.d 脚本安装:

#!/bin/bash
code-server --install-extension redhat.java@1.3.0
code-server --install-extension vscjava.vscode-java-debug@0.38.0

注意:编辑器路径已标准化为 /opt/editor/bin/code-server

8. 内容渲染引擎

逐步淘汰原有的"经典"渲染器,转向基于 Hugo 的现代渲染系统。建议新工作坊采用 Hugo 格式编写教学内容。

配置管理变更

9. 门户默认设置

门户默认值配置位置调整:

新版规范

spec:
  portal:
    workshop:
      defaults:
        capacity: 6
        reserved: 2
        initial: 4

10. 环境变量管理

推荐使用 setup.d 脚本配合 .env 文件替代原有的 profile.d 机制:

#!/bin/bash
echo "MY_VAR=value" >> $WORKSHOP_ENV

迁移实施建议

  1. 分阶段迁移:先测试关键工作坊,再逐步推广
  2. 镜像重建:所有定制镜像需基于 Educates 基础镜像重建
  3. 安全评审:检查安全策略是否符合新规范
  4. 性能测试:验证资源配额是否满足需求
  5. 用户培训:介绍新特性的使用方式

通过系统性地应用这些变更,您可以顺利将工作坊从 Learning Center 迁移到功能更强大、安全性更高的 Educates 2.X 平台。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
143
1.91 K
kernelkernel
deepin linux kernel
C
22
6
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
273
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
927
551
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
421
392
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
189
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
75
64
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
344
1.3 K
easy-eseasy-es
Elasticsearch 国内Top1 elasticsearch搜索引擎框架es ORM框架,索引全自动智能托管,如丝般顺滑,与Mybatis-plus一致的API,屏蔽语言差异,开发者只需要会MySQL语法即可完成对Es的相关操作,零额外学习成本.底层采用RestHighLevelClient,兼具低码,易用,易拓展等特性,支持es独有的高亮,权重,分词,Geo,嵌套,父子类型等功能...
Java
36
8