From 5bee32caa90942d8919cbf0d2f942195c27b3a9d Mon Sep 17 00:00:00 2001 From: hyp4293 <429302517@qq.com> Date: Wed, 12 Jun 2024 23:43:44 +0800 Subject: [PATCH] KubeEdge Image PrePull Feature Guide Document Signed-off-by: hyp4293 <429302517@qq.com> --- .../Instruction-Document.md | 56 +++++++------------ .../Instruction-Document.md | 50 ++++++----------- 2 files changed, 39 insertions(+), 67 deletions(-) rename docs/{Image-PrePull-Feature-Enhancement-Instruction-Document => advanced}/Instruction-Document.md (74%) rename i18n/zh/docusaurus-plugin-content-docs/current/{Image-PrePull-Feature-Enhancement-Instruction-Document => advanced}/Instruction-Document.md (76%) diff --git a/docs/Image-PrePull-Feature-Enhancement-Instruction-Document/Instruction-Document.md b/docs/advanced/Instruction-Document.md similarity index 74% rename from docs/Image-PrePull-Feature-Enhancement-Instruction-Document/Instruction-Document.md rename to docs/advanced/Instruction-Document.md index 1dba83fa07..cfc247b32c 100644 --- a/docs/Image-PrePull-Feature-Enhancement-Instruction-Document/Instruction-Document.md +++ b/docs/advanced/Instruction-Document.md @@ -2,7 +2,7 @@ KubeEdge version 1.16 introduces a new feature called Image Pre-Pull, which allows users to load images ahead of time on edge nodes through the Kubernetes API of ImagePrePullJob. This feature supports pre-pull multiple images in batches across multiple edge nodes or node groups, helping to reduce the failure rates and inefficiencies associated with loading images during application deployment or updates, especially in large-scale scenarios. -API example for pre-pull mirror image: +API example for ImagePrePullJob: ``` apiVersion: operations.kubeedge.io/v1alpha1 @@ -10,7 +10,7 @@ kind: ImagePrePullJob metadata: name: imageprepull-example labels: - description:ImagePrePullLabel + description: ImagePrePullLabel spec: imagePrePullTemplate: images: @@ -43,41 +43,22 @@ NAME STATUS ROLES AGE VERSION cloud.kubeedge Ready control-plane,master 3d v1.27.3 edge.kubeedge Ready agent,edge 2d v1.27.7-kubeedge-v1.16.0 -Note: The following verification will use the edge node edge.kubeedge. If you refer to this article for related verification, the configuration of the edge node name in subsequent steps needs to be changed according to your actual situation. +Note: The following operations will use the edge node edge.kubeedge. If you refer to this document for related operations, the configuration of the edge node name in subsequent steps needs to be changed according to your actual situation. ``` -**2)Ensure that the K8s apiserver has the following configuration enabled** +**2)Ensure that the CloudCore has the following configuration enabled** ``` taskManager: - enable: true // 由false修改为true + enable: true // Change from false to true ``` changes can be made by editing the file kubectl edit configmap cloudcore -n kubeedge with commands, and restarting the cloudcore component of the K8s apiserver. -**3)Preparing Sample Code ** -yaml file example code -``` -apiVersion: operations.kubeedge.io/v1alpha1 -kind: ImagePrePullJob -metadata: - name: imageprepull-example -spec: - imagePrePullTemplate: - concurrency: 1 - failureTolerate: '0.1' - images: - - test:nginx - nodeNames: - - edge.kubeedge - imageSecrets: default/secret - retryTimes: 1 - timeoutSeconds: 120 -``` -## 2. Prepare the image and Secret for the private image repository +## 2. Prepare the Secret for the privare image Here is a private image repository prepared for demonstration purposes using Alibaba Cloud's registry URL: registry.cn-hangzhou.aliyuncs.com. The demo space used is jilimoxing, and modifications may be necessary based on actual circumstances during the actual operation. **1)Pushing nginx into the private image repository** @@ -88,15 +69,15 @@ Here is a private image repository prepared for demonstration purposes using Ali ``` **2)Create a Secret on the cloud** - -Using Kubectl create secret docker-registry to generate a secret for a private image repository, modify it according to your actual situation. +Secret is not a required field in ImagePrePullJob. If you need to prepull private image, you can generate a secret for it. +You can also use kubectl to create a Secret for accessing a container registry,such as when you don`t have a Docker configuration file: ``` [root@cloud ~]# kubectl create secret docker-registry my-secret \ - --docker-server=registry.cn-hangzhou.aliyuncs.com \ - --docker-username=23021*****@qq.com \ - --docker-password=Xy***** \ - --docker-email=23021*****@qq.com + --docker-server=tiger@acme.example \ + --docker-username=tiger \ + --docker-password=pass1234 \ + --docker-email=my-registry.example:5000 [root@cloud ~]# kubectl get secret -A NAMESPACE NAME TYPE DATA AGE @@ -139,6 +120,15 @@ spec: ``` +**3) Get ImagePrepulljob Status** + +use:kubectl get imageprepulljobs.operations.kubeedge.io imageprepull-example -o jsonpath='{.status}' + +``` +[root@ke-cloud ~]# kubectl get imageprepulljobs.operations.kubeedge.io imageprepull-example -o jsonpath='{.status}' +[root@ke-cloud ~]# {"action":"Success","event":"Pull","state":"Successful","status":[{"imageStatus":[{"image":"registry.cn-hangzhou.aliyuncs.com/jilimoxing/test:nginx","state":"Successful"}],"nodeStatus":{"action":"Success","event":"Pull","nodeName":"edge.kubeedge","state":"Successful","time":"2024-04-26T18:51:41Z"}}],"time":"2024-04-26T18:51:41Z"} +``` + ## 4. Check if the edge node image has been pre-pull successfully Enter the edge terminal and use the command ctr -n k8s.io i ls to view. @@ -151,7 +141,3 @@ REF TYPE registry.cn-hangzhou.aliyuncs.com/jilimoxing/test:nginx application/vnd.docker.distribution.manifest.v2+json sha256:73e957703f1266530db0aeac1fd6a3f87c1e59943f4c13eb340bb8521c6041d7 67.3 MiB linux/amd64 ``` -## 5. Other - -**1)For more official KubeEdge examples, please refer to https://github.com/kubeedge/examples** - diff --git a/i18n/zh/docusaurus-plugin-content-docs/current/Image-PrePull-Feature-Enhancement-Instruction-Document/Instruction-Document.md b/i18n/zh/docusaurus-plugin-content-docs/current/advanced/Instruction-Document.md similarity index 76% rename from i18n/zh/docusaurus-plugin-content-docs/current/Image-PrePull-Feature-Enhancement-Instruction-Document/Instruction-Document.md rename to i18n/zh/docusaurus-plugin-content-docs/current/advanced/Instruction-Document.md index 77c246f373..5305f0275e 100644 --- a/i18n/zh/docusaurus-plugin-content-docs/current/Image-PrePull-Feature-Enhancement-Instruction-Document/Instruction-Document.md +++ b/i18n/zh/docusaurus-plugin-content-docs/current/advanced/Instruction-Document.md @@ -44,10 +44,10 @@ NAME STATUS ROLES AGE VERSION cloud.kubeedge Ready control-plane,master 3d v1.27.3 edge.kubeedge Ready agent,edge 2d v1.27.7-kubeedge-v1.16.0 -说明:本文接下来的验证将使用边缘节点edge.kubeedge进行,如果你参考本文进行相关验证,后续边缘节点名称的配置需要根据你的实际情况进行更改。 +说明:本文接下来的操作将使用边缘节点edge.kubeedge进行,如果你参考本文进行相关操作,后续边缘节点名称的配置需要根据你的实际情况进行更改。 ``` -**2)确保k8s apiserver开启了以下配置:** +**2)确保CloudCore开启了以下配置:** ``` @@ -56,29 +56,10 @@ edge.kubeedge Ready agent,edge 2d v1.27.7-kubeedge-v1.16.0 ``` 可以通过命令修改kubectl edit configmap cloudcore -n kubeedge文件,并重启k8s-apiserver组件的cloudcore来进行更改。 -**3)准备示例代码:** -yaml文件示例代码 -``` -apiVersion: operations.kubeedge.io/v1alpha1 -kind: ImagePrePullJob -metadata: - name: imageprepull-example -spec: - imagePrePullTemplate: - concurrency: 1 - failureTolerate: '0.1' - images: - - test:nginx - nodeNames: - - edge.kubeedge - imageSecrets: default/secret - retryTimes: 1 - timeoutSeconds: 120 -``` -## 2. 准备私有镜像仓的镜像和Secret +## 2. 为私有镜像准备密钥 在这里准备了一个阿里云的私有镜像仓用作演示:registry.cn-hangzhou.aliyuncs.com/,使用的演示空间为jilimoxing。实际操作过程中可以依据真实情况进行修改 **1)推送nginx进入私有镜像仓** @@ -88,15 +69,15 @@ spec: ``` **2)在云端创建Secret** - -使用Kubectl create secret docker-registry生成私有镜像仓库的secret,根据你的实际情况来进行修改 +Secret 不是 ImagePrePullJob 中的必填字段。如果你需要预拉私有镜像,你可以为它生成一个密钥。 +您还可以使用kubectl创建一个用于访问docker registry的Secret,例如在没有Docker配置文件的情况下: ``` [root@cloud ~]# kubectl create secret docker-registry my-secret \ - --docker-server=registry.cn-hangzhou.aliyuncs.com \ - --docker-username=23021*****@qq.com \ - --docker-password=Xy***** \ - --docker-email=23021*****@qq.com + --docker-server=tiger@acme.example \ + --docker-username=tiger \ + --docker-password=pass1234 \ + --docker-email=my-registry.example:5000 [root@cloud ~]# kubectl get secret -A NAMESPACE NAME TYPE DATA AGE @@ -138,6 +119,15 @@ spec: [root@ke-cloud ~]# kubectl apply -f imageprepull.yaml ``` +**3) 获取 ImagePrepulljob 的状态** + +使用命令:kubectl get imageprepulljobs.operations.kubeedge.io imageprepull-example -o jsonpath='{.status}'进行查看 + +``` +[root@ke-cloud ~]# kubectl get imageprepulljobs.operations.kubeedge.io imageprepull-example -o jsonpath='{.status}' +[root@ke-cloud ~]# {"action":"Success","event":"Pull","state":"Successful","status":[{"imageStatus":[{"image":"registry.cn-hangzhou.aliyuncs.com/jilimoxing/test:nginx","state":"Successful"}],"nodeStatus":{"action":"Success","event":"Pull","nodeName":"edge.kubeedge","state":"Successful","time":"2024-04-26T18:51:41Z"}}],"time":"2024-04-26T18:51:41Z"} +``` + ## 4. 检查边缘节点镜像是否预加载成功 @@ -150,7 +140,3 @@ spec: REF TYPE DIGEST SIZE PLATFORMS LABELS registry.cn-hangzhou.aliyuncs.com/jilimoxing/test:nginx application/vnd.docker.distribution.manifest.v2+json sha256:73e957703f1266530db0aeac1fd6a3f87c1e59943f4c13eb340bb8521c6041d7 67.3 MiB linux/amd64 ``` - -## 5. 其他 - -**1)更多的KubeEdge官方示例请参考 https://github.com/kubeedge/examples** \ No newline at end of file