You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@skywalking.apache.org by ta...@apache.org on 2019/03/04 14:49:02 UTC

[incubator-skywalking] branch master updated: remove cn docs. (#2315)

This is an automated email from the ASF dual-hosted git repository.

tanjian pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/incubator-skywalking.git


The following commit(s) were added to refs/heads/master by this push:
     new c50c804  remove cn docs. (#2315)
c50c804 is described below

commit c50c804bc8d76c77f86f7391549616cc4f899dfd
Author: Jared Tan <ji...@daocloud.io>
AuthorDate: Mon Mar 4 22:48:54 2019 +0800

    remove cn docs. (#2315)
---
 docs/README.md                                     |   3 -
 docs/others/cn/FAQ/README.md                       |   2 -
 docs/others/cn/README.md                           |  32 --
 docs/others/cn/concepts-and-designs/README.md      |  20 --
 .../cn/concepts-and-designs/backend-overview-cn.md |  25 --
 .../cn/concepts-and-designs/manual-sdk-cn.md       |  20 --
 docs/others/cn/concepts-and-designs/oal-cn.md      | 100 ------
 docs/others/cn/concepts-and-designs/overview-cn.md |  30 --
 .../concepts-and-designs/probe-introduction-cn.md  |  33 --
 .../cn/concepts-and-designs/project-goals-cn.md    |   2 -
 .../others/cn/concepts-and-designs/query-oap-cn.md |   2 -
 .../concepts-and-designs/scope-definitions-cn.md   | 167 ---------
 .../cn/concepts-and-designs/service-agent-cn.md    |   2 -
 .../concepts-and-designs/service-mesh-probe-cn.md  |  28 --
 .../cn/concepts-and-designs/ui-overview-cn.md      |   2 -
 .../others/cn/guides/Component-library-settings.md |  65 ----
 docs/others/cn/guides/How-to-build.md              | 106 ------
 docs/others/cn/guides/How-to-release.md            | 377 ---------------------
 .../cn/guides/Java-Plugin-Development-Guide.md     | 299 ----------------
 docs/others/cn/guides/README.md                    |  43 ---
 docs/others/cn/guides/backend-oal-scripts.md       |  11 -
 docs/others/cn/guides/storage-extention.md         |  41 ---
 docs/others/cn/guides/write-oal.md                 |  15 -
 docs/others/cn/protocols/README.md                 |   2 -
 docs/others/cn/setup/README.md                     |  34 --
 docs/others/cn/setup/backend/backend-receivers.md  |   2 -
 docs/others/cn/setup/backend/backend-ui-setup.md   |   2 -
 docs/others/cn/setup/istio/README.md               |   2 -
 .../cn/setup/service-agent/java-agent/README.md    |   2 -
 29 files changed, 1469 deletions(-)

diff --git a/docs/README.md b/docs/README.md
index 6eaaaf7..1be58ab 100644
--- a/docs/README.md
+++ b/docs/README.md
@@ -23,9 +23,6 @@ Also, if you have some related to us, welcome to submit a pull request to add.
 if you see some problem. 
 Or better yet, submit your own contributions through pull request to help make them better.
 
-For documents in other languages, contributed by our community.
-- [中文 :cn:](others/cn/README.md)
-
 ___
 ### Users from 5.x
 SkyWalking 5.x is still supported by the community. For the user plans to upgrade from 5.x to 6.x, you should know there are some definitions of concepts changed.
diff --git a/docs/others/cn/FAQ/README.md b/docs/others/cn/FAQ/README.md
deleted file mode 100644
index 62396e4..0000000
--- a/docs/others/cn/FAQ/README.md
+++ /dev/null
@@ -1,2 +0,0 @@
-# 常见问题解答
-TODO
diff --git a/docs/others/cn/README.md b/docs/others/cn/README.md
deleted file mode 100644
index 7766e3d..0000000
--- a/docs/others/cn/README.md
+++ /dev/null
@@ -1,32 +0,0 @@
-# SkyWalking 6 中文文档
-注:中文文档由社区志愿者提供,官方文档以英文为准。
-# 欢迎
-**这是SkyWalking 6 中文文档。期待加入我们**
-
-您可以从这里了解**SkyWalking**的架构、部署和使用,以及如何基于**SkyWalking**进行开发。
-
-- [概念和设计](./concepts-and-designs/README.md)。概念和设计解释了SkyWalking最重要的核心理念。如果您想了解**SkyWalking**酷炫的特性以及可视化是如何运转的,您可以从这里学习。
-- [安装部署](./setup/README.md)。 安装程序指南包含了在不同方案中安装SkyWalking的方式。同时,作为一个平台,它提供了包括监控和报警的几种提供可观察性的方法。
-- [贡献指南](./guides/README.md)。指南适用于PPMC,提交者或新贡献者。您可以通过这里从一开始就知道如何参与贡献。
-- [协议](./protocols/README.md)。协议说明了探针与后端之间的通讯方式。任何对上报链路探测数据感兴趣的人都应该阅读这个。
-- [常见问题解答](./FAQ/README.md)。当您遇到问题时,请先查看此处,此处包括了清单、已知的安装问题和二次开发实验等。
-
-此外,此处提供了一些有意思或者你会感兴趣的链接:
-
-- [Apache SkyWalking发布页面](http://skywalking.apache.org/downloads/)上提供了最新版本和以往的版本。更改日志请参考[这里](../CHANGES.md)。
-- 你可以在[社区资源目录](https://github.com/OpenSkywalking/Community)中找到关于Skywalking的会议、在线视频或者文章。如果你也有与此相关的内容,欢迎向我们提交Pull Request。
-- 我们一直在寻求帮助来改进我们的文档和代码,因此如果您发现问题,请不要犹豫,[提出问题](https://github.com/apache/incubator-skywalking/issues/new)
-或者更好的是,通过Pull Request提交您的贡献,来帮助改善。
-
-对于其他语言的文档,由我们的社区提供,[官方文档](../../README.md)以英文文档为准。
-- [中文 :cn:](./README.md)
-
-___
-### 使用 5.x 版本的用户
-SkyWalking 5.x 仍受社区支持。对于用户计划从5.x升级到6.x,您应该知道关于有一些概念的定义的变更。
-
-最重要的两个改变了的概念是:
-1. Application(在5.x中)更改为**Service**(在6.x中),Application Instance也更改为**Service Instance**。
-2. Service(在5.x中)更改为**Endpoint**(在6.x中)。
-
-
diff --git a/docs/others/cn/concepts-and-designs/README.md b/docs/others/cn/concepts-and-designs/README.md
deleted file mode 100644
index d959595..0000000
--- a/docs/others/cn/concepts-and-designs/README.md
+++ /dev/null
@@ -1,20 +0,0 @@
-# 概念和设计
-概念和设计可以帮助你去学习和理解`SkyWalking`以及其生态
-
-- `SkyWalking`是什么?
-  - [总览与核心概念](overview-cn.md). 深入介绍和描述了项目,包括了项目解决的问题。
-  - [项目目标](project-goals-cn.md). 介绍了SkyWalking的目标,这些目标目前也是`SkyWalking`的侧重点并且很多的功能都是关于它的。
-
-当你阅读完上面的文档之后,你应该就可以明白`SkyWalking`的基本目标了。现在,你可以选择下面你感兴趣的部分,并深入研究。 
-
-- 探针
-  - [介绍](probe-introduction-cn.md). 引导读者去理解什么是探针,目前有多少种不同的探针存在并且为什么需要它们。
-  - [服务自动埋点工具](service-agent-cn.md). 介绍了`SkyWalking`的服务自动埋点工具做了什么?目前`SkyWalking`支持多少种语言?
-  - [手动埋点SDK](manual-sdk-cn.md). 介绍了手动埋点在`SkyWalking`生态之中的角色
-  - [服务网格探针](service-mesh-probe-cn.md). 介绍了`SkyWalking`为什么要从服务网格和代理探针中接收到遥测数据,并且`SkyWalking`是如何做到的。
-- 后端
-  - [总览](backend-overview-cn.md). 非常深入地介绍了OAP后端。
-  - [观测分析语言](oal-cn.md). 介绍了定义聚合行为定义的核心语言。
-  - [OAP的查询](query-oap-cn.md). 介绍了如果从后端去查询数据,其中包含了一个简单的指标数据,拓扑图,Trace数据或者日志数据
-- UI
-  - [UI总览](ui-overview-cn.md).
diff --git a/docs/others/cn/concepts-and-designs/backend-overview-cn.md b/docs/others/cn/concepts-and-designs/backend-overview-cn.md
deleted file mode 100644
index 11a39a0..0000000
--- a/docs/others/cn/concepts-and-designs/backend-overview-cn.md
+++ /dev/null
@@ -1,25 +0,0 @@
-# 可观测性分析平台
-`OAP`(可观测性分析平台)是从`SkyWalking 6.x`开始的一个新的概念. 而且`OAP`将会替代掉`SkyWalking6.x`**之前版本**的整个后端。 
-下面将会讲解下整个新平台的功能。
-
-## OAP的功能
-`OAP`可以接受更多的数据来源,这些数据来源主要分为两类:**链路跟踪**和**指标**
-- **链路跟踪**. 支持`SkyWalking`原生的数据格式,`Zipkin v1,v2`的数据格式和`Jaeger`的数据格式.
-- **指标**. `SkyWalking`已经与服务网格平台(`Istio`,` Envoy`, `Linkerd`)进行整合,可以从这些服务网格平台的数据面板或者控制面板提供可观测性。
-而且,`Skywalking`的原生`agent`也可以运行在指标模式之下,这能够极大地提升性能。
-
-通过使用`SkyWalking`的日志插件和`toolkits`,`SkyWalking`可以通过使用`trace id`或者`span id`将链路与日志串联起来,从而可以将日志系统与链路系统进行可视化集成。
-
-跟之前一样,我们提供了`gRpc`和`Http`协议去让那些我们无法支持的生态系统更好地融入进来。
-
-## 链路跟踪 之 OAP
-`OAP`中的链路跟踪有两条方式去运行,
-1. 与`SkyWalking 5`版本保持一致. 将所有的链路数据(包含`Zipkin` 格式的数据)都压缩成`SkyWalking`的原生格式,然后通过`OAP`去分析这些已经统一格式的数据去获取到指标,最终将这些数据进行流式聚合。
-2. 将这些链路数据只是用作某些类型的日志集合,仅仅只提供存储以及整个链路的可视化功能。
-
-并且,`SkyWalking`可以接受其他系统(`Zipkin`,`Jeager`,`OpenCensus`)传过来的链路数据,并使用上面的两种方式去处理
-
-## 指标 之 OAP
-指标在`SkyWalking6`版本是一个全新的功能。可以不通过链路数据为一个基于指标连通节点的分布式系统建立可观测性。
-
-流式模型的`OAP`集群会将指标数据进行聚合。具体信息可以查看[可观测性分析语言](oal-cn.md),它提供了一个简单的脚本风格方式去进行数据聚合分析。
\ No newline at end of file
diff --git a/docs/others/cn/concepts-and-designs/manual-sdk-cn.md b/docs/others/cn/concepts-and-designs/manual-sdk-cn.md
deleted file mode 100644
index 60d24f3..0000000
--- a/docs/others/cn/concepts-and-designs/manual-sdk-cn.md
+++ /dev/null
@@ -1,20 +0,0 @@
-## 手动埋点SDK
-我们目前并没有提供任何关于手动埋点的SDK。
-
-欢迎考虑贡献以下语言的探针:
-- Go
-- Python
-- C++
-
-## 什么是SkyWalking的格式和传输协议?
-可以在[协议文档](../protocols/README.md)中查看细节.
-
-## SkyWalking可以对以上的语言提供OpenCensus的出口?
-在我写这份文件的时候是不支持的。因为OC(OpenCensus)并不提供上下文可扩展机制的支持,也没有提供在操纵span的时候提供任何的hook机制。
-SkyWalking依靠这些去传播更多的东西而不是trace id和span id。
-
-我们已经在讨论中了,你可以查看https://github.com/census-instrumentation/opencensus-specs/issues/70。
-在OC正式提供这一点后, 我们才可以提供。
-
-## 那Zipkin埋点SDK可以吗?
-可以在后端文档中查看[Zipkin接收器](../setup/backend/backend-receivers.md),它与上面提到的有些不同。
diff --git a/docs/others/cn/concepts-and-designs/oal-cn.md b/docs/others/cn/concepts-and-designs/oal-cn.md
deleted file mode 100644
index 6b39204..0000000
--- a/docs/others/cn/concepts-and-designs/oal-cn.md
+++ /dev/null
@@ -1,100 +0,0 @@
-## 观测分析语言
-提供OAL(可观测性分析语言)来分析流模式下传入的数据。
-
-OAL主要关注服务, 服务实例和端点的度量、指标信息。正因为如此, OAL很容易学习和使用。
-
-考虑到性能、读取和调试, OAL被定义为一种编译语言。
-OAL脚本将在打包阶段编译为普通的java代码。
-
-## 语法
-脚本必须以`*.oal`命名结尾。
-
-```
-
-METRIC_NAME = from(SCOPE.(* | [FIELD][,FIELD ...]))
-[.filter(FIELD OP [INT | STRING])]
-.FUNCTION([PARAM][, PARAM ...])
-```
-
-## 作用域(Scope)
-主要的 **SCOPE** 包含 are `All`, `Service`, `ServiceInstance`, `Endpoint`, `ServiceRelation`, `ServiceInstanceRelation`, `EndpointRelation`.
-其中有一些二级作用域,隶属于一级作用域。
-
-你可以在[Scope定义](scope-definitions-cn.md)中查看到所有的作用域(Scope)和字段(Fields)。
-
-## 过滤器
-通过使用字段名称和表达式的过滤器来生成字段值的条件。
-
-表达式支持通过`and`,`or`和 `(...)`进行链接。
-操作运算符支持`=`, `!=`, `>`, `<`, `in (v1, v2, ...`, `like "%..."`。在语法不支持或错误的情况下进行触发器编译
-或代码生成的时候,基于字段类型的类型检测会报错。
-
-## 聚合函数
-SkyWalking OAP core提供了一些默认的函数,你也可以实现更多的聚合函数。
-
-提供的函数
-- `longAvg`.来源数据的平均值。输入的字段必须是long类型的。
-> instance_jvm_memory_max = from(ServiceInstanceJVMMemory.max).longAvg();
-
-此例中, 输入数据是每个ServiceInstanceJVMMemory的请求, 计算基于字段`max`的平均值。
-
-- `doubleAvg`.来源数据的平均值。输入的字段必须是double类型的。
-> instance_jvm_cpu = from(ServiceInstanceJVMCPU.usePercent).doubleAvg();
-
-此例中, 输入是每个ServiceInstanceJVMCPU的请求,计算基于字段`usePercent`的平均值。
-
-- `percent`. 统计来源数据中符合条件的百分比。
-> endpoint_percent = from(Endpoint.*).percent(status == true);
-
-此例中, 所有输入都是每个端点的请求,匹配条件是`endpoint.status == true`。
-
-- `sum`.统计来源数据中的总和。
-> Service_Calls_Sum = from(Service.*).sum();
-
-此例中,代表着统计每个服务的调用次数。
-
-- `p99`, `p95`, `p90`, `p75`, `p50`. 参考[p99 in WIKI](https://en.wikipedia.org/wiki/Percentile)
-> All_p99 = from(All.latency).p99(10);
-
-此例中,统计来源数据的百分之九十九的情况。
-
-- `thermodynamic`.参考[Headmap in WIKI](https://en.wikipedia.org/wiki/Heat_map))
-> All_heatmap = from(All.latency).thermodynamic(100, 20);
-
-此例中,统计所有来源数据的热力图。
-
-## 指标、度量名称
-存储实现器、警报和查询模块的指标名称。类型推断由skywalking core支持。
-
-## 分组
-所有指标数据将Scope.ID和最小量级的时间桶分组。
-
-- 在`Endpoint` scope中, Scope.ID = Endpoint id (基于服务及其端点的唯一id)
-
-## 更多例子
-```
-// Caculate p99 of both Endpoint1 and Endpoint2
-Endpoint_p99 = from(Endpoint.latency).filter(name in ("Endpoint1", "Endpoint2")).summary(0.99)
-
-// Caculate p99 of Endpoint name started with `serv`
-serv_Endpoint_p99 = from(Endpoint.latency).filter(name like ("serv%")).summary(0.99)
-
-// Caculate the avg response time of each Endpoint
-Endpoint_avg = from(Endpoint.latency).avg()
-
-// Caculate the histogram of each Endpoint by 50 ms steps.
-// Always thermodynamic diagram in UI matches this metric. 
-Endpoint_histogram = from(Endpoint.latency).histogram(50)
-
-// Caculate the percent of response status is true, for each service.
-Endpoint_success = from(Endpoint.*).filter(status = "true").percent()
-
-// Caculate the percent of response code in [200, 299], for each service.
-Endpoint_200 = from(Endpoint.*).filter(responseCode like "2%").percent()
-
-// Caculate the percent of response code in [500, 599], for each service.
-Endpoint_500 = from(Endpoint.*).filter(responseCode like "5%").percent()
-
-// Caculate the sum of calls for each service.
-EndpointCalls = from(Endpoint.*).sum()
-```
diff --git a/docs/others/cn/concepts-and-designs/overview-cn.md b/docs/others/cn/concepts-and-designs/overview-cn.md
deleted file mode 100644
index 3397165..0000000
--- a/docs/others/cn/concepts-and-designs/overview-cn.md
+++ /dev/null
@@ -1,30 +0,0 @@
-# 概览
-   SkyWalking一个开源可观测性平台,用于收集、分析、聚合和可视化来自服务和云原生基础设施的数据。SkyWalking提供了一种简单的方法,可以让你清晰的查看分布式系统、甚至是跨云环境中。它更像是现代化APM(Application Performance Manager),专为云原生、基于容器和分布式系统而设计的。
-
-## 为什么要使用SkyWalking?
-   SkyWalking提供了在许多不同场景下观察和监控分布式系统的解决方案。首先,与传统方式不同,SkyWalking为服务实例提供自动语言探针,例如在Java,C#和NodeJS中。与此同时,他正准备为Go,C++提供手动语言探针SDK。此外,更多语言需要,运行时代码风险可控,云原生基础设施变得更加强大,SkyWalking使用Service Mesh基础网探针收集数据,来理解整个分布式系统。通常它为**服务**、**服务实例**、**端点**提供可观察性能力。
-    
-   `服务`、`服务实例`和`端点`的概念在今天到处使用,所以我们首先要清楚它们在SkyWalking中的含义。
-             
-- **服务**  表示提供相同行为请求的一个`服务集合`或`服务组`工作负载。当你用语言探针或SDK时,你可以定义服务名称。或是SkyWalking使用你定义的名字在Istio这类平台中。
-- **服务实例**  表示`服务组`中的每个工作负载都称作`服务实例`。就像`pods`在Kubernetes中一样,它不需要是OS中的单个进程。然而,如果您正在使用语言探针,一个服务实例则实际上是OS中的单个进程。
-- **端点**  表示某个服务传入请求的路径,例如HTTP URI路径或gRPC服务类+方法签名。
- 
-通过使用SkyWalking,您可以观察`服务`和`端点`之间的拓扑关系和每个`服务实例`的metrics,并为`服务实例`和`端点`设置警报规则。
-   
-除此之外,您还可以通过使用Zipkin、Jaeger、OpenCensus以及SkyWalking的语言探针或者SDK进行分布式全链路跟踪。
-   
-## 架构
-
-   SkyWalking在逻辑上分为四个部分:探针,平台后端,存储和UI。
-   
-   <img src="http://skywalking.apache.org/assets/frame.jpeg"/>
-
-- **探针**  基于不同的来源是不同的。它们收集数据并根据SkyWalking需求重新格式化。
-- **平台后端**  是一个后端服务,支持集群部署。它用于聚合,分析和驱动从探针到UI的流程。它还提供可插拔能力为不同的数据源(如Zipkin)、存储器实现和集群管理。您甚至可以使用[观察分析语言](oal-cn.md)自定义聚合和分析。
-- **存储**  是开放的。您可以选择现有的实现,例如ElasticSearch、H2或Sharding-Sphere管理的MySQL集群,也可以实现自己的。当然,非常感谢您为新的存储实现做出贡献。
-- **UI**  酷炫且非常强大,你也可以自己定制UI匹配后端。
-   
-## 接下来目标是什么?
-   
-   * 了解SkyWalking的[项目目标](project-goals-cn.md)
\ No newline at end of file
diff --git a/docs/others/cn/concepts-and-designs/probe-introduction-cn.md b/docs/others/cn/concepts-and-designs/probe-introduction-cn.md
deleted file mode 100644
index 819cc59..0000000
--- a/docs/others/cn/concepts-and-designs/probe-introduction-cn.md
+++ /dev/null
@@ -1,33 +0,0 @@
-## 探测器介绍
-在SkyWalking中,探测器代表探针或者被集成到目标系统的SDK库以此负责收集包括跟踪和度量在内的遥测数据。
-基于目标系统的技术堆栈, 探头可以使用很多不同的方式来做。但它们的最终效果应该是一样的,那就是收集和重新格式化数据, 然后发送到后端。
-
-大体上看,SkyWalking中有大致三大类型的探测器。
-- **基于语言的原生探针**. 这种类型的探针运行在目标服务中, 就像用户代码的一部分。 如SkyWalking的Java探针,
-通过`-javaagent`参数指令在运行时增强代码,`增强(manipulate)`意味着改变和注入到用户的代码。
-另外一种则是由️目标类库提供的一些钩子(hook)或者拦截等机制。因此,你会发现,这些方法都是基于语言和类库的。
-
-- **服务网格探测器**. 服务网格探测器将从服务网格中的控制面板(control panel)或者代理(proxy)等sidecar中收集数据。
-在过去,代理(proxy)只是一个集群的入口,但是现在通过服务网格和sidecar我们可以在此基础上进行观测。
-
-- **第三方埋点类库**. SkyWalking接收其他主流的埋点类库的数据格式。SkyWalking后端会分析并将这些追踪或者指标数据转换成SkyWalking支持的格式。
-这些特性会在支持Zipkin span数据的时候提供。查看[针对其他追踪器的接收器](../setup/backend/backend-receivers.md)了解相关信息。
-
-没有必要同时使用**基于语言的原生探针**和**服务网格探测器**,因为它们都是收集指标数据。
-这导致的结果就是, 你的系统承受了两次载荷, 因此分析数字将会翻倍。
-
-这里有几种推荐的使用方式:
-1. 仅使用**基于语言的原生探针**
-1. 仅使用**第三方埋点类库**,类似Zipkin生态系统
-1. 仅使用**服务网格探测器**
-1. 在**基于语言的原生探针**处于跟踪状态的基础上使用**服务网格探测器**或者**第三方埋点类库**(推荐使用)
-
-另外,举例说明什么是**处于跟踪状态**?
-
-默认情况下,**基于语言的原生探针**和**第三方埋点类库**都会发送分布式追踪数据到后端,后端会分析并聚合这些数据。
-**处于跟踪状态**则意味着后端认为只需保存它们这些比如日志的追踪,并在跟踪和指标之间建立链接,比如`这些追踪属于哪个服务和端点?`。
-
-## 下一步是什么?
-- 从[服务自动埋点](service-agent-cn.md),[Manual埋点SDK](manual-sdk-cn.md),[Service Mesh探测器](service-mesh-probe-cn.md) 
-和 [Zipkin接收器](../setup/backend/backend-receivers.md)了解更多。
-- 在理解探测器之后,可以查看[后端总览](backend-overview-cn.md)来理解分析和存储。
diff --git a/docs/others/cn/concepts-and-designs/project-goals-cn.md b/docs/others/cn/concepts-and-designs/project-goals-cn.md
deleted file mode 100644
index 228702f..0000000
--- a/docs/others/cn/concepts-and-designs/project-goals-cn.md
+++ /dev/null
@@ -1,2 +0,0 @@
-## 项目目标
-TODO
\ No newline at end of file
diff --git a/docs/others/cn/concepts-and-designs/query-oap-cn.md b/docs/others/cn/concepts-and-designs/query-oap-cn.md
deleted file mode 100644
index f7e4160..0000000
--- a/docs/others/cn/concepts-and-designs/query-oap-cn.md
+++ /dev/null
@@ -1,2 +0,0 @@
-## OAP的查询
-TODO
\ No newline at end of file
diff --git a/docs/others/cn/concepts-and-designs/scope-definitions-cn.md b/docs/others/cn/concepts-and-designs/scope-definitions-cn.md
deleted file mode 100644
index 89d87fc..0000000
--- a/docs/others/cn/concepts-and-designs/scope-definitions-cn.md
+++ /dev/null
@@ -1,167 +0,0 @@
-# 作用域(Scopes)和 字段(Fields)
-通过使用聚合函数, 请求将按时间分组, 并且在每个作用域中都有**Group Key(s)**。
-
-
-### `All`作用域
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| endpoint  | 表示每次请求的端点。  |   | string |
-| latency  | 表示每次请求的延时。 |   |  int(in ms)  |
-| status  | 表示每次请求是成功或失败。  |   | bool(true for success)  |
-| responseCode | 如果是HTTP请求,表示响应的状态码。比如:200, 404, 302| | int |
-
-### `Service`作用域
-
-计算服务的每个请求中的度量数据。
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| id | 表示服务的唯一ID | yes | int |
-| name | 表示服务的名称 | | string |
-| serviceInstanceName | 表示引用的服务实例id的名称 | | string |
-| endpointName | 表示端点的名称, 比如HTTP URI的全路径  | | string |
-| latency | 表示每次请求的延时 | | int |
-| status | 表示每次请求成功或失败 | | bool(true for success)  |
-| responseCode | 如果是HTTP请求,表示响应的状态码。比如:200, 404, 302 | | int|
-| type | 表示请求的类型,比如: Database, HTTP, RPC, gRPC. | | enum |
-
-### `ServiceInstance`作用域
-
-计算服务实例的每个请求中的度量数据。
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| id | 表示服务实例的唯一ID,通常是一个数 | yes | int |
-| name |  表示服务实例的名称. 比如`ip:port@Service Name`.  **注意**: 目前原生的探针使用 `processId@Service name` 作为实例名称, 当您要在聚合中设置筛选器时, 这是无效的。 | | string|
-| serviceName | 表示服务名 | | string |
-| endpointName | 表示端点的名称, 比如HTTP URI的全路径. | | string|
-| latency | 表示每次请求的延时. | | int |
-| status | 表示每次请求成功或失败. | | bool(true for success) |
-| responseCode | 如果是HTTP请求,表示响应的状态码。 | | int |
-| type | 表示请求的类型,比如: Database, HTTP, RPC, gRPC. | | enum |
-
-#### `ServiceInstance`的二级作用域 
-
-如果服务实例是 jvm 并由 javaagent 收集, 则计算度量数据。
-
-1. `ServiceInstanceJVMCPU`作用域
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| id | 表示服务实例的唯一ID,通常是一个数 | yes | int |
-| name |  表示服务实例的名称. 比如`ip:port@Service Name`.  **注意**: 目前原生的探针使用 `processId@Service name` 作为实例名称, 当您要在聚合中设置筛选器时, 这是无效的。 | | string|
-| serviceName | 表示服务名 | | string |
-| usePercent | 表示消耗cpu时间的百分比值 | | double|
-
-2. `ServiceInstanceJVMMemory` 作用域
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| id | 表示服务实例的唯一ID,通常是一个数. | yes | int |
-| name |  表示服务实例的名称. 比如`ip:port@Service Name`.  **注意**: 目前原生的探针使用 `processId@Service name` 作为实例名称, 当您要在聚合中设置筛选器时, 这是无效的。 | | string|
-| serviceName | 表示服务名. | | string |
-| heapStatus | 表示此值的内存度量值是堆或非堆 | | bool |
-| init | 参考JVM文档 | | long |
-| max | 参考JVM文档 | | long |
-| used | 参考JVM文档 | | long |
-| committed | 参考JVM文档 | | long |
-
-3. `ServiceInstanceJVMMemoryPool`作用域
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| id | 表示服务实例的唯一ID,通常是一个数. | yes | int |
-| name |  表示服务实例的名称. 比如`ip:port@Service Name`.  **注意**: 目前原生的探针使用 `processId@Service name` 作为实例名称, 当您要在聚合中设置筛选器时, 这是无效的。 | | string|
-| serviceName | 表示服务名. | | string |
-| poolType | 基于不同版本的JVM包括CODE_CACHE_USAGE, NEWGEN_USAGE, OLDGEN_USAGE, SURVIVOR_USAGE, PERMGEN_USAGE, METASPACE_USAGE | | enum |
-| init | 参考JVM文档 | | long |
-| max | 参考JVM文档 | | long |
-| used | 参考JVM文档 | | long |
-| committed | 参考JVM文档 | | long |
-
-4. `ServiceInstanceJVMGC`作用域
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| id | 表示服务实例的唯一ID,通常是一个数. | yes | int |
-| name |  表示服务实例的名称. 比如`ip:port@Service Name`.  **注意**: 目前原生的探针使用 `processId@Service name` 作为实例名称, 当您要在聚合中设置筛选器时, 这是无效的。 | | string|
-| serviceName | 表示服务名. | | string |
-| phrase | 包括NEW和OLD | | Enum |
-| time | GC消耗时间 | | long |
-| count | GC操作的次数 | | long |
-
-### `Endpoint`作用域
-
-计算服务中端点的每个请求的度量数据。
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| id | 表示端点的唯一ID,通常是一个数. | yes | int |
-| name | 表示端点的名称, 比如HTTP URI的全路径. | | string |
-| serviceName | 表示服务名. | | string |
-| serviceInstanceName | 表示引用的服务实例id的名称 | | string |
-| latency | 表示每次请求的延时. | | int |
-| status | 表示每次请求成功或失败. | | bool(true for success) |
-| responseCode | 如果是HTTP请求,表示响应的状态码。 | | int |
-| type | 表示请求的类型,比如: Database, HTTP, RPC, gRPC. | | enum |
-
-### `ServiceRelation`作用域
-
-计算每个请求中,一个服务和另一个服务之间的度量数据。
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| sourceServiceId | 表示来源服务的id. | yes | int |
-| sourceServiceName | 表示来源服务的名称 | | string |
-| sourceServiceInstanceName | 表示来源服务实例的名称 | | string |
-| destServiceId | 表示目的服务的id | yes | string |
-| destServiceName | 表示目的服务的名称. | | string |
-| destServiceInstanceName | 表示目的服务实例的名称.| | string|
-| endpoint | 表示在此次调用中使用的端点. | | string
-| componentId | 表示在此次调用中使用的组件的ID. | yes | string
-| latency | 表示每次请求的延时. | | int |
-| status | 表示每次请求成功或失败. | | bool(true for success) |
-| responseCode | 如果是HTTP请求,表示响应的状态码。| | int |
-| type | 表示请求的类型,比如: Database, HTTP, RPC, gRPC. | | enum |
-| detectPoint | 表示检测到的关系所在位置。比如: 客户端、服务器或者代理。 | yes | enum|
-
-### `ServiceInstanceRelation`作用域
-
-计算每个请求中,一个服务实例和另一个服务实例之间的指标数据
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| sourceServiceInstanceId | 表示来源服务实例的id. | yes | int|
-| sourceServiceName | 表示来源服务的名称. | | string |
-| sourceServiceInstanceName | 表示来源服务实例的名称. | | string |
-| destServiceName | 表示目的服务名称. | | |
-| destServiceInstanceId | 表示目的服务实例的id. | yes | int| 
-| destServiceInstanceName | 表示目的服务实例的名称. | | string |
-| endpoint | 表示在此次调用中使用的端点. | | string
-| componentId | 表示在此次调用中使用的组件的ID. | yes | string
-| latency | 表示每次请求的延时. | | int |
-| status | 表示每次请求成功或失败. | | bool(true for success) |
-| responseCode | 如果是HTTP请求,表示响应的状态码。| | int |
-| type | 表示请求的类型,比如: Database, HTTP, RPC, gRPC. | | enum |
-| detectPoint | 表示检测到的关系所在位置。比如: 客户端、服务器或者代理。 | yes | enum|
-
-### `EndpointRelation`作用域
-
-计算一个端点和另一个端点之间依赖关系的指标数据。
-这种关系很难检测, 同样取决于传播上一端点的追踪库。
-因此, `EndpointRelation`作用域聚合仅在由SkyWalking原生追踪下的服务中生效,
-包括自动埋点探针(如java、.net)、OpenCensus SkyWalking exporter的实现或其他依据SkyWalking规范传播的追踪上下文。
-
-| Name | Remarks | Group Key | Type | 
-|---|---|---|---|
-| endpointId | 表示依赖中为父节点的端点的id | yes | int |
-| endpoint | 表示依赖中为父节点的端点| | string| 
-| childEndpointId | 表示在第一行中依赖中作为子节点的端点id | yes | int| 
-| childEndpoint| 表示在第二行中依赖中作为子节点的端点 | | string |
-| rpcLatency | 表示端点到子端点中rpc的耗时。除去父端点本身的耗时。
-| componentId | 表示在此次调用中使用的组件的ID. | yes | string
-| status | 表示每次请求成功或失败. | | bool(true for success) |
-| responseCode | 如果是HTTP请求,表示响应的状态码。| | int |
-| type | 表示请求的类型,比如: Database, HTTP, RPC, gRPC. | | enum |
-| detectPoint | 表示检测到的关系所在位置。比如: 客户端、服务器或者代理。 | yes | enum|
diff --git a/docs/others/cn/concepts-and-designs/service-agent-cn.md b/docs/others/cn/concepts-and-designs/service-agent-cn.md
deleted file mode 100644
index 0a45314..0000000
--- a/docs/others/cn/concepts-and-designs/service-agent-cn.md
+++ /dev/null
@@ -1,2 +0,0 @@
-## 服务自动埋点工具
-TODO
\ No newline at end of file
diff --git a/docs/others/cn/concepts-and-designs/service-mesh-probe-cn.md b/docs/others/cn/concepts-and-designs/service-mesh-probe-cn.md
deleted file mode 100644
index b1819c3..0000000
--- a/docs/others/cn/concepts-and-designs/service-mesh-probe-cn.md
+++ /dev/null
@@ -1,28 +0,0 @@
-## 服务网格探针
-服务网格探测器通过服务网格中提供的可扩展机制来实现, 如istio。
-
-## 什么是服务网格?
-下面引用了Istio的官方文档。
-> The term service mesh is often used to describe the network of microservices that make up such applications and the interactions between them. 
-As a service mesh grows in size and complexity, it can become harder to understand and manage. 
-Its requirements can include discovery, load balancing, failure recovery, metrics, and monitoring, and often more complex operational requirements 
-such as A/B testing, canary releases, rate limiting, access control, and end-to-end authentication.
-
-## 探测器从哪里收集数据?
-Istio是一个很典型的服务网格的设计与实现。其中定义了被广泛使用的**控制面板**和**数据面板**。Istio架构图如下:
-
-<img src="https://istio.io/docs/concepts/what-is-istio/img/overview/arch.svg"/>
-
-服务网格探测器可以选择从**控制面板**或**数据面板**收集数据。在Istio中,意味着将从Mixer(控制面板)或者Envoy sidecar(数据面板)收集数据。
-它们的基础数据是相同的, 探测器收集在每个请求中从客户端和服务器端收集遥测实体。
-
-## 服务网格如何使后端工作?
-从这种探测器中国呢可以看到并没有追踪相关的数据,那么SkyWalking为何依然能够正常工作呢?
-
-服务网格探测器从每次请求中收集遥测数据,因此探测器知道请求的来源、目的、端点、延时和状态。
-通过这些信息,SkyWalking后端通过结合这些和经过每个节点的来源数据的指标信息得到整体的拓扑图。
-后端在解析追踪数据的时候需要保持一致的指标信息。因此,正确阐述则是:
-**服务网格指标是追踪解析器生成的指标。他们是一样的。**
-
-## 下一步是什么?
-- 如果你想使用服务网格探测器, 阅读[在Service Mesh中设置SkyWalking](../setup/README.md#on-service-mesh) document.
diff --git a/docs/others/cn/concepts-and-designs/ui-overview-cn.md b/docs/others/cn/concepts-and-designs/ui-overview-cn.md
deleted file mode 100644
index 2c1fb36..0000000
--- a/docs/others/cn/concepts-and-designs/ui-overview-cn.md
+++ /dev/null
@@ -1,2 +0,0 @@
-## UI总览
-TODO
\ No newline at end of file
diff --git a/docs/others/cn/guides/Component-library-settings.md b/docs/others/cn/guides/Component-library-settings.md
deleted file mode 100644
index fbb74bf..0000000
--- a/docs/others/cn/guides/Component-library-settings.md
+++ /dev/null
@@ -1,65 +0,0 @@
-# 组件库设置
-组件库设置与受监视应用程序中使用的您自己或第三方库有关。
-
-在 agent 或 SDK 中, 无论将库名称收集为ID或String(简单地说,例如SpringMVC),收集器格式化ID中的数据,以获得更好的性能和更少的存储要。
-
-此外,收集器根据组件库推测远程服务,例如:
-组件库是MySQL驱动程序库,那么远程服务应该是MySQL Server。
-
-出于这两个原因,收集器需要此文件中的两部分设置:
-
-1.组件库ID,名称和语言。
-1.远程服务器映射,基于本地库。
-
-**必须在此文件中定义所有组件名称和ID。**
-
-## 组件库ID
-定义受监视应用程序中使用的所有组件库的名称和ID。
-这是双向映射,agent或SDK可以value(ID)来表示上行链路数据中的组件名称。
-
-- Name:agent和UI中使用的组件名称
-- id:唯一ID。 一旦发布,所有ID都会被保留。
-- languages:程序语言可以使用此组件。 多语言应该用`,`分隔
-
-### ID 规则
-- Java and 多语言共享: (0, 3000]
-- .NET 平台使用: (3000, 4000]
-- Node.js 平台使用: (4000, 5000]
-- Go 平台使用: (5000, 6000]
-- PHP 平台使用: (6000, 7000]
-- Python 使用: (7000, 8000]
-
-实例
-```yaml
-Tomcat:
-  id: 1
-  languages: Java
-HttpClient:
-  id: 2
-  languages: Java,C#,Node.js
-Dubbo:
-  id: 3
-  languages: Java
-H2:
-  id: 4
-  languages: Java
-```
-
-## 远端服务映射
-远端服务器根据本地组件推断而出,映射基于组件库名称.
-
-- Key: 客户端组件库名称
-- Value: 服务组件名称
-
-```yaml
-Component-Server-Mappings:
-  Jedis: Redis
-  StackExchange.Redis: Redis
-  Redisson: Redis
-  Lettuce: Redis
-  Zookeeper: Zookeeper
-  SqlClient: SqlServer
-  Npgsql: PostgreSQL
-  MySqlConnector: Mysql
-  EntityFrameworkCore.InMemory: InMemoryDatabase
-```
\ No newline at end of file
diff --git a/docs/others/cn/guides/How-to-build.md b/docs/others/cn/guides/How-to-build.md
deleted file mode 100644
index b501e69..0000000
--- a/docs/others/cn/guides/How-to-build.md
+++ /dev/null
@@ -1,106 +0,0 @@
-# 编译指南
-本文档会介绍Skywalking在maven和您使用的IDE下如何进行编译和构建.
-
-## 项目构建
-**因为我们使用了`Git submodule`,所以我们建议不要使用`GitHub`标签或发布页面来下载用于编译的源代码。**
-
-### 从GitHub代码构建
-1. 准备git、JDK8和maven3。
-1. `git clone https://github.com/apache/incubator-skywalking.git`
-1. `cd incubator-skywalking/`
-1. 使用`git checkout [tagname]`切换对应的标签代码版本(可选项,如果要从源代码构建版本,则切换)
-1. `git submodule init`
-1. `git submodule update`
-1. 运行 `./mvnw clean package -DskipTests`
-1. 打包后的代码在`/dist`文件夹中(Linux系统使用.tar.gz文件 and Windows使用.zip文件)。
-
-### 从Apache源代码发行版本构建
-- 什么是 `Apache源代码发行版本`?
-
-对于每个正式的Apache发行版本,都有一个完整且独立的源代码tar包,其中包含所有源代码。您可以从[SkyWalking Apache 下载页面](http://skywalking.apache.org/downloads/)下载它。 编译时不需要与git相关的东西。 只需按照以下步骤操作
-
-1. 准备JDK8和maven3
-1. 运行 `./mvnw clean package -DskipTests`
-1. 打包后的代码在`/dist`文件夹中(Linux系统使用.tar.gz文件 and Windows使用.zip文件)。
-
-## 设置IntelliJ IDEA
-1. 将项目按照maven项目的形式导入进来。
-1. 运行 `./mvnw compile -Dmaven.test.skip=true`编译项目并生成源代码。 因为Skywalking使用gRPC和protobuf。
-1. 所以还需要设置 **Generated Source Codes** 文件夹.
-    * **apm-protocol/apm-network/target/generated-sources/protobuf** 文件夹下的`grpc-java` 和 `java`
-    * **oap-server/server-core/target/generated-sources/protobuf** 文件夹下的`grpc-java` 和 `java`
-    * **oap-server/server-receiver-plugin/skywalking-istio-telemetry-receiver-plugin/target/generated-sources/protobuf** 文件夹下的`grpc-java` 和 `java`
-    * **oap-server/generate-tool-grammar/target/generated-sources** 文件夹下的 `antlr4`
-    * **oap-server/generated-analysis/target/generated-sources** 文件夹下的 `oal`
-    
-## 设置Eclipse IDE
-1. 将项目按照maven项目的形式导入进来。
-2. 要支持多个源目录,需要添加以下配置 `incubator-skywalking/pom.xml`:
-
-```
-<plugin>
-    <groupId>org.codehaus.mojo</groupId>
-    <artifactId>build-helper-maven-plugin</artifactId>
-    <version>1.8</version>
-    <executions>
-        <execution>
-            <id>add-source</id>
-            <phase>generate-sources</phase>
-            <goals>
-                <goal>add-source</goal>
-            </goals>
-            <configuration>
-                <sources>
-                    <source>src/java/main</source>
-                    <source>apm-protocol/apm-network/target/generated-sources/protobuf</source>
-                    <source>apm-collector/apm-collector-remote/collector-remote-grpc-provider/target/generated-sources/protobuf</source>
-               </sources>
-            </configuration>
-        </execution>
-    </executions>
-</plugin>
-```
-3. 添加以下配置,让eclipse的M2e插件支持执行的解决方案配置
-
-```
-<pluginManagement>
-    <plugins>
-    <!--This plugin's configuration is used to store Eclipse m2e settings 
-    only. It has no influence on the Maven build itself. -->
-        <plugin>
-            <groupId>org.eclipse.m2e</groupId>
-            <artifactId>lifecycle-mapping</artifactId>
-            <version>1.0.0</version>
-            <configuration>
-                <lifecycleMappingMetadata>
-                    <pluginExecutions>
-                        <pluginExecution>
-                            <pluginExecutionFilter>
-                                <groupId>org.codehaus.mojo</groupId>
-                                <artifactId>build-helper-maven-plugin</artifactId>
-                                <versionRange>[1.8,)</versionRange>
-                                <goals>
-                                    <goal>add-source</goal>
-                                </goals>
-                            </pluginExecutionFilter>
-                        </pluginExecution>
-                    </pluginExecutions>
-                </lifecycleMappingMetadata>
-            </configuration>
-        </plugin>
-    </plugins>
-</pluginManagement>
-```
-4. 将Google guava依赖项添加到 **apm-collector-remote/collector-remote-grpc-provider/pom.xml**文件中
-
-```
-<dependency>
-   <groupId>com.google.guava</groupId>
-   <artifactId>guava</artifactId>
-   <version>24.0-jre</version>
-</dependency>
-```
-5. 运行 `./mvnw compile -Dmaven.test.skip=true`
-6. 运行 `maven update`. update命令前不能有clean(这将清除complie生成的proto转换Java文件)
-7. 运行 `./mvnw compile` 编译 collector-remote-grpc-provider 和 apm-protocol
-8. 刷新项目
diff --git a/docs/others/cn/guides/How-to-release.md b/docs/others/cn/guides/How-to-release.md
deleted file mode 100644
index 1f332d6..0000000
--- a/docs/others/cn/guides/How-to-release.md
+++ /dev/null
@@ -1,377 +0,0 @@
-Apache SkyWalking 发布指南
---------------------
-本文档指导每个提交者在Apache Way中发布SkyWalking,并且还帮助提交者检查发布的投票。
-
-
-## 设置您的开发环境
-按照 [Apache maven部署环境文档](http://www.apache.org/dev/publishing-maven-artifacts.html#dev-env)设置gpg工具和加密密码
-
-使用以下代码块作为模板并将其放入 ~/.m2/settings.xml
-
-```
-<settings>
-...
-  <servers>
-    <!-- To publish a snapshot of some part of Maven -->
-    <server>
-      <id>apache.snapshots.https</id>
-      <username> <!-- YOUR APACHE LDAP USERNAME --> </username>
-      <password> <!-- YOUR APACHE LDAP PASSWORD (encrypted) --> </password>
-    </server>
-    <!-- To stage a release of some part of Maven -->
-    <server>
-      <id>apache.releases.https</id>
-      <username> <!-- YOUR APACHE LDAP USERNAME --> </username>
-      <password> <!-- YOUR APACHE LDAP PASSWORD (encrypted) --> </password>
-    </server>
-   ...
-  </servers>
-</settings>
-```
-
-## 添加您的GPG公钥
-1. 将您的GPG公钥添加到 [SkyWalking GPG KEYS](https://dist.apache.org/repos/dist/release/incubator/skywalking/KEYS) 文件中,
-只有你是一个提交者,使用你的Apache id和密码登录这个svn,并更新文件。 **不要覆盖现有文件**
-1. 将您的GPG公钥上传到公共GPG站点。 如[MIT's 站点](http://pgp.mit.edu:11371/). 这个网站应该在Apache maven staging repository检查列表
-
-## 测试你的配置
-此步骤仅用于测试,如果您的env设置正确,则不需要每次都检查。
-```
-./mvnw clean install -Papache-release (这将构建工件,来源和标志)
-```
-
-## 准备发布
-```
-./mvnw release:clean
-./mvnw release:prepare -DautoVersionSubmodules=true -Pauto-submodule
-```
-_你可以在发布之前做一个GPG标志,如果你需要输入密码进行签名,而且maven没有给出机会,
-但只是失败。 运行`gpg --sign xxx`到任何文件都可以记住密码有足够的时间来发布._
-
-## 发布阶段 
-```
-./mvnw release:perform -DskipTests -Pauto-submodule
-```
-1.将版本号设置为x.y.z,标记为** v ** x.y.z(版本标记必须以** v **开头,您将在下一步中找到目的。)
-1.该版本将自动插入临时存储库中。
-
-## 构建并签署源代码包
-```shell
-export RELEASE_VERSION=x.y.z (example: RELEASE_VERSION=5.0.0-alpha)
-cd tools/releasing
-sh create_source_release.sh
-```
-
-**注意**, `create_source_release.sh` 只适合MacOS。 欢迎任何人贡献Windows bat和Linux shell。
-
-这个脚本应该做以下事情
-1. 使用 `v` + `RELEASE_VERSION` 作为标记来克隆代码。
-1. 完成 `git submodule init/update` .
-1. 排除目标源tar中的所有不必要的文件,例如.git,.github,.gitmodules。 有关详细信息,请参阅脚本。
-1. 执行 `gpg` 和 `shasum 512`. 
-
-
-应该在`tools/releasing`文件夹中找到`apache-skywalking-apm-incubating-x.y.z-src.tgz`和.asc, .sha512结尾的文件
-
-## 在Apache Nexus Staging存储库中查找和下载分发
-1. 使用ApacheId登录 `https://repository.apache.org/`。
-1. 跳转到 `https://repository.apache.org/#stagingRepositories`。
-1. 搜索 `skywalking` 并找到您的暂存存储库。
-1. 关闭存储库并等待所有检查通过。 在此步骤中,将检查您的GPG KEYS。参考[设置PGP文档](#add-your-gpg-public-key),如果你以前没有这样做过。
-1. 跳转到 `{REPO_URL}/org/apache/skywalking/apache-skywalking-apm-incubating/x.y.z`
-1. 下载 `.tar.gz` 和 `.zip` 且有 .asc 和 .sha1 结尾的文件
-
-
-## 上传到Apache svn
-1. 使用ApacheId登录 `https://dist.apache.org/repos/dist/dev/incubator/skywalking/`。
-1. 创建文件夹,按发行版本和圆形命名,例如:x.y.z。
-1. 将源代码包上传到包含.asc,.sha512的文件夹
-    * 包名:apache-skywalking-incubating-x.y.z-src.tar.gz
-    * 有关详细信息,请参见“构建和签署源代码包”一节 
-1. 使用.asc,.sha512将分发包上载到该文件夹
-    * 包名:apache-skywalking-incubating-x.y.z.tar.gz, apache-skywalking-incubating-x.y.z.zip
-    * 有关详细信息,请参见“在Apache Nexus Staging存储库中查找和下载分发”一节
-    * 创建.sha512包: `shasum -a 512 file > file.sha512`
-
-## 发表内部公告
-在开发邮件列表中发送公告邮件。
-
-```
-邮件标题: [ANNOUNCE] SkyWalking x.y.z test build available
-
-邮件内容:
-The test build of x.y.z is available.
-
-This is our Apache Incubator release.
-We welcome any comments you may have, and will take all feedback into
-account if a quality vote is called for this build.
-
-Release notes:
-
- * https://github.com/apache/incubator-skywalking/blob/master/CHANGES.md
-
-Release Candidate:
-
- * https://dist.apache.org/repos/dist/dev/incubator/skywalking/xxxx
- * sha512 checksums
-   - sha512xxxxyyyzzz apache-skywalking-apm-incubating-x.x.x-src.tgz
-   - sha512xxxxyyyzzz apache-skywalking-apm-incubating-x.x.x.tar.gz
-   - sha512xxxxyyyzzz apache-skywalking-apm-incubating-x.x.x.zip
-
-Maven 2 staging repository:
-
- * https://repository.apache.org/content/repositories/xxxx/org/apache/skywalking/
-
-Release Tag :
-
- * (Git Tag) x.y.z
-
-Release CommitID :
-
- * https://github.com/apache/incubator-skywalking/tree/(Git Commit ID)
- * Git submodule
-   * skywalking-ui: https://github.com/apache/incubator-skywalking-ui/tree/(Git Commit ID)
-   * apm-protocol/apm-network/src/main/proto: https://github.com/apache/incubator-skywalking-data-collect-protocol/tree/(Git Commit ID)
-   * oap-server/server-query-plugin/query-graphql-plugin/src/main/resources/query-protocol https://github.com/apache/incubator-skywalking-query-protocol/tree/(Git Commit ID)
-
-Keys to verify the Release Candidate :
-
- * http://pgp.mit.edu:11371/pks/lookup?op=get&search=0x2EF5026E70A55777 corresponding to pengys@apache.org
-
-Guide to build the release from source :
-
- * https://github.com/apache/incubator-skywalking/blob/x.y.z/docs/en/guides/How-to-build.md
-
-A vote regarding the quality of this test build will be initiated
-within the next couple of days.
-```
-
-## 等待至少48小时的测试响应
-任何PPMC,提交者或贡献者都可以测试发布和反馈的功能。
-基于此,PPMC将决定是否开始投票。
-
-## 在dev群组中投票
-在`dev @ skywalking.apache.org`中投票
-
-```
-邮件标题: [VOTE] Release Apache SkyWalking (incubating) version x.y.z
-
-邮件内容:
-Hi All,
-This is a call for vote to release Apache SkyWalking (Incubating) version x.y.z.
-
-Release notes:
-
- * https://github.com/apache/incubator-skywalking/blob/x.y.z/CHANGES.md
-
-Release Candidate:
-
- * https://dist.apache.org/repos/dist/dev/incubator/skywalking/xxxx
- * sha512 checksums
-   - sha512xxxxyyyzzz apache-skywalking-apm-incubating-x.x.x-src.tgz
-   - sha512xxxxyyyzzz apache-skywalking-apm-incubating-x.x.x.tar.gz
-   - sha512xxxxyyyzzz apache-skywalking-apm-incubating-x.x.x.zip
-
-Maven 2 staging repository:
-
- * https://repository.apache.org/content/repositories/xxxx/org/apache/skywalking/
-
-Release Tag :
-
- * (Git Tag) x.y.z
-
-Release CommitID :
-
- * https://github.com/apache/incubator-skywalking/tree/(Git Commit ID)
- * Git submodule
-   * skywalking-ui: https://github.com/apache/incubator-skywalking-ui/tree/(Git Commit ID)
-   * apm-protocol/apm-network/src/main/proto: https://github.com/apache/incubator-skywalking-data-collect-protocol/tree/(Git Commit ID)
-   * oap-server/server-query-plugin/query-graphql-plugin/src/main/resources/query-protocol https://github.com/apache/incubator-skywalking-query-protocol/tree/(Git Commit ID)
-
-Keys to verify the Release Candidate :
-
- * http://pgp.mit.edu:11371/pks/lookup?op=get&search=0x2EF5026E70A55777 corresponding to pengys@apache.org
-
-Guide to build the release from source :
-
- * https://github.com/apache/incubator-skywalking/blob/x.y.z/docs/en/guides/How-to-build.md
-
-Voting will start now (xxxx date) and will remain open for at least 72 hours, Request all PPMC members to give their vote.
-[ ] +1 Release this package.
-[ ] +0 No opinion.
-[ ] -1 Do not release this package because....
-```
-
-## 投票检查
-所有PPMC成员和提交者都应在投票+1之前检查这些。
-
-1. 功能测试。
-1. staging repository中的所有工件都使用.asc,.md5,* sha1文件发布
-1. 源代码和下发包 (apache-skywalking-incubating-x.y.z-src.tar.gz, apache-skywalking-incubating-x.y.z.tar.gz, apache-skywalking-incubating-x.y.z.zip)
-都应该在 `https://dist.apache.org/repos/dist/dev/incubator/skywalking/x.y.z` 且包含 .asc, .sha512
-1. `LICENSE` 和 `NOTICE` 文件在源代码和分发包中。
-1. 检查 `shasum -c apache-skywalking-apm-incubating-x.y.z-src.tgz.sha512`
-1. 构建发布源代码包 (apache-skywalking-incubating-x.y.z-src.tar.gz) by following this [文档](https://github.com/apache/incubator-skywalking/blob/master/docs/en/How-to-build.md#build-from-apache-source-codes).
-1. Apache RAT检查。运行`./mvnw apache-rat:check`. (源代码中没有二进制文件)
-1. 需要有免责声明
-
-投票结果应遵循这些。
-1.PPMC投票是+1绑定,所有其他投票是+1没有约束力。
-1.在72小时内,你得到至少3(+1绑定),并且+1比-1更多。投票通过。
-
-## 要求在Apache IPMC中投票
-在`general @ incubator.apache.org`中投票
-
-```
-邮件标题: [VOTE] Release Apache SkyWalking (incubating) version x.y.z
-
-邮件内容:
-Hi All,
-This is a call for vote to release Apache SkyWalking (Incubating) version x.y.z.
-
-The Apache SkyWalking community has tested, voted and approved the proposed
-release of Apache SkyWalking (Incubating) x.y.z
-
-We now kindly request the Incubator PMC members review and vote on this
-incubator release.
-
-SkyWalking: APM (application performance monitor) tool for distributed systems, 
-especially designed for microservices, cloud native and container-based (Docker, Kubernetes, Mesos) architectures. 
-Underlying technology is a distributed tracing system.
-
-Vote Thread:
-
- * From `list.apache.org`
-
-Result Thread:
-
- * From the vote thread.
-
-Release notes:
-
- * https://github.com/apache/incubator-skywalking/blob/x.y.z/CHANGES.md
-
-Release Candidate:
-
- * https://dist.apache.org/repos/dist/dev/incubator/skywalking/xxxx
- * sha512 checksums
-   - sha512xxxxyyyzzz apache-skywalking-apm-incubating-x.x.x-src.tgz
-   - sha512xxxxyyyzzz apache-skywalking-apm-incubating-x.x.x.tar.gz
-   - sha512xxxxyyyzzz apache-skywalking-apm-incubating-x.x.x.zip
-
-Maven 2 staging repository:
-
- * https://repository.apache.org/content/repositories/xxxx/org/apache/skywalking/
-
-Release Tag :
-
- * (Git Tag) x.y.z
-
-Release CommitID :
-
- * https://github.com/apache/incubator-skywalking/tree/(Git Commit ID)
- * Git submodule
-   * skywalking-ui: https://github.com/apache/incubator-skywalking-ui/tree/(Git Commit ID)
-   * apm-protocol/apm-network/src/main/proto: https://github.com/apache/incubator-skywalking-data-collect-protocol/tree/(Git Commit ID)
-   * oap-server/server-query-plugin/query-graphql-plugin/src/main/resources/query-protocol https://github.com/apache/incubator-skywalking-query-protocol/tree/(Git Commit ID)
-
-Keys to verify the Release Candidate :
-
- * http://pgp.mit.edu:11371/pks/lookup?op=get&search=0x2EF5026E70A55777 corresponding to pengys@apache.org
-
-Guide to build the release from source :
-
- * https://github.com/apache/incubator-skywalking/blob/x.y.z/docs/en/guides/How-to-build.md
-
-Voting will start now (xxxx date) and will remain open for at least 72 hours, Request IPMC to give their vote.
-[ ] +1 Release this package.
-[ ] +0 No opinion.
-[ ] -1 Do not release this package because....
-```
-
-## 投票结果邮件
-关闭投票,如果:
-1. I在72小时内,你得到至少3(+1绑定),并且+1比-1更多。 投票通过。 在IPMC投票中,只有孵化器项目PMC
-投票将被视为+1绑定。
-1. 一些评论者在这个版本中发现了一些严重的错误,团队可以决定取消投票并准备一个新的RC。
-
-发送邮件到 `general@incubator.apache.org` 涉及投票结果和状态.
-```
-邮件标题: [Result][VOTE] Release Apache SkyWalking (incubating) version x.y.z
-
-邮件内容:
-Hi all,
-
-The vote for releasing Apache SkyWalking x.y.z (incubating) is closed, now.
-
-Vote result:
-x (+1 binding) (Names of voters)
-y -1.
-
-Thank you everyone for taking the time to review the release and help us. 
-
-I will process to publish the release and send ANNOUNCE.
-```
-
-## 发版
-1. 将源代码tar球和发行版移动到 `https://dist.apache.org/repos/dist/release/incubator/skywalking/`.
-
-```
-> export SVN_EDITOR=vim
-> svn mv https://dist.apache.org/repos/dist/dev/incubator/skywalking/x.y.z https://dist.apache.org/repos/dist/release/incubator/skywalking
-....
-enter your apache password
-....
-
-```
-2. 在nexus staging repo中发布.
-3. 公共下载源和下发 tar/zip 位于 `http://www.apache.org/dyn/closer.cgi/incubator/skywalking/x.y.z/xxx`.
-我们只发布Apache镜像路径作为发布信息。
-4. 公共asc和sha512位于 `https://www.apache.org/dist/incubator/skywalking/x.y.z/xxx`
-5. 公共密钥指向 `https://www.apache.org/dist/incubator/skywalking/KEYS`
-6. 将ANNOUNCE邮件发送到 `general@incubator.apache.org` 和 `dev@skywalking.apache.org`.
-
-```
-邮件标题: [ANNOUNCE] Release Apache SkyWalking (incubating) version x.y.z
-
-邮件内容:
-Hi all,
-
-Apache SkyWalking (incubating) Team is glad to announce the first release of Apache SkyWalking Incubating x.y.z.
-
-SkyWalking: APM (application performance monitor) tool for distributed systems, 
-especially designed for microservices, cloud native and container-based (Docker, Kubernetes, Mesos) architectures. 
-Underlying technology is a distributed tracing system.
-
-Vote Thread: 
-
-Download Links : http://skywalking.apache.org/downloads/
-
-Release Notes : https://github.com/apache/incubator-skywalking/blob/x.y.z/CHANGES.md
-
-Website: http://skywalking.apache.org/
-
-SkyWalking Resources:
-- Issue: https://github.com/apache/incubator-skywalking/issues
-- Mailing list: dev@skywalkiing.incubator.apache.org
-- Documents: https://github.com/apache/incubator-skywalking/blob/x.y.z/docs/README.md
-
-
-- Apache SkyWalking (incubating) Team
-
-=====
-*Disclaimer*
-
-Apache SkyWalking (incubating) is an effort undergoing incubation at The
-Apache Software Foundation (ASF), sponsored by the name of Apache
-Incubator PMC. Incubation is required of all newly accepted
-projects until a further review indicates that the
-infrastructure, communications, and decision making process have
-stabilized in a manner consistent with other successful ASF
-projects. While incubation status is not necessarily a reflection
-of the completeness or stability of the code, it does indicate
-that the project has yet to be fully endorsed by the ASF.
-```
-
-7. 更新网站下载页面。 http://skywalking.apache.org/downloads/ 。 包括新的下载源,分发,sha512,asc和文档,链接。 可通过遵循上述规则(3) - (6)找到链接。
-8. 在网站主页甚至页面上添加发布活动。 通过更改日志或主要功能宣布公开发布。
diff --git a/docs/others/cn/guides/Java-Plugin-Development-Guide.md b/docs/others/cn/guides/Java-Plugin-Development-Guide.md
deleted file mode 100644
index 6ab318e..0000000
--- a/docs/others/cn/guides/Java-Plugin-Development-Guide.md
+++ /dev/null
@@ -1,299 +0,0 @@
-# 插件开发指南
-本文档描述了如何理解,开发和贡献插件。
-
-## 概念
-### Span
-Span是分布式跟踪系统中一个重要且通用的概念。
-可从[Google Dapper Paper](https://research.google.com/pubs/pub36356.html) 和
-[OpenTracing](http://opentracing.io)学习**Span**相关知识
-
-SkyWalking从2017年开始支持OpenTracing和OpenTracing-Java API,我们的Span概念与论文和OpenTracing类似。我们也扩展了Span。
-
-Span有三种类型
-
-1.1 EntrySpan
-EntrySpan代表服务提供者,也是服务器端的端点。 作为一个APM系统,我们的目标是
-应用服务器。 所以几乎所有的服务和MQ-comsumer都是EntrySpan。
-
-1.2 LocalSpan
-LocalSpan表示普通的Java方法,它与远程服务无关,也不是MQ生产者/消费者
-也不是服务(例如HTTP服务)提供者/消费者。
-
-1.3 ExitSpan
-ExitSpan代表一个服务客户端或MQ的生产者,在SkyWalking的早期命名为“LeafSpan”。
-例如 通过JDBC访问DB,读取Redis / Memcached被编目为ExitSpan。
-
-### ContextCarrier
-为了实现分布式跟踪,需要绑定跨进程的跟踪,并且应该传播上下文
-整个过程。 这就是ContextCarrier的职责。
-
-以下是有关如何在`A -> B`分布式调用中使用**ContextCarrier**的步骤。
-
-1. 在客户端,创建一个新的空的`ContextCarrier`。
-1. 通过 `ContextManager#createExitSpan` 创建一个 ExitSpan 或者 使用 `ContextManager#inject` 来初始化 `ContextCarrier`.
-1. 将`ContextCarrier`所有信息放到heads(例如HTTP HEAD)、attachments(例如Dubbo RPC framework) 或者messages(例如Kafka)
-1. 通过服务调用,将`ContextCarrier`传递到服务端。
-1. 在服务端,在对应组件的heads、attachments或messages获取`ContextCarrier`所有消息。
-1. `ContestManager#createEntrySpan`创建EntrySpan 或者使用 `ContextManager#extract` 将服务端和客户端的绑定。
-
-让我们通过Apache HTTPComponent client插件 和Tomcat 7服务器插件演示,步骤如下:
-
-1. 客户端Apache HTTPComponent client插件
-
-```java
-            span = ContextManager.createExitSpan("/span/operation/name", contextCarrier, "ip:port");
-            CarrierItem next = contextCarrier.items();
-            while (next.hasNext()) {
-                next = next.next();
-                httpRequest.setHeader(next.getHeadKey(), next.getHeadValue());
-            }
-```
-
-2. 服务端Tomcat 7服务器插件
-
-```java
-            ContextCarrier contextCarrier = new ContextCarrier();
-            CarrierItem next = contextCarrier.items();
-            while (next.hasNext()) {
-                next = next.next();
-                next.setHeadValue(request.getHeader(next.getHeadKey()));
-            }
-
-            span = ContextManager.createEntrySpan(“/span/operation/name”, contextCarrier);
-```
-
-### ContextSnapshot
-除了跨进程,跨线程也是需要支持的,例如异步线程(内存中的消息队列)和批处理在java中很常见,跨进程和跨线程十分相似,因为都是需要传播
-上下文。 唯一的区别是,不需要跨线程序列化。
-
-以下是有关跨线程传播的三个步骤:
-1. 使用`ContextManager#capture`获取ContextSnapshot对象。
-2. 让子线程以任何方式,通过方法参数或由现有参数携带来访问ContextSnapshot
-3. 在子线程中使用`ContextManager#continued`。
-
-## 核心 API
-### ContextManager
-ContextManager提供所有主要API。
-
-1. Create EntrySpan
-
-```java
-public static AbstractSpan createEntrySpan(String endpointName, ContextCarrier carrier)
-```
-按操作名称创建 EntrySpan (例如服务名称, uri) 和 **ContextCarrier**.
-
-2. Create LocalSpan
-
-```java
-public static AbstractSpan createLocalSpan(String endpointName)
-```
-按操作名称创建 LocalSpan (例如完整的方法结构)
-
-3. Create ExitSpan
-
-```java
-public static AbstractSpan createExitSpan(String endpointName, ContextCarrier carrier, String remotePeer)
-```
-按操作名称创建 ExitSpan (例如服务名称, uri) 和 **ContextCarrier** 和 对端地址 (例如ip+port或hostname+port)
-
-### AbstractSpan
-```java
-    /**
-     * Set the component id, which defines in {@link ComponentsDefine}
-     *
-     * @param component
-     * @return the span for chaining.
-     */
-    AbstractSpan setComponent(Component component);
-
-    /**
-     * Only use this method in explicit instrumentation, like opentracing-skywalking-bridge.
-     * It it higher recommend don't use this for performance consideration.
-     *
-     * @param componentName
-     * @return the span for chaining.
-     */
-    AbstractSpan setComponent(String componentName);
-
-    AbstractSpan setLayer(SpanLayer layer);
-
-    /**
-     * Set a key:value tag on the Span.
-     *
-     * @return this Span instance, for chaining
-     */
-    AbstractSpan tag(String key, String value);
-
-    /**
-     * Record an exception event of the current walltime timestamp.
-     *
-     * @param t any subclass of {@link Throwable}, which occurs in this span.
-     * @return the Span, for chaining
-     */
-    AbstractSpan log(Throwable t);
-
-    AbstractSpan errorOccurred();
-
-    /**
-     * Record an event at a specific timestamp.
-     *
-     * @param timestamp The explicit timestamp for the log record.
-     * @param event the events
-     * @return the Span, for chaining
-     */
-    AbstractSpan log(long timestamp, Map<String, ?> event);
-
-    /**
-     * Sets the string name for the logical operation this span represents.
-     *
-     * @return this Span instance, for chaining
-     */
-    AbstractSpan setOperationName(String endpointName);
-```
-除了设置操作名称,标签信息和日志外,还要设置两个属性,即component(组件)和layer(层),特别是对于EntrySpan和ExitSpan。
-
-SpanLayer 是span的编目. 有五个值:
-1. UNKNOWN (默认)
-1. DB
-1. RPC_FRAMEWORK, (为了RPC框架,非普通的HTTP调用)for a RPC framework, not an ordinary HTTP
-1. HTTP
-1. MQ
-
-组件ID由SkyWalking项目定义和保留,对于组件的名称或ID的扩展,请遵循[组件库的定义与扩展](Component-library-settings.md) 
-
-## 开发插件
-### Abstract(抽象)
-跟踪的基本方法是拦截Java方法,使用字节码操作技术和AOP概念。
-SkyWalking包装了字节码操作技术并跟踪上下文的传播,
-所以你只需要定义拦截点(换句话说就是Spring的切面)
-
-### Intercept(拦截)
-SkyWalking提供两类通用的定义去拦截构造器,实例方法和类方法。
-* Extend `ClassInstanceMethodsEnhancePluginDefine` defines `Contructor` intercept points and `instance method` intercept points.
-* 继承 `ClassInstanceMethodsEnhancePluginDefine` 定义 `Contructor`(构造器)拦截点和 `instance method`(实例化方法)拦截点.
-* 继承 `ClassStaticMethodsEnhancePluginDefine` 定义 `class method`(类方法)拦截点.
-
-当然,您也可以集成`ClassEnhancePluginDefine`去设置所有的拦截点,担着不常用。
-
-### Implement plugin(实现插件)
-下文,我将通过扩展`ClassInstanceMethodsEnhancePluginDefine`来演示如何实现一个插件
-
-1. 定义目标类的名称
-
-```java
-protected abstract ClassMatch enhanceClass();
-```
-
-ClassMatch 以下有四种方法表示如何去匹配目标类:
-* byName, 通过完整的类名(package name + `.` + class name)(包名+类名)。
-* byClassAnnotationMatch, 通过目标类存在某些注释。
-* byMethodAnnotationMatch, 通过目标类的方法存在某些注释.
-* byHierarchyMatch, 通过目标类的父类或接口
-
-**注意事项**:
-* 禁止使用 `*.class.getName()` 去获取类名, 建议你使用文字字符串,这是为了
-避免ClassLoader问题。
-* `by*AnnotationMatch` 不支持继承的注释.
-* 非必要的话,不推荐使用 `byHierarchyMatch`, 因为使用它可能会触发拦截
-许多未被发现的方法,会导致性能问题和不稳定。
-
-实例:
-
-```java
-@Override
-protected ClassMatch enhanceClassName() {
-    return byName("org.apache.catalina.core.StandardEngineValve");		
-}		      
-
-```
-
-2. 定义实例方法拦截点
-
-```java
-protected InstanceMethodsInterceptPoint[] getInstanceMethodsInterceptPoints();
-
-public interface InstanceMethodsInterceptPoint {
-    /**
-     * class instance methods matcher.
-     *
-     * @return methods matcher
-     */
-    ElementMatcher<MethodDescription> getMethodsMatcher();
-
-    /**
-     * @return represents a class name, the class instance must instanceof InstanceMethodsAroundInterceptor.
-     */
-    String getMethodsInterceptor();
-
-    boolean isOverrideArgs();
-}
-```
-
-也可以使用`Matcher`来设置目标方法。 如果要更改参数,请在`isOverrideArgs`中返回** true ** 参考拦截器。
-
-以下部分将告诉您如何实现拦截器。
-
-3. Add plugin define into skywalking-plugin.def file
-```properties
-tomcat-7.x/8.x=TomcatInstrumentation
-```
-
-
-### 实现一个拦截器
-作为一个实例方法的拦截器,需要实现
-`org.apache.skywalking.apm.agent.core.plugin.interceptor.enhance.InstanceMethodsAroundInterceptor`
-```java
-/**
- * A interceptor, which intercept method's invocation. The target methods will be defined in {@link
- * ClassEnhancePluginDefine}'s subclass, most likely in {@link ClassInstanceMethodsEnhancePluginDefine}
- *
- * @author wusheng
- */
-public interface InstanceMethodsAroundInterceptor {
-    /**
-     * called before target method invocation.
-     *
-     * @param result change this result, if you want to truncate the method.
-     * @throws Throwable
-     */
-    void beforeMethod(EnhancedInstance objInst, Method method, Object[] allArguments, Class<?>[] argumentsTypes,
-        MethodInterceptResult result) throws Throwable;
-
-    /**
-     * called after target method invocation. Even method's invocation triggers an exception.
-     *
-     * @param ret the method's original return value.
-     * @return the method's actual return value.
-     * @throws Throwable
-     */
-    Object afterMethod(EnhancedInstance objInst, Method method, Object[] allArguments, Class<?>[] argumentsTypes,
-        Object ret) throws Throwable;
-
-    /**
-     * called when occur exception.
-     *
-     * @param t the exception occur.
-     */
-    void handleMethodException(EnhancedInstance objInst, Method method, Object[] allArguments, Class<?>[] argumentsTypes,
-        Throwable t);
-}
-```
-在before,after和exception处理阶段使用核心API。
-
-
-### 将插件贡献到Apache SkyWalking 仓库中
-我们欢迎大家贡献插件。
-
-请按照以下步骤操作:
-
-1. 提交有关您要贡献哪些插件的问题,包括支持的版本。
-1. 在`apm-sniffer / apm-sdk-plugin`或`apm-sniffer / optional-plugins`下创建子模块,名称应包含支持的库名和版本
-1. Create sub modules under `apm-sniffer/apm-sdk-plugin` or `apm-sniffer/optional-plugins`, and the name should include supported library name and versions
-1. 按照本指南进行开发。 确保提供评论和测试用例。
-1. 开发并测试。
-1. 发送拉取请求并要求审核。
-1. 提供自动测试用例。 
-所有测试用例都托管在[SkyAPMTest/agent-auto-integration-testcases repository](https://github.com/SkyAPMTest/agent-auto-integration-testcases).
-关于如何编写测试用例,请按照[如何编写](https://github.com/SkyAPMTest/agent-auto-integration-testcases/blob/master/docs/how-to-write-a-plugin-testcase.md) 文档来实现.
-1. 在提供自动测试用例并在CI中递交测试后,插件提交者会批准您的插件。
-1. SkyWalking接受的插件。 
diff --git a/docs/others/cn/guides/README.md b/docs/others/cn/guides/README.md
deleted file mode 100644
index 390e3db..0000000
--- a/docs/others/cn/guides/README.md
+++ /dev/null
@@ -1,43 +0,0 @@
-# 贡献指南
-你可以通过以下方式,为SkyWalking社区做成贡献。
-
-- 审阅SkyWalking的文档,指出或修复文档不准确的地方,也可以将SkyWalking文档翻译成其他语言。
-- 下载我们的[发布版本](http://skywalking.apache.org/downloads/),尝试用其监控你的应用程序,并向我们反馈您的想法、疑问或使用案例。
-- 阅读我们的源码,带着细节信息向我们提问。
-- 发现bug时,可在这里[提交问题](https://github.com/apache/incubator-skywalking/issues), 并且您也可以尝试修复它。
-- 你可以从完成[社区需要的帮助](https://github.com/apache/incubator-skywalking/issues?q=is%3Aopen+is%3Aissue+label%3A%22help+wanted%22),
-着手做起.
-- 提交问题或讨论在[GitHub问题处](https://github.com/apache/incubator-skywalking/issues/new).
-- 通过[网页邮件列表](https://lists.apache.org/list.html?dev@skywalking.apache.org)查看所有邮件的讨论,如果您是SkyWalking项目的committer,可在浏览器模式下登录并使用邮件列表。否则,根据按照下面进行订阅。
-- 问题的报告和讨论也可在 `dev@skywalking.apache.org`进行, 
-发送邮件到`dev-subscribe@skywalking.apache.org`,按照回复订阅邮件列表。
-
-
-## 与我们联系
-以下所有渠道均向社区开放,您可以选择自己喜欢的方式。
-
-* 提交[问题](https://github.com/apache/incubator-skywalking/issues)
-* 邮件列表: **dev@skywalking.apache.org**. 发送邮件到 `dev-subscribe@skywalking.apache.org`,按照回复订阅邮件列表。
-* [Gitter](https://gitter.im/openskywalking/Lobby)
-* QQ群: 392443393
-
-## 对于代码开发者
-作为开发者,首先阅读[编译指南](How-to-build.md). 它会告诉你如何在本地构建。
-
-### 项目扩展
-SkyWalking项目支持许多扩展现有功能的方法。 如果你对这些方式感兴趣,
-阅读以下指南。
-
-- [Java agent 插件开发指南](Java-Plugin-Development-Guide.md).
-本指南将帮助您开发SkyWalking Java agent插件以支持更多框架或组件。 无论是进行开源插件或私有插件的开发都需要阅读这个指南。
-- 如果您想开发其他语言的探针或组件,请阅读[组件库定义和扩展](Component-library-settings.md) 文档.
-- [数据存储扩展开发指南](storage-extention.md). 除了官方已经支持的存储实现外,可帮助钱在的贡献者实现新的数据存储的实现。
-- [通过oal脚本自定义分析](write-oal.md). 指导您使用oal脚本来提供自己所需的指标。
-### UI开发者
-Skywalking UI 由静态页面和Web容器构成。
-
-- **静态页面** 是建立在 [Ant Design Pro](https://pro.ant.design/)之上,Skywalking UI源码托管在[Skywalking UI](https://github.com/apache/incubator-skywalking-ui)。
-- **Web容器** 源代码在`apm-webapp`模块中。这是一个简单的zuul代理,用于托管静态资源并使用GraphQL想后端发送查询请求。
-
-## 发布
-[Apache发布指南](How-to-release.md)向提交者团队介绍了正式的Apache版本发布流程,以避免破坏任何Apache规则。如果您在重新分发中保留我们的许可和通知,则Apache许可允许每个人重新分发。
\ No newline at end of file
diff --git a/docs/others/cn/guides/backend-oal-scripts.md b/docs/others/cn/guides/backend-oal-scripts.md
deleted file mode 100644
index cba020c..0000000
--- a/docs/others/cn/guides/backend-oal-scripts.md
+++ /dev/null
@@ -1,11 +0,0 @@
-# 官方 OAL(可观测性分析语言) 脚本
-首先请阅读[OAL 介绍](../../../en/concepts-and-designs/oal.md).
-
-发行版本中官方脚本:`generated-analysis-x.y.z.jar/official_analysis.oal`,并且源代码库在模块`server-core`中**src/main/resources/official_analysis.oal**。
-**注意**, 这个文件虽然包含在发行版本中,但是在项目运行期间不会起任何作用。您需要使用OAL工具器去真实的分析代码。所生成的代码在`server-core`模块**org.apache.skywalking.oap.server.core.analysis.generated**中
-
-此脚本中命名的所有度量标准都可用于警报和UI查询。 当然,你可以改变这个
-脚本并重新生成分析过程和度量标准,例如添加过滤条件。
-
-如果您尝试添加或删除某些指标,UI项目可能出现问题,我们建议您在计划时执行此操作是
-基于自定义分析核心构建自己的UI。
\ No newline at end of file
diff --git a/docs/others/cn/guides/storage-extention.md b/docs/others/cn/guides/storage-extention.md
deleted file mode 100644
index 0996b77..0000000
--- a/docs/others/cn/guides/storage-extention.md
+++ /dev/null
@@ -1,41 +0,0 @@
-# 数据存储扩展
-SkyWalking g已经提供了多种存储解决方案。在本文档中,您可以
-学习如何轻松实现新存储。
-
-## 定义您的数据存储提供实现
-1. 定义一个类扩展 `org.apache.skywalking.oap.server.library.module.ModuleProvider`.
-2. 将此数据存储提供实现继承存储模块。
-```java
-@Override 
-public Class<? extends ModuleDefine> module() {
-    return StorageModule.class;
-}
-```
-
-## 实现所有DAO接口
-下面是所有数据存储所需实现的DAO接口
-
-1. IServiceInventoryCacheDAO
-1. IServiceInstanceInventoryCacheDAO
-1. H2EndpointInventoryCacheDAO
-1. H2NetworkAddressInventoryCacheDAO
-1. IBatchDAO
-1. StorageDAO
-1. IRegisterLockDAO
-1. H2TopologyQueryDAO
-1. IMetricQueryDAO
-1. ITraceQueryDAO
-1. IMetadataQueryDAO
-1. IAggregationQueryDAO
-1. IAlarmQueryDAO
-1. IHistoryDeleteDAO
-
-## 注册所有的service实现
-在 `public void prepare()`, 使用 `this#registerServiceImplementation` 方法去注册绑定您的接口实现。
-
-## 实例
-`org.apache.skywalking.oap.server.storage.plugin.elasticsearch.StorageModuleElasticsearchProvider` 
-或 `org.apache.skywalking.oap.server.storage.plugin.jdbc.mysql.MySQLStorageProvider`  就是一个很好的例子。
-
-## 重新发布新的数据存储实现
-您不必为了实现数据存储而克隆主托管库,您可以轻松地依赖我们的Apache版本。看一下 [OpenSkywalking/SkyWalking-With-Es5x-Storage](https://github.com/OpenSkywalking/SkyWalking-With-Es5x-Storage) 仓库, SkyWalking v6 重新发布 ElasticSearch 5 TCP 链接数据存储的实现。
\ No newline at end of file
diff --git a/docs/others/cn/guides/write-oal.md b/docs/others/cn/guides/write-oal.md
deleted file mode 100644
index e62d81a..0000000
--- a/docs/others/cn/guides/write-oal.md
+++ /dev/null
@@ -1,15 +0,0 @@
-# 编写 OAL(可观测性分析语言) 脚本
-阅读 [OAL 概述](../../../en/concepts-and-designs/oal.md) 以了解oal脚本。
-
-## 在源代码中查找oal脚本
-官方official_analysis.oal在[这里](../../../../oap-server/generated-analysis/src/main/resources/official_analysis.oal).
-
-## 生成工具
-`oap-server/generate-tool` 模块包含编译工具的源代码。 该工具已经集成在
-maven编译阶段。 所以,除非您想要更改工具源代码,否则无需进行任何设置。
-
-运行 `./mvnw compile` 或 `./mvnw package`, 生成的oal脚本代码位于`oap-server/generate-tool/target/generated-sources/oal/*`.
-
-## 编写并重新编译
-您可以更改`official_analysis.oal`脚本, 然后重新编译代码.
-生成的代码位于 **oap-server/generated-analysis/target/generated-sources/oal**.
\ No newline at end of file
diff --git a/docs/others/cn/protocols/README.md b/docs/others/cn/protocols/README.md
deleted file mode 100644
index 4181dfb..0000000
--- a/docs/others/cn/protocols/README.md
+++ /dev/null
@@ -1,2 +0,0 @@
-# 协议
-TODO
diff --git a/docs/others/cn/setup/README.md b/docs/others/cn/setup/README.md
deleted file mode 100644
index 55abd1d..0000000
--- a/docs/others/cn/setup/README.md
+++ /dev/null
@@ -1,34 +0,0 @@
-# 安装部署
-安装部署基于你将要使用哪种方式。如果你还不太理解,请先参考[概念和设计](../concepts-and-designs/README.md)。
-
-**重要: 请确认受监控的服务器的系统时间和OAP服务的是按保持一致。**
-
-
-## 下载官方发布版本
-- 后端,UI和Java探针通过Apache发布,你可以在 [Apache SkyWalking 下载页面](http://skywalking.apache.org/downloads/)找到.
-
-## 服务中的语言探针
-
-- [Java探针](service-agent/java-agent/README.md). 介绍了在不改代码的情况下将Java探针安装在服务中。
-
-
-下面的探针和SDK兼容SkyWalking的格式和协议,但是由第三方维护。
-你可以去社区的项目中找到发行版和使用方式。
-
-- [SkyAPM .NET Core 探针](https://github.com/SkyAPM/SkyAPM-dotnet). 请阅读.NET Core 探针文档了解详情。
-
-- [SkyAPM Node.js 探针](https://github.com/SkyAPM/SkyAPM-nodejs). 请阅读Node.js server side 探针文档了解详情。
-
-- [SkyAPM PHP SDK](https://github.com/SkyAPM/SkyAPM-php-sdk). 请阅读 PHP 探针文档了解详情。
-
-## 在服务网格中部署
-  - Istio
-    - [SkyWalking on Istio](istio/README.md). 介绍如何避开Istio Mixer的适配器来运行Skywalking。
-    
-
-## 安装后端
-参考[后端和前端部署文档](backend/backend-ui-setup.md)来学习和配置,或者开启新特性以在不同场景下使用。
-
-## 更新日志
-后端, 前端和Java探针的所有更新可[参考](../../../../CHANGES.md).
-
diff --git a/docs/others/cn/setup/backend/backend-receivers.md b/docs/others/cn/setup/backend/backend-receivers.md
deleted file mode 100644
index 7fbb3a4..0000000
--- a/docs/others/cn/setup/backend/backend-receivers.md
+++ /dev/null
@@ -1,2 +0,0 @@
-# 选择接收器
-TODO
diff --git a/docs/others/cn/setup/backend/backend-ui-setup.md b/docs/others/cn/setup/backend/backend-ui-setup.md
deleted file mode 100644
index c844082..0000000
--- a/docs/others/cn/setup/backend/backend-ui-setup.md
+++ /dev/null
@@ -1,2 +0,0 @@
-# 后端和前端
-TODO
diff --git a/docs/others/cn/setup/istio/README.md b/docs/others/cn/setup/istio/README.md
deleted file mode 100644
index a99d3b5..0000000
--- a/docs/others/cn/setup/istio/README.md
+++ /dev/null
@@ -1,2 +0,0 @@
-# 配合Istio
-TODO
diff --git a/docs/others/cn/setup/service-agent/java-agent/README.md b/docs/others/cn/setup/service-agent/java-agent/README.md
deleted file mode 100644
index 044d8f2..0000000
--- a/docs/others/cn/setup/service-agent/java-agent/README.md
+++ /dev/null
@@ -1,2 +0,0 @@
-# 安装Java探针
-TODO