Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add chinese translation of edged/edgehub/eventbus with help of chatgpt #621

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 3 additions & 3 deletions docs/architecture/edge/edgehub.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ It forwards the messages received from the cloud to the corresponding module at
The main functions performed by edgehub are :-

- Keep Alive
- Publish Client Info
- Publish Connection Info
magichan marked this conversation as resolved.
Show resolved Hide resolved
- Route to Cloud
- Route to Edge

Expand All @@ -23,9 +23,9 @@ The main functions performed by edgehub are :-
A keep-alive message or heartbeat is sent to cloudHub after every heartbeatPeriod.


## Publish Client Info
## Publish Connection Info

- The main responsibility of publish client info is to inform the other groups or modules regarding the status of connection to the cloud.
- The main responsibility of publish connection info is to inform the other groups or modules regarding the status of connection to the cloud.

- It sends a beehive message to all groups (namely metaGroup, twinGroup and busGroup), informing them whether cloud is connected or disconnected.

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,129 +2,129 @@
title: Edged
sidebar_position: 1
---
## Overview
## 概览

EdgeD is an edge node module which manages pod lifecycle. It helps users to deploy containerized workloads or applications at the edge node. Those workloads could perform any operation from simple telemetry data manipulation to analytics or ML inference and so on. Using `kubectl` command line interface at the cloud side, users can issue commands to launch the workloads.
EdgeD 是负责管理 Pod 生命周期的边缘节点模块。它帮助用户在边缘节点部署容器化的工作负载或应用程序。这些工作负载可以执行任意操作,从简单地遥测数据处理到复杂地数据分析/机器学习推理。用户可以在云端使用 `kubectl` 命令行发出命令来启动工作负载。

Several OCI-compliant runtimes are supported through the Container Runtime Interface (CRI). See [KubeEdge runtime configuration](../../setup/prerequisites/runtime.md) for more information on how to configure edged to make use of other runtimes.
通过容器运行时接口(CRI),EdgeD 支持多个 OCI 兼容的容器运行时。有关如何配置 EdgeD 以使用其他运行时的更多信息,请参见 [KubeEdge 运行时配置](../../setup/prerequisites/runtime.md)

There are many modules which work in tandem to achieve edged's functionalities.
众多模块协同工作实现 EdgeD 的功能。
magichan marked this conversation as resolved.
Show resolved Hide resolved

![EdgeD Overall](/img/edged/edged-overall.png)

*Fig 1: EdgeD Functionalities*
*Fig 1: EdgeD 功能集*

## Pod Management
## Pod 管理

It is handles for pod addition, deletion and modification. It also tracks the health of the pods using pod status manager and pleg.
Its primary jobs are as follows:
该模块负责处理 Pod 的添加、删除和修改。它还使用 Pod 状态管理器和 PLEG 跟踪 Pod 的健康状态。
其主要工作如下:

- Receives and handles pod addition/deletion/modification messages from metamanager.
- Handles separate worker queues for pod addition and deletion.
- Handles worker routines to check worker queues to do pod operations.
- Keeps separate cache for config map and secrets respectively.
- Regular cleanup of orphaned pods
- 接收并处理来自 MetaManager 的 Pod 添加/删除/修改消息。
- 为 Pod 添加和删除事件创建各自独立的工作队列。
- 建立工作协程用于检查工作队列,执行 Pod 操作
- 为 ConfigMap 和 Secret 各自设置独立的缓存。
- 定期清理被遗弃的Pod

![Pod Addition Flow](/img/edged/pod-addition-flow.png)

*Fig 2: Pod Addition Flow*
*Fig 2: Pod 添加工作流*

![Pod Deletion Flow](/img/edged/pod-deletion-flow.png)

*Fig 3: Pod Deletion Flow*
*Fig 3: Pod 删除工作流*

![Pod Updation Flow](/img/edged/pod-update-flow.png)

*Fig 4: Pod Updation Flow*
*Fig 4: Pod 更新工作流*

