Long-Term Supported Versions

    KubeEdge Deployment Guide

    Description

    KubeEdge

    KubeEdge is an open source system dedicated to solving problems in edge scenarios. It extends the capabilities of containerized application orchestration and device management to edge devices. Based on Kubernetes, KubeEdge provides core infrastructure support for networks, application deployment, and metadata synchronization between the cloud and the edge. KubeEdge supports MQTT and allows for custom logic to enable communication for the resource-constrained devices at the edge. KubeEdge consists of components deployed on the cloud and edge nodes. The components are now open source.

    https://kubeedge.io/

    iSulad

    iSulad is a lightweight container runtime daemon designed for IoT and cloud infrastructure. It is lightweight, fast, and is not restricted by hardware specifications or architectures. It is suitable for wide application in various scenarios, such as cloud, IoT, and edge computing.

    https://gitee.com/openeuler/iSulad

    Cluster Overview

    Component Versions

    ComponentVersion
    OSopenEuler 22.03
    Kubernetes1.20.2-4
    iSulad2.0.11
    KubeEdgev1.8.0

    Node Planning Example

    NodeLocationComponents
    cloud.kubeedgeCloudKubernetes (Master), iSulad, CloudCore
    edge.kubeedgeEdgeiSulad, EdgeCore

    Note: You can run the hostnamectl set-hostname [cloud,edge].kubeedge command to set the cloud and edge node names in advance.

    Preparations

    Tool Package Download

    kubeedge-tools provides complete offline installation packages and deployment scripts for easy and quick KubeEdge cluster deployment even if the node cannot access the Internet.

    # Download and decompress the kubeedge-tools package on both the cloud and edge nodes.
    $ wget -O kubeedge-tools.zip https://gitee.com/Poorunga/kubeedge-tools/repository/archive/master.zip
    $ unzip kubeedge-tools.zip
    
    # Go to the kubeedge-tools directory for all the subsequent operations.
    $ cd kubeedge-tools-master
    

    Kubernetes Deployment

    Perform the following operations on the cloud node only.

    Initializing the Cloud Environment

    $ ./setup-cloud.sh
    

    Deploying Kubernetes

    Deploy Kubernetes by referring to the Kubernetes Cluster Deployment Guide.

    Note: Preferentially, use kubeadm to deploy Kubernetes if the cloud node has access to the Internet. The procedure is as follows:

    $ kubeadm init --apiserver-advertise-address=[cloud_node_IP_address] --kubernetes-version v1.20.15 --pod-network-cidr=10.244.0.0/16 --upload-certs --cri-socket=/var/run/isulad.sock
    ...
    Your Kubernetes control-plane has initialized successfully!
    ...
    
    # After Kubernetes is installed, copy the specified file to the directory as prompted.
    #   mkdir -p $HOME/.kube
    #   sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
    #   sudo chown $(id -u):$(id -g) $HOME/.kube/config
    

    Configuring Network for the Cloud Container

    Container Network Interface (CNI) software that provides network for Kubernetes nodes include flannel, Calico, Cilium, and more. If you have not decided which CNI software to use, run the following command to configure network for the cloud container:

    $ ./install-flannel-cloud.sh
    

    Checking Deployment Status

    # Check whether the node status is normal (Ready)
    $ kubectl get nodes
    NAME             STATUS   ROLES                  AGE   VERSION
    cloud.kubeedge   Ready    control-plane,master   12m   v1.20.2
    
    # Check whether the Kubernetes components are normal (Running)
    $ kubectl get pods -n kube-system
    NAME                                     READY   STATUS    RESTARTS   AGE
    coredns-74ff55c5b-4ptkh                  1/1     Running   0          15m
    coredns-74ff55c5b-zqx5n                  1/1     Running   0          15m
    etcd-cloud.kubeedge                      1/1     Running   0          15m
    kube-apiserver-cloud.kubeedge            1/1     Running   0          15m
    kube-controller-manager-cloud.kubeedge   1/1     Running   0          15m
    kube-flannel-cloud-ds-lvh4n              1/1     Running   0          13m
    kube-proxy-2tcnn                         1/1     Running   0          15m
    kube-scheduler-cloud.kubeedge            1/1     Running   0          15m
    

    Deployment

    CloudCore Deployment

    Perform the following operations on the cloud node only.

    Initializing the Cluster

    # Set --advertise-address to the IP address of the cloud node.
    $ keadm init --advertise-address="cloud_node_IP_address" --kubeedge-version=1.8.0
    ...
    CloudCore started
    

    Configuring CloudCore

    $ ./patch-cloud.sh
    

    Checking Deployment Status

    # active (running) indicates a normal status
    $ systemctl status cloudcore | grep running
         Active: active (running) since Fri 2022-03-04 10:54:30 CST; 5min ago
    

    CloudCore has been deployed on the cloud node. Then, deploy EdgeCore on the edge node.

    EdgeCore Deployment

    Perform the following operations only on the edge node unless otherwise specified.

    Initializing the Edge Environment

    $ ./setup-edge.sh
    

    Managing the Edge Node

    # Run the keadm gettoken command on the cloud node.
    $ keadm gettoken
    96058ab80ffbeb87fe58a79bfb19ea13f9a5a6c3076a17c00f80f01b406b4f7c.eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE2NDY0NDg4NzF9.1mJegWB7SUVjgf-OvAqILgbZXeMHR9eOzMxpNFc42SI
    # Save this token for subsequent steps.
    
    
    # Run the keadm join command on the edge node.
    # Set --cloudcore-ipport to the IP address and port number (10000) of the cloud node. Set --token to the token saved in the previous step.
    $ keadm join --cloudcore-ipport=clou_node_IP_address:10000 --kubeedge-version=1.8.0 --token=96058ab80ffbeb87fe58a79bfb19ea13f9a5a6c3076a17c00f80f01b406b4f7c.eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE2NDY0NDg4NzF9.1mJegWB7SUVjgf-OvAqILgbZXeMHR9eOzMxpNFc42SI
    ...
    KubeEdge edgecore is running...
    

    Configuring EdgeCore

    $ ./patch-edge.sh
    

    Configuring Network for the Edge Container

    If you have not decided which CNI software to use, run the following command to configure network for the edge container:

    # Run the command on the cloud node.
    $ ./install-flannel-edge.sh
    

    Checking Whether the Edge Node is Managed

    # Run the command on the cloud node. You can see that the edge node is added.
    $ kubectl get nodes
    NAME             STATUS   ROLES                  AGE     VERSION
    cloud.kubeedge   Ready    control-plane,master   1h      v1.20.2
    edge.kubeedge    Ready    agent,edge             10m     v1.19.3-kubeedge-v1.8.0
    

    The KubeEdge cluster has been deployed. Next, let's test the task delivery from the cloud to the edge.

    Application Deployment

    Perform the following operations on the cloud node only.

    Deploying Nginx

    $ kubectl apply -f yamls/nginx-deployment.yaml
    deployment.apps/nginx-deployment created
    
    # Check whether Nginx is deployed on the edge node and running.
    $ kubectl get pod -owide | grep nginx
    nginx-deployment-84b99f4bf-jb6sz   1/1     Running   0          30s   10.244.1.2   edge.kubeedge   <none>           <none>
    

    Testing the Function

    # Access the IP address of Nginx on the edge node.
    $ curl 10.244.1.2:80
    <!DOCTYPE html>
    <html>
    <head>
    <title>Welcome to nginx!</title>
    <style>
    html { color-scheme: light dark; }
    body { width: 35em; margin: 0 auto;
    font-family: Tahoma, Verdana, Arial, sans-serif; }
    </style>
    </head>
    <body>
    <h1>Welcome to nginx!</h1>
    <p>If you see this page, the nginx web server is successfully installed and
    working. Further configuration is required.</p>
    
    <p>For online documentation and support please refer to
    <a href="http://nginx.org/">nginx.org</a>.<br/>
    Commercial support is available at
    <a href="http://nginx.com/">nginx.com</a>.</p>
    
    <p><em>Thank you for using nginx.</em></p>
    </body>
    </html>
    

    The deployment of KubeEdge is complete.

    Bug Catching

    Buggy Content

    Bug Description

    Submit As Issue

    It's a little complicated....

    I'd like to ask someone.

    PR

    Just a small problem.

    I can fix it online!

    Bug Type
    Specifications and Common Mistakes

    ● Misspellings or punctuation mistakes;

    ● Incorrect links, empty cells, or wrong formats;

    ● Chinese characters in English context;

    ● Minor inconsistencies between the UI and descriptions;

    ● Low writing fluency that does not affect understanding;

    ● Incorrect version numbers, including software package names and version numbers on the UI.

    Usability

    ● Incorrect or missing key steps;

    ● Missing prerequisites or precautions;

    ● Ambiguous figures, tables, or texts;

    ● Unclear logic, such as missing classifications, items, and steps.

    Correctness

    ● Technical principles, function descriptions, or specifications inconsistent with those of the software;

    ● Incorrect schematic or architecture diagrams;

    ● Incorrect commands or command parameters;

    ● Incorrect code;

    ● Commands inconsistent with the functions;

    ● Wrong screenshots.

    Risk Warnings

    ● Lack of risk warnings for operations that may damage the system or important data.

    Content Compliance

    ● Contents that may violate applicable laws and regulations or geo-cultural context-sensitive words and expressions;

    ● Copyright infringement.

    How satisfied are you with this document

    Not satisfied at all
    Very satisfied
    Submit
    Click to create an issue. An issue template will be automatically generated based on your feedback.
    Bug Catching
    编组 3备份