我们从制作测试用镜像开始,后续一步一步实现在k8s中使pod根据cpu用量自动扩展pod个数。
知识准备
在做这个示例之前,需要了解k8s(也叫kubernetes)基本原理,了解k8s是用来干嘛的即可,以及deployment、service、hpa、镜像、docker等概念。不然会有些晕的,不知道这些配置和这些操作是用来做什么的。
制作镜像并上传到github仓库(ghcr.io)
准备镜像
测试用的代码在
https://download.csdn.net/download/weilaozongge/89398031
-
把代码下载下来,安装好docker环境
执行代码包中的 docker_build.sh,会在本地创建好镜像,后续会使用这个镜像来做测试。
执行 docker images可以查看是否成功生成镜像。 -
给生成的镜像打个tag
docker tag tools_cpu_burner_by_api:latest ghcr.io/wang-xuewen/tools_cpu_burner_by_api_image:latest
上传到github仓库
- 创建并登录到你的 GitHub 账户。
- 进入 Personal Access Tokens 页面。
- 点击 “Generate new token”。
- 在 “Select scopes” 部分,选中
write:packages
,read:packages
, 和delete:packages
。 - 生成并保存你的 Token。
- 回到本地docker环境,登录到ghcr
docker login ghcr.io -u <your-github-username> -p <your-personal-access-token>
比如:docker login ghcr.io -u wang-xuewen -p ghp_tqALE31LARQNTWSBDIBLoNM1BgBpPxxxxxx
- 推送镜像
docker push ghcr.io/your-github-username/your-image:tag
比如:docker push ghcr.io/wang-xuewen/tools_cpu_burner_by_api_image:latest
如果成功,会在https://github.com/wang-xuewen?tab=packages 页面中看到推送上来的镜像。
安装k8s (既kubernetes)
本地k8s安装教程参考这里:
https://blog.csdn.net/weilaozongge/article/details/138954175?spm=1001.2014.3001.5502
https://blog.csdn.net/weilaozongge/article/details/139267389?spm=1001.2014.3001.5502
注意:安装好k8s之后必须安装metrics。k8s通过metrics才能感知cpu使用量,然后扩展pod个数。
创建 Deployment
Deployment是一种资源对象,用于管理Pods的部署和更新
生成secret
在创建deployment之前,需要创建secret,以便 depolyment通过认证后可以从github镜像仓库中拉取镜像。
举例:
kubectl create secret docker-registry ghcr-secret \
--docker-server=ghcr.io \
--docker-username=wang-xuewen \
--docker-password=ghp_9xLt7VnnmC2CoYOfYJvvHsVC1Fcsxxxxxxx \
[email protected]
其中password是前面生成的Token
创建 deployment
在 Kubernetes 中,可以使用
标签:xuewen,示例,ghcr,io,镜像,Pod,k8s,docker From: https://blog.csdn.net/weilaozongge/article/details/139630306