## Pod Lifecycle Event Generator
## Pod 生命周期事件生成器(Pod Lifecycle Event Generator, PLEG)

This module helps in monitoring pod status for edged. Every second, using probes for liveness and readiness, it updates the information with pod status manager for every pod.
该模块帮助 EdgeD 监控 Pod 的状态。每隔一秒,该模块就使用存活探针和就绪探针更新 Pod 状态管理器中的每个 Pod 的信息。

![PLEG Design](/img/edged/pleg-flow.png)

*Fig 5: PLEG at EdgeD*
*Fig 5: EdgeD 的 PLEG*

## CRI for edged
## EdgeD 的 CRI 支持

Container Runtime Interface (CRI) – a plugin interface which enables edged to use a wide variety of container runtimes like Docker, containerd, CRI-O, etc., without the need to recompile. For more on how to configure KubeEdge for container runtimes, see [KubeEdge runtime configuration](../../setup/prerequisites/runtime).
容器运行时接口(CRI) 是一种插件接口,使 EdgeD 能够使用多种容器运行时,如 DockercontainerdCRI-O 等,而无需重新编译。有关如何配置 KubeEdge 以使用容器运行时的更多信息,请参见 [KubeEdge 容器运行时配置](../../setup/prerequisites/runtime.md)。

#### Why CRI for edged?
CRI support for multiple container runtimes in edged is needed in order to:
+ Support light-weight container runtimes on resource-constrained edge nodes which are unable to run the existing Docker runtime.
+ Support multiple container runtimes like Docker, containerd, CRI-O, etc., on edge nodes.
#### 为什么 EdgeD 需要 CRI?
支持多个容器运行时的 CRI 对 EdgeD 是必要的,这以便于:
+ 支持在资源受限的边缘节点上运行轻量级容器运行时,这些节点无法运行现有的 Docker 运行时。
+ 支持在边缘节点上运行多个容器运行时,如 DockercontainerdCRI-O 等。

Support for corresponding CNI with pause container and IP will be considered later.
提供暂停容器和 IP 能力的 CNI 将在以后考虑支持。

![CRI Design](/img/edged/edged-cri.png)

*Fig 6: CRI at EdgeD*
*Fig 6: EdgeD 上的 CRI*

## Secret Management
## Secret 管理

In edged, Secrets are handled separately. For operations like addition, deletion and modification, there are separate sets of config messages and interfaces.
Using these interfaces, secrets are updated in cache store.
The flow diagram below explains the message flow.
在 EdgeD 中,Secrets 被单独处理。对于添加、删除和修改等操作,都有单独的配置消息和接口。
使用这些接口,Secrets 被更新到缓存存储中。
下面的流程图解释了消息工作流。

![Secret Message Handling](/img/edged/secret-handling.png)

*Fig 7: Secret Message Handling at EdgeD*
*Fig 7: EdgeD 中 Secret 消息的处理*

Edged uses the MetaClient module to fetch secrets from MetaManager. If edged queries for a new secret which is not yet stored in MetaManager, the request is forwarded to the Cloud. Before sending the response containing the secret, MetaManager stores it in a local database. Subsequent queries for the same secret key will be retrieved from the database, reducing latency. The flow diagram below shows how a secret is fetched from MetaManager and the Cloud. It also descibes how the secret is stored in MetaManager.
EdgeD 使用 MetaClient 模块从 MetaManager 获取 Secret。如果 EdgeD 查询一个尚未存储在 MetaManager 中的 Secret,对应的查询请求将被转发到云端。在返回包含 Secret 的响应之前,MetaManager 会将其存储在本地数据库中。对于相同的 Secret 键的后续查询将从数据库中检索,从而减少延迟。下面的流程图显示了如何从 MetaManager 和云端获取 Secret。它还描述了如何将 Secret 存储在 MetaManager 中。

![Query Secret](/img/edged/query-secret-from-edged.png)

