Helm适配华为云&OBS心得
前一阵,在网上闲逛时,偶然发现华为云发布一些列的对接华为云的任务(https://developer.huaweicloud.cn/programs/opensource/contributing/)。在任务中,我找了一个比较简单的任务入手。那就是Helm适配OBS开源验证任务。
1 任务流程
1.1 任务的目的
本任务的主要目的是让Helm支持华为云OBS服务,chart(chart就是一个描述Kubernetes相关资源的文件集合)存储到华为云OBS上,拓展OBS服务的影响力。方便Helm的用户使用华为云服务时能够顺利对接OBS服务。
1.2 报名流程
- 在喜欢的任务上进行报名,填写自己的申请,留下自己的邮箱,之后华为官方会发送任务计划书到邮箱内。
- 开通开发者空间,进行实名认证,加入沃土云创计划个人方向。
- 进入激励管理》开源共创,进入任务,此时在需求分析节点,提交之前发送到邮箱内的任务计划书。
- 提交任务计划书之后,审批后进入开发阶段,阅读任务计划书,了解需要开发的内容。
- 此时需要申领服务器,主要是Gaussdb,华为云CCE(类似k8s),CodeArts(ci/cd)。
- 开发完整之后,在CCE上进行验证,在CodeArts上进行部署。
- 测试完成后,可以申请任务验收。将自己的代码分支博文等信息打包成zip文件进行上传。
- 后面就是等发钱啦。
1.3 开发代码
不涉及
1.4 上云第一步-购买OBS
- 在华为云官网,点击产品,选择对象存储服务OBS,点击购买
- 选择以下选项,进行提交
区域:广州(选离自己最近的城市)
资源包类型:标准存储多AZ包
规格:按照自己需要的大小(我选的是40G)
1.5 上云第二步-购买CCE
在华为云官网,点击产品,输入cce,选择cce,点击购买。
- 执行以下步骤,进行提交
页面顶部控制栏,选择地区,也就是上云第一步购买Gaussdb的地区
集群类型:cce turbo
计费模式:按需付费
集群名称:(随便写)
集群版本:v1.29
集群规模:50
集群 master 实例数:单实例
虚拟私有云:默认(购买Gaussdb使用的虚拟私有云,必须保持一致,否则访问数据库不通)
容器子网(Pod CIDR):默认(购买Gaussdb使用的虚拟子网,必须保持一致,否则访问数据库不通)
其他默认,点击提交。进入插件选择页面。
保持默认插件,点击插件配置,点击确认配置,点击提交。
1.6 新建节点
在左侧找到节点池,新建节点。注意这里使用的cpu,内存等都需要更大一点,否则cce的集群会启动失败
1.7 配置CodeArts
不涉及
2 验收材料
1. 开源软件fork地址:不涉及
2. 开源软件修改记录(可以有多个修改记录):
不涉及
3. 推送上游社区PR(包括代码、文档、可以有多个):
不涉及
4. 验证DEMO地址:
不涉及
5. 验证DEMO修改记录(可以有多个修改记录,只包含和本任务验证强相关的提交记录,比如添加依赖、增加配置文件、演示开源软件功能使用的代码等):
不涉及
6. 博客地址:https://bbs.huaweicloud.cn/blogs/440762
3 资源清单
3.1 CCE
产品名称 |
集群类型 |
集群版本 |
集群规模 |
云容器引擎CCE |
Turbo集群 |
V1.29 |
50 |
3.2 ECS
产品名称 |
CPU架构 |
实例类型 |
公共镜像 |
镜像版本 |
弹性云服务器 |
鲲鹏计算 |
鲲鹏通用计算增强型 |
Huawei Cloud EulerOS |
Huawei Cloud EulerOS 2.0标准版 64位 ARM版(10GiB) |
3.3 OBS
产品名称 |
资源包类型 |
桶类别 |
对象存储服务OBS |
存储包 |
标准存储多AZ包 |
4 测试结果
4.1 验证思路
使用https://gitcode.com/HuaweiCloudDeveloper/OpenSourceForHuaweiWiki/issues/26
中方案一:通过 S3 兼容 API 验证方案是指利用 OBS 提供的 S3 兼容 API 进行交互。
编写chart yaml后制作成chart推送到OBS,从OBS拉取下来chart上传到CCE的应用模板进行部署。
4.2 安装helm-s3插件
helm plugin install https://github.com/hypnoglow/helm-s3.git
4.3 设置环境变量
export AWS_ACCESS_KEY_ID=xxx
export AWS_SECRET_ACCESS_KEY=xxx
export AWS_DEFAULT_REGION=cn-south-1
export AWS_ENDPOINT="obs.cn-south-1.myhuaweicloud.com"
export AWS_DISABLE_SSL=true
4.4 创建新的存储库
helm s3 init s3://minio-4dc9/charts
4.5 按名称使用此仓库
helm repo add mynewrepo s3://minio-4dc9/charts
4.6 编写zookeeper、edge-service、admin-service、admin-website、authentication-server、resource-server的chart yaml
Chart地址:https://gitcode.com/moseszane168/open-source-for-huawei-demo-chart/overview
4.7 打包和发布
helm package ./admin-service
helm package ./admin-website
helm package ./authentication-server
helm package ./edge-service
helm package ./resource-server
helm package ./zookeeper-test
4.8 推送chart到OBS
helm s3 push ./admin-service-0.1.0.tgz mynewrepo
helm s3 push ./admin-website-0.1.0.tgz mynewrepo
helm s3 push ./authentication-server-0.1.0.tgz mynewrepo
helm s3 push ./edge-service-0.1.0.tgz mynewrepo
helm s3 push ./resource-server-0.1.0.tgz mynewrepo
helm s3 push ./zookeeper-test-0.1.0.tgz mynewrepo
4.9 从OBS拉取chart
helm pull s3://minio-4dc9/charts/admin-service-0.1.0.tgz
helm pull s3://minio-4dc9/charts/admin-website-0.1.0.tgz
helm pull s3://minio-4dc9/charts/authentication-server-0.1.0.tgz
helm pull s3://minio-4dc9/charts/edge-service-0.1.0.tgz
helm pull s3://minio-4dc9/charts/resource-server-0.1.0.tgz
helm pull s3://minio-4dc9/charts/zookeeper-test-0.1.0.tgz
4.10 将chart包上传到CCE应用模板安装
- 点赞
- 收藏
- 关注作者
评论(0)