首页
/ VMware Tanzu Labs Educates 培训平台本地开发环境搭建指南

VMware Tanzu Labs Educates 培训平台本地开发环境搭建指南

2025-06-19 11:03:08作者:伍希望

前言

VMware Tanzu Labs Educates 培训平台是一个功能强大的Kubernetes教学平台,专为技术培训和教育场景设计。本文将详细介绍如何在本地环境中搭建Educates开发环境,帮助开发者高效地进行培训内容开发。

本地环境概述

Educates提供了一个命令行工具,可以快速在本地创建基于Kind的Kubernetes集群,并部署完整的Educates平台。这个本地环境包含以下核心组件:

  1. 基于Kind的轻量级Kubernetes集群
  2. Educates平台核心服务
  3. 本地镜像仓库(用于存储培训内容和自定义基础镜像)
  4. 可选的本地DNS解析器
  5. 可选的镜像镜像服务

基础环境搭建

创建本地集群

使用以下命令创建本地Kubernetes集群并部署Educates:

educates create-cluster

这个命令会执行以下操作:

  1. 使用Kind创建本地Kubernetes集群
  2. 部署Educates平台组件
  3. 创建本地镜像仓库
  4. 配置默认的nip.io域名访问

删除本地集群

当开发工作完成后,可以使用以下命令删除集群:

educates delete-cluster

如果需要完全清理所有资源(包括本地镜像仓库和DNS解析器),可以添加--all参数:

educates delete-cluster --all

本地镜像仓库管理

Educates本地环境包含一个专用的镜像仓库,用于存储培训内容和自定义镜像。

镜像仓库基本使用

  • 推送镜像到本地仓库时,使用localhost:5001作为仓库地址
  • 在Kubernetes集群内部,可以使用registry.default.svc.cluster.local访问仓库
  • 在培训定义中,推荐使用$(image_repository)变量引用仓库地址

镜像仓库维护

清理未引用的镜像层以释放空间:

educates local registry prune

重新部署镜像仓库:

educates local registry deploy

删除镜像仓库:

educates local registry delete

自定义配置

配置管理

Educates支持通过YAML文件进行自定义配置:

编辑全局默认配置:

educates local config edit

查看当前配置:

educates local config view

自定义域名配置

默认使用nip.io域名存在以下限制:

  • 无法获取官方信任的TLS证书
  • 某些需要安全入口的功能无法使用

建议使用自定义域名并配置TLS证书:

educates create-cluster --domain your-domain.test

或在配置文件中指定:

clusterIngress:
  domain: your-domain.test

TLS证书配置

添加TLS证书

对于使用Let's Encrypt生成的证书:

educates local secrets add tls your-domain-tls \
 --cert /path/to/fullchain.pem \
 --key /path/to/privkey.pem \
 --domain your-domain.test

对于自签名CA证书:

educates local secrets add ca your-domain-ca \
 --cert /path/to/rootCA.pem \
 --domain your-domain.test

本地DNS解析器

在macOS上部署本地DNS解析器:

educates local resolver deploy

创建resolver配置文件:

sudo mkdir /etc/resolver
sudo sh -c "cat > /etc/resolver/your-domain.test << EOF
nameserver 127.0.0.1
EOF"

测试DNS解析:

scutil --dns www.your-domain.test

删除DNS解析器:

educates local resolver delete

镜像镜像服务

镜像镜像服务可以缓存远程仓库的镜像,提高拉取速度并减少带宽消耗。

配置镜像镜像

在集群配置中添加:

localKindCluster:
  registryMirrors:
    - mirror: docker.io
      url: registry-1.docker.io

管理镜像镜像

部署镜像镜像:

educates local mirror deploy docker.io --url registry-1.docker.io

删除镜像镜像:

educates local mirror delete docker.io

最佳实践建议

  1. 对于长期开发环境,建议使用自定义域名而非nip.io
  2. 为生产环境准备时,应使用可信CA签发的证书
  3. 定期清理镜像仓库以释放磁盘空间
  4. 对于常用基础镜像,配置镜像镜像服务提高效率
  5. 在团队开发中,统一配置管理可以保证环境一致性

常见问题排查

  1. DNS解析失败:检查/etc/resolver配置和本地解析器服务状态
  2. 证书信任问题:确保CA证书已正确添加到系统和Educates配置
  3. 镜像拉取失败:验证镜像镜像服务配置和网络连接
  4. 资源不足:Kind集群默认配置较低,可根据需要调整资源分配

通过本文介绍的配置方法,开发者可以快速搭建功能完善的Educates本地开发环境,高效地进行培训内容开发和测试。

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

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
144
1.92 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
274
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
930
553
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
422
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
65
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