*Fig 8: Query Secret by EdgeD*
*Fig 8: EdgeD 查询 Secret*

## Probe Management
## 探针管理(Probe Management)

Probe management creates two probes for readiness and liveness respectively for pods to monitor the containers. The readiness probe helps by monitoring when the pod has reached a running state. The liveness probe helps by monitoring the health of pods, indicating if they are up or down.
As explained earlier, the PLEG module uses its services.
探针管理为 Pod 创建就绪(readiness)探针和存活(liveness)探针,以监视容器。就绪探针监测 Pod 是否已达到运行状态。存活探针通过监测 Pod 的健康状况,指示它们是否正常运行或已经宕机。
正如前面所述,PLEG 模块依赖探针管理模块。


## ConfigMap Management
In edged, ConfigMaps are also handled separately. For operations like addition, deletion and modification, there are separate sets of config messages and interfaces.
Using these interfaces, ConfigMaps are updated in cache store.
## ConfigMap 管理
使用这些接口,ConfigMaps 被更新到缓存存储中。
The flow diagram below explains the message flow.
下面的流程图解释了消息工作流。

![ConfigMap Message Handling](/img/edged/configmap-handling.png)

*Fig 9: ConfigMap Message Handling at EdgeD*
*Fig 9: EdgeD 的 ConfigMap 消息处理工作流*

Edged uses the MetaClient module to fetch ConfigMaps from MetaManager. If edged queries for a new ConfigMap which is not yet stored in MetaManager, the request is forwarded to the Cloud. Before sending the response containing the ConfigMap, MetaManager stores it in a local database. Subsequent queries for the same ConfigMap key will be retrieved from the database, reducing latency. The flow diagram below shows how ConfigMaps are fetched from MetaManager and the Cloud. It also descibes how ConfigMaps are stored in MetaManager.
EdgeD 使用 MetaClient 模块从 MetaManager 获取 ConfigMaps。如果 EdgeD 查询一个尚未存储在 MetaManager 中的 ConfigMap,对应的查询请求将被转发到云端。在返回包含 ConfigMap 的响应之前,MetaManager 会将其存储在本地数据库中。对于相同的 ConfigMap 键的后续查询将从数据库中检索,从而减少延迟。下面的流程图显示了如何从 MetaManager 和云端获取 ConfigMap。它还描述了如何将 ConfigMap 存储在 MetaManager 中。

![Query Configmaps](/img/edged/query-configmap-from-edged.png)

*Fig 10: Query Configmaps by EdgeD*
*Fig 10: EdgeD 查询 ConfigMap*

## Container GC
## 容器回收(Container GC)

The container garbage collector is an edged routine which wakes up every minute, collecting and removing dead containers using the specified container gc policy.
The policy for garbage collecting containers is determined by three variables, which can be user-defined:
+ `MinAge` is the minimum age at which a container can be garbage collected, zero for no limit.
+ `MaxPerPodContainer` is the maximum number of dead containers that any single pod (UID, container name) pair is allowed to have, less than zero for no limit.
+ `MaxContainers` is the maximum number of total dead containers, less than zero for no limit. Generally, the oldest containers are removed first.
容器垃圾收集器是一个 EdgeD 协程,该协程被每分钟唤醒一次,并根据指定的容器垃圾收集策略清除死掉的容器。
容器垃圾收集策略由三个变量决定,这些变量可以由用户定义:
+ `MinAge` 是容器可以被垃圾收集的最小年龄,如果为零则没有限制。
+ `MaxPerPodContainer` 是任何单个 Pod(UID,容器名称)能被允许拥有的最大死掉容器数量,如果小于零则没有限制。
+ `MaxContainers` 是死掉容器总和的最大数量,如果小于零则没有限制。通常,最老的容器首先被删除。

## Image GC
## 镜像回收(Image GC)

The image garbage collector is an edged routine which wakes up every 5 secs, and collects information about disk usage based on the policy used.
The policy for garbage collecting images takes two factors into consideration, `HighThresholdPercent` and `LowThresholdPercent`. Disk usage above the high threshold will trigger garbage collection, which attempts to delete unused images until the low threshold is met. Least recently used images are deleted first.
镜像垃圾收集器是一个 EdgeD 协程,每 5 秒唤醒一次,并根据设置的策略收集关于磁盘使用情况的信息。
镜像垃圾收集策略考虑了两个因素,`HighThresholdPercent` `LowThresholdPercent`。磁盘使用量超过高阈值将触发垃圾收集,尝试删除未使用的镜像,直到低阈值被满足。最近未使用的镜像首先被删除。

## Status Manager
## 状态管理器(Status Manager)

Status manager is an independent edge routine, which collects pods statuses every 10 seconds and forwards this information to the cloud using the metaclient interface.
状态管理器是一个独立的 EdgeD 协程,每 10 秒收集一次 Pod 的状态,并使用 MetaClient 接口将这些信息转发到云端。

![Status Manager Flow](/img/edged/pod-status-manger-flow.png)

*Fig 11: Status Manager Flow*
*Fig 11: 状态管理器工作流*

## Volume Management
## 卷管理(Volume Management)

Volume manager runs as an edge routine which brings out the information of which volume(s) are to be attached/mounted/unmounted/detached based on pods scheduled on the edge node.
卷管理器作为一个 EdgeD 协程运行,根据边缘节点上调度的 Pod,提取哪些卷需要被挂载/卸载/卸载/分离的信息。

Before starting the pod, all the specified volumes referenced in pod specs are attached and mounted, Till then the flow is blocked and with it other operations.
在启动 Pod 之前,将挂载 Pod 规范中引用的所有指定卷,直到完成挂载操作,其他操作都会被阻塞。

## MetaClient

Metaclient is an interface of Metamanger for edged. It helps edged to get ConfigMaps and secret details from metamanager or cloud.
It also sends sync messages, node status and pod status towards metamanger to cloud.
Metaclient 是 EdgeD 的 MetaManager 接口。它帮助 EdgeD 从 MetaManager 或云端获取 ConfigMaps 和 Secret 详情。
它还向 MetaManager 发送同步消息、节点状态和 Pod 状态到云端。
Original file line number Diff line number Diff line change
Expand Up @@ -2,76 +2,72 @@
title: EdgeHub
sidebar_position: 3
---
## Overview
## 概览

Edge hub is responsible for interacting with CloudHub component present in the cloud. It can connect to the CloudHub using either a web-socket connection or using [QUIC](https://quicwg.org/ops-drafts/draft-ietf-quic-applicability.html) protocol.
It supports functions like sync cloud side resources update, report edged side host and device status changes.
EdgeHub 负责与云端的 CloudHub 组件进行交互。它可以使用 WebSocket 连接或使用 [QUIC](https://quicwg.org/ops-drafts/draft-ietf-quic-applicability.html) 协议连接到 CloudHub。
它支持同步云端资源更新、报告边缘端主机和设备状态更改等功能。

It acts as the communication link between the edge and the cloud.
It forwards the messages received from the cloud to the corresponding module at the edge and vice-versa.
该模块充当边缘和云之间的通信链路,
它将从云端接收到的消息转发到边缘端的相应模块,反之亦然。

The main functions performed by edgehub are :-
EdgeHub 主要功能包括:

- Keep Alive
- Publish Client Info
- Route to Cloud
- Route to Edge
- 保活
- 发布连接信息
- 路由到云端
- 路由到边缘端


## Keep Alive
## 保活

A keep-alive message or heartbeat is sent to cloudHub after every heartbeatPeriod.
每间隔一个心跳周期,EdgeHub 都会向 CloudHub 发送保活消息或心跳。


## Publish Client Info
## 发布连接信息

- The main responsibility of publish client info is to inform the other groups or modules regarding the status of connection to the cloud.
- 发布连接信息的主要职责是将和云的连接状态通知到其他 Beehive 组或 Beehive 模块。

- It sends a beehive message to all groups (namely metaGroup, twinGroup and busGroup), informing them whether cloud is connected or disconnected.
- 他向所有组(metaGrouptwinGroup busGroup)发送一个 Beehive 消息,通知他们云是否已连接或已断开。


## Route To Cloud
## 路由到云端

The main responsibility of route to cloud is to receive from the other modules (through beehive framework), all the
messages that are to be sent to the cloud, and send them to cloudHub through the websocket connection.
路由到云端的主要职责是接收来自其他模块(通过 Beehive 框架)的要发送到云端的消息,
并通过 WebSocket 连接将这些消息发送到 CloudHub。

The major steps involved in this process are as follows :-
这个过程中涉及的主要步骤如下:

1. Continuously receive messages from beehive Context
2. Send that message to cloudHub
3. If the message received is a sync message then :
1. 不断地从 Beehive Context 接收消息
2. 将这些消息发送到 CloudHub
3. 如果接收到的消息是一个同步消息,则:

3.1 If response is received on syncChannel then it creates a map[string] chan containing the messageID of the message as key
3.1. 如果在 syncChannel 上收到响应,则它会创建一个 `map[string]chan`,其中包含以消息的 messageID 作为键的键值对

3.2 It waits for one heartbeat period to receive a response on the channel created, if it does not receive any response on the channel within the specified time then it times out.
3.2. 它等待一个心跳周期,在创建的通道上接收响应,如果在指定时间内没有在通道上收到任何响应,则认为超时。

3.3 The response received on the channel is sent back to the module using the SendResponse() function.
3.3. 在通道上收到的响应将使用 SendResponse() 函数发送回模块。
magichan marked this conversation as resolved.
Show resolved Hide resolved

![Route to Cloud](/img/edgehub/route-to-cloud.png)

## Route To Edge
## 路由到边缘端

The main responsibility of route to edge is to receive messages from the cloud (through the websocket connection) and
send them to the required groups through the beehive framework.
路由到边缘端的主要职责是接收来自云端(通过 WebSocket 连接)的消息,
并通过 Beehive 框架将这些消息发送到所需的组。

The major steps involved in this process are as follows :-
这个过程中涉及的主要步骤如下:

- Receive message from cloudHub

- Check whether the route group of the message is found.

- Check if it is a response to a SendSync() function.

- If it is not a response message then the message is sent to the required group

- If it is a response message then the message is sent to the syncKeep channel
- 从 CloudHub 接收消息
- 检查消息的路由组是否存在。
- 检查它是否是 SendSync() 函数的响应。
- 如果不是响应消息,则将消息发送到所需的组
- 如果是响应消息,则将消息发送到 syncKeep 通道

![Route to Edge](/img/edgehub/route-to-edge.png)


## Usage
## 用法

EdgeHub can be configured to communicate in two ways as mentioned below:
EdgeHub 可以配置为以下两种方式进行通信:

- **Through websocket protocol**: Click [here](https://github.com/kubeedge/kubeedge/tree/master/docs/proposals/quic-design.md#edgehub-connect-to-cloudhub-through-websocket-protocol) for details.
- **Through QUIC protocol**: Click [here](https://github.com/kubeedge/kubeedge/tree/master/docs/proposals/quic-design.md#edgehub-connect-to-cloudhub-through-quic) for details.
- **通过 WebSocket 协议**:点击[这里](https://github.com/kubeedge/kubeedge/tree/master/docs/proposals/quic-design.md#edgehub-connect-to-cloudhub-through-websocket-protocol) 查看详情。
- **通过 QUIC 协议**:点击[这里](https://github.com/kubeedge/kubeedge/tree/master/docs/proposals/quic-design.md#edgehub-connect-to-cloudhub-through-quic) 查看详情。
Loading