diff --git a/docusaurus.config.js b/docusaurus.config.js
index f5c5a3086a3..dcc95ea22c2 100644
--- a/docusaurus.config.js
+++ b/docusaurus.config.js
@@ -161,14 +161,15 @@ const darkCodeTheme = require('prism-react-renderer/themes/dracula');
label: 'Doc',
position: 'right',
items: [
- {label: '1.6.0', to: '/docs/latest/about/introduction'},
+ {label: '1.7.0', to: '/docs/latest/about/introduction'},
+ {label: '1.6.0', to: '/docs/1.6.0/about/introduction'},
{label: '1.5.0', to: '/docs/1.5.0/about/introduction'},
{label: '1.4.0', to: '/docs/1.4.0/about/introduction'},
// {label: '1.3.1', to: '/docs/1.3.1/about/introduction'},
// {label: '1.3.0', to: '/docs/1.3.0/introduction'},
// {label: '1.2.0', to: '/docs/1.2.0/introduction'},
// {label: '1.1.1', to: '/docs/1.1.1/introduction'},
- {label: 'Next(1.7.0)', to: '/docs/1.7.0/about/introduction'},
+ {label: 'Next(1.8.0)', to: '/docs/1.8.0/about/introduction'},
{label: 'All Version', to: '/versions'}
]
},
@@ -358,7 +359,7 @@ const darkCodeTheme = require('prism-react-renderer/themes/dracula');
createRedirects(existingPath) {
if (existingPath.includes('/latest')) {
return [
- existingPath.replace('/latest', '/1.5.0'),
+ existingPath.replace('/latest', '/1.7.0'),
];
}
return undefined; // Return a false value: no redirect created
diff --git a/download/main.md b/download/main.md
index 1a92f523eef..cdad04b8046 100644
--- a/download/main.md
+++ b/download/main.md
@@ -9,6 +9,7 @@ Use the links below to download the Apache Linkis Releases, the latest release i
| Version | Release Date | Source | Binary | Web Binary | Release Notes |
|----------------------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
+| 1.7.0 | 2025-01-06 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.6.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.6.0.md) |
| 1.6.0 | 2024-07-12 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.6.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.6.0.md) |
| 1.5.0 | 2023-12-27 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.5.0.md) |
| 1.4.0 | 2023-08-05 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.4.0.md) |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs-download/current/main.md b/i18n/zh-CN/docusaurus-plugin-content-docs-download/current/main.md
index 69f354a2cb6..47b24e2b435 100644
--- a/i18n/zh-CN/docusaurus-plugin-content-docs-download/current/main.md
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs-download/current/main.md
@@ -8,19 +8,20 @@ sidebar_position: 0
| 版本 | 发布时间 | 源码 | 项目安装包 | 管理台安装包 | Release Notes |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
-| 1.6.0 | 2024-07-12 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.6.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.6.0.md) |
-| 1.5.0 | 2023-12-27 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.5.0.md) |
-| 1.4.0 | 2023-08-05 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.4.0.md) |
-| 1.3.2 | 2023-04-03 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.3.2.md) |
-| 1.3.1 | 2023-01-18 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.3.1.md) |
-| 1.3.0 | 2022-10-25 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.3.0.md) |
-| 1.2.0 | 2022-09-05 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.2.0.md) |
-| 1.1.3 | 2022-08-01 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.1.3.md) |
-| 1.1.2 | 2022-07-04 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.1.2.md) |
-| 1.1.1 | 2022-05-24 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.1.1.md) |
-| 1.1.0 | 2022-04-15 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.1.0.md) |
-| 1.0.3 | 2022-01-29 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.0.3.md) |
-| 1.0.2 (Non-ASF ) | 2021-09-02 | [[Source](https://github.com/apache/linkis/archive/refs/tags/1.0.2.tar.gz)] | [[Binary](https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeDatasphere/Linkis/1.0.2/wedatasphere-linkis-1.0.2-combined-package-dist.tar.gz)] | | [Release-Notes](release-notes-1.0.2.md) |
+| 1.7.0 | 2025-01-06 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.7.0/apache-linkis-1.7.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.6.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.6.0.md) |
+| 1.6.0 | 2024-07-12 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.6.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.6.0/apache-linkis-1.6.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.6.0.md) |
+| 1.5.0 | 2023-12-27 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.5.0/apache-linkis-1.5.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.5.0.md) |
+| 1.4.0 | 2023-08-05 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.4.0/apache-linkis-1.4.0-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.4.0.md) |
+| 1.3.2 | 2023-04-03 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/1.3.2/apache-linkis-1.3.2-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.3.2.md) |
+| 1.3.1 | 2023-01-18 | [[Source](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-web-bin.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/linkis/release-1.3.1/apache-linkis-1.3.1-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.3.1.md) |
+| 1.3.0 | 2022-10-25 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.3.0/apache-linkis-1.3.0-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.3.0.md) |
+| 1.2.0 | 2022-09-05 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.2.0/apache-linkis-1.2.0-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.2.0.md) |
+| 1.1.3 | 2022-08-01 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.3/apache-linkis-1.1.3-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.1.3.md) |
+| 1.1.2 | 2022-07-04 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.2/apache-linkis-1.1.2-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.1.2.md) |
+| 1.1.1 | 2022-05-24 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.1/apache-linkis-1.1.1-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.1.1.md) |
+| 1.1.0 | 2022-04-15 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.1.0/apache-linkis-1.1.0-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.1.0.md) |
+| 1.0.3 | 2022-01-29 | [[Source](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-src.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-src.tar.gz.asc)] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-src.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-bin.tar.gz.asc) ][[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-bin.tar.gz.sha512)] | [[Binary](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-web-bin.tar.gz)] [[Sign](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-web-bin.tar.gz.asc )] [[SHA512](https://www.apache.org/dyn/closer.lua/incubator/linkis/release-1.0.3/apache-linkis-1.0.3-incubating-web-bin.tar.gz.sha512)] | [Release-Notes](release-notes-1.0.3.md) |
+| 1.0.2 (Non-ASF ) | 2021-09-02 | [[Source](https://github.com/apache/linkis/archive/refs/tags/1.0.2.tar.gz)] | [[Binary](https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeDatasphere/Linkis/1.0.2/wedatasphere-linkis-1.0.2-combined-package-dist.tar.gz)] | | [Release-Notes](release-notes-1.0.2.md) |
## 完整性校验
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/current.json b/i18n/zh-CN/docusaurus-plugin-content-docs/current.json
index 89db75babb4..054e0655fad 100644
--- a/i18n/zh-CN/docusaurus-plugin-content-docs/current.json
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/current.json
@@ -1,6 +1,6 @@
{
"version.label": {
- "message": "Next(1.7.0)",
+ "message": "Next(1.8.0)",
"description": "The label for version current"
},
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0.json
new file mode 100644
index 00000000000..89db75babb4
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0.json
@@ -0,0 +1,163 @@
+{
+ "version.label": {
+ "message": "Next(1.7.0)",
+ "description": "The label for version current"
+ },
+
+ "sidebar.tutorialSidebar.category.About Linkis": {
+ "message": "关于 Linkis"
+ },
+
+ "sidebar.tutorialSidebar.category.Quick Experience": {
+ "message": "快速体验",
+ "description": "The label for category Quick in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Deployment": {
+ "message": "部署指南",
+ "description": "The label for category advanced Deployment in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.User Guide": {
+ "message": "使用指南",
+ "description": "The label for category User Guide in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Engine Usage": {
+ "message": "引擎使用",
+ "description": "The label for category Engine Usage in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Tuning And Troubleshooting": {
+ "message": "调优排障",
+ "description": "The label for category Tuning And Troubleshooting in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Error Guide": {
+ "message": "错误码",
+ "description": "The label for category Error Guide in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.API Docs": {
+ "message": "API文档",
+ "description": "The label for category API Docs in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Table Structure": {
+ "message": "表结构",
+ "description": "The label for category Table Structure in sidebar tutorialSidebar"
+ },
+
+ "sidebar.tutorialSidebar.category.Architecture": {
+ "message": "架构设计",
+ "description": "The label for category Architecture in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Commons": {
+ "message": "公共依赖模块",
+ "description": "The label for category Commons in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Computation Governance Services": {
+ "message": "计算治理模块",
+ "description": "The label for category Computation Governance Services in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Engine": {
+ "message": "引擎服务",
+ "description": "The label for category Engine Services in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Linkis Manager": {
+ "message": "Manager架构",
+ "description": "The label for category Linkis Manager in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Public Enhancement Services": {
+ "message": "公共增强模块",
+ "description": "The label for category Public Enhancement Services in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Context Service": {
+ "message": "上下文服务",
+ "description": "The label for category Public Enhancement Services in sidebar tutorialSidebar"
+ },
+
+ "sidebar.tutorialSidebar.category.Microservice Governance Services": {
+ "message": "微服务实例模块",
+ "description": "The label for category Microservice Governance Services in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Orchestrator": {
+ "message": "编排器架构",
+ "description": "The label for category Orchestrator Services in sidebar tutorialSidebar"
+ },
+
+ "sidebar.tutorialSidebar.category.Upgrade Guide": {
+ "message": "升级指南",
+ "description": "The label for category Upgrade Guide in sidebar tutorialSidebar"
+ },
+
+ "sidebar.tutorialSidebar.category.Development": {
+ "message": "开发指南",
+ "description": "The label for category Development Doc in sidebar tutorialSidebar"
+ },
+ "sidebar.tutorialSidebar.category.Development Specification": {
+ "message": "开发规范",
+ "description": "The label for category Development Specification in sidebar tutorialSidebar"
+ },
+
+ "sidebar.tutorialSidebar.category.Components": {
+ "message": "组件介绍",
+ "description": "The label for category Components in sidebar tutorialSidebar"
+ },
+
+ "sidebar.tutorialSidebar.category.Engine Plugin Management Service": {
+ "message": "引擎插件管理服务",
+ "description": "Engine Plugin Management Service"
+ },
+ "sidebar.tutorialSidebar.category.Computing Governance Portal Service": {
+ "message": "计算治理入口服务",
+ "description": "Computing Governance Portal Service"
+ },
+ "sidebar.tutorialSidebar.category.Computing Governance Management Services": {
+ "message": "计算治理管理服务",
+ "description": "Computing Governance Management Services"
+ },
+ "sidebar.tutorialSidebar.category.Public Service": {
+ "message": "公共服务",
+ "description": "Public Service"
+ },
+ "sidebar.tutorialSidebar.category.Quick Start": {
+ "message": "快速上手",
+ "description": "quick start"
+ },
+ "sidebar.tutorialSidebar.category.Integrated": {
+ "message": "集成",
+ "description": "integrated"
+ },
+ "sidebar.tutorialSidebar.category.Console Manual": {
+ "message": "管理台的使用",
+ "description": "console manual"
+ },
+ "sidebar.tutorialSidebar.category.Security Authentication": {
+ "message": "安全认证"
+ },
+ "sidebar.tutorialSidebar.category.Service Architecture": {
+ "message": "微服务架构",
+ "description": "linkis service architecture"
+ },
+ "sidebar.tutorialSidebar.category.Feature": {
+ "message": "关键特性架构",
+ "description": "key feature architechture"
+ },
+ "sidebar.tutorialSidebar.category.Control Panel": {
+ "message": "管理台的使用",
+ "description": "control panel usage"
+ },
+ "sidebar.tutorialSidebar.category.Advice Configuration": {
+ "message": "建议配置",
+ "description": "Linkis advice configuration"
+ },
+ "sidebar.tutorialSidebar.category.LinkisManger Services": {
+ "message": "LinkisManger 服务",
+ "description": "LinkisManger Services"
+ },
+ "sidebar.tutorialSidebar.category.Entrance Services": {
+ "message": "Entrance 服务",
+ "description": "Entrance Services"
+ },
+ "sidebar.tutorialSidebar.category.Version Feature": {
+ "message": "版本特性",
+ "description": "Version Feature"
+ }
+
+
+
+}
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/_category_.json
new file mode 100644
index 00000000000..2c333deaa77
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "关于 Linkis",
+ "position": 1.0
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/configuration.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/configuration.md
new file mode 100644
index 00000000000..fa6358f012b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/configuration.md
@@ -0,0 +1,179 @@
+---
+title: 建议配置
+sidebar_position: 0.2
+---
+
+## 1 软硬件环境建议配置
+
+Linkis 在上层应用程序和底层引擎之间构建了一层计算中间件。 作为一款开源分布式计算中间件,可以很好地部署和运行在 Intel 架构服务器及主流虚拟化环境下,并支持主流的Linux操作系统环境
+
+### 1.1 Linux 操作系统版本要求
+
+| 操作系统 | 版本 |
+| --- | --- |
+| Red Hat Enterprise Linux | 7.0 及以上 |
+| CentOS | 7.0 及以上 |
+| Oracle Enterprise Linux | 7.0 及以上 |
+| Ubuntu LTS | 16.04 及以上 |
+
+> **注意:** 以上 Linux 操作系统可运行在物理服务器以及 VMware、KVM、XEN 主流虚拟化环境上
+
+### 1.2 服务器建议配置
+
+Linkis 支持运行在 Intel x86-64 架构的 64 位通用硬件服务器平台。对生产环境的服务器硬件配置有以下建议:
+
+#### 生产环境
+
+| **CPU** | **内存** | **硬盘类型** | **网络** | **实例数量** |
+| --- | --- | --- | --- | --- |
+| 16核+ | 32GB+ | SAS | 千兆网卡 | 1+ |
+
+> **注意:**
+>
+> - 以上建议配置为部署 Linkis的最低配置,生产环境强烈推荐使用更高的配置
+> - 硬盘大小配置建议 50GB+ ,系统盘和数据盘分开
+
+### 1.3 软件要求
+
+Linkis二进制包基于以下软件版本进行编译:
+
+| 组件 | 版本 | 说明 |
+| --- | --- | --- |
+| Hadoop | 3.3.4 | |
+| Hive | 3.1.3 | |
+| Spark | 3.2.1 | |
+| Flink | 1.12.2 | |
+| openLooKeng | 1.5.0 | |
+| Sqoop | 1.4.6 | |
+| ElasticSearch | 7.6.2 | |
+| Presto | 0.234 | |
+| Python | Python2 | |
+
+> **注意:**
+> 如果本地安装组件版本与上述不一致,需要进行修改对应组件版本,自行编译二进制包进行安装。
+
+### 1.4 客户端 Web 浏览器要求
+
+Linkis推荐 Chrome 73版本进行前端访问
+
+
+## 2 常用场景
+
+### 2.1 开启测试模式
+开发过程需要免密接口,可在`linkis.properties`替换或追加此配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.test.mode | false | 是否打开调试模式,如果设置为 true,所有微服务都支持免密登录,且所有EngineConn打开远程调试端口 |
+| wds.linkis.test.user | hadoop | 当wds.linkis.test.mode=true时,免密登录的默认登录用户 |
+
+![](./images/test-mode.png)
+
+
+### 2.2 登录用户设置
+Apache Linkis 默认使用配置文件来管理admin用户,可以在`linkis-mg-gateway.properties`替换或追加此配置。如需多用户可接入LDAP实现。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.admin.user | hadoop | 管理员用户名 |
+| wds.linkis.admin.password | 123456 | 管理员用户密码 |
+
+![](./images/login-user.png)
+
+
+### 2.3 LDAP设置
+Apache Linkis 可以通过参数接入LDAP实现多用户管理,可以在`linkis-mg-gateway.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.ldap.proxy.url | 无 | LDAP URL地址 |
+| wds.linkis.ldap.proxy.baseDN | 无 | LDAP baseDN地址 |
+| wds.linkis.ldap.proxy.userNameFormat | 无 | |
+
+![](./images/ldap.png)
+
+### 2.4 关闭资源检查
+Apache Linkis 提交任务时有时会调试异常,如:资源不足;可以在`linkis-cg-linkismanager.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.manager.rm.request.enable | true | 资源检查 |
+
+![](./images/resource-enable.png)
+
+### 2.5 开启引擎调试
+Apache Linkis EC可以开启调试模式,可以在`linkis-cg-linkismanager.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.engineconn.debug.enable | true | 是否开启引擎调试 |
+
+![](./images/engine-debug.png)
+
+### 2.6 Hive元数据配置
+Apache Linkis 的public-service服务需要读取hive的元数据;可以在`linkis-ps-publicservice.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| hive.meta.url | 无 | HiveMetaStore数据库的URL。 |
+| hive.meta.user | 无 | HiveMetaStore数据库的user |
+| hive.meta.password | 无 | HiveMetaStore数据库的password |
+
+![](./images/hive-meta.png)
+
+### 2.7 Linkis 数据库配置
+Apache Linkis 访问默认使用Mysql作为数据存储,可以在`linkis.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.server.mybatis.datasource.url | 无 | 数据库连接字符串,例如:jdbc:mysql://127.0.0.1:3306/dss?characterEncoding=UTF-8 |
+| wds.linkis.server.mybatis.datasource.username | 无 | 数据库用户名,例如:root |
+| wds.linkis.server.mybatis.datasource.password | 无 | 数据库密码,例如:root |
+
+![](./images/linkis-db.png)
+
+### 2.8 Linkis Session 缓存配置
+Apache Linkis 支持使用redis进行session的共享;可以在`linkis.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| linkis.session.redis.cache.enabled | None | 是否开启 |
+| linkis.session.redis.host | 127.0.0.1 | 主机名 |
+| linkis.session.redis.port | 6379 | 端口,例如 |
+| linkis.session.redis.password | None | 密码 |
+
+![](./images/redis.png)
+
+### 2.9 Linkis 模块开发配置
+Apache Linkis 开发时可通过此参数,自定义加载模块的数据库、Rest接口、实体对象;可以在`linkis-ps-publicservice.properties`进行修改,多个模块之间使用逗号分割。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.server.restful.scan.packages | 无 | restful 扫描包,例如:org.apache.linkis.basedatamanager.server.restful |
+| wds.linkis.server.mybatis.mapperLocations | 无 | mybatis mapper文件路径,例如: classpath*:org/apache/linkis/basedatamanager/server/dao/mapper/*.xml|
+| wds.linkis.server.mybatis.typeAliasesPackage | 无 | 实体别名扫描包,例如:org.apache.linkis.basedatamanager.server.domain |
+| wds.linkis.server.mybatis.BasePackage | 无 | 数据库dao层扫描,例如:org.apache.linkis.basedatamanager.server.dao |
+
+![](./images/deverlop-conf.png)
+
+### 2.10 Linkis 模块开发配置
+Apache Linkis 开发时可通过此参数,自定义加载模块的路由;可以在`linkis.properties`进行修改,多个模块之间使用逗号分割。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.gateway.conf.publicservice.list | cs,contextservice,data-source-manager,metadataQuery,metadatamanager,query,jobhistory,application,configuration,filesystem,udf,variable,microservice,errorcode,bml,datasource,basedata-manager | publicservice服务支持路由的模块 |
+
+![](./images/list-conf.png)
+
+### 2.11 Linkis 文件系统及物料存放路径
+Apache Linkis 开发时可通过此参数,自定义加载模块的路由;可以在`linkis.properties`进行修改,多个模块之间使用逗号分割。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.filesystem.root.path | file:///tmp/linkis/ | 本地用户目录,需在该目录下建立以用户名为名称的文件夹 |
+| wds.linkis.filesystem.hdfs.root.path | hdfs:///tmp/ | HDFS用户目录 |
+| wds.linkis.bml.is.hdfs | true | 是否启用hdfs |
+| wds.linkis.bml.hdfs.prefix | /apps-data | hdfs路径 |
+| wds.linkis.bml.local.prefix | /apps-data | 本地路径 |
+
+![](./images/fs-conf.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/glossary.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/glossary.md
new file mode 100644
index 00000000000..76ed35f4abc
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/glossary.md
@@ -0,0 +1,105 @@
+---
+title: 名词解释和服务介绍
+sidebar_position: 0.3
+---
+
+## 1.名词解释
+
+Linkis 基于微服务架构开发,其服务可以分为3类服务群(组):计算治理服务组、公共增强服务组和微服务治理服务组。
+- 计算治理服务组(Computation Governance Services):处理任务的核心服务,支持计算任务/请求处理流程的4个主要阶段(提交->准备->执行->结果);
+- 公共增强服务组(Public Enhancement Services):提供基础的支撑服务,包括上下文服务、引擎/udf物料的管理服务、历史任务等公共服务及数据源的管理服务等;
+- 微服务治理服务组(Microservice Governance Services):定制化的Spring Cloud Gateway、Eureka。提供微服务的基础底座
+
+下面将对这三组服务的关键名词和服务进行介绍:
+
+### 1.1 关键模块名词
+
+首先我们了解下关键模块的名词
+
+| 简称 | 全称 | 主要功能 |
+|-------- |------------------------- |---------------------|
+| MG/mg | Microservice Governance | 微服务治理 |
+| CG/cg | Computation Governance | 计算治理 |
+| EC/ec | EngineConn | 引擎连接器 |
+| - | Engine | 底层计算存储引擎,如spark、hive、shell |
+| ECM/ecm | EngineConnManager | 引擎连接器的管理 |
+| ECP/ecp | EngineConnPlugin | 引擎连接器插件 |
+| RM/rm | ResourceManager | 资源管理器,用于管控任务资源和用户资源使用和控制 |
+| AM/am | AppManager | 应用管理器,用于管控EngineConn和ECM服务 |
+| LM/lm | LinkisManager | Linkis管理器服务,包含了:RM、AM、LabelManager等模块 |
+| PES/pes | Public Enhancement Services | 公共增强服务 |
+| - | Orchestrator | 编排器,用于Linkis任务编排,任务多活、混算、AB等策略支持 |
+| UJES | Unified Job Execute Service | 统一作业执行服务 |
+| DDL/ddl | Data Definition Language | 数据库定义语言 |
+| DML/dml | Data Manipulation Language | 数据操纵语言 |
+
+### 1.2 任务关键名词
+
+- JobRequest: 任务请求,对应Client提交给Linkis的任务,包含任务的执行内容、用户、标签等信息
+- RuntimeMap: 任务运行时参数,任务的运行时参数,任务级别生效,如放置多数据源的数据源信息
+- StartupMap: 引擎连接器启动参数,用于EngineConn连机器启动的参数,EngineConn进程生效,如设置spark.executor.memory=4G
+- UserCreator: 任务创建者信息:包含用户信息User和Client提交的应用信息Creator,用于任务和资源的租户隔离
+- submitUser: 任务提交用户
+- executeUser: 任务真实执行用户
+- JobSource: 任务来源信息,记录任务的IP或者脚本地址
+- errorCode: 错误码,任务错误码信息
+- JobHistory: 任务历史持久化模块,提供任务的历史信息查询
+- ResultSet: 结果集,任务对应的结果集,默认以.dolphin文件后缀进行保存
+- JobInfo: 任务运行时信息,如日志、进度、资源信息等
+- Resource: 资源信息,每个任务都会消耗资源
+- RequestTask: EngineConn的最小执行单元,传输给EngineConn执行的任务单元
+
+
+
+## 2. 服务介绍
+
+本节主要对Linkis的服务进行介绍,了解Linkis启动后会有哪些服务,以及服务的作用。
+
+### 2.1 服务列表
+
+Linkis启动后各个服务群(组)下包括的微服务如下:
+
+| 归属的微服务群(组) | 服务名 | 主要功能 |
+| ---- | ---- | ---- |
+| MGS | linkis-mg-eureka | 负责服务注册与发现,上游其他组件也会复用linkis的注册中心,如dss|
+| MGS | linkis-mg-gateway | 作为Linkis的网关入口,主要承担了请求转发、用户访问认证 |
+| CGS | linkis-cg-entrance | 任务提交入口是用来负责计算任务的接收、调度、转发执行请求、生命周期管理的服务,并且能把计算结果、日志、进度返回给调用方 |
+| CGS | linkis-cg-linkismanager|提供了AppManager(应用管理)、ResourceManager(资源管理)、LabelManager(标签管理)、引擎连接器插件管理的能力 |
+| CGS | linkis-cg-engineconnmanager | EngineConn的管理器,提供引擎的生命周期管理 |
+| CGS | linkis-cg-engineconn| 引擎连接器服务,是与底层计算存储引擎(Hive/Spark)的实际连接的服务,包含了与实际引擎的会话信息。对于底层计算存储引擎来说 它充当了一个客户端的角色,由任务触发启动|
+| PES | linkis-ps-publicservice|公共增强服务组模块服务,为其他微服务模块提供统一配置管理、上下文服务、BML物料库、数据源管理、微服务管理和历史任务查询等功能 |
+
+启动后开源看到的所有服务如下图:
+![Linkis_Eureka](/Images/deployment/Linkis_combined_eureka.png)
+
+### 2.1 公共增强服务详解
+公共增强服务组(PES)在1.3.1版本后默认将相关模块服务合并为一个服务linkis-ps-publicservice提供相关功能,当然如果你希望分开部署也支持的。您只需要将对应模块的服务打包部署即可。
+合并后的公共增强服务,主要包含了以下功能:
+
+| 简称 | 全称 | 主要功能 |
+|-------- |------------------------- |---------------------|
+| CS/cs | Context Service | 上下文服务,用于任务间传递结果集、变量、文件等 |
+| UDF/udf | UDF | UDF管理模块,提供UDF和函数的管理功能,支持共享和版本控制 |
+| variable | Variable | 全局自定义模块,提供全局自定变量的管理功能 |
+| script | Script-dev | 脚本文件操作服务,提供脚本编辑保存、脚本目录管理功能 |
+| jobHistory | JobHistory | 任务历史持久化模块,提供任务的历史信息查询 |
+| BML/bml | BigData Material library | 大数据物料库 |
+| - | Configuration | 配置管理,提供配置参数的管理和查看的功能 |
+| - | instance-label | 微服务管理服务,提供微服务和路由标签的映射管理功能 |
+| - | error-code | 错误码管理,提供通过错误码管理的功能 |
+| DMS/dms | Data Source Manager Service | 数据源管理服务 |
+| MDS/mds | MetaData Manager Service | 元数据管理服务 |
+| - | linkis-metadata | 提供Hive元数据信息查看功能,后续将会合并到到MDS |
+| - | basedata-manager | 基础数据管理,用于管理Linkis自身的基础元数据信息 |
+
+## 3 模块介绍
+本节主要对Linkis的大模块和功能进行主要介绍
+
+- linkis-commons: linkis的公共模块,包含了公共的工具类模块、RPC模块、微服务基础等模块
+- linkis-computation-governance: 计算治理模块,包含了计算治理多个服务的模块:Entrance、LinkisManager、EngineConnManager、EngineConn等
+- linkis-engineconn-plugins: 引擎连接器插件模块,包含了所有的引擎连接器插件实现
+- linkis-extensions: Linkis的扩展增强模块,不是必要功能模块,现在主要包含了文件代理操作的IO模块
+- linkis-orchestrator: 编排模块,用于Linkis任务编排,任务多活、混算、AB等高级策略支持
+- linkis-public-enhancements: 公共增强模块,包含了所有的公共服务用于给到linkis内部和上层应用组件进行调用
+- linkis-spring-cloud-services: spring cloud相关的服务模块,包含了gateway、注册中心等
+- linkis-web: 前端模块
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/deverlop-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/deverlop-conf.png
new file mode 100644
index 00000000000..3d5fc8af601
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/deverlop-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/engine-debug.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/engine-debug.png
new file mode 100644
index 00000000000..788bd2b58f0
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/engine-debug.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/fs-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/fs-conf.png
new file mode 100644
index 00000000000..85c4234a9b4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/fs-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/hive-meta.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/hive-meta.png
new file mode 100644
index 00000000000..50c02906a77
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/hive-meta.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/ldap.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/ldap.png
new file mode 100644
index 00000000000..9625ae20be0
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/ldap.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/linkis-db.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/linkis-db.png
new file mode 100644
index 00000000000..35f7f5573df
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/linkis-db.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/list-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/list-conf.png
new file mode 100644
index 00000000000..d19c194a023
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/list-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/login-user.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/login-user.png
new file mode 100644
index 00000000000..477c634f1d4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/login-user.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/redis.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/redis.png
new file mode 100644
index 00000000000..3a064640613
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/redis.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/resource-enable.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/resource-enable.png
new file mode 100644
index 00000000000..973fcee8409
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/resource-enable.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/test-mode.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/test-mode.png
new file mode 100644
index 00000000000..3466b1b8857
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/images/test-mode.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/introduction.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/introduction.md
new file mode 100644
index 00000000000..d28a99ba891
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/about/introduction.md
@@ -0,0 +1,115 @@
+---
+title: 简述
+sidebar_position: 0
+---
+## 关于 Linkis
+
+Linkis 在上层应用程序和底层引擎之间构建了一层计算中间件。通过使用Linkis 提供的REST/WebSocket/JDBC 等标准接口,上层应用可以方便地连接访问MySQL/Spark/Hive/Presto/Flink 等底层引擎,同时实现统一变量、脚本、用户定义函数和资源文件等用户资源的跨上层应用互通,以及通过REST标准接口提供了数据源管理和数据源对应的元数据查询服务。
+作为计算中间件,Linkis 提供了强大的连通、复用、编排、扩展和治理管控能力。通过将应用层和引擎层解耦,简化了复杂的网络调用关系,降低了整体复杂度,同时节约了整体开发和维护成本。
+Linkis 自2019年开源发布以来,已累计积累了700多家试用企业和1000多位沙盒试验用户,涉及金融、电信、制造、互联网等多个行业。许多公司已经将Linkis 作为大数据平台底层计算存储引擎的统一入口,和计算请求/任务的治理管控利器。
+
+![没有Linkis 之前](/Images-zh/before_linkis_cn.png)
+
+![有了Linkis 之后](/Images-zh/after_linkis_cn.png)
+
+## 核心特点
+- **丰富的底层计算存储引擎支持**:Spark、Hive、Python、Shell、Flink、JDBC、Pipeline、Sqoop、OpenLooKeng、Presto、ElasticSearch、Trino、SeaTunnel 等;
+- **丰富的语言支持**:SparkSQL、HiveSQL、Python、Shell、Pyspark、Scala、JSON 和 Java 等;
+- **强大的计算治理能力**: 能够提供基于多级标签的任务路由、负载均衡、多租户、流量控制、资源控制等能力;
+- **全栈计算存储引擎架构支持**: 能够接收、执行和管理针对各种计算存储引擎的任务和请求,包括离线批量任务、交互式查询任务、实时流式任务和数据湖任务;
+- **统一上下文服务**:支持跨用户、系统、计算引擎去关联管理用户和系统的资源文件(JAR、ZIP、Properties 等),结果集、参数变量、函数、UDF等,一处设置,处处自动引用;
+- **统一物料**: 提供了系统和用户级物料管理,可分享和流转,跨用户、跨系统共享物料;
+- **统一数据源管理**: 提供了Hive、ElasticSearch、Mysql、Kafka、MongoDB 等类型数据源信息的增删查改、版本控制、连接测试和对应数据源的元数据信息查询能力;
+- **错误码能力**:提供了任务常见错误的错误码和解决方案,方便用户自助定位问题;
+
+## 支持的引擎类型
+| **引擎名** | **支持底层组件版本 (默认依赖版本)** | **Linkis 1.X 版本要求** | **是否默认包含在发布包中** | **说明** |
+|:---- |:---- |:---- |:---- |:---- |
+|Spark|Apache 2.0.0~2.4.7, CDH >= 5.4.0, (默认Apache Spark 2.4.3)|\>=1.0.0_rc1|是|Spark EngineConn, 支持SQL, Scala, Pyspark 和R 代码。|
+|Hive|Apache >= 1.0.0, CDH >= 5.4.0, (默认Apache Hive 2.3.3)|\>=1.0.0_rc1|是|Hive EngineConn, 支持HiveQL 代码。|
+|Python|Python >= 2.6, (默认Python2*)|\>=1.0.0_rc1|是|Python EngineConn, 支持python 代码。|
+|Shell|Bash >= 2.0|\>=1.0.0_rc1|是|Shell EngineConn, 支持Bash shell 代码。|
+|JDBC|MySQL >= 5.0, Hive >=1.2.1, (默认Hive-jdbc 2.3.4)|\>=1.0.0_rc1|否|JDBC EngineConn, 已支持Mysql,Oracle,KingBase,PostgreSQL,SqlServer,DB2,Greenplum,DM,Doris,ClickHouse,TiDB,Starrocks,GaussDB和OceanBase, 可快速扩展支持其他有JDBC Driver 包的引擎, 如SQLite|
+|Flink |Flink >= 1.12.2, (默认Apache Flink 1.12.2)|\>=1.0.2|否|Flink EngineConn, 支持FlinkSQL 代码,也支持以Flink Jar 形式启动一个新的Yarn 应用程序。|
+|Pipeline|-|\>=1.0.2|否|Pipeline EngineConn, 支持文件的导入和导出。|
+|openLooKeng|openLooKeng >= 1.5.0, (默认openLookEng 1.5.0)|\>=1.1.1|否|openLooKeng EngineConn, 支持用Sql查询数据虚拟化引擎openLooKeng。|
+|Sqoop| Sqoop >= 1.4.6, (默认Apache Sqoop 1.4.6)|\>=1.1.2|否|Sqoop EngineConn, 支持 数据迁移工具 Sqoop 引擎。|
+|Presto|Presto >= 0.180|\>=1.2.0|否|Presto EngineConn, 支持Presto SQL 代码。|
+|ElasticSearch|ElasticSearch >=6.0|\>=1.2.0|否|ElasticSearch EngineConn, 支持SQL 和DSL 代码。|
+|Trino | Trino >=371 | >=1.3.1 | 否 | Trino EngineConn, 支持Trino SQL 代码 |
+|Seatunnel | Seatunnel >=2.1.2 | >=1.3.1 | 否 | Seatunnel EngineConn, 支持Seatunnel SQL 代码 |
+
+
+
+## 下载
+请前往[Linkis releases 页面](https://linkis.apache.org/zh-CN/download/main) 下载Linkis 已编译的部署安装包或源码包。
+
+## 安装部署
+
+请参考[编译指南](../development/build.md)来编译Linkis源代码。
+请参考[安装部署文档](../deployment/deploy-quick.md) 来部署Linkis 。
+
+## 示例和使用指引
+- [各引擎使用指引](../engine-usage/overview.md)
+- [API 文档](../api/overview.md)
+
+## 文档
+完整的Linkis文档代码存放在[linkis-website仓库中](https://github.com/apache/linkis-website)
+
+## 架构概要
+Linkis 基于微服务架构开发,其服务可以分为3类:计算治理服务、公共增强服务和微服务治理服务。
+- 计算治理服务,支持计算任务/请求处理流程的3个主要阶段:提交->准备->执行。
+- 公共增强服务,包括上下文服务、物料管理服务及数据源服务等。
+- 微服务治理服务,包括定制化的Spring Cloud Gateway、Eureka、Open Feign。
+
+下面是Linkis的架构概要图,更多详细架构文档请见 [Linkis/Architecture](../architecture/overview.md)。
+![architecture](/Images/Linkis_1.0_architecture.png)
+
+基于Linkis 计算中间件,我们在大数据平台套件[WeDataSphere](https://github.com/WeBankFinTech/WeDataSphere) 中构建了许多应用和工具系统,下面是目前可用的开源项目。
+
+![wedatasphere_stack_Linkis](/Images/wedatasphere_stack_Linkis.png)
+
+- [**DataSphere Studio** - 数据应用集成开发框架](https://github.com/WeBankFinTech/DataSphereStudio)
+
+- [**Scriptis** - 数据研发IDE工具](https://github.com/WeBankFinTech/Scriptis)
+
+- [**Visualis** - 数据可视化工具](https://github.com/WeBankFinTech/Visualis)
+
+- [**Schedulis** - 工作流调度工具](https://github.com/WeBankFinTech/Schedulis)
+
+- [**Qualitis** - 数据质量工具](https://github.com/WeBankFinTech/Qualitis)
+
+- [**MLLabis** - 容器化机器学习notebook 开发环境](https://github.com/WeBankFinTech/prophecis)
+
+更多项目开源准备中,敬请期待。
+
+## 贡献
+我们非常欢迎和期待更多的贡献者参与共建Linkis, 不论是代码、文档或是其他能够帮助到社区的贡献形式。
+
+代码和文档相关的贡献请参照[贡献指引](/community/how-to-contribute)。
+
+
+## 联系我们
+
+**方式1 邮件列表**
+
+|名称|描述|订阅|取消订阅|存档|
+|:-----|:--------|:-----|:------|:-----|
+| [dev@linkis.apache.org](mailto:dev@linkis.apache.org) | 社区活动信息 | [订阅](mailto:dev-subscribe@linkis.apache.org) | [取消订阅](mailto:dev-unsubscribe@linkis.apache.org) | [存档](http://mail-archives.apache.org/mod_mbox/linkis-dev) |
+
+**方式2 Issue**
+
+通过github提交[issue](https://github.com/apache/linkis/issues/new/choose),以便跟踪处理和经验沉淀共享
+
+**方式2 微信助手**
+
+|微信小助手|微信公众号|
+|:---|---|
+| | |
+
+
+Meetup 视频 [Bilibili](https://space.bilibili.com/598542776?from=search&seid=14344213924133040656)。
+
+## 谁在使用 Linkis
+我们创建了[一个 issue](https://github.com/apache/linkis/issues/23) 以便用户反馈和记录谁在使用Linkis。
+Linkis 自2019年开源发布以来,累计已有700多家试验企业和1000+沙盒试验用户,涉及金融、电信、制造、互联网等多个行业。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/_category_.json
new file mode 100644
index 00000000000..02d23f945ae
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "API 文档",
+ "position": 7
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/_category_.json
new file mode 100644
index 00000000000..803138a2024
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "Http API",
+ "position": 6
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-engineplugin-api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-engineplugin-api/_category_.json
new file mode 100644
index 00000000000..8f625f20e9e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-engineplugin-api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "引擎插件管理服务",
+ "position": 4
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-engineplugin-api/engine-plugin-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-engineplugin-api/engine-plugin-api.md
new file mode 100644
index 00000000000..1c83e70e2a6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-engineplugin-api/engine-plugin-api.md
@@ -0,0 +1,576 @@
+---
+title: 引擎插件API
+sidebar_position: 3
+---
+
+** EnginePluginRestful 类 **
+
+## 刷新
+
+
+**接口地址**:`/api/rest_j/v1/engineplugin/refresh`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:
刷新单个资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|ecType|类型|query|false|string|
+|version|版本|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 刷新所有
+
+
+**接口地址**:`/api/rest_j/v1/engineplugin/refreshAll`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:刷新所有ec resource
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 回滚
+
+**接口地址**:`/api/rest_j/v1/engineplugin/rollBack`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+回滚当前引擎插件的物料版本
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| --------------------- | ------------------------- | -------- | -------- | --------------------- | ------ |
+| engineConnBmlResource | EngineConnBmlResource实体 | body | true | EngineConnBmlResource | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+## 获取引擎在物料中的所有版本
+
+**接口地址**:/api/rest_j/v1/engineplugin/getVersionList
+
+**请求方式**:GET
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+获取引擎插件在物料管理系统中的所有版本
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| ------------- | ---------------- | -------- | -------- | --------------------- | ------ |
+| bmlResourceId | 引擎的物料资源id | body | true | EngineConnBmlResource | |
+| ecType | 引擎名称 | body | false | String | |
+| version | 引擎版本 | body | false | String | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+
+
+## 获取所有引擎名称
+
+**接口地址**:/api/rest_j/v1/engineplugin/getTypeList
+
+**请求方式**:GET
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+获取所有类型的引擎名称
+
+**请求参数**
+
+
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "typeList": [
+ "hive",
+ "io_file",
+ "jdbc",
+ "openlookeng",
+ "python",
+ "shell",
+ "spark"
+ ]
+ }
+}
+```
+
+
+
+## 获取引擎的所有版本
+
+**接口地址**:/api/rest_j/v1/engineplugin/getTypeVersionList/{type}
+
+**请求方式**:GET
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+获取所有类型的引擎名称
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------------- | -------- | -------- | -------- | ------ |
+| type | 引擎的类型名称 | path | true | String | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "queryList": [
+ "v4"
+ ]
+ }
+}
+```
+
+
+
+## 更新引擎插件
+
+**接口地址**:/api/rest_j/v1/engineplugin/updateEnginePluginBML
+
+**请求方式**:POST
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+更新指定引擎插件
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | ------------ | -------- | -------- | ------------- | ------ |
+| file | 引擎物料文件 | body | true | MultipartFile | |
+| ecType | 引擎类型名称 | body | true | String | |
+| version | 引擎版本 | body | true | String | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "mes": "upload file success"
+ }
+}
+```
+
+
+
+## 引擎插件
+
+**接口地址**:/api/rest_j/v1/engineplugin/list
+
+**请求方式**:GET
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+请求所有引擎插件信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| ----------- | ------------ | -------- | -------- | -------------- | ------ |
+| currentPage | 当前页面 | qurey | true | integer(int32) | |
+| ecType | 引擎类型名称 | qurey | false | String | |
+| version | 引擎版本 | qurey | false | String | |
+| pageSize | 页面大小 | qurey | true | integer(int32) | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "totalPage": 17,
+ "queryList": [
+ {
+ "id": 239,
+ "engineConnType": "python",
+ "version": "python2",
+ "fileName": "lib.zip",
+ "lastModified": 1661950452000,
+ "fileSize": 6093507,
+ "bmlResourceId": "8edb8e88-fc75-4ce3-a330-3ece9ec533cb",
+ "bmlResourceVersion": "v000001",
+ "createTime": "2022-08-31 20:56:59",
+ "lastUpdateTime": "2022-08-31 20:56:59"
+ },
+ {
+ "id": 238,
+ "engineConnType": "python",
+ "version": "python2",
+ "fileName": "conf.zip",
+ "lastModified": 1661950450000,
+ "fileSize": 43841,
+ "bmlResourceId": "a46beb9b-7368-4900-a2a6-241f1ec49002",
+ "bmlResourceVersion": "v000001",
+ "createTime": "2022-08-31 20:56:54",
+ "lastUpdateTime": "2022-08-31 20:56:54"
+ }
+ ]
+ }
+}
+```
+
+
+
+## 新增引擎插件
+
+**接口地址**:/api/rest_j/v1/engineplugin/uploadEnginePluginBML
+
+**请求方式**:POST
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+上传新增一个引擎插件
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | ------------------ | -------- | -------- | ------------- | ------ |
+| file | 引擎物料文件压缩包 | body | true | MultipartFile | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "mes": "upload file success"
+ }
+}
+```
+
+
+
+## 删除引擎插件
+
+**接口地址**:/api/rest_j/v1/engineplugin/deleteEnginePluginBML
+
+**请求方式**:GET
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+删除指定引擎插件
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | ------------ | -------- | -------- | -------- | ------ |
+| ecType | 引擎类型名称 | qurey | true | String | |
+| version | 引擎版本 | qurey | false | String | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{"method":null,"status":0,"message":"OK","data":{"msg":"delete successfully"}}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-engineplugin-api/engineconn-plugin-refresh.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-engineplugin-api/engineconn-plugin-refresh.md
new file mode 100644
index 00000000000..ad77d066d23
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-engineplugin-api/engineconn-plugin-refresh.md
@@ -0,0 +1,108 @@
+---
+title: 引擎物料刷新API
+sidebar_position: 2
+---
+>主要用于引擎的物料资源({LINKIS_INSTALL_HOME}/lib/linkis-engineconn-plugin 下,引擎的jar包/配置文件 )更新至BML中。
+
+## refresh
+
+**接口地址**:`/api/rest_j/v1/engineplugin/refresh`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新指定引擎的物料资源
+
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|ecType|引擎类型|query|true|string||
+|version|版本 可以为空或则*|query|false|string||
+
+**请求示例**:
+```
+#url
+http://ip:port/api/rest_j/v1/engineplugin/refresh?ecType=hive&version=2.3.3
+
+#请求头部
+Content-Type:application/json
+Token-Code:BML-AUTH
+Token-User:hadoop
+```
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data||object||
+|message||string||
+|method||string||
+|status||integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "msg": "Refresh successfully"
+ }
+}
+```
+
+
+## refreshAll
+
+
+**接口地址**:`/api/rest_j/v1/engineplugin/refreshAll`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新所有引擎的物料资源
+
+
+**请求参数**:
+无
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data||object||
+|message||string||
+|method||string||
+|status||integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "msg": "Refresh successfully"
+ }
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-entrance-api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-entrance-api/_category_.json
new file mode 100644
index 00000000000..2efa3b26626
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-entrance-api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "Entrnace 服务",
+ "position": 5
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-entrance-api/task-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-entrance-api/task-management-api.md
new file mode 100644
index 00000000000..acb362e570d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-entrance-api/task-management-api.md
@@ -0,0 +1,129 @@
+---
+title: 任务管理
+sidebar_position: 2
+---
+** EntranceMetricRestfulApi 类 **
+
+
+# 任务管理
+
+
+## 启动任务
+
+
+**接口地址**:`/api/rest_j/v1/entrance/api/metrics/runningtask`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:启动任务
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 任务信息
+
+
+**接口地址**:`/api/rest_j/v1/entrance/api/metrics/taskinfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:任务信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|创建者|query|false|string|
+|engineTypeLabel|引擎类型标签|query|false|string|
+|user|user|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-entrance-api/task-operation-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-entrance-api/task-operation-api.md
new file mode 100644
index 00000000000..11064238525
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-entrance-api/task-operation-api.md
@@ -0,0 +1,569 @@
+---
+title: 任务操作
+sidebar_position: 1
+---
+** EntranceRestfulApi 类 **
+
+
+## 处理任务请求
+
+
+**接口地址**:`/api/rest_j/v1/entrance/execute`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:execute函数处理的是用户提交执行任务的请求
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|json|json|body|true|object|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 提交execute函数
+
+
+**接口地址**:`/api/rest_j/v1/entrance/submit`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:提交execute函数
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|Submit|json|body|true|Submit|Submit|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 结束任务
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/kill`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:kill任务
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|ID|path|false|string|
+|taskID|任务ID|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 结束Jobs
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/killJobs`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:结束Jobs
+
+**请求示例**:
+```javascript
+{
+ "taskIDList": [],
+ "idList": []
+}
+```
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|id请求路径生成|path|true|string|
+|taskIDList|任务ID集合|false|String|String|
+|idList|ID集合|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/entrance/#id/killJobs",
+ "status": 0,
+ "message": "success",
+ "data": {
+ "messages": [{
+ "method": "",
+ "status": 0,
+ "message": "",
+ "data": {
+ "execID": ""
+ }
+ }]
+ }
+}
+```
+
+
+## 任务日志
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/log`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取任务日志
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|任务ID|path|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 暂停任务
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/pause`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:暂停任务
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|任务ID|path|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 任务进展
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/progress`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:任务进展
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|任务ID|path|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 资源进展
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/progressWithResource`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:资源进展
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|ID|path|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 任务状态
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/status`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:任务状态
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|ID|path|false|string|
+|taskID|任务ID|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/_category_.json
new file mode 100644
index 00000000000..ad07bddc12e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "LinkisManager 服务",
+ "position": 2
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/ec-resource-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/ec-resource-management-api.md
new file mode 100644
index 00000000000..c10e93d3f03
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/ec-resource-management-api.md
@@ -0,0 +1,291 @@
+---
+title: EC资源信息管理
+sidebar_position: 4
+---
+** ECResourceInfoRestfulApi 类 **
+
+
+
+
+## 删除EC信息
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/ecinfo/delete/{ticketid}}`
+
+
+**请求方式**:`DELETE`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:删除EC信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|ticketid|ticketid|path|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|204|No Content|
+|401|Unauthorized|
+|403|Forbidden|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取EC信息
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/ecinfo/get`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:获取EC信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|ticketid|ticketid|query|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+## 搜索历史EC信息
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/ecinfo/ecrHistoryList`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:获取EC信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|instance|instance|query|false|string|
+|creator|creator|query|false|string|
+|startDate|startDate|query|false|string|
+|endDate|endDate|query|false|string|
+|engineType|engineType|query|false|string|
+|pageNow|pageNow|query|false|Int|
+|pageSize|pageSize|query|false|Int|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ {
+ "message": "",
+ "status": 0,
+ "data": {
+ "engineList": [
+ {
+ "id": -94209540.07806732,
+ "requestResource": "consectetur dolor eiusmod ipsum",
+ "releasedResource": "est in id Ut",
+ "usedTimes": -51038117.02855969,
+ "ticketId": "adipisicing in nostrud do",
+ "ecmInstance": "id magna Lorem eiusmod",
+ "engineType": "dolor",
+ "usedTime": -38764910.74278392,
+ "logDirSuffix": "sunt eiusmod aute et",
+ "releaseTime": -33417043.232267484,
+ "usedResource": "in amet veniam velit",
+ "requestTimes": -15643696.319572791,
+ "labelValue": "veniam incididunt magna",
+ "releaseTimes": 96384811.3484546,
+ "createTime": 38434279.49900183,
+ "serviceInstance": "consequat aliqua in enim",
+ "createUser": "Lorem Ut occaecat amet"
+ },
+ {
+ "labelValue": "adipisicing deserunt do",
+ "usedTimes": 49828407.223826766,
+ "usedResource": "mollit laboris cupidatat enim",
+ "releaseTimes": -73400915.22672182,
+ "releasedResource": "est qui id ipsum mollit",
+ "requestResource": "deserunt reprehenderit ut",
+ "serviceInstance": "do laborum",
+ "requestTimes": -33074164.700212136,
+ "ecmInstance": "dolore",
+ "logDirSuffix": "ea incididunt",
+ "createUser": "Ut exercitation officia dolore ipsum",
+ "usedTime": 25412456.522457644,
+ "createTime": -93227549.70578489,
+ "id": -84032815.0589972,
+ "ticketId": "eu in mollit do",
+ "engineType": "non Ut eu",
+ "releaseTime": 34923394.9602966
+ },
+ {
+ "releaseTime": -91057731.93164417,
+ "usedTime": 99226623.97199354,
+ "id": 59680041.603043556,
+ "requestResource": "officia Ut enim nulla",
+ "usedTimes": -14680356.219609797,
+ "logDirSuffix": "proident amet reprehenderit tempor",
+ "ticketId": "minim esse",
+ "releaseTimes": 37270921.94107443,
+ "serviceInstance": "enim adipisicing cupidatat",
+ "createUser": "culpa",
+ "requestTimes": -33504917.797325186,
+ "releasedResource": "et dolore quis",
+ "ecmInstance": "elit dolor adipisicing id",
+ "createTime": -38827280.78902944,
+ "engineType": "ullamco in eiusmod reprehenderit aute",
+ "labelValue": "dolore qui labore nulla laboris",
+ "usedResource": "irure sint nostrud Excepteur sunt"
+ },
+ {
+ "requestResource": "deserunt incididunt enim",
+ "releaseTimes": -16708903.732444778,
+ "id": 80588551.12419662,
+ "ecmInstance": "et veniam",
+ "releaseTime": -50240956.63233949,
+ "usedTimes": -5348294.728038415,
+ "labelValue": "incididunt tempor reprehenderit quis eu",
+ "createUser": "in in",
+ "serviceInstance": "minim sit",
+ "ticketId": "in dolore",
+ "usedTime": -30138563.761232898,
+ "logDirSuffix": "quis laborum ea",
+ "createTime": 65920455.93896958,
+ "requestTimes": 38810152.0160971,
+ "engineType": "est in Ut proident",
+ "usedResource": "nulla laboris Ut",
+ "releasedResource": "cupidatat irure"
+ },
+ {
+ "usedResource": "Lorem adipisicing dolor",
+ "createTime": -11906770.11266476,
+ "labelValue": "et id magna",
+ "releaseTimes": 32546901.20497243,
+ "id": -90442428.4679744,
+ "logDirSuffix": "aute ut eu commodo",
+ "ticketId": "cillum sint non deserunt",
+ "requestResource": "non velit sunt consequat culpa",
+ "requestTimes": -75282512.0022062,
+ "usedTime": 6378131.554130778,
+ "releasedResource": "Duis in",
+ "serviceInstance": "dolore ut officia",
+ "usedTimes": 70810503.51038182,
+ "createUser": "voluptate sed",
+ "ecmInstance": "laboris do sit dolore ipsum",
+ "engineType": "id",
+ "releaseTime": 37544575.30154848
+ }
+ ]
+ }
+ }
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/ecm-resource-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/ecm-resource-management-api.md
new file mode 100644
index 00000000000..0acd06d3b4f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/ecm-resource-management-api.md
@@ -0,0 +1,462 @@
+---
+title: ECM资源管理
+sidebar_position: 3
+---
+** EMRestfulApi 类 **
+
+
+
+## 执行ECM操作
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/executeECMOperation`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 执行ECM操作开始
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/executeECMOperationByEC`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## ECM管理中状态列表
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/listAllECMHealthyStatus`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:获取状态列表清单
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|onlyEditable|是否仅可编辑|query|false|boolean|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/listAllECMHealthyStatus",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "nodeHealthy": []
+ }
+}
+```
+
+
+## ECM资源清单
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/listAllEMs`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:获取所有ECM资源详细清单列表可根据条件查询,默认查询所有
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|instance|实例名称|query|false|string|
+|nodeHealthy|状态,状态有以下枚举类型 ‘Healthy‘, ‘UnHealthy‘, ‘WARN‘, ’StockAvailable’, ‘StockUnavailable’|query|false|string|
+|owner|创建者|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/listAllEMs",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "EMs": [{
+ "labels": [{
+ "stringValue": "",
+ "labelKey": "",
+ "feature": "",
+ "instance": "",
+ "serviceInstance": {
+ "instance": "",
+ "applicationName": ""
+ },
+ "serviceName": "",
+ "featureKey": "",
+ "empty":
+ }],
+ "applicationName": "",
+ "instance": ":",
+ "resourceType": "",
+ "maxResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "minResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "usedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "lockedResource": {
+ "memory": 0,
+ "cores": 0,
+ "instance": 0
+ },
+ "expectedResource": {
+ "memory": 0,
+ "cores": 0,
+ "instance": 0
+ },
+ "leftResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "owner": "",
+ "runningTasks": null,
+ "pendingTasks": null,
+ "succeedTasks": null,
+ "failedTasks": null,
+ "maxMemory": ,
+ "usedMemory": ,
+ "systemCPUUsed": null,
+ "systemLeftMemory": ,
+ "nodeHealthy": "",
+ "msg": "",
+ "startTime":
+ }]
+ }
+}
+```
+
+
+## 编辑EMC实例
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/modifyEMInfo`
+
+
+**请求方式**:`PUT`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:编辑或修改下编辑EMC管理下的实例
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|引擎标签|false|String|String|
+|emStatus|实例状态,状态有以下枚举类型 ‘Healthy‘, ‘UnHealthy‘, ‘WARN‘, ’StockAvailable’, ‘StockUnavailable’|false|String|String|
+|instance|引擎实例名称|false|String|String|
+|labelKey|添加内容里面的标签,属于labels集合 内 map里的key|false|String|String|
+|labels|引擎实例更新参数内容,集合存放的是map类型的|false|List|List|
+|stringValue|添加内容里面的标签对于的值,属于labels集合 内 map里的value|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/modifyEMInfo",
+ "status": 0,
+ "message": "success",
+ "data": {}
+}
+```
+
+
+## 打开引擎日志
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/openEngineLog`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:打开引擎日志,默认打开stdout类型的引擎日志
+
+**请求示例**:
+```javascript
+{
+ applicationName: ""
+ emInstance: ""
+ instance: ""
+ parameters: {
+ pageSize: ,
+ fromLine: ,
+ logType: ""
+ }
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|引擎标签|String|false|String|
+|emInstance|实例名称|String|false|String|
+|fromLine|来自线路|String|false|String|
+|instance|引擎实例名称|String|false|String|
+|logType|日志类型,默认stdout类型,属于parameters|String|false|String|
+|pageSize|页面大小|String|false|String|
+|parameters|分页信息|Map|false|Map|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/openEngineLog",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "result": {
+ "logPath": "",
+ "logs": [""],
+ "endLine": ,
+ "rows":
+ },
+ "isError": false,
+ "errorMsg": ""
+ }
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/engine-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/engine-management-api.md
new file mode 100644
index 00000000000..405cebd174f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/engine-management-api.md
@@ -0,0 +1,585 @@
+---
+title: 引擎管理
+sidebar_position: 2
+---
+** EngineRestfulApi 类 **
+
+
+
+
+## 创建引擎连接
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/createEngineConn`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:创建引擎连接
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 执行引擎连接操作
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/executeEngineConnOperation`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:执行引擎连接操作
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取引擎连接
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/getEngineConn`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:获取引擎连接
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## kill引擎连接
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/killEngineConn`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:kill引擎连接
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 所有节点状态
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/listAllNodeHealthyStatus`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:所有节点状态
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|onlyEditable|onlyEditable|query|false|boolean|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/listAllNodeHealthyStatus",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "nodeStatus": []
+ }
+}
+```
+
+
+## 列表引擎
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/listEMEngines`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:列表引擎
+
+**请求示例**:
+```javascript
+{
+ em: {
+ serviceInstance: {
+ applicationName: "linkis-cg-engineconnmanager",
+ instance: "localhost110003:9102"
+ }
+ }
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|引擎标签名称,属于serviceInstance中的值|String|false|String|
+|em|入参最外层|Map|false|Map|
+|emInstance|引擎实例名称跟‘em’一个级别属于最外层|String|false|String|
+|engineType|引擎类型跟‘em’一个级别属于最外层|String|false|String|
+|instance|实例名称|String|false|String|
+|nodeStatus|状态跟‘em’一个级别属于最外层,状态有以下枚举类型 ‘Healthy‘, ‘UnHealthy‘, ‘WARN‘, ’StockAvailable’, ‘StockUnavailable’|String|false|String|
+|owner|创建者跟‘em’一个级别属于最外层|String|false|String|
+|serviceInstance|入参属于‘’em|Map|false|Map|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/listEMEngines",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "engines": []
+ }
+}
+```
+
+
+## 引擎用户集合
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/listUserEngines`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:引擎用户集合
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 编辑引擎实例
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/modifyEngineInfo`
+
+
+**请求方式**:`PUT`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:编辑引擎实例内容
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|引擎标签|false|String|String|
+|emStatus|运行状态|false|String|String|
+|instance|引擎实例名称|false|String|String|
+|labelKey|添加内容里面的标签,属于labels集合 内 map里的key|false|String|String|
+|labels|引擎实例更新参数内容,集合存放的是map类型的|false|List|List|
+|stringValue|添加内容里面的标签对于的值,属于labels集合 内 map里的value|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## kill引擎
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/enginekill`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:关闭引擎,可关闭一个也可关闭多个
+
+
+**请求示例**:
+```javascript
+ [
+ {
+ engineInstance: "",
+ applicationName:""
+ }
+ ]
+
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|应用名称,最外层是个数组和engineInstance参数是一个级别|false|String|String|
+|engineInstance|引擎实例名称,最外层是个数组和applicationName参数是一个级别|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/resource-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/resource-management-api.md
new file mode 100644
index 00000000000..660b769e06f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-cg-linkismanager-api/resource-management-api.md
@@ -0,0 +1,612 @@
+---
+title: 资源管理
+sidebar_position: 1
+---
+** RMMonitorRest 类 **
+
+
+
+
+## 所有用户资源
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/allUserResource`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:所有用户资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|creator|query|false|string|
+|engineType|engineType|query|false|string|
+|page|page|query|false|integer(int32)|
+|size|size|query|false|integer(int32)|
+|username|username|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "total": 34,
+ "resources": [{
+ "id": ,
+ "username": "",
+ "creator": "",
+ "engineTypeWithVersion": "",
+ "resourceType": "",
+ "maxResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "minResource": {
+ "memory": ,
+ "cores":
+ "instance": 0
+ },
+ "usedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "lockedResource": {
+ "memory": 0,
+ "cores": 0,
+ "instance": 0
+ },
+ "expectedResource": null,
+ "leftResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "createTime": ,
+ "updateTime": ,
+ "loadResourceStatus": "",
+ "queueResourceStatus":
+ }]
+ }
+}
+```
+
+
+## 应用列表
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/applicationlist`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取资源管理中的应用引擎列表清单
+
+**请求示例**:
+```javascript
+{
+ userCreator: ""
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|userCreator|userCreator|query|true|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": ,
+ "status": ,
+ "message": "",
+ "data": {
+ "applications": [{
+ "creator": "",
+ "applicationList": {
+ "usedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "maxResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "lockedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "minResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "engineInstances": [{
+ "resource": {
+ "resourceType": "",
+ "maxResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "minResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "usedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "lockedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "expectedResource": null,
+ "leftResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ }
+ },
+ "engineType": "",
+ "owner": "",
+ "instance": "",
+ "creator": "",
+ "startTime": "",
+ "status": "",
+ "label": ""
+ }]
+ }
+ }]
+ }
+}
+```
+
+
+## 引擎类型
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/engineType`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:引擎类型
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 引擎管理器
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/engines`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:引擎管理器
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|param|param|body|false|object|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 队列管理器
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/queueresources`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:队列管理器
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|param|param|body|true|object|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 队列
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/queues`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:队列
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|param|param|body|false|object|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 重置资源
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/resetResource`
+
+
+**请求方式**:`DELETE`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:重置资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|resourceId|query|false|integer(int32)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|204|No Content|
+|401|Unauthorized|
+|403|Forbidden|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 资源信息
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/userresources`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:查询资源列表清单及资源详细数据如使用百分比
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|param|param|body|false|object|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "userResources": [{
+ "userCreator": "",
+ "engineTypes": [{
+ "engineType": "",
+ "percent": ""
+ }],
+ "percent": ""
+ }]
+ }
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/_category_.json
new file mode 100644
index 00000000000..59702fc1d1a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "上下文服务",
+ "position": 3
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-history-service-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-history-service-api.md
new file mode 100644
index 00000000000..2abed90e746
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-history-service-api.md
@@ -0,0 +1,317 @@
+---
+title: 上下文历史记录服务
+sidebar_position: 14
+---
+** ContextHistoryRestfulApi 类 **
+
+
+
+## 创建历史记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/createHistory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:创建历史记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextHistory|历史上下文|false|String|String|
+|contextID|上下文id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取多个历史记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/getHistories`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取多个历史记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|String|false|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取历史记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/getHistory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取历史记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文Id|false|String|String|
+|source|上下文源|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除历史记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeHistory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除历史记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextHistory|历史上下文|false|String|String|
+|contextID|上下文id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 搜索历史记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/searchHistory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:搜索历史记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文Id|false|String|String|
+|keywords|关键词|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-listening-service-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-listening-service-api.md
new file mode 100644
index 00000000000..aa8cd645fe1
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-listening-service-api.md
@@ -0,0 +1,189 @@
+---
+title: 上下文监听服务
+sidebar_position: 16
+---
+** ContextListenerRestfulApi 类 **
+
+
+# 上下文监听服务
+
+
+## heartbeat
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/heartbeat`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## onBindIDListener
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/onBindIDListener`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## onBindKeyListener
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/onBindKeyListener`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-logging-service-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-logging-service-api.md
new file mode 100644
index 00000000000..ef207bc1cfd
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-logging-service-api.md
@@ -0,0 +1,380 @@
+---
+title: 上下文记录服务
+sidebar_position: 17
+---
+** ContextIDRestfulApi 类 **
+
+
+## 创建文本记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/createContextID`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:创建文本记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文Id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取文本ID
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/getContextID`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取文本ID
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextId|上下文Id|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除文本ID
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeContextID`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除文本ID
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextId|上下文Id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 重置文本ID
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/resetContextID`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:重置文本ID
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextId|上下文Id|String|false|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 搜索文本Id执行时间
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/searchContextIDByTime`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:搜索文本Id执行时间
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|accessTimeEnd|访问结束时间|query|false|string|
+|accessTimeStart|访问开始时间|query|false|string|
+|createTimeEnd|创建结束时间|query|false|string|
+|createTimeStart|创建时间|query|false|string|
+|pageNow|页码|query|false|string|
+|pageSize|页面大小|query|false|string|
+|updateTimeEnd|更新结束时间|query|false|string|
+|updateTimeStart|更新时间|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 修改文本ID
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/updateContextID`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:修改文本ID
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextId|上下文Id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-service-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-service-api.md
new file mode 100644
index 00000000000..9ee466ecaef
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-cs-api/context-service-api.md
@@ -0,0 +1,692 @@
+---
+title: 上下文API
+sidebar_position: 15
+---
+** ContextRestfulApi 类 **
+
+
+
+## 通过ID清除所以上下文
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/clearAllContextByID`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:通过ID清除所以上下文
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|idList|上下文id集合|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 通过时间清除所以上下文
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/clearAllContextByTime`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:通过时间清除所以上下文
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|accessTimeEnd|访问时间结束|false|String|String|
+|accessTimeStart|访问时间开始|false|String|String|
+|createTimeEnd|创建时间结束|false|String|String|
+|createTimeStart|创建时间|false|String|String|
+|updateTimeStart|更新开始时间|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取上下文内容
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/getContextValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取上下文内容
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKey|contextKey|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除所有value
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeAllValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除所有value
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKey|contextKey|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 通过value前缀删除所有值
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeAllValueByKeyPrefix`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:通过前缀和上下文类型删除所有值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|contextID|false|String|String|
+|keyPrefix|keyPrefix|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 通过key前缀和上下文类型删除所有值
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeAllValueByKeyPrefixAndContextType`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:通过前缀和上下文类型删除所有值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextKeyType|contextKeyType|false|String|String|
+|keyPrefix|keyPrefix|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除value
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除value
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKey|contextKey|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 重置value
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/resetValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:重置value
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKey|contextKey|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 搜索上下文内容
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/searchContextValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:搜索上下文内容
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|condition|condition|false|String|String|
+|contextID|上下文id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 设置value
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/setValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:设置value
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKeyValue|contextKeyValue|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 设置key
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/setValueByKey`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:给value设置key
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKey|contextKey|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/_category_.json
new file mode 100644
index 00000000000..f6d702cc1dc
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "公共服务",
+ "position": 1
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/bm-operation-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/bm-operation-management-api.md
new file mode 100644
index 00000000000..7e2ec8ce12d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/bm-operation-management-api.md
@@ -0,0 +1,449 @@
+---
+title: BM项目操作管理
+sidebar_position: 15
+---
+** BmlProjectRestful 类 **
+
+
+
+
+## 附件资源项目
+
+
+**接口地址**:`/api/rest_j/v1/bml/attachResourceAndProject`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:附件资源项目
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|projectName|项目名称|false|String|String|
+|resourceId|资源名称|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 创建Bml项目
+
+
+**接口地址**:`/api/rest_j/v1/bml/createBmlProject`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:创建Bml项目
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+|accessUsers|访问用户|false|String|String|
+|editUsers|编辑用户|false|String|String|
+|projectName|项目名称|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 下载共享资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/downloadShareResource`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:下载共享资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源ID|query|false|string|
+|version|版本|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 项目信息
+
+
+**接口地址**:`/api/rest_j/v1/bml/getProjectInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取项目信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|projectName|项目名称|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 更新项目用户
+
+
+**接口地址**:`/api/rest_j/v1/bml/updateProjectUsers`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新项目用户
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+|accessUsers|访问用户|false|String|String|
+|editUsers|编辑用户|false|String|String|
+|projectName|项目名称|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 更新共享资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/updateShareResource`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`multipart/form-data`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新共享资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|file|文件|formData|false|ref|
+|resourceId|资源ID|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 上载共享资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/uploadShareResource`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:上载共享资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|expireTime|失效时间|query|false|string|
+|expireType|失效类型|query|false|string|
+|file|文件集合|formData|false|ref|
+|isExpire|是否失效|query|false|string|
+|maxVersion|mav版本|query|false|ref|
+|projectName|项目名称|query|false|string|
+|resourceHeader|资源标头|query|false|string|
+|system|系统|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/bml-resource-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/bml-resource-management-api.md
new file mode 100644
index 00000000000..7e857c0253b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/bml-resource-management-api.md
@@ -0,0 +1,812 @@
+---
+title: BML资源管理
+sidebar_position: 14
+---
+** BmlRestfulApi 类 **
+
+
+
+## 更新owner
+
+
+**接口地址**:`/api/rest_j/v1/bml/changeOwner`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新owner
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|newOwner|旧Owner|false|String|String|
+|oldOwner|新Owner|false|String|String|
+|resourceId|资源Id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 复制资源到其他用户
+
+
+**接口地址**:`/api/rest_j/v1/bml/copyResourceToAnotherUser`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:复制资源到指定用户
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|anotherUser|指定用户|false|String|String|
+|resourceId|资源Id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/deleteResource`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除版本
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|true|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除多个资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/deleteResources`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除多个资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceIds|资源Id集合,删除多个资源|true|List|List|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除版本
+
+
+**接口地址**:`/api/rest_j/v1/bml/deleteVersion`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除版本
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|true|String|String|
+|version|版本|true|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 下载资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/download`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:通过resourceId 和 version两个参数获取下载对应的资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|query|false|string|
+|version|资源版本,如果不指定,默认为最新|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取Basic
+
+
+**接口地址**:`/api/rest_j/v1/bml/getBasic`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取Basic
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|query|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取资源信息
+
+
+**接口地址**:`/api/rest_j/v1/bml/getResourceInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取资源信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取资源信息
+
+
+**接口地址**:`/api/rest_j/v1/bml/getResources`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取资源信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|currentPage|页码|query|false|string|
+|pageSize|页面大小|query|false|string|
+|system|系统|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取版本信息
+
+
+**接口地址**:`/api/rest_j/v1/bml/getVersions`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取bml版本信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|currentPage|页码|query|false|string|
+|pageSize|页面大小|query|false|string|
+|resourceId|资源ID|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 回滚版本
+
+
+**接口地址**:`/api/rest_j/v1/bml/rollbackVersion`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:回滚版本
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|false|String|String|
+|version|回滚版本|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 更新资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/updateVersion`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`multipart/form-data`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:用户通过http的方式更新资源文件
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|file|file文件|formData|true|ref|
+|resourceId|用户希望更新资源的resourceId|query|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 上传资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/upload`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:上传资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|file|file|formData|true|array|file|
+|expireTime|expireTime|query|false|string|
+|expireType|expireType|query|false|string|
+|isExpire|isExpire|query|false|string|
+|maxVersion|maxVersion|query|false|integer(int32)|
+|resourceHeader|resourceHeader|query|false|string|
+|system|system|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/bmlfs-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/bmlfs-management-api.md
new file mode 100644
index 00000000000..46172201166
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/bmlfs-management-api.md
@@ -0,0 +1,201 @@
+---
+title: BMLFS管理
+sidebar_position: 13
+---
+** BMLFsRestfulApi 类 **
+
+
+
+## 打开ScriptFromBML
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/openScriptFromBML`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:openScriptFromBML
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|fileName|文件名称|query|true|string|
+|creator|创建者|query|false|string|
+|projectName|项目名称|query|false|string|
+|resourceId|资源Id|query|false|string|
+|version|版本|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 打开来自BML的script
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/product/openScriptFromBML`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:/product/openScriptFromBML
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|fileName|文件名称|query|true|string|
+|creator|创建者|query|false|string|
+|resourceId|资源Id|query|false|string|
+|version|版本|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 保存来自BML的script
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/saveScriptToBML`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:保存来自BML的script
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|创建者|true|String|String|
+|fileName|文件名称|true|String|String|
+|metadata|元数据|true|String|String|
+|projectName|项目名称|true|String|String|
+|resourceId|资源ID|true|String|String|
+|scriptContent|内容|true|String|String|
+|SaveScriptToBML|json|body|true|SaveScriptToBML|SaveScriptToBML|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/currency-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/currency-api.md
new file mode 100644
index 00000000000..799e15cf3f5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/currency-api.md
@@ -0,0 +1,62 @@
+---
+title: 通用API
+sidebar_position: 12
+---
+** CommonRestfulApi 类 **
+
+## 下线某个服务
+
+
+**接口地址**:`/api/rest_j/v1/offline`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:下线某个服务
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/data-source-manager-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/data-source-manager-api.md
new file mode 100644
index 00000000000..a59787377f8
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/data-source-manager-api.md
@@ -0,0 +1,1500 @@
+---
+title: 数据源API
+sidebar_position: 11
+---
+
+
+** DataSourceAdminRestfulApi 类 **
+
+## queryDataSourceEnv
+**接口地址**:`/api/rest_j/v1/data-source-manager/env`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 查询数据源配置的集群环境信息列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|currentPage|currentPage|query|false|integer(int32)|
+|name|name|query|false|string|
+|pageSize|pageSize|query|false|integer(int32)|
+|typeId|typeId|query|false|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/env",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "queryList": [
+ {
+ "id": 2,
+ "envName": "测试环境UAT",
+ "envDesc": "测试环境UAT",
+ "dataSourceTypeId": 4,
+ "connectParams": {
+ "hadoopConf": {
+ "hive.metastore.execute.setugi": "true"
+ },
+ "uris": "thrift://localhost:9083"
+ },
+ "createTime": 1647249913000,
+ "modifyTime": 1647249913000
+ },
+ {
+ "id": 3,
+ "envName": "开源测试环境",
+ "envDesc": "开源测试环境",
+ "dataSourceTypeId": 4,
+ "connectParams": {
+ "keytab": "4dd408ad-a2f9-4501-83b3-139290977ca2",
+ "uris": "thrift://bdpclustername:9083",
+ "principle": "hadoop@WEBANK.COM"
+ },
+ "createTime": 1647249913000,
+ "modifyTime": 1647249913000
+ }
+ ]
+ }
+}
+```
+## getAllEnvListByDataSourceType
+**接口地址**:`/api/rest_j/v1/data-source-manager/env-list/all/type/{typeId}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 查询某种数据源配置的集群信息列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|typeId|typeId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/env-list/all/type/4",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "envList": [
+ {
+ "id": 1,
+ "envName": "测试环境SIT"
+ },
+ {
+ "id": 2,
+ "envName": "测试环境UAT"
+ },
+ {
+ "id": 3,
+ "envName": "开源测试环境"
+ }
+ ]
+ }
+}
+```
+## insertJsonEnv
+**接口地址**:`/api/rest_j/v1/data-source-manager/env/json`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求示例**:
+```javascript
+{
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "envDesc": "",
+ "envName": "",
+ "id": 0,
+ "modifyTime": "",
+ "modifyUser": ""
+}
+```
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceEnv|dataSourceEnv|body|true|DataSourceEnv|DataSourceEnv|
+| connectParams||false|object|
+| createTime||false|string(date-time)|
+| createUser||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer(int64)|
+| envDesc||false|string|
+| envName||false|string|
+| id||false|integer(int64)|
+| modifyTime||false|string(date-time)|
+| modifyUser||false|string|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+## getEnvEntityById
+**接口地址**:`/api/rest_j/v1/data-source-manager/env/{envId}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:查询某环境详细信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|envId|envId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/env/1",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "env": {
+ "id": 1,
+ "envName": "测试环境SIT",
+ "envDesc": "测试环境SIT",
+ "connectParams": {
+ "hadoopConf": {
+ "hive.metastore.execute.setugi": "true"
+ },
+ "uris": "thrift://localhost:9083"
+ },
+ "createTime": 1647249913000,
+ "modifyTime": 1647249913000
+ }
+ }
+}
+```
+## removeEnvEntity
+**接口地址**:`/api/rest_j/v1/data-source-manager/env/{envId}`
+
+**请求方式**:`DELETE`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|envId|envId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+## updateJsonEnv
+**接口地址**:`/api/rest_j/v1/data-source-manager/env/{envId}/json`
+
+**请求方式**:`PUT`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求示例**:
+```javascript
+{
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "envDesc": "",
+ "envName": "",
+ "id": 0,
+ "modifyTime": "",
+ "modifyUser": ""
+}
+```
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceEnv|dataSourceEnv|body|true|DataSourceEnv|DataSourceEnv|
+| connectParams||false|object|
+| createTime||false|string(date-time)|
+| createUser||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer(int64)|
+| envDesc||false|string|
+| envName||false|string|
+| id||false|integer(int64)|
+| modifyTime||false|string(date-time)|
+| modifyUser||false|string|
+|envId|envId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+------
+** DataSourceCoreRestfulApi类**
+
+## queryDataSource
+**接口地址**:`/api/rest_j/v1/data-source-manager/info`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:查询数据源具体信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|currentPage|currentPage|query|false|integer(int32)|
+|identifies|identifies|query|false|string|
+|name|name|query|false|string|
+|pageSize|pageSize|query|false|integer(int32)|
+|system|system|query|false|string|
+|typeId|typeId|query|false|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "totalPage": 12,
+ "queryList": [
+ {
+ "id": 11,
+ "dataSourceName": "test1256",
+ "dataSourceTypeId": 4,
+ "createSystem": "Linkis",
+ "createTime": 1647909291000,
+ "createUser": "hadoop",
+ "versionId": 1,
+ "expire": false,
+ "dataSourceType": {
+ "id": "11",
+ "name": "hive",
+ "layers": 0
+ }
+ },
+ {
+ "id": 10,
+ "dataSourceName": "hive-test",
+ "dataSourceDesc": "hive test",
+ "dataSourceTypeId": 4,
+ "createSystem": "Linkis",
+ "createTime": 1647862455000,
+ "modifyTime": 1647930476000,
+ "modifyUser": "hadoop",
+ "createUser": "hadoop",
+ "versionId": 3,
+ "publishedVersionId": 1,
+ "expire": false,
+ "dataSourceType": {
+ "id": "10",
+ "name": "hive",
+ "layers": 0
+ }
+ }
+
+ ]
+ }
+}
+```
+## removeDataSource
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/delete/{dataSourceId}`
+
+**请求方式**:`DELETE`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:删除某条数据源数据
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info/delete/1",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "removeId": 1
+ }
+}
+```
+## insertJsonInfo
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/json`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求示例**:
+```javascript
+{
+ "connectParams": {},
+ "createIdentify": "",
+ "createSystem": "",
+ "createTime": "",
+ "createUser": "",
+ "dataSourceDesc": "",
+ "dataSourceEnv": {
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "envDesc": "",
+ "envName": "",
+ "id": 0,
+ "modifyTime": "",
+ "modifyUser": ""
+ },
+ "dataSourceEnvId": 0,
+ "dataSourceName": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "expire": true,
+ "id": 0,
+ "labels": "",
+ "modifyTime": "",
+ "modifyUser": "",
+ "publishedVersionId": 0,
+ "versionId": 0,
+ "versions": [
+ {
+ "comment": "",
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "datasourceId": 0,
+ "parameter": "",
+ "versionId": 0
+ }
+ ]
+}
+```
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSource|dataSource|body|true|DataSource|DataSource|
+| connectParams||false|object|
+| createIdentify||false|string|
+| createSystem||false|string|
+| createTime||false|string(date-time)|
+| createUser||false|string|
+| dataSourceDesc||false|string|
+| dataSourceEnv||false|DataSourceEnv|DataSourceEnv|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer|
+| envDesc||false|string|
+| envName||false|string|
+| id||false|integer|
+| modifyTime||false|string|
+| modifyUser||false|string|
+| dataSourceEnvId||false|integer(int64)|
+| dataSourceName||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer(int64)|
+| expire||false|boolean|
+| id||false|integer(int64)|
+| labels||false|string|
+| modifyTime||false|string(date-time)|
+| modifyUser||false|string|
+| publishedVersionId||false|integer(int64)|
+| versionId||false|integer(int64)|
+| versions||false|array|DatasourceVersion|
+| comment||false|string|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| datasourceId||false|integer|
+| parameter||false|string|
+| versionId||false|integer|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+## getInfoByDataSourceName
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/name/{dataSourceName}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:通过datsourceName查询数据源信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info/name/hive-test",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "info": {
+ "id": 10,
+ "dataSourceName": "hive-test",
+ "dataSourceDesc": "hive test",
+ "dataSourceTypeId": 4,
+ "createSystem": "Linkis",
+ "connectParams": {
+ "envId": "3"
+ },
+ "createTime": 1647862455000,
+ "modifyTime": 1647930476000,
+ "modifyUser": "hadoop",
+ "createUser": "hadoop",
+ "versionId": 3,
+ "publishedVersionId": 1,
+ "expire": false,
+ "dataSourceType": {
+ "name": "hive",
+ "layers": 0
+ }
+ }
+ }
+}
+```
+## getInfoByDataSourceId
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/{dataSourceId}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info/1",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "info": {
+ "id": 1,
+ "dataSourceName": "开源共建环境",
+ "dataSourceDesc": "123",
+ "dataSourceTypeId": 1,
+ "createSystem": "Linkis",
+ "connectParams": {
+ "host": "127.0.0.1",
+ "password": "xxxxx",
+ "port": "9600",
+ "username": "linkis"
+ },
+ "createTime": 1647258360000,
+ "modifyTime": 1647437692000,
+ "modifyUser": "hadoop",
+ "createUser": "hadoop",
+ "versionId": 1,
+ "publishedVersionId": 1,
+ "expire": false,
+ "dataSourceType": {
+ "name": "mysql",
+ "icon": "https://uat.dongcha.weoa.com/static/img/logo.770c1525.png",
+ "layers": 0
+ }
+ }
+ }
+}
+```
+## expireDataSource
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/{dataSourceId}/expire`
+
+**请求方式**:`PUT`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info/1/expire",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "expireId": 1
+ }
+}
+```
+## updateDataSourceInJson
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/{dataSourceId}/json`
+
+**请求方式**:`PUT`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求示例**:
+```javascript
+{
+ "connectParams": {},
+ "createIdentify": "",
+ "createSystem": "",
+ "createTime": "",
+ "createUser": "",
+ "dataSourceDesc": "",
+ "dataSourceEnv": {
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "envDesc": "",
+ "envName": "",
+ "id": 0,
+ "modifyTime": "",
+ "modifyUser": ""
+ },
+ "dataSourceEnvId": 0,
+ "dataSourceName": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "expire": true,
+ "id": 0,
+ "labels": "",
+ "modifyTime": "",
+ "modifyUser": "",
+ "publishedVersionId": 0,
+ "versionId": 0,
+ "versions": [
+ {
+ "comment": "",
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "datasourceId": 0,
+ "parameter": "",
+ "versionId": 0
+ }
+ ]
+}
+```
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSource|dataSource|body|true|DataSource|DataSource|
+| connectParams||false|object|
+| createIdentify||false|string|
+| createSystem||false|string|
+| createTime||false|string(date-time)|
+| createUser||false|string|
+| dataSourceDesc||false|string|
+| dataSourceEnv||false|DataSourceEnv|DataSourceEnv|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer|
+| envDesc||false|string|
+| envName||false|string|
+| id||false|integer|
+| modifyTime||false|string|
+| modifyUser||false|string|
+| dataSourceEnvId||false|integer(int64)|
+| dataSourceName||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer(int64)|
+| expire||false|boolean|
+| id||false|integer(int64)|
+| labels||false|string|
+| modifyTime||false|string(date-time)|
+| modifyUser||false|string|
+| publishedVersionId||false|integer(int64)|
+| versionId||false|integer(int64)|
+| versions||false|array|DatasourceVersion|
+| comment||false|string|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| datasourceId||false|integer|
+| parameter||false|string|
+| versionId||false|integer|
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+## getInfoByDataSourceIdAndVersion
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/{dataSourceId}/{version}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+|version|version|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info/1/1",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "info": {
+ "id": 1,
+ "dataSourceName": "开源共建环境",
+ "dataSourceDesc": "123",
+ "dataSourceTypeId": 1,
+ "createSystem": "Linkis",
+ "connectParams": {
+ "host": "127.0.0.1",
+ "password": "xxxxx",
+ "port": "9600",
+ "username": "linkis"
+ },
+ "createTime": 1647258360000,
+ "modifyTime": 1647437692000,
+ "modifyUser": "hadoop",
+ "createUser": "hadoop",
+ "versionId": 1,
+ "publishedVersionId": 1,
+ "expire": false,
+ "dataSourceType": {
+ "name": "mysql",
+ "icon": "https://uat.dongcha.weoa.com/static/img/logo.770c1525.png",
+ "layers": 0
+ }
+ }
+ }
+}
+```
+## getKeyDefinitionsByType
+**接口地址**:`/api/rest_j/v1/data-source-manager/key-define/type/{typeId}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|typeId|typeId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/key-define/type/4",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "keyDefine": [
+ {
+ "id": 6,
+ "key": "envId",
+ "description": "集群环境",
+ "name": "集群环境",
+ "valueType": "SELECT",
+ "require": true,
+ "dataSource": "/data-source-manager/env-list/all/type/4"
+ },
+ {
+ "id": 7,
+ "key": "keyTabFile",
+ "description": "KeyTab文件",
+ "name": "keyTab文件",
+ "valueType": "FILE",
+ "require": false,
+ "dataSource": "http://127.0.0.1:9001/api/rest_j/v1/bml/upload"
+ }
+ ]
+ }
+}
+```
+## getConnectParams
+**接口地址**:`/api/rest_j/v1/data-source-manager/name/{dataSourceName}/connect-params`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/name/linkis_test256/connect-params",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "connectParams": {
+ "host": "127.0.0.1",
+ "password": "xxxxx",
+ "port": "9600",
+ "username": "linkis"
+ }
+ }
+}
+```
+## insertJsonParameter
+**接口地址**:`/api/rest_j/v1/data-source-manager/parameter/{dataSourceId}/json`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+|params|params|body|true|object|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+## publishByDataSourceId
+**接口地址**:`/api/rest_j/v1/data-source-manager/publish/{dataSourceId}/{versionId}`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+|versionId|versionId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/publish/3/2",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+## getAllDataSourceTypes
+**接口地址**:`/api/rest_j/v1/data-source-manager/type/all`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+暂无
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/type/all",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "typeList": [
+ {
+ "id": "1",
+ "name": "mysql",
+ "description": "mysql数据库",
+ "option": "mysql数据库",
+ "classifier": "关系型数据库",
+ "icon": "https://uat.dongcha.weoa.com/static/img/logo.770c1525.png",
+ "layers": 3
+ },
+
+ {
+ "id": "4",
+ "name": "hive",
+ "description": "hive数据库",
+ "option": "hive",
+ "classifier": "大数据存储",
+ "layers": 3
+ }
+
+ ]
+ }
+}
+```
+## getConnectParams
+**接口地址**:`/api/rest_j/v1/data-source-manager/{dataSourceId}/connect-params`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/3/connect-params",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "connectParams": {
+ "host": "127.0.0.1",
+ "password": "xxxxx",
+ "port": "9600",
+ "username": "linkis"
+ }
+ }
+}
+```
+## getVersionList
+**接口地址**:`/api/rest_j/v1/data-source-manager/{dataSourceId}/versions`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/1/versions",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "versions": [
+ {
+ "versionId": 1,
+ "datasourceId": 1,
+ "connectParams": {
+ "host": "127.0.0.1",
+ "password": "xxxxx",
+ "port": "9600",
+ "username": "linkis"
+ },
+ "parameter": "{\"host\":\"127.0.0.1\",\"port\":\"9600\",\"username\":\"linkis\",\"password\":\"rO0ABXQACUFiY2RAMjAyMg==\"}",
+ "comment": "初始化版本",
+ "createUser": "hadoop"
+ }
+ ]
+ }
+}
+```
+## connectDataSource
+**接口地址**:`/api/rest_j/v1/data-source-manager/{dataSourceId}/{version}/op/connect`
+
+**请求方式**:`PUT`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+|version|version|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/1/1/op/connect",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "ok": true
+ }
+}
+```
+
+-----
+** DataSourceOperateRestfulApi类 **
+
+## connect
+**接口地址**:`/api/rest_j/v1/data-source-manager/op/connect/json`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求示例**:
+```javascript
+{
+ "connectParams": {},
+ "createIdentify": "",
+ "createSystem": "",
+ "createTime": "",
+ "createUser": "",
+ "dataSourceDesc": "",
+ "dataSourceEnv": {
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "envDesc": "",
+ "envName": "",
+ "id": 0,
+ "modifyTime": "",
+ "modifyUser": ""
+ },
+ "dataSourceEnvId": 0,
+ "dataSourceName": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "expire": true,
+ "id": 0,
+ "labels": "",
+ "modifyTime": "",
+ "modifyUser": "",
+ "publishedVersionId": 0,
+ "versionId": 0,
+ "versions": [
+ {
+ "comment": "",
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "datasourceId": 0,
+ "parameter": "",
+ "versionId": 0
+ }
+ ]
+}
+```
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSource|dataSource|body|true|DataSource|DataSource|
+| connectParams||false|object|
+| createIdentify||false|string|
+| createSystem||false|string|
+| createTime||false|string(date-time)|
+| createUser||false|string|
+| dataSourceDesc||false|string|
+| dataSourceEnv||false|DataSourceEnv|DataSourceEnv|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer|
+| envDesc||false|string|
+| envName||false|string|
+| id||false|integer|
+| modifyTime||false|string|
+| modifyUser||false|string|
+| dataSourceEnvId||false|integer(int64)|
+| dataSourceName||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer(int64)|
+| expire||false|boolean|
+| id||false|integer(int64)|
+| labels||false|string|
+| modifyTime||false|string(date-time)|
+| modifyUser||false|string|
+| publishedVersionId||false|integer(int64)|
+| versionId||false|integer(int64)|
+| versions||false|array|DatasourceVersion|
+| comment||false|string|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| datasourceId||false|integer|
+| parameter||false|string|
+| versionId||false|integer|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/file-system-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/file-system-api.md
new file mode 100644
index 00000000000..34e3a4b71e8
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/file-system-api.md
@@ -0,0 +1,1041 @@
+---
+title: 文件系统
+sidebar_position: 10
+---
+** FsRestfulApi 类 **
+
+
+
+
+
+## 创建新的Dir
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/createNewDir`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:创建新的Dir
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|路径|true|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 创建新的文件
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/createNewFile`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:创建新的文件
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|路径|true|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除dir文件或者文件
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/deleteDirOrFile`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除dir文件或者文件
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|true|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 下载
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/download`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:下载
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|charset|字符集|true|String|String|
+|path|地址|true|String|String|
+|json|json|body|true||
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 文件信息
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/fileInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:文件信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|query|true|string|
+|pageSize|页面大小|query|false|ref|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## formate
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/formate`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:resultsets转换成Excel
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|encoding|编码|query|true|string|
+|escapeQuotes|escapeQuotes|query|true|string|
+|fieldDelimiter|字段分隔符|query|true|string|
+|hasHeader|哈希值|query|true|boolean|
+|quote|引用|query|true|string|
+|path|地址|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 函数列表
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/getDirFileTrees`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取udf函数列表
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|请求路径|query|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/filesystem/getDirFileTrees",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "dirFileTrees": {
+ "name": "",
+ "path": "",
+ "properties": null,
+ "children": [{
+ "name": "",
+ "path": "",
+ "properties": {
+ "size": "",
+ "modifytime": ""
+ },
+ "children": ,
+ "isLeaf": ,
+ "parentPath": ""
+ }],
+ "isLeaf": ,
+ "parentPath":
+ }
+ }
+}
+```
+
+
+## 根路径
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/getUserRootPath`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取根路径
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|pathType|文件类型|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 是否存在
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/isExist`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:是否存在
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|query|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 打开文件
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/openFile`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:打开文件
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|query|true|string|
+|charset|字符集|query|false|string|
+|page|页码|query|false|ref|
+|pageSize|页面大小|query|false|ref|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/filesystem/openFile",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "metadata": [{
+ "columnName": "_c0",
+ "comment": "NULL",
+ "dataType": ""
+ }],
+ "totalPage": ,
+ "totalLine": ,
+ "page": ,
+ "type": "",
+ "fileContent": [
+ [""]
+ ]
+ }
+}
+```
+
+
+## 打开日志记录
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/openLog`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:打开日志记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|query|false|string|
+|proxyUser|代理用户|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/filesystem/openLog",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "log": ["", ""]
+ }
+}
+```
+
+
+## 重新命名
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/rename`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:重新给文件命名
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|newDest|新名称|false|String|String|
+|oldDest|旧名称|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 结果集转换成Excel
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/resultsetToExcel`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:结果集转换成Excel
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|autoFormat|是否自动|query|false|boolean|
+|charset|结果集|query|false|string|
+|csvSeperator|csv分隔栏|query|false|string|
+|limit|限度|query|false|ref|
+|nullValue|空值|query|false|string|
+|outputFileName|输出文件名称|query|false|string|
+|outputFileType|输出文件类型|query|false|string|
+|path|地址|query|false|string|
+|quoteRetouchEnable|是否引用修饰|query|false|boolean|
+|sheetName|sheet名称|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## resultsets转换成Excel
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/resultsetsToExcel`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:resultsets转换成Excel
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|autoFormat|是否自动|query|true|boolean|
+|limit|限度|query|true|ref|
+|nullValue|空值|query|true|string|
+|outputFileName|输出文件名称|query|true|string|
+|path|地址|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 保存脚本
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/saveScript`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:保存脚本
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|true|String|String|
+|SaveScript|json|body|true|SaveScript|SaveScript|
+|charset|字符集|false|String|String|
+|params|页面大小|false|Object|Object|
+|scriptContent|页码|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 上传
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/upload`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:上传文件,可传多个文件
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|file|文件|formData|false|ref|
+|path|地址|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/global-variable-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/global-variable-api.md
new file mode 100644
index 00000000000..00a153ce779
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/global-variable-api.md
@@ -0,0 +1,137 @@
+---
+title: 添加全局变量
+sidebar_position: 8
+---
+** VariableRestfulApi 类 **
+
+
+## 全局变量列表
+
+
+**接口地址**:`/api/rest_j/v1/variable/listGlobalVariable`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取全局变量清单
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized||
+|403|Forbidden||
+|404|Not Found||
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object||
+|message|描述|string||
+|method|请求url|string||
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 添加全局变量
+
+
+**接口地址**:`/api/rest_j/v1/variable/saveGlobalVariable`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:添加全局变量
+
+**请求示例**:
+```javascript
+{
+ globalVariables: [{
+ keyID: ,
+ key: "",
+ valueID: ,
+ value: ""
+ }]
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|globalVariables|新增参数数据一对多key:globalVariables,value:List||Map|true|Map|
+|key|参数名称,属于globalVariables||String|true|String|
+|value|变量值,跟key属于键值对 属于被globalVariables包含||List|true|List|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created||
+|401|Unauthorized||
+|403|Forbidden||
+|404|Not Found||
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object||
+|message|描述|string||
+|method|请求url|string||
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/variable/saveGlobalVariable",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/homepage-function-interface-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/homepage-function-interface-api.md
new file mode 100644
index 00000000000..eac4f43bded
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/homepage-function-interface-api.md
@@ -0,0 +1,327 @@
+---
+title: 管理台首页API
+sidebar_position: 7
+---
+** QueryRestfulApi 类 **
+
+
+## 管理员验证
+
+
+**接口地址**:`/api/rest_j/v1/jobhistory/governanceStationAdmin`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:用来验证是否为管理员,如果是则返回true不是则false
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ data: {solution: null, admin: true}
+ message: "OK"
+ method: "/api/jobhistory/governanceStationAdmin"
+ status: 0
+}
+```
+
+
+## 全局历史
+
+
+**接口地址**:`/api/rest_j/v1/jobhistory/list`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:根据条件获取全局历史数据列表默认获取全部
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|创建者|query|false|string|
+|endDate|结束时间|query|false|integer(int64)|
+|executeApplicationName|操作人|query|false|string|
+|isAdminView|是否为管理员模式或者普通模式|query|false|boolean|
+|pageSize|页面数量|query|false|ref|
+|proxyUser|代理用户|query|false|string|
+|startDate|开始时间|query|false|integer(int64)|
+|status|结束时间|query|false|string|
+|taskID|ID|query|false|integer(int64)|
+|tpageNow|页码|query|false|ref|
+|pageNow|pageNow|query|false|integer(int32)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ {
+ "method": "/api/jobhistory/list",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "solution": null,
+ "totalPage": 90,
+ "tasks": [{
+ "taskID": ,
+ "instance": ",
+ "execId": "",
+ "umUser": "",
+ "engineInstance": null,
+ "executionCode": "",
+ "progress": "",
+ "logPath": "",
+ "resultLocation": "",
+ "status": "",
+ "createdTime": ,
+ "updatedTime": ,
+ "engineType": "",
+ "errCode": 0,
+ "errDesc": "",
+ "executeApplicationName": "",
+ "requestApplicationName": "",
+ "runType": "datachecker",
+ "paramsJson": "",
+ "costTime": 1000,
+ "strongerExecId": "",
+ "sourceJson": "",
+ "sourceTailor": "",
+ "engineStartTime": null,
+ "labels": [],
+ "canRetry": ,
+ "subJobs":
+ }]
+ }
+}
+}
+```
+
+
+## 获取未完成任务列表
+
+
+**接口地址**:`/api/rest_j/v1/jobhistory/listundone`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取未完成任务列表
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|creator|query|false|string|
+|endDate|结束时间|query|false|integer(int64)|
+|engineType|engineType|query|false|string|
+|pageNow|pageNow|query|false|ref|
+|pageSize|pageSize|query|false|ref|
+|startDate|开始时间|query|false|ref|
+|startTaskID|startTaskID|query|false|integer(int64)|
+|status|status|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## job任务详细记录
+
+
+**接口地址**:`/api/rest_j/v1/jobhistory/{id}/get`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:job任务详细记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|历史记录Id|query|false|integer(int64)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/jobhistory/1928730/get",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "task": {
+ "taskID": ,
+ "instance": "",
+ "execId": "",
+ "umUser": "",
+ "engineInstance": "",
+ "executionCode": "",
+ "progress": "",
+ "logPath": "",
+ "resultLocation": "",
+ "status": "",
+ "createdTime":,
+ "updatedTime": ,
+ "engineType": "",
+ "errCode": ,
+ "errDesc": "",
+ "executeApplicationName": "",
+ "requestApplicationName": "",
+ "runType": "hql",
+ "paramsJson": "",
+ "costTime": ,
+ "strongerExecId": "",
+ "sourceJson": "",
+ "sourceTailor": "",
+ "engineStartTime": null,
+ "labels": [""],
+ "canRetry": false,
+ "subJobs": null
+ }
+ }
+}
+```
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/instance-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/instance-management-api.md
new file mode 100644
index 00000000000..20db12d0883
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/instance-management-api.md
@@ -0,0 +1,288 @@
+---
+title: 实例管理
+sidebar_position: 6
+---
+** InstanceRestful 类 **
+
+
+
+
+## 微服务实例列表
+
+
+**接口地址**:`/api/rest_j/v1/microservice/allInstance`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取微服务管理模块实例列表可获取单个或多个默认全部
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "instances": [{
+ "id": ,
+ "updateTime": ,
+ "createTime": ,
+ "applicationName": ",
+ "instance": "",
+ "labels": [{
+ "stringValue": "",
+ "labelKey": "",
+ "feature": "",
+ "id": 5,
+ "labelValueSize": 0,
+ "modifiable": true,
+ "updateTime": ,
+ "createTime": ,
+ "featureKey": "",
+ "empty":
+ }]
+ }]
+ }
+}
+```
+
+
+## 获取eurekaURL
+
+
+**接口地址**:`/api/rest_j/v1/microservice/eurekaURL`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:返回eurekaURL
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "url": ""
+ }
+}
+```
+
+
+## 编辑微服务实例
+
+
+**接口地址**:`/api/rest_j/v1/microservice/instanceLabel`
+
+
+**请求方式**:`PUT`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:编辑或修改下微服务管理中的实例
+
+**请求示例**:
+```javascript
+{
+ applicationName: "linkis-ps-cs"
+ instance: "localhost110004:9108"
+ labels: [{
+ labelKey: "route",
+ stringValue: "cs_2_dev"
+}]}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|引擎标签|String|false|String|
+|instance|引擎实例名称|String|String|String|
+|labelKey|添加内容里面的标签,属于labels集合 内 map里的key|String|String|String|
+|labels|引擎实例更新参数内容,集合存放的是map类型的|List|String|List|
+|stringValue|添加内容里面的标签对于的值,属于labels集合 内 map里的value|String|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "success",
+ "data": {
+ "labels": [{
+ "stringValue": "",
+ "labelKey": "",
+ "feature": null,
+ "modifiable": ,
+ "featureKey": "",
+ "empty":
+ }]
+ }
+}
+```
+
+
+## 可以修改的label 类型
+
+
+**接口地址**:`/api/rest_j/v1/microservice/modifiableLabelKey`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取可以修改的label类型列表,列表数据如‘userCreator,route’
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "keyList": []
+ }
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/jobhistory-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/jobhistory-api.md
new file mode 100644
index 00000000000..e74ae07e3ce
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/jobhistory-api.md
@@ -0,0 +1,251 @@
+---
+title: 历史作业API
+sidebar_position: 1
+---
+
+** QueryRestfulApi 类 **
+
+## 判断用户是否是管理员
+**接口地址**:`/api/rest_j/v1/jobhistory/governanceStationAdmin`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 判断用户是否是管理员
+
+**请求参数**:
+无
+
+**响应示例**:
+
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "admin": true
+ }
+}
+```
+
+
+## 获取数据源的数据库名称列表
+**接口地址**:`/api/rest_j/v1/jobhistory/{id}/get`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:获取数据源的数据库名称列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|id|path|true|string||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "task": {
+ "taskID": 1,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "FAILED",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ }
+ }
+}
+```
+
+## 历史任务列表
+**接口地址**:`/api/rest_j/v1/jobhistory/list`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:历史任务列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|startDate|startDate|path|false|Long||
+|endDate|endDate|path|false|Long||
+|status|status|path|false|string||
+|pageNow|pageNow|path|false|Integer||
+|pageSize|pageSize|path|false|Integer||
+|taskID|taskID|path|false|Long||
+|executeApplicationName|executeApplicationName|path|false|string||
+|creator|creator|path|false|string||
+|proxyUser|proxyUser|path|false|string||
+|isAdminView|isAdminView|path|false|Boolean||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "tasks": [{
+ "taskID": 1,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "FAILED",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ },
+ {
+ "taskID": 2,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "FAILED",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ }],
+ "totalPage": 1
+ }
+}
+```
+
+## 未完成的历史任务列表
+**接口地址**:`/api/rest_j/v1/jobhistory/listundone`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:未完成的历史任务列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|startDate|startDate|path|false|Long||
+|endDate|endDate|path|false|Long||
+|status|status|path|false|string||
+|pageNow|pageNow|path|false|Integer||
+|pageSize|pageSize|path|false|Integer||
+|startTaskID|startTaskID|path|false|Long||
+|engineType|engineType|path|false|string||
+|creator|creator|path|false|string||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "tasks": [{
+ "taskID": 1,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "Running",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ },
+ {
+ "taskID": 2,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "Running",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ }],
+ "totalPage": 1
+ }
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/link-error-code.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/link-error-code.md
new file mode 100644
index 00000000000..5b8daff94a3
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/link-error-code.md
@@ -0,0 +1,65 @@
+---
+title: Linkis错误代码
+sidebar_position: 5
+---
+** LinkisErrorCodeRestful 类 **
+
+
+
+## 获取Linkis错误代码
+
+
+**接口地址**:`/api/rest_j/v1/errorcode/getAllErrorCodes`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取Linkis错误代码列表
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/mdq-table-interface-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/mdq-table-interface-api.md
new file mode 100644
index 00000000000..75c153c7f5a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/mdq-table-interface-api.md
@@ -0,0 +1,317 @@
+---
+title: Mdq表API
+sidebar_position: 4
+---
+** MdqTableRestfulApi 类 **
+
+
+## 生成新建库表的DDL语句
+
+
+**接口地址**:`/api/rest_j/v1/datasource/displaysql`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:生成新建库表的DDL语句
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|table|表|String|false|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取分区统计信息
+
+
+**接口地址**:`/api/rest_j/v1/datasource/getPartitionStatisticInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取分区统计信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|database|数据源|query|false|string|
+|partitionSort|分区排序|String|false|String|
+|tableName|表名称|query|false|string|
+|partitionPath|partitionPath|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取表信息
+
+
+**接口地址**:`/api/rest_j/v1/datasource/getTableBaseInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取表信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|database|数据源|query|false|string|
+|tableName|表名称|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取表格字段信息
+
+
+**接口地址**:`/api/rest_j/v1/datasource/getTableFieldsInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取表格字段信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|database|数据源|query|false|string|
+|tableName|表名称|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取表统计信息
+
+
+**接口地址**:`/api/rest_j/v1/datasource/getTableStatisticInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取表统计信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|database|数据源|query|false|string|
+|pageNow|页码|query|false|string|
+|pageSize|页面大小|query|false|string|
+|partitionSort|分区排序|query|false|string|
+|tableName|表名称|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/metadatamanager-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/metadatamanager-api.md
new file mode 100644
index 00000000000..c23802ccfc5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/metadatamanager-api.md
@@ -0,0 +1,331 @@
+---
+title: 元数据查询API
+sidebar_position: 3
+---
+> 本接口为已废弃的老接口,请使用新接口[元数据查询新API](./metadatamanager-api.md)
+
+** MetadataCoreRestful 类 **
+
+## getColumns
+**接口地址**:`/api/rest_j/v1/metadatamanager/columns/{dataSourceId}/db/{database}/table/{table}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 获取数据表的column信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|database|database|path|true|string|
+|system|system|query|true|string|
+|table|table|path|true|string|
+
+**响应示例**:
+
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "columns": [
+ {
+ "index": 1,
+ "primaryKey": true,
+ "name": "id",
+ "type": "INT"
+ },
+ {
+ "index": 2,
+ "primaryKey": false,
+ "name": "datasource_name",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 3,
+ "primaryKey": false,
+ "name": "datasource_desc",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 4,
+ "primaryKey": false,
+ "name": "datasource_type_id",
+ "type": "INT"
+ },
+ {
+ "index": 5,
+ "primaryKey": false,
+ "name": "create_identify",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 6,
+ "primaryKey": false,
+ "name": "create_system",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 7,
+ "primaryKey": false,
+ "name": "parameter",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 8,
+ "primaryKey": false,
+ "name": "create_time",
+ "type": "DATETIME"
+ },
+ {
+ "index": 9,
+ "primaryKey": false,
+ "name": "modify_time",
+ "type": "DATETIME"
+ },
+ {
+ "index": 10,
+ "primaryKey": false,
+ "name": "create_user",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 11,
+ "primaryKey": false,
+ "name": "modify_user",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 12,
+ "primaryKey": false,
+ "name": "labels",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 13,
+ "primaryKey": false,
+ "name": "version_id",
+ "type": "INT"
+ },
+ {
+ "index": 14,
+ "primaryKey": false,
+ "name": "expire",
+ "type": "TINYINT"
+ },
+ {
+ "index": 15,
+ "primaryKey": false,
+ "name": "published_version_id",
+ "type": "INT"
+ }
+ ]
+ }
+}
+```
+
+
+## getDatabases
+**接口地址**:`/api/rest_j/v1/metadatamanager/dbs/{dataSourceId}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:获取数据源的数据库名称列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|system|system|query|true|string|
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "dbs": [
+ "information_schema",
+ "linkis",
+ "linkis_sit"
+ ]
+ }
+}
+```
+
+
+## getPartitions
+**接口地址**:`/api/rest_j/v1/metadatamanager/partitions/{dataSourceId}/db/{database}/table/{table}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|database|database|path|true|string|
+|system|system|query|true|string|
+|table|table|path|true|string|
+|traverse|traverse|query|false|boolean|
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "props": {
+ "partKeys": [
+ "ds"
+ ],
+ "root": {}
+ }
+ }
+}
+```
+
+## getTableProps
+**接口地址**:`/api/rest_j/v1/metadatamanager/props/{dataSourceId}/db/{database}/table/{table}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|database|database|path|true|string|
+|system|system|query|true|string|
+|table|table|path|true|string|
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "props": {
+ "skip.header.line.count": "1",
+ "columns.types": "int:int:string:string:string:string:string:string:string:string:string:string:string:string:string:string:string:string",
+ "columns": "id,age,job,marital,education,default,balance,housing,loan,contact,day,month,duration,campaign,pdays,previous,poutcome,y",
+ "field.delim": ",",
+ "transient_lastDdlTime": "1646732554",
+ "partition_columns.types": "string",
+ "columns.comments": "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000",
+ "bucket_count": "-1",
+ "serialization.ddl": "struct demo_data { i32 id, i32 age, string job, string marital, string education, string default, string balance, string housing, string loan, string contact, string day, string month, string duration, string campaign, string pdays, string previous, string poutcome, string y}",
+ "file.outputformat": "org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat",
+ "partition_columns": "ds",
+ "colelction.delim": "-",
+ "serialization.lib": "org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe",
+ "name": "dss_autotest.demo_data",
+ "location": "hdfs://bdpdev01/user/hive/warehouse/hadoop/dss_autotest.db/demo_data",
+ "mapkey.delim": ":",
+ "file.inputformat": "org.apache.hadoop.mapred.TextInputFormat",
+ "serialization.format": ",",
+ "column.name.delimiter": ","
+ }
+ }
+}
+```
+
+
+## getPartitionProps
+**接口地址**:`/api/rest_j/v1/metadatamanager/props/{dataSourceId}/db/{database}/table/{table}/partition/{partition}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|database|database|path|true|string|
+|partition|partition|path|true|string|
+|system|system|query|true|string|
+|table|table|path|true|string|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## getTables
+**接口地址**:`/api/rest_j/v1/metadatamanager/tables/{dataSourceId}/db/{database}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 获取数据源的某个数据库的数据表列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|database|database|path|true|string|
+|system|system|query|true|string|
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "tables": [
+ "test",
+ "test_0317a",
+ "test_import_sqoop_1",
+ "test_linkis_sqoop_1",
+ "test_linkis_sqoop_2",
+ "test_linkis_sqoop_3",
+ "upload_test"
+ ]
+ }
+}
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/metadataquery-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/metadataquery-api.md
new file mode 100644
index 00000000000..0274ae27d77
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/metadataquery-api.md
@@ -0,0 +1,266 @@
+---
+title: 元数据查询API(新)
+sidebar_position: 3
+---
+> 元数据查询接口优化之后的新接口,已废弃的旧接口见[元数据查询API](./metadatamanager-api.md),相对于旧接口,主要调整请求的路径和接口参数命名
+
+** MetadataQueryRestful 类 **
+
+## getColumns
+
+**接口地址**:`/api/rest_j/v1/metadataQuery/getColumns`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 获取数据表的column信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string||
+|envId|envId|path| false |string||
+|database|database|path|true|string||
+|system|system|query|true|string||
+|table|table|path|true|string||
+
+**响应示例**:
+
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "columns": [
+ {
+ "index": 1,
+ "primaryKey": true,
+ "name": "id",
+ "type": "INT"
+ },
+ {
+ "index": 2,
+ "primaryKey": false,
+ "name": "datasource_name",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 3,
+ "primaryKey": false,
+ "name": "datasource_desc",
+ "type": "VARCHAR"
+ },
+ ]
+ }
+}
+```
+
+
+## getDatabases
+**接口地址**:`/api/rest_j/v1/metadataQuery/getDatabases`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:获取数据源的数据库名称列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- |-------| -------- | ------ |
+|dataSourceName|dataSourceName|path| true |string||
+|envId|envId|path| false |string||
+|system|system|query| true |string||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "dbs": [
+ "information_schema",
+ "linkis",
+ "linkis_sit"
+ ]
+ }
+}
+```
+
+
+## getPartitions
+
+> 返回值调整为 props -> partitions
+
+**接口地址**:`/api/rest_j/v1/metadataQuery/getPartitions`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string||
+|database|database|path|true|string||
+|system|system|query|true|string||
+|table|table|path|true|string||
+|traverse|traverse|query|false|boolean||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "partitions": {
+ "partKeys": [
+ "ds"
+ ],
+ "root": {}
+ }
+ }
+}
+```
+
+## getTableProps
+**接口地址**:`/api/rest_j/v1/metadataQuery/getTableProps`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string||
+|database|database|path|true|string||
+|system|system|query|true|string||
+|table|table|path|true|string||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "props": {
+ "skip.header.line.count": "1",
+ "columns.types": "int:int:string:string:string:string:string:string:string:string:string:string:string:string:string:string:string:string",
+ "columns": "id,age,job,marital,education,default,balance,housing,loan,contact,day,month,duration,campaign,pdays,previous,poutcome,y",
+ "field.delim": ",",
+ "transient_lastDdlTime": "1646732554",
+ "partition_columns.types": "string",
+ "columns.comments": "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000",
+ "bucket_count": "-1",
+ "serialization.ddl": "struct demo_data { i32 id, i32 age, string job, string marital, string education, string default, string balance, string housing, string loan, string contact, string day, string month, string duration, string campaign, string pdays, string previous, string poutcome, string y}",
+ "file.outputformat": "org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat",
+ "partition_columns": "ds",
+ "colelction.delim": "-",
+ "serialization.lib": "org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe",
+ "name": "dss_autotest.demo_data",
+ "location": "hdfs://localhost01/user/hive/warehouse/hadoop/dss_autotest.db/demo_data",
+ "mapkey.delim": ":",
+ "file.inputformat": "org.apache.hadoop.mapred.TextInputFormat",
+ "serialization.format": ",",
+ "column.name.delimiter": ","
+ }
+ }
+}
+```
+
+
+## getPartitionProps
+**接口地址**:`/api/rest_j/v1/metadataQuery/getPartitionProps`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string||
+|database|database|path|true|string||
+|partition|partition|path|true|string||
+|system|system|query|true|string||
+|table|table|path|true|string||
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## getTables
+**接口地址**:`/api/rest_j/v1/metadataQuery/getTables`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 获取数据源的某个数据库的数据表列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string||
+|envId|envId|path| false |string||
+|database|database|path|true|string||
+|system|system|query|true|string||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "tables": [
+ "test",
+ "test_0317a",
+ "test_import_sqoop_1",
+ "test_linkis_sqoop_1",
+ "test_linkis_sqoop_2",
+ "test_linkis_sqoop_3",
+ "upload_test"
+ ]
+ }
+}
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/parameter-configuration-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/parameter-configuration-api.md
new file mode 100644
index 00000000000..89a3288ba5d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/parameter-configuration-api.md
@@ -0,0 +1,891 @@
+---
+title: 参数配置
+sidebar_position: 3
+---
+** ConfigurationRestfulApi 类 **
+
+
+
+
+## 添加KeyForEngine
+
+
+**接口地址**:`/api/rest_j/v1/configuration/addKeyForEngine`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:添加KeyForEngine
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|engineType|engineType|query|false|string|
+|keyJson|keyJson|query|false|string|
+|token|token|query|false|string|
+|version|version|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 新增应用类型
+
+
+**接口地址**:`/api/rest_j/v1/configuration/createFirstCategory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:新增应用类型标签
+
+**请求示例**:
+```javascript
+{
+ "categoryName": “”,
+ "description": ""
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|categoryName|引用类型标签名称|String|false|String|
+|description|描述|String|false|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/createFirstCategory",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+
+## 新增参数配置
+
+
+**接口地址**:`/api/rest_j/v1/configuration/createSecondCategory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:添加参数配置
+
+**请求示例**:
+```javascript
+{
+ categoryId: ,
+ description: "",
+ engineType: "",
+ version: ""
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|categoryId|参数配置Id|String|true|String|
+|description|描述|String|true|String|
+|engineType|引擎类型|String|true|String|
+|version|版本号|String|true|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/createSecondCategory",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+
+## 删除配置
+
+
+**接口地址**:`/api/rest_j/v1/configuration/deleteCategory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除参数配置
+
+**请求示例**:
+```javascript
+{
+ categoryId:
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|categoryId|参数配置Id|String|true|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/deleteCategory",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+
+## 引擎类型列表
+
+
+**接口地址**:`/api/rest_j/v1/configuration/engineType`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取引擎类型列表
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/engineType",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "engineType": []
+ }
+}
+```
+
+
+## 应用类型
+
+
+**接口地址**:`/api/rest_j/v1/configuration/getCategory`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:参数配置中应用类型标签
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/getCategory",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "Category": [{
+ "categoryId": ,
+ "labelId": ,
+ "categoryName": "",
+ "childCategory": [],
+ "description": null,
+ "tag": null,
+ "createTime": ,
+ "updateTime": ,
+ "level": ,
+ "fatherCategoryName": ""
+ }],
+ "description": null,
+ "tag": null,
+ "createTime": ,
+ "updateTime": ,
+ "level": ,
+ "fatherCategoryName":
+ }]
+ }
+}
+```
+
+
+## 队列资源
+
+
+**接口地址**:`/api/rest_j/v1/configuration/getFullTreesByAppName`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:参数配置中的队列资源模块返回队列资源的列及值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|标签名称|query|false|string|
+|engineType|engineType|query|false|string|
+|version|version|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/getFullTreesByAppName",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "fullTree": [{
+ "name": "队列资源",
+ "description": null,
+ "settings": [{
+ "id": ,
+ "key": "",
+ "description": "",
+ "name": "",
+ "defaultValue": "",
+ "validateType": "",
+ "validateRange": "[]",
+ "level": 1,
+ "engineType": ,
+ "treeName": "",
+ "valueId": ,
+ "configValue": "",
+ "configLabelId": ,
+ "unit": null,
+ "isUserDefined": ,
+ "hidden": ,
+ "advanced":
+ }]
+ }]
+ }
+}
+```
+
+
+## 获取键值
+
+
+**接口地址**:`/api/rest_j/v1/configuration/keyvalue`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取键值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|configKey|configKey|query|true|string|
+|creator|creator|query|false|string|
+|engineType|engineType|query|false|string|
+|version|version|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 保存键值
+
+
+**接口地址**:`/api/rest_j/v1/configuration/keyvalue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:保存键值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|configKey|configKey|true|String|String|
+|configValue|configValue|true|String|String|
+|creator|creator|true|String|String|
+|engineType|engineType|true|String|String|
+|version|version|true|String|String|
+|SaveKeyValue|json|body|true|SaveKeyValue|SaveKeyValue|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除键值
+
+
+**接口地址**:`/api/rest_j/v1/configuration/keyvalue`
+
+
+**请求方式**:`DELETE`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除键值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|configKey|configKey|true|String|String|
+|creator|creator|true|String|String|
+|engineType|engineType|true|String|String|
+|version|version|true|String|String|
+|DeleteKeyValue|json|body|true|DeleteKeyValue|DeleteKeyValue|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|204|No Content|
+|401|Unauthorized|
+|403|Forbidden|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## rpc测试
+
+
+**接口地址**:`/api/rest_j/v1/configuration/rpcTest`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:rpc测试
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|creator|query|false|string|
+|engineType|engineType|query|false|string|
+|username|username|query|false|string|
+|version|version|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 保存队列资源
+
+
+**接口地址**:`/api/rest_j/v1/configuration/saveFullTree`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:保存队列资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|应用类型名称|String|true|String|
+|description|描述,属于fullTree中的内容|String|true|String|
+|engineType|引擎类型|String|true|String|
+|fullTree|应用类型下的详细信息|List|true|List|
+|name|队列资源名称,属于fullTree中的内容|String|true|String|
+|settings|队列资源中的详细内容,属于fullTree中的内容|List|true|List|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/saveFullTree",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+
+## 更新类别信息
+
+
+**接口地址**:`/api/rest_j/v1/configuration/updateCategoryInfo`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新类别信息
+
+
+**响应示例**:
+```javascript
+{
+ description: "",
+ categoryId:
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|categoryId|categoryId|String|true|String|
+|description|description|String|true|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/updateCategoryInfo",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/udf-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/udf-api.md
new file mode 100644
index 00000000000..97f07f1b7e1
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/http/linkis-ps-publicservice-api/udf-api.md
@@ -0,0 +1,1395 @@
+---
+title: UDF操作管理
+sidebar_position: 16
+---
+
+** UDFApi 类 **
+
+## 新增
+
+**接口地址**:`/api/rest_j/v1/udf/add`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:新增
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|clusterName|clusterName|false|String|String|
+|createTime|创建时间|false|Date|Date|
+|createUser|创建者|false|String|String|
+|description|描述|false|String|String|
+|directory|分类,个人函数一级目录|false|String|String|
+|isExpire|是否失效|false|Boolean|Boolean|
+|isLoad|是否负载|false|Boolean|Boolean|
+|isShared|是否共享|false|Boolean|Boolean|
+|path|仅存储用户上一次上传的路径 作提示用|false|String|String|
+|registerFormat|注册执行地址|false|String|String|
+|sys|sys|false|String|String|
+|treeId|treeId|false|Long|Long|
+|udfName|udfName|false|String|String|
+|udfType|udfType|false|Integer|Integer|
+|updateTime|更新时间|false|Date|Date|
+|useFormat|使用格式|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## udf树形菜单
+
+
+**接口地址**:`/api/rest_j/v1/udf/all`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取udf树形菜单详细信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|请求路径|false|String|String|
+|jsonString|jsonString|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取udf用户列表
+
+
+**接口地址**:`/api/rest_j/v1/udf/allUdfUsers`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取udf用户列表
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|json|json|body|true|JsonNode|JsonNode|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 证实
+
+
+**接口地址**:`/api/rest_j/v1/udf/authenticate`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:证明…是真实的
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除
+
+
+**接口地址**:`/api/rest_j/v1/udf/delete/{id}`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|id|path|false|integer(int64)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## udf文件下载到本地
+
+
+**接口地址**:`/api/rest_j/v1/udf/downloadToLocal`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:根据版本参数下载UDF文件到本地
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|integer|
+|version|version|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## UDF查看源码
+
+
+**接口地址**:`/api/rest_j/v1/udf/downloadUdf`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**: UDF查看源码
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|integer|
+|version|version|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## UDF共享用户列表
+
+
+**接口地址**:`/api/rest_j/v1/udf/getSharedUsers`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:UDF共享用户列表
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|integer|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## UDF移交
+
+
+**接口地址**:`/api/rest_j/v1/udf/handover`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:UDF移交
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|handoverUser|切换用户|false|String|String|
+|udfId|udfId|false|integer|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 是否负载
+
+
+**接口地址**:`/api/rest_j/v1/udf/isload`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:是否负载
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|isLoad|是否负载|query|false|boolean|
+|udfId|udfId|query|false|integer(int64)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 函数列表
+
+
+**接口地址**:`/api/rest_j/v1/udf/list`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取函数列表
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|ListUDF|json|body|true|ListUDF|ListUDF|
+|category|类别|false|String|String|
+|treeId|树形菜单Id|false|String|String|
+|type|函数类型,比如expire,self,share等类型|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 基本信息
+
+
+**接口地址**:`/api/rest_j/v1/udf/managerPages`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:基本信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|curPage|页码|false|Integer|Integer|
+|pageSize|页面大小|false|Integer|Integer|
+|udfName|udf名称|false|String|String|
+|udfType|udf类型|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 出版
+
+
+**接口地址**:`/api/rest_j/v1/udf/publish`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:UDF版本发布
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|integer|
+|version|version|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 回退版本
+
+
+**接口地址**:`/api/rest_j/v1/udf/rollback`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:回退版本
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|integer|
+|version|version|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 设置过期
+
+
+**接口地址**:`/api/rest_j/v1/udf/setExpire`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:设置过期
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|Long|Long|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## UDF共享
+
+
+**接口地址**:`/api/rest_j/v1/udf/shareUDF`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:UDF共享
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|sharedUsers|sharedUsers|false|List|List|
+|udfInfo|udfInfo|false|UDFInfo|UDFInfo|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## tree新增
+
+
+**接口地址**:`/api/rest_j/v1/udf/tree/add`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:tree新增
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|category|category|false|String|String|
+|childrens|childrens|false|List|List|
+|clusterName|clusterName|false|String|String|
+|createTime|createTime|false|Date|Date|
+|description|description|false|String|String|
+|id|id|false|Long|Long|
+|name|name|false|String|String|
+|parent|parent|false|Long|Long|
+|udfInfos|udfInfos|false|List|List|
+|updateTime|updateTime|false|Date|Date|
+|userName|userName|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## tree删除
+
+
+**接口地址**:`/api/rest_j/v1/udf/tree/delete/{id}`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:tree删除
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|id|path|false|integer(int64)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## tree更新
+
+
+**接口地址**:`/api/rest_j/v1/udf/tree/update`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:tree更新
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|category|category|false|String|String|
+|childrens|childrens|false|List|List|
+|clusterName|clusterName|false|String|String|
+|createTime|createTime|false|Date|Date|
+|description|description|false|String|String|
+|id|id|false|Long|Long|
+|name|name|false|String|String|
+|parent|parent|false|Long|Long|
+|udfInfos|udfInfos|false|List|List|
+|updateTime|updateTime|false|Date|Date|
+|userName|userName|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 更新
+
+
+**接口地址**:`/api/rest_j/v1/udf/update`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:UDF修改
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|description|描述|false|String|String|
+|id|id|false|Long|Long|
+|isLoad|是否负载|false|Boolean|Boolean|
+|path|仅存储用户上一次上传的路径 作提示用|false|String|String|
+|registerFormat|注册执行地址|false|String|String|
+|udfName|udfName|false|String|String|
+|udfType|udfType|false|Integer|Integer|
+|useFormat|使用格式|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取用户目录
+
+
+**接口地址**:`/api/rest_j/v1/udf/userDirectory`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取用户个人函数的一级分类
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|category|获取指定集合类型用户目录,如类型为UDF即获取该类型下的用户目录|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 版本列表
+
+
+**接口地址**:`/api/rest_j/v1/udf/versionList`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:版本列表查看
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|query|false|integer(int64)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/jdbc-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/jdbc-api.md
new file mode 100644
index 00000000000..fbfef1539ea
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/jdbc-api.md
@@ -0,0 +1,59 @@
+---
+title: JDBC Driver 文档
+sidebar_position: 4
+---
+## 1. 引入依赖模块:
+第一种方式在pom里面依赖JDBC模块:
+```xml
+
+ org.apache.linkis
+ linkis-jdbc-driver
+ ${linkis.version}
+
+```
+**注意:** 该模块还没有deploy到中央仓库,需要在linkis-computation-governance/linkis-jdbc-driver目录里面执行`mvn install -Dmaven.test.skip=true`进行本地安装。
+
+**第二种方式通过打包和编译:**
+1. 在Linkis项目中进入到linkis-computation-governance/linkis-jdbc-driver目录然后在终端输入指令进行打包`mvn assembly:assembly -Dmaven.test.skip=true`
+该打包指令会跳过单元测试的运行和测试代码的编译,并将JDBC模块需要的依赖一并打包进Jar包之中。
+2. 打包完成后在JDBC的target目录下会生成两个Jar包,Jar包名称中包含dependencies字样的那个就是我们需要的驱动包
+
+## 2. 建立测试类:
+建立Java的测试类LinkisJDBCTest,具体接口含义可以见注释:
+
+```java
+package org.apache.linkis.jdbc.test;
+
+import java.sql.*;
+
+public class LinkisJDBCTest {
+
+ public static void main(String[] args) throws SQLException, ClassNotFoundException {
+
+ //1. load driver:org.apache.linkis.ujes.jdbc.UJESSQLDriver
+ Class.forName("org.apache.linkis.ujes.jdbc.UJESSQLDriver");
+
+ //2. Get Connection:jdbc:linkis://gatewayIP:gatewayPort/dbName?EngineType=hive&creator=test, user/password
+ Connection connection = DriverManager.getConnection("jdbc:linkis://127.0.0.1:9001/default?EngineType=hive&creator=test","hadoop","hadoop");
+ //3. Create statement
+ Statement st= connection.createStatement();
+ ResultSet rs=st.executeQuery("show tables");
+ //4.get result
+ while (rs.next()) {
+ ResultSetMetaData metaData = rs.getMetaData();
+ for (int i = 1; i <= metaData.getColumnCount(); i++) {
+ System.out.print(metaData.getColumnName(i) + ":" +metaData.getColumnTypeName(i)+": "+ rs.getObject(i) + " ");
+ }
+ System.out.println();
+ }
+ //close resource
+ rs.close();
+ st.close();
+ connection.close();
+ }
+}
+```
+
+备注:
+1. 其中EngineType为指定对应的引擎类型:支持Spark/hive/presto/shell等
+2. 其中creator为指定对应的应用类型,用于应用间的资源隔离
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/linkis-task-operator.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/linkis-task-operator.md
new file mode 100644
index 00000000000..ecc10804201
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/linkis-task-operator.md
@@ -0,0 +1,402 @@
+---
+title: 任务提交执行 Rest API 文档
+sidebar_position: 3
+---
+- Linkis Restful接口的返回,都遵循以下的标准返回格式:
+
+```json
+{
+ "method": "",
+ "status": 0,
+ "message": "",
+ "data": {}
+}
+```
+
+**约定**:
+
+ - method:返回请求的Restful API URI,主要是 WebSocket 模式需要使用。
+ - status:返回状态信息,其中:-1表示没有登录,0表示成功,1表示错误,2表示验证失败,3表示没该接口的访问权限。
+ - data:返回具体的数据。
+ - message:返回请求的提示信息。如果status非0时,message返回的是错误信息,其中data有可能存在stack字段,返回具体的堆栈信息。
+
+更多关于 Linkis Restful 接口的规范,请参考:[Linkis Restful 接口规范](../development/development-specification/api)
+
+### 1. 提交执行
+
+- 接口 `/api/rest_j/v1/entrance/submit`
+
+- 提交方式 `POST`
+
+```json
+{
+ "executionContent": {
+ "code": "show tables",
+ "runType": "sql"
+ },
+ "params": {
+ "variable": {// task variable
+ "testvar": "hello"
+ },
+ "configuration": {
+ "runtime": {// task runtime params
+ "jdbc.url": "XX"
+ },
+ "startup": { // ec start up params
+ "spark.executor.cores": "4"
+ }
+ }
+ },
+ "source": { //task source information
+ "scriptPath": "file:///tmp/hadoop/test.sql"
+ },
+ "labels": {
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+- 返回示例
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/submit",
+ "status": 0,
+ "message": "请求执行成功",
+ "data": {
+ "execID": "030418IDEhivelocalhost010004:10087IDE_hadoop_21",
+ "taskID": "123"
+ }
+}
+```
+
+- execID是用户任务提交到 Linkis 之后,为该任务生成的唯一标识执行ID,为 String 类型,这个ID只在任务运行时有用,类似PID的概念。ExecID 的设计为`(requestApplicationName长度)(executeAppName长度)(Instance长度)${requestApplicationName}${executeApplicationName}${entranceInstance信息ip+port}${requestApplicationName}_${umUser}_${index}`
+
+- taskID 是表示用户提交task的唯一ID,这个ID由数据库自增生成,为 Long 类型
+
+
+### 2. 获取状态
+
+- 接口 `/api/rest_j/v1/entrance/${execID}/status`
+
+- 提交方式 `GET`
+
+- 返回示例
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/{execID}/status",
+ "status": 0,
+ "message": "获取状态成功",
+ "data": {
+ "execID": "${execID}",
+ "status": "Running"
+ }
+}
+```
+
+### 3. 获取日志
+
+- 接口 `/api/rest_j/v1/entrance/${execID}/log?fromLine=${fromLine}&size=${size}`
+
+- 提交方式 `GET`
+
+- 请求参数fromLine是指从第几行开始获取,size是指该次请求获取几行日志
+
+- 返回示例,其中返回的fromLine需要作为下次请求该接口的参数
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/${execID}/log",
+ "status": 0,
+ "message": "返回日志信息",
+ "data": {
+ "execID": "${execID}",
+ "log": ["error日志","warn日志","info日志", "all日志"],
+ "fromLine": 56
+ }
+}
+```
+
+### 4. 获取进度
+
+- 接口 `/api/rest_j/v1/entrance/${execID}/progress`
+
+- 提交方式 `GET`
+
+- 返回示例
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/{execID}/progress",
+ "status": 0,
+ "message": "返回进度信息",
+ "data": {
+ "execID": "${execID}",
+ "progress": 0.2,
+ "progressInfo": [
+ {
+ "id": "job-1",
+ "succeedTasks": 2,
+ "failedTasks": 0,
+ "runningTasks": 5,
+ "totalTasks": 10
+ },
+ {
+ "id": "job-2",
+ "succeedTasks": 5,
+ "failedTasks": 0,
+ "runningTasks": 5,
+ "totalTasks": 10
+ }
+ ]
+ }
+}
+```
+
+### 5. kill任务
+
+- 接口 `/api/rest_j/v1/entrance/${execID}/kill`
+
+- 提交方式 `GET`
+
+- 返回示例
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/{execID}/kill",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "execID":"${execID}"
+ }
+}
+```
+
+### 6. 获取任务信息
+
+- 接口 `/api/rest_j/v1/jobhistory/{id}/get`
+
+- 提交方式 `GET`
+
+- 请求参数
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|id|path|true|string||
+
+
+- 返回示例
+
+```json
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "task": {
+ "taskID": 1,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "FAILED",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ }
+ }
+}
+```
+
+### 7. 获取结果集信息
+
+支持多结果集信息
+
+- 接口 `/api/rest_j/v1/filesystem/getDirFileTrees`
+
+- 提交方式 `GET`
+
+- 请求参数
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|结果集目录路径|query|true|string||
+
+
+- 返回示例
+
+```json
+{
+ "method": "/api/filesystem/getDirFileTrees",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "dirFileTrees": {
+ "name": "1946923",
+ "path": "hdfs:///tmp/hadoop/linkis/2022-07-06/211446/IDE/1946923",
+ "properties": null,
+ "children": [
+ {
+ "name": "_0.dolphin",
+ "path": "hdfs:///tmp/hadoop/linkis/2022-07-06/211446/IDE/1946923/_0.dolphin",//result set 1
+ "properties": {
+ "size": "7900",
+ "modifytime": "1657113288360"
+ },
+ "children": null,
+ "isLeaf": true,
+ "parentPath": "hdfs:///tmp/hadoop/linkis/2022-07-06/211446/IDE/1946923"
+ },
+ {
+ "name": "_1.dolphin",
+ "path": "hdfs:///tmp/hadoop/linkis/2022-07-06/211446/IDE/1946923/_1.dolphin",//result set 2
+ "properties": {
+ "size": "7900",
+ "modifytime": "1657113288614"
+ },
+ "children": null,
+ "isLeaf": true,
+ "parentPath": "hdfs:///tmp/hadoop/linkis/2022-07-06/211446/IDE/1946923"
+ }
+ ],
+ "isLeaf": false,
+ "parentPath": null
+ }
+ }
+}
+```
+
+### 8. 获取结果集内容
+
+- 接口 `/api/rest_j/v1/filesystem/openFile`
+
+- 提交方式 `GET`
+
+- 请求参数
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|结果集文件|query|true|string||
+|charset|字符集|query|false|string||
+|page|页码|query|false|ref||
+|pageSize|页面大小|query|false|ref||
+
+
+- 返回示例
+
+```json
+{
+ "method": "/api/filesystem/openFile",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "metadata": [
+ {
+ "columnName": "count(1)",
+ "comment": "NULL",
+ "dataType": "long"
+ }
+ ],
+ "totalPage": 0,
+ "totalLine": 1,
+ "page": 1,
+ "type": "2",
+ "fileContent": [
+ [
+ "28"
+ ]
+ ]
+ }
+}
+```
+
+### 9. 获取结果集按照文件流的方式
+
+获取结果集为CSV和Excel按照流的方式
+
+- 接口 `/api/rest_j/v1/filesystem/resultsetToExcel`
+
+- 提交方式 `GET`
+
+- 请求参数
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|autoFormat|是否自动转换格式|query|false|boolean||
+|charset|字符集|query|false|string||
+|csvSeperator|csv分隔栏|query|false|string||
+|limit|获取行数|query|false|ref||
+|nullValue|空值转换|query|false|string||
+|outputFileName|输出文件名称|query|false|string||
+|outputFileType|输出文件类型 csv 或者Excel|query|false|string||
+|path|结果集路径|query|false|string||
+
+- 返回示例
+
+```json
+文件流
+```
+
+### 10. 兼容0.X的任务执行接口
+
+- 接口 `/api/rest_j/v1/entrance/execute`
+
+- 提交方式 `POST`
+
+```json
+{
+ "executeApplicationName": "hive", //Engine type
+ "requestApplicationName": "dss", //Client service type
+ "executionCode": "show tables",
+ "params": {
+ "variable": {// task variable
+ "testvar": "hello"
+ },
+ "configuration": {
+ "runtime": {// task runtime params
+ "jdbc.url": "XX"
+ },
+ "startup": { // ec start up params
+ "spark.executor.cores": "4"
+ }
+ }
+ },
+ "source": { //task source information
+ "scriptPath": "file:///tmp/hadoop/test.sql"
+ },
+ "labels": {
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ },
+ "runType": "hql", //The type of script to run
+ "source": {"scriptPath":"file:///tmp/hadoop/1.hql"}
+}
+```
+
+- Sample Response
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/execute",
+ "status": 0,
+ "message": "Request executed successfully",
+ "data": {
+ "execID": "030418IDEhivelocalhost010004:10087IDE_hadoop_21",
+ "taskID": "123"
+ }
+}
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/login-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/login-api.md
new file mode 100644
index 00000000000..aa896f0ebde
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/login-api.md
@@ -0,0 +1,133 @@
+---
+title: 登录文档
+sidebar_position: 2
+---
+
+
+
+## 1.对接LDAP服务
+
+进入/conf目录,执行命令:
+
+```bash
+ vim linkis-mg-gateway.properties
+```
+
+添加LDAP相关配置:
+```bash
+wds.linkis.ldap.proxy.url=ldap://127.0.0.1:1389/ # 您的LDAP服务URL
+wds.linkis.ldap.proxy.baseDN=dc=webank,dc=com # 您的LDAP服务的配置
+```
+
+## 2.免登录配置
+
+如何打开测试模式,实现免登录?进入/conf目录,执行命令:
+
+```bash
+ vim linkis-mg-gateway.properties
+```
+
+将测试模式打开,参数如下:
+
+```shell
+ wds.linkis.test.mode=true # 打开测试模式
+ wds.linkis.test.user=hadoop # 指定测试模式下,所有请求都代理给哪个用户
+```
+
+## 3.登录接口汇总
+
+我们提供以下几个与登录相关的接口:
+
+ - 登录
+ - 登出
+ - 心跳
+
+
+## 4.接口详解
+
+- Linkis Restful接口的返回,都遵循以下的标准返回格式:
+
+```json
+{
+ "method": "",
+ "status": 0,
+ "message": "",
+ "data": {}
+}
+```
+
+**约定**:
+
+ - method:返回请求的Restful API URI,主要是 WebSocket 模式需要使用。
+ - status:返回状态信息,其中:-1表示没有登录,0表示成功,1表示错误,2表示验证失败,3表示没该接口的访问权限。
+ - data:返回具体的数据。
+ - message:返回请求的提示信息。如果status非0时,message返回的是错误信息,其中data有可能存在stack字段,返回具体的堆栈信息。
+
+更多关于 Linkis Restful 接口的规范,请参考:[Linkis Restful 接口规范](../development/development-specification/api)
+
+### 4.1 登录
+
+- 接口 `/api/rest_j/v1/user/login`
+
+- 提交方式 `POST`
+
+```json
+ {
+ "userName": "",
+ "password": ""
+ }
+```
+
+- 返回示例
+
+```json
+ {
+ "method": null,
+ "status": 0,
+ "message": "login successful(登录成功)!",
+ "data": {
+ "isAdmin": false,
+ "userName": ""
+ }
+ }
+```
+
+其中:
+
+ - isAdmin: Linkis只有admin用户和非admin用户,admin用户的唯一特权,就是支持在Linkis管理台查看所有用户的历史任务。
+
+### 4.2 登出
+
+- 接口 `/api/rest_j/v1/user/logout`
+
+- 提交方式 `POST`
+
+ 无参数
+
+- 返回示例
+
+```json
+ {
+ "method": "/api/rest_j/v1/user/logout",
+ "status": 0,
+ "message": "退出登录成功!"
+ }
+```
+
+### 4.3 心跳
+
+- 接口 `/api/rest_j/v1/user/heartbeat`
+
+- 提交方式 `POST`
+
+ 无参数
+
+- 返回示例
+
+```json
+ {
+ "method": "/api/rest_j/v1/user/heartbeat",
+ "status": 0,
+ "message": "维系心跳成功!"
+ }
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/overview.md
new file mode 100644
index 00000000000..a4d0d3889aa
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/api/overview.md
@@ -0,0 +1,13 @@
+---
+title: 总览
+sidebar_position: 1
+---
+
+## 1. 文档说明
+Linkis1.0 在Linkix0.x版本的基础上进行了重构优化,同时也兼容了0.x的接口,但是为了防止在使用1.0版本时存在兼容性问题,需要您仔细阅读以下文档:
+
+1. 使用Linkis1.0定制化开发时,需要使用到Linkis的权限认证接口,请仔细阅读 [登录API文档](login-api.md)。
+
+2. Linkis1.0提供JDBC的接口,需要使用JDBC的方式接入Linkis,请仔细阅读[任务提交执行JDBC API文档](jdbc-api.md)。
+
+3. Linkis1.0提供了Rest接口,如果需要在Linkis的基础上开发上层应用,请仔细阅读[任务提交执行Rest API文档](linkis-task-operator.md)。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/_category_.json
new file mode 100644
index 00000000000..33d9cbb6e4d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "架构设计",
+ "position": 7
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/_category_.json
new file mode 100644
index 00000000000..35d4ecf92fb
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "关键特性架构",
+ "position": 4
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/_category_.json
new file mode 100644
index 00000000000..1b0f37a1f69
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "公共模块",
+ "position": 1
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/proxy-user.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/proxy-user.md
new file mode 100644
index 00000000000..3284e323f7b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/proxy-user.md
@@ -0,0 +1,38 @@
+---
+title: Linkis 支持代理用户提交架构设计
+sidebar_position: 6
+---
+
+## 1 背景
+目前linkis在执行用户提交的任务时,linkis主要进程服务会通过sudo -u ${submit user} 切换到对应用户下,然后执行对应的引擎启动命令,
+这就需要为每个${submit user} 提前创建对应的系统用户,并且配置好相关的环境变量。
+对于新用户,需要一系列的环境的初始化准备工作,如果频繁的用户变化,会增大运维成本,而且用户过多,没法针对单个用户配置资源,资源之间无法很好的管控。如果能够实现A代理给指定的代理用户执行,可以将执行入口统一收敛,解决需要初始化环境的问题。
+
+## 2 基本概念
+- 登陆用户:通过用户名密码直接登陆系统的用户
+- 代理用户:作为登陆用户实际执行操作的用户称之为代理用户,代理登陆用户的相关操作
+
+## 3 实现的目标
+- 登陆用户A可以进行代理用户的选择,决定代理给哪个代理用户
+- 登陆用户A可以将任务代理给代理用户B执行
+- 登陆用户A代理到代理用户B时,可以查看B相关的执行记录,任务结果等数据
+- 一个代理用户同时可以代理多个登陆用户,但是一个登陆用户同一时刻只能关联某一个代理用户
+
+## 4 实现大体思路
+
+修改现有接口cookie处理,需要能在cookie中解析出登录用户和代理用户
+```html
+代理用户的cookie的key为:linkis_user_session_proxy_ticket_id_v1
+登录用户的cookie: linkis_user_session_ticket_id_v1
+
+```
+
+- linkis的相关接口需要 在原来获取UserName的基础上,要能识别出代理用户信息,使用代理用户进行各项操作。并记录审计日志,包含用户的任务执行操作,下载操作
+- 任务提交执行的时候,entrance入口服务需要修改执行的用户为代理用户
+
+## 5 需要考虑&注意的事项
+
+- 用户分为代理用户和非代理用户,代理类型的用户不能进行再次代理到其他用户执行
+- 需要控制登陆用户与可代理的系统用户列表,禁止出现任意代理的情况,避免权限不可控。最好支持数据库表来配置,并可以直接修改生效,不需要重启服务
+- 单独记录日志文件包含代理用户的操作,如代理执行、函数更新等PublicService的代理用户操作全部记录到日志中,方便审计
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/rpc.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/rpc.md
new file mode 100644
index 00000000000..1a310f51705
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/rpc.md
@@ -0,0 +1,137 @@
+---
+title: RPC 模块
+sidebar_position: 2
+---
+
+基于Feign的微服务之间HTTP接口调用,只能满足简单的A微服务实例根据简单的规则随机访问B微服务之中的某个服务实例,而这个B微服务实例如果想异步回传信息给调用方,是根本无法实现的。
+同时,由于Feign只支持简单的服务选取规则,无法做到将请求转发给指定的微服务实例,无法做到将一个请求广播给接收方微服务的所有实例。
+Linkis RPC是基于Spring Cloud + Feign实现的一套微服务间的异步请求和广播通信服务,可以独立于Linkis而使用。
+
+
+
+## 1. 简介
+Linkis RPC作为底层的通信方案,将提供SDK集成到有需要的微服务之中。
+一个微服务既可以作为请求调用方,也可以作为请求接收方。
+
+作为请求调用方时,将通过Sender请求目标接收方微服务的Receiver,作为请求接收方时,将提供Receiver用来处理请求接收方Sender发送过来的请求,以便完成同步响应或异步响应。
+![](/Images/Architecture/RPC-01.png)
+
+```
+org.apache.linkis.rpc.Sender
+org.apache.linkis.rpc.Receiver
+```
+
+### 1.1. 架构设计图
+![Linkis RPC架构图](/Images-zh/Architecture/Commons/linkis-rpc.png)
+### 1.2. 模块说明
+主要模块的功能介绍如下:
+* Eureka:服务注册中心,用户管理服务,服务发现。
+* Sender发送器:服务请求接口,发送端使用Sender向接收端请求服务。
+* Receiver接收器:服务请求接收相应接口,接收端通过该接口响应服务。
+* Interceptor拦截器:Sender发送器会将使用者的请求传递给拦截器。拦截器拦截请求,对请求做额外的功能性处理,分别是广播拦截器用于对请求广播操作、重试拦截器用于对失败请求重试处理、缓存拦截器用于简单不变的请求读取缓存处理、和提供默认实现的默认拦截器。
+* Decoder,Encoder:用于请求的编码和解码。
+* Feign:是一个http请求调用的轻量级框架,声明式WebService客户端程序,用于Linkis-RPC底层通信。
+* Listener:监听模块,主要用于监听广播请求。
+
+
+
+## 2. 实现
+
+基于请求调用方的Sender体系和请求接收方的Receiver体系,构成了Linkis RPC的全部架构。
+![](/Images/Architecture/RPC-01.png)
+
+### 2.1 发送端
+Linkis RPC作为底层的通信层,发送端无需调用者写任何的实际代码。
+
+- 调用者通过调用Linkis RPC提供的SDK,通过微服务名(Service Name)或指定微服务实例(微服务名+微服务实例的IP和端口),获取一个Sender发送器。
+
+Sender提供的可使用方法,见如下伪代码:
+```
+abstract class Sender {
+ Object ask(Object message);
+ Object ask(Object message, Duration timeout);
+ void send(Object message);
+ void deliver(Object message);
+}
+
+其中:
+1. ask方法为同步请求响应方法,要求接收端必须同步返回响应;
+2. send方法为同步请求方法,只负责同步将请求发送给接收端,不要求接收端给出答复;
+3. deliver则为异步请求方法,只要发送端的进程不异常退出,在稍后会通过其它线程将请求发送给接收端。
+```
+
+- 调用者作为发送端,通过Sender发送器提供的请求方法,发送请求给接收端。
+- Sender发送器会将调用者的请求传递给拦截器,进行一系列发送前的逻辑处理。
+
+拦截器拦截请求,开始对请求做额外的功能性处理:
+
+**广播拦截器**
+```
+org.apache.linkis.rpc.interceptor.common.BroadcastRPCInterceptor
+```
+广播拦截器只对需要进行广播的请求生效。
+广播拦截器会提供特殊的广播接口,如果本次请求实现了该广播接口,且该请求不是正在广播中,广播拦截器则认为本次请求需要进行广播,这时会触发广播操作。
+
+**重试拦截器**
+
+```
+org.apache.linkis.rpc.interceptor.common.RetryableRPCInterceptor
+```
+
+重试拦截器会对接下来的所有步骤提供重试功能。
+如果接收端要求重试,或者发送请求时出现了ConnectException(连接异常),或者调用者指定某些异常需要重试,这时重试拦截器会自动进行重试。
+
+
+**缓存拦截器**
+```
+org.apache.linkis.rpc.interceptor.common.CacheableRPCInterceptor
+```
+
+缓存拦截器是针对一些响应内容不大可能经常变动的同步请求而设定的。
+缓存拦截器也会提供特殊的缓存接口,如果本次请求实现了缓存接口,会首先在缓存拦截器中寻找缓存,不存在缓存才会继续请求,并在拿到响应后,先将响应缓存起来,再将响应返回。
+
+**公共默认拦截器**
+```
+org.apache.linkis.rpc.interceptor.common.CommonRPCInterceptor
+```
+
+
+公共默认拦截器用于调用接下来的处理步骤(示例参考:org.apache.linkis.rpc.BaseRPCSender#ask)
+
+
+- 请求编码器会先将用户请求的数据(实体Bean)转换成序列化的JSON字符串,然后传递给Feign客户端生成器。
+- Feign客户端生成器,生成可访问接收端Restful请求接收器的Feign客户端。
+- 生成的Feign客户端,会调用Eureka客户端,获取所有微服务列表,通过服务选择器,如果调用者指定微服务名,则通过Feign的负载均衡策略,
+ 选择一个合适的接收方微服务实例进行请求转发,否则服务选择器会重写Spring Cloud Feign的FeignLoadBalancer(Feign负载均衡器),
+ 在创建LoadBalancerCommand时,请求调用者指定的微服务实例(微服务名+微服务实例address)。
+ 调用Feign客户端,开始请求接收端的Restful请求接收器。
+
+**自定义拦截器**
+
+调用者也可以自己实现自定义拦截器(在linkis-commons/linkis-rpc/src/main/scala/org/apache/linkis/rpc/interceptor/common下实现RPCInterceptor接口,并通过@Component注入),用于实现一些特定的功能。
+
+### 2.2 接收端
+接收端需要调用者**实现Receiver接口**,用于处理真正的业务逻辑。
+- 1. RPCReceiveRestful请求接收器作为Linkis RPC内嵌的HTTP请求Web Service服务,负责接收发送端的请求
+- 2. RPCReceiveRestful请求接收器接收到请求后,先调用请求解码器对请求进行解码,解析出实际的请求信息和发送端微服务信息(微服务名+微服务实例的IP和端口),如果解析失败,会直接响应解析请求失败。
+- 3. 将解析后的请求信息和发送端微服务信息放入请求消息队列;
+- 4. 请求消费器会消费请求消息队列里,已经解码的发送端请求。
+- 5. 通过调用Receiver管理器获取一个合适的Receiver;同时通过发送端微服务信息,使用Sender生成器生成一个指向发送端的Sender。 然后请求消费器将实际的请求信息和生成的发送端Sender,传给Receiver进行处理。
+- 6. Receiver作为用户请求的实际处理单元,要求调用者必须实现Receiver接口,完成对调用端请求的实际处理逻辑。
+```
+Receiver的伪代码如下:
+public interface Receiver {
+ void receive(Object message, Sender sender);
+ Object receiveAndReply(Object message, Sender sender);
+ Object receiveAndReply(Object message, Duration duration, Sender sender);
+}
+```
+Receiver提供了处理同步请求和异步请求的方法。
+- 如果本次请求是异步请求,则调用Receiver的receive方法,由上层业务决定是否需要通过发送端的Sender回传响应。
+- 如果本次请求是同步请求,则调用 Receiver的receiveAndReply方法,将返回值作为响应结果,回传发送端。
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/variable.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/variable.md
new file mode 100644
index 00000000000..ebcca3464c6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/commons/variable.md
@@ -0,0 +1,102 @@
+---
+title: 自定义变量设计
+sidebar_position: 1
+---
+
+## 1. 总述
+### 需求
+1. 用户希望Linkis能够提供一些公共变量然后执行的时候进行替换,比如用户每天都会批量跑同一段sql,需要指定上一天的分区时间,如果基于sql去写会比较复杂如果系统提供一个run_date的变量将会非常方便使用。
+2. 用户希望Linkis支持date pattern计算,支持在代码中写&{YYYY-MM-DD}等变量计算时间变量
+3. 用户希望自己定义变量,比如定一个一个float变量,然后在代码中进行使用
+
+### 目标
+1. 支持任务代码的变量替换
+2. 支持自定义变量,支持用户在脚本和提交给Linkis的任务参数定义自定义变量,支持简单的+,-等计算
+3. 预设置系统变量:run_date,run_month,run_today等系统变量
+4. 支持date pattern变量,支持pattern的+,-操作
+
+## 2. 总体设计
+ 在Linkis任务执行过程中自定义变量在Entrance进行,主要通过Entrance在任务提交执行前的拦截器进行拦截替换实现,通过正则表达式获取到任务代码中使用到的变量和定义的变量,并通过任务传入的自定义变量初始值完成代码的替换,变成最终可以执行的代码。
+
+### 2.1 技术架构
+ 自定义变量整体架构如下,用于任务提交过来后,会经过变量替换拦截器。首先会解析出所有代码中用到的变量和表达式,然后通过和系统以及用户自定义的变量初始值进行替换,最终将解析后的代码提交给EngineConn执行。所以到底层引擎已经是替换好的代码。
+
+![arc](/Images/Architecture/Commons/var_arc.png)
+
+备注:变量和解析的功能因为比较通用,抽成工具类定义在linkis-commons中:org.apache.linkis.common.utils.VariableUtils
+
+### 2.2 业务架构
+ 此次的特性主要是为了完成变量替换的解析、计算、替换功能,主要涉及到linkis的Entrance模块做代码拦截和Linkis-commons模块定义的变量替换的工具类:
+
+| 组件名| 一级模块 | 二级模块 | 功能点 |
+|---|---|---|---|
+| Linkis | CG | Entrance|拦截任务的代码并调用linkis-common的VariableUtils进行代码替换|
+| Linkis | Linkis-commons | linkis-common|提供变量、解析、计算的工具类VariableUtils|
+
+## 3. 模块设计
+### 3.1核心执行流程
+[输入端] 输入端为代码和代码类型(python/sql/scala/sh).
+[处理流程] Entrance在接受到任务后会首先进过拦截器,启动变量拦截器会完成变量的解析、替换、计算
+整体时序图如下:
+
+![time](/Images/Architecture/Commons/var_time.png)
+
+这里需要说明的是:
+1. 自定义变量和系统变量使用方式为${},如${run_date}
+2. date pattern变量的使用方式为&{},如&{yyyy-01-01} 值为2022-01-01。
+ 之所以分成两种不同的方式是为了防止自定义变量定义的字符串中包含pattern字符,如定义了一个y=1的自定义变量可能代表不同的含义,会被pattern任务是年变量
+
+
+### 3.2具体细节:
+1、run_date为核心自带日期变量,支持用户自定义日期,如果不指定默认为当前系统时间的前一天。
+2、其他衍生内置日期变量定义:其他日期内置变量都是相对run_date计算出来的,一旦run_date变化,其他变量值也会自动跟着变化,其他日期变量不支持设置初始值,只能通过修改run_date进行修改。
+3、内置变量支持更加丰富的使用场景:${run_date-1}为run_data的前一天;${run_month_begin-1}为run_month_begin的上个月的第一天,这里的-1表示减一个月。
+4、Pattern类型变量也是基于run_date进行计算,然后再进行替换和+—
+
+### 3.3 变量作用域
+在linkis中自定义变量也有作用域,优先级为脚本中定义的变量大于在任务参数中定义的Variable大于内置的run_date变量。任务参数中定义如下:
+```
+## restful
+{
+ "executionContent": {"code": "select \"${f-1}\";", "runType": "sql"},
+ "params": {
+ "variable": {f: "20.1"},
+ "configuration": {
+ "runtime": {
+ "linkis.openlookeng.url":"http://127.0.0.1:9090"
+ }
+ }
+ },
+ "source": {"scriptPath": "file:///mnt/bdp/hadoop/1.sql"},
+ "labels": {
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+## java SDK
+JobSubmitAction.builder
+ .addExecuteCode(code)
+ .setStartupParams(startupMap)
+ .setUser(user) //submit user
+ .addExecuteUser(user) //execute user
+ .setLabels(labels)
+ .setVariableMap(varMap) //setVar
+ .build
+```
+
+## 4. 接口设计:
+主要工具类为:
+```
+VariableUtils:
+def replace(replaceStr: String): String 替换代码中的变量返回替换后的代码
+def replace(replaceStr: String, variables: util.Map[String, Any]): String 支持传入自定义变量的值,进行替换
+def replace(code: String, runtType: String, variables: util.Map[String, String]): String 支持传入代码类型,按照不同的类型进行替换解析
+```
+
+
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/_category_.json
new file mode 100644
index 00000000000..883115fccbc
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "计算治理服务架构",
+ "position": 2
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine-conn-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine-conn-manager.md
new file mode 100644
index 00000000000..535a47e8d33
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine-conn-manager.md
@@ -0,0 +1,51 @@
+---
+title: EngineConnManager 架构
+sidebar_position: 2
+---
+
+EngineConnManager(ECM):EngineConn的管理器,提供引擎的生命周期管理,同时向RM汇报负载信息和自身的健康状况。
+
+### 一、ECM架构
+
+![](/Images-zh/Architecture/engine/ecm-01.png)
+
+### 二、二级模块介绍
+
+**Linkis-engineconn-linux-launch**
+
+引擎启动器,核心类为LinuxProcessEngineConnLauch,用于提供执行命令的指令。
+
+**Linkis-engineconn-manager-core**
+
+ECM的核心模块,包含ECM健康上报、EngineConn健康上报功能的顶层接口,定义了ECM服务的相关指标,以及构造EngineConn进程的核心方法。
+
+| 核心顶层接口/类 | 核心功能 |
+|---------------------|------------------------------------------|
+| EngineConn | 定义了EngineConn的属性,包含的方法和参数 |
+| EngineConnLaunch | 定义了EngineConn的启动方法和停止方法 |
+| ECMEvent | 定义了ECM相关事件 |
+| ECMEventListener | 定义了ECM相关事件监听器 |
+| ECMEventListenerBus | 定义了ECM的监听器总线 |
+| ECMMetrics | 定义了ECM的指标信息 |
+| ECMHealthReport | 定义了ECM的健康上报信息 |
+| NodeHealthReport | 定义了节点的健康上报信息 |
+
+**Linkis-engineconn-manager-server**
+
+ECM的服务端,定义了ECM健康信息处理服务、ECM指标信息处理服务、ECM注册服务、EngineConn启动服务、EngineConn停止服务、EngineConn回调服务等顶层接口和实现类,主要用于ECM对自己和EngineConn的生命周期管理以及健康信息上报、发送心跳等。
+
+模块中的核心Service和功能简介如下:
+
+| 核心service | 核心功能 |
+|---------------------------------|-------------------------------------------------|
+| EngineConnLaunchService | 包含生成EngineConn和启动进程的核心方法 |
+| BmlResourceLocallizationService | 用于将BML的引擎相关资源下载并生成本地化文件目录 |
+| ECMHealthService | 向AM定时上报自身的健康心跳 |
+| ECMMetricsService | 向AM定时上报自身的指标状况 |
+| EngineConnKillSerivce | 提供停止引擎的相关功能 |
+| EngineConnListService | 提供缓存和管理引擎的相关功能 |
+| EngineConnCallBackService | 提供回调引擎的功能 |
+
+ECM构建EngineConn启动流程:
+
+![](/Images-zh/Architecture/engine/engineconn-01.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/_category_.json
new file mode 100644
index 00000000000..7d5b0b6f6b9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "引擎连接器架构",
+ "position": 5
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/add-an-engine-conn.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/add-an-engine-conn.md
new file mode 100644
index 00000000000..f5ae4c565a5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/add-an-engine-conn.md
@@ -0,0 +1,114 @@
+---
+title: EngineConn 启动流程
+sidebar_position: 3
+---
+
+EngineConn的新增,是Linkis计算治理的计算任务准备阶段的核心流程之一。它主要包括了Client端(Entrance或用户客户端)向LinkisManager发起一个新增EngineConn的请求,LinkisManager为用户按需、按标签规则,向EngineConnManager发起一个启动EngineConn的请求,并等待EngineConn启动完成后,将可用的EngineConn返回给Client的整个流程。
+
+如下图所示,接下来我们来详细说明一下整个流程:
+
+![EngineConn新增流程](/Images-zh/Architecture/EngineConn新增流程/EngineConn新增流程.png)
+
+## 1. LinkisManager接收客户端请求
+
+**名词解释**:
+
+- LinkisManager:是Linkis计算治理能力的管理中枢,主要的职责为:
+ 1. 基于多级组合标签,为用户提供经过复杂路由、资源管控和负载均衡后的可用EngineConn;
+
+ 2. 提供EC和ECM的全生命周期管理能力;
+
+ 3. 为用户提供基于多级组合标签的多Yarn集群资源管理功能。主要分为 AppManager(应用管理器)、ResourceManager(资源管理器)、LabelManager(标签管理器)三大模块,能够支持多活部署,具备高可用、易扩展的特性。
+
+ AM模块接收到Client的新增EngineConn请求后,首先会对请求做参数校验,判断请求参数的合法性;其次是通过复杂规则选中一台最合适的EngineConnManager(ECM),以用于后面的EngineConn启动;接下来会向RM申请启动该EngineConn需要的资源;最后是向ECM请求创建EngineConn。
+
+下面将对四个步骤进行详细说明。
+
+### 1.1 请求参数校验
+
+ AM模块在接受到引擎创建请求后首先会做参数判断,首先会做请求用户和创建用户的权限判断,接着会对请求带上的Label进行检查。因为在AM后续的创建流程当中,Label会用来查找ECM和进行资源信息记录等,所以需要保证拥有必须的Label,现阶段一定需要带上的Label有UserCreatorLabel(例:hadoop-IDE)和EngineTypeLabel(例:spark-2.4.3)。
+
+### 1.2 EngineConnManager(ECM)选择
+
+ ECM选择主要是完成通过客户端传递过来的Label去选择一个合适的ECM服务去启动EngineConn。这一步中首先会通过LabelManager去通过客户端传递过来的Label去注册的ECM中进行查找,通过按照标签匹配度进行顺序返回。在获取到注册的ECM列表后,会对这些ECM进行规则选择,现阶段已经实现有可用性检查、资源剩余、机器负载等规则。通过规则选择后,会将标签最匹配、资源最空闲、负载低的ECM进行返回。
+
+### 1.3 EngineConn资源申请
+
+1. 在获取到分配的ECM后,AM接着会通过调用EngineConnPluginServer服务请求本次客户端的引擎创建请求会使用多少的资源,这里会通过封装资源请求,主要包含Label、Client传递过来的EngineConn的启动参数、以及从Configuration模块获取到用户配置参数,通过RPC调用ECP服务去获取本次的资源信息。
+
+2. EngineConnPluginServer服务在接收到资源请求后,会先通过传递过来的标签找到对应的引擎标签,通过引擎标签选择对应引擎的EngineConnPlugin。然后通过EngineConnPlugin的资源生成器,对客户端传入的引擎启动参数进行计算,算出本次申请新EngineConn所需的资源,然后返回给LinkisManager。
+
+ **名词解释:**
+- EgineConnPlugin:是Linkis对接一个新的计算存储引擎必须要实现的接口,该接口主要包含了这种EngineConn在启动过程中必须提供的几个接口能力,包括EngineConn资源生成器、EngineConn启动命令生成器、EngineConn引擎连接器。具体的实现可以参考Spark引擎的实现类:[SparkEngineConnPlugin](https://github.com/apache/linkis/blob/master/linkis-engineconn-plugins/spark/src/main/scala/com/webank/wedatasphere/linkis/engineplugin/spark/SparkEngineConnPlugin.scala)。
+
+- EngineConnPluginServer:是加载了所有的EngineConnPlugin,对外提供EngineConn的所需资源生成能力和EngineConn的启动命令生成能力的微服务。
+
+- EngineConnPlugin资源生成器(EngineConnResourceFactory):通过传入的参数,计算出本次EngineConn启动时需要的总资源。
+
+- EngineConn启动命令生成器(EngineConnLaunchBuilder):通过传入的参数,生成该EngineConn的启动命令,以提供给ECM去启动引擎。
+3. AM在获取到引擎资源后,会接着调用RM服务去申请资源,RM服务会通过传入的Label、ECM、本次申请的资源,去进行资源判断。首先会判断客户端对应Label的资源是否足够,然后再会判断ECM服务的资源是否足够,如果资源足够,则本次资源申请通过,并对对应的Label进行资源的加减。
+
+### 1.4 请求ECM创建引擎
+
+1. 在完成引擎的资源申请后,AM会封装引擎启动的请求,通过RPC发送给对应的ECM进行服务启动,并获取到EngineConn的实例对象;
+2. AM接着会去通过EngineConn的上报信息判断EngineConn是否启动成功变成可用状态,如果是就会将结果进行返回,本次新增引擎的流程也就结束。
+
+## 2. ECM启动EngineConn
+
+名词解释:
+
+- EngineConnManager(ECM):EngineConn的管理器,提供引擎的生命周期管理,同时向RM汇报负载信息和自身的健康状况。
+
+- EngineConnBuildRequest:LinkisManager传递给ECM的启动引擎命令,里面封装了该引擎的所有标签信息、所需资源和一些参数配置信息。
+
+- EngineConnLaunchRequest:包含了启动一个EngineConn所需的BML物料、环境变量、ECM本地必需环境变量、启动命令等信息,让ECM可以依此构建出一个完整的EngineConn启动脚本。
+
+ECM接收到LinkisManager传递过来的EngineConnBuildRequest命令后,主要分为三步来启动EngineConn:1. 请求EngineConnPluginServer,获取EngineConnPluginServer封装出的EngineConnLaunchRequest;2. 解析EngineConnLaunchRequest,封装成EngineConn启动脚本;3. 执行启动脚本,启动EngineConn。
+
+### 2.1 EngineConnPluginServer封装EngineConnLaunchRequest
+
+通过EngineConnBuildRequest的标签信息,拿到实际需要启动的EngineConn类型和对应版本,从EngineConnPluginServer的内存中获取到该EngineConn类型的EngineConnPlugin,通过该EngineConnPlugin的EngineConnLaunchBuilder,将EngineConnBuildRequest转换成EngineConnLaunchRequest。
+
+### 2.2 封装EngineConn启动脚本
+
+ECM获取到EngineConnLaunchRequest之后,将EngineConnLaunchRequest中的BML物料下载到本地,并检查EngineConnLaunchRequest要求的本地必需环境变量是否存在,校验通过后,将EngineConnLaunchRequest封装成一个EngineConn启动脚本
+
+### 2.3 执行启动脚本
+
+目前ECM只对Unix系统做了Bash命令的支持,即只支持Linux系统执行该启动脚本。
+
+启动前,会通过sudo命令,切换到对应的请求用户去执行该脚本,确保启动用户(即JVM用户)为Client端的请求用户。
+
+执行该启动脚本后,ECM会实时监听脚本的执行状态和执行日志,一旦执行状态返回非0,则立马向LinkisManager汇报EngineConn启动失败,整个流程完成;否则则一直监听启动脚本的日志和状态,直到该脚本执行完成。
+
+## 3. EngineConn初始化
+
+ECM执行了EngineConn的启动脚本后,EngineConn微服务正式启动。
+
+名词解释:
+
+- EngineConn微服务:指包含了一个EngineConn、一个或多个Executor,用于对计算任务提供计算能力的实际微服务。我们说的新增一个EngineConn,其实指的就是新增一个EngineConn微服务。
+
+- EngineConn:引擎连接器,是与底层计算存储引擎的实际连接单元,包含了与实际引擎的会话信息。它与Executor的差别,是EngineConn只是起到一个连接、一个客户端的作用,并不真正的去执行计算。如SparkEngineConn,其会话信息为SparkSession。
+
+- Executor:执行器,作为真正的计算存储场景执行器,是实际的计算存储逻辑执行单元,对EngineConn各种能力的具体抽象,提供交互式执行、订阅式执行、响应式执行等多种不同的架构能力。
+
+EngineConn微服务的初始化一般分为三个阶段:
+
+1. 初始化具体引擎的EngineConn。先通过Java main方法的命令行参数,封装出一个包含了相关标签信息、启动信息和参数信息的EngineCreationContext,通过EngineCreationContext初始化EngineConn,完成EngineConn与底层Engine的连接建立,如:SparkEngineConn会在该阶段初始化一个SparkSession,用于与一个Spark application建立了连通关系。
+
+2. 初始化Executor。EngineConn初始化之后,接下来会根据实际的使用场景,初始化对应的Executor,为接下来的用户使用,提供服务能力。比如:交互式计算场景的SparkEngineConn,会初始化一系列可以用于提交执行SQL、PySpark、Scala代码能力的Executor,支持Client往该SparkEngineConn提交执行SQL、PySpark、Scala等代码。
+
+3. 定时向LinkisManager汇报心跳,并等待EngineConn结束退出。当EngineConn对应的底层引擎异常、或是超过最大空闲时间、或是Executor执行完成、或是用户手动kill时,该EngineConn自动结束退出。
+
+----
+
+到了这里,EngineConn的新增流程就基本结束了,最后我们再来总结一下EngineConn的新增流程:
+
+- 客户端向LinkisManager发起新增EngineConn的请求;
+
+- LinkisManager校验参数合法性,先是根据标签选择合适的ECM,再根据用户请求确认本次新增EngineConn所需的资源,向LinkisManager的RM模块申请资源,申请通过后要求ECM按要求启动一个新的EngineConn;
+
+- ECM先请求EngineConnPluginServer获取一个包含了启动一个EngineConn所需的BML物料、环境变量、ECM本地必需环境变量、启动命令等信息的EngineConnLaunchRequest,然后封装出EngineConn的启动脚本,最后执行启动脚本,启动该EngineConn;
+
+- EngineConn初始化具体引擎的EngineConn,然后根据实际的使用场景,初始化对应的Executor,为接下来的用户使用,提供服务能力。最后定时向LinkisManager汇报心跳,等待正常结束或被用户终止。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/engine-conn-metrics.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/engine-conn-metrics.md
new file mode 100644
index 00000000000..e5fa561def5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/engine-conn-metrics.md
@@ -0,0 +1,77 @@
+---
+title: EngineConn Metrics 上报特性
+sidebar_position: 5
+tags: [Feature]
+---
+
+
+## 1. 功能需求
+### 1.1 需求背景
+ 上报信息缺少引擎信息、以及上报的资源和进度接口有冗余,降低了性能,需要对其进行优化调整,并且在上报协议中增加扩展模块。
+
+### 1.2 目标
+- 增加了包含资源、进度、额外信息的RPC 协议,支持在一次请求中上报这些信息
+- 重构已有的资源、进度上报的链路,将上报相关信息的动作合并为一个请求
+
+## 2. 总体设计
+
+本次需求涉及`linkis-entrance、linkis-computation-orchestrator、linkis-orchestrator-ecm-plugin、linkis-computation-engineconn`模块。在`computation-engineconn`模块添加和重构上报信息,并且在entrance端解析这些信息和入库。
+
+### 2.1 技术架构
+
+引擎信息上报架构如图所示。用户提交任务到entrance后,entrance向linkismanager申请引擎。
+申请到引擎后,向EngineConn提交任务,并接收任务的定时上报(资源、进度、状态)。直到任务执行完毕,entrance在用户查询时返回最终结果。
+本次需求修改,需要在entrance中新增引擎metrics信息入库;
+在Orchestrator中将Resource和Progress接口信息合并,并且增加metrics等额外信息;
+在交互式引擎ComputationEngineConn端将上报的资源和进度信息合并,并且额外上报引擎统计信息。
+
+![engineconn-mitrics-1.png](/Images-zh/Architecture/EngineConn/engineconn-mitrics-1.png)
+
+
+### 2.2 业务架构
+此次特性涉及功能点模块如下:
+
+| 一级模块 | 二级模块 | 功能点 |
+| :------------ | :------------ | :------------ |
+| Entrance | | 合并资源和进度接口;解析新增引擎metrics |
+| Orchestrator | orchestrator-core | 合并资源和进度接口;处理TaskRunningInfo消息 |
+| Orchestrator | orchestrator-plugin-ecm | 合并监听引擎信息的资源和进度接口 |
+| Orchestrator | computation-engineconn | 合并资源和进度的上报接口;新增上报引擎示例metrics |
+
+
+## 3. 模块设计
+### 核心执行流程
+- [输入端]输入端为交互式引擎端`computation-engineconn`。引擎在执行任务时,上报运行信息`TaskRunningInfo`,包含原有的`TaskProgressInfo`和`TaskResourceInfo`,新增了引擎示例信息和引擎现有任务数信息。
+- [处理流程]`orchestrator-plugin-ecm`负责监听引擎运行任务时的上报信息,接收上报信息,并生成`TaskRunningInfoEvent`异步消息,
+发给`OrchestratorAsyncListenerBus`处理。注册到`OrchestratorAsyncListener`的`TaskRunningInfoListener`收到消息,触发`listener`方法,回调到`Entrance`的Job的`TaskRunningInfo`回调方法。
+回调方法解析出`TaskRunningInfo`中的资源、进度、引擎`metrancs`信息,分别进行持久化。
+
+![engineconn-mitrics-2.png](/Images-zh/Architecture/EngineConn/engineconn-mitrics-2.png)
+
+## 4. 数据结构
+
+需求新增了`RPC protocol TaskRunningInfo` ,无新增db表
+
+## 5. 接口设计
+无对外接口
+
+## 6. 非功能性设计:
+### 6.1 安全
+RPC接口内部鉴权,不涉及对外安全问题
+
+### 6.2 性能
+合并了两个RPC接口,减少上报次数,提升了性能
+
+### 6.3 容量
+metrics信息较少,无影响
+
+### 6.4 高可用
+不涉及
+
+
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/engine-conn-plugin.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/engine-conn-plugin.md
new file mode 100644
index 00000000000..1ab526636e9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/engine-conn-plugin.md
@@ -0,0 +1,73 @@
+---
+title: EngineConnPlugin 服务架构
+sidebar_position: 6
+---
+
+引擎连接器插件是一种能够动态加载引擎连接器并减少版本冲突发生的实现,具有方便扩展、快速刷新、选择加载的特性。为了能让开发用户自由扩展Linkis的Engine引擎,并动态加载引擎依赖避免版本冲突,设计研发了EngineConnPlugin,允许以实现既定的插件化接口的方式引入新引擎到计算中间件的执行生命周期里,
+插件化接口对引擎的定义做了拆解,包括参数初始化、分配引擎资源,构建引擎连接以及设定引擎默认标签。
+
+一、ECP架构图
+
+![](/Images-zh/Architecture/linkis-engineConnPlugin-01.png)
+
+二级模块介绍:
+==============
+
+EngineConn-Plugin-Server
+------------------------
+
+引擎连接器插件服务是对外提供注册插件、管理插件,以及插件资源构建的入口服务。成功注册加载的引擎插件会包含资源分配和启动参数配置的逻辑,在引擎初始化过程中,EngineConn
+Manager等其他服务通过RPC请求调用Plugin Server里对应插件的逻辑。
+
+| 核心类 | 核心功能 |
+|----------------------------------|---------------------------------------|
+| EngineConnLaunchService | 负责构建引擎连接器启动请求 |
+| EngineConnResourceFactoryService | 负责生成引擎资源 |
+| EngineConnResourceService | 负责从BML下载引擎连接器使用的资源文件 |
+
+
+EngineConn-Plugin-Loader 引擎连接器插件加载器
+---------------------------------------
+
+引擎连接器插件加载器是用来根据请求参数动态加载引擎连接器插件的加载器,并具有缓存的特性。具体加载流程主要由两部分组成:1)插件资源例如主程序包和程序依赖包等加载到本地(未开放)。2)插件资源从本地动态加载入服务进程环境中,例如通过类加载器加载入JVM虚拟机。
+
+| 核心类 | 核心功能 |
+|---------------------------------|----------------------------------------------|
+| EngineConnPluginsResourceLoader | 加载引擎连接器插件资源 |
+| EngineConnPluginsLoader | 加载引擎连接器插件实例,或者从缓存加载已有的 |
+| EngineConnPluginClassLoader | 动态从jar中实例化引擎连接器实例 |
+
+EngineConn-Plugin-Cache 引擎插件缓存模组
+----------------------------------------
+
+引擎连接器插件缓存是专门用来缓存已经加载的引擎连接器的缓存服务,并支持读取、更新、移除的能力。已经加载进服务进程的插件会被连同其类加载器一起缓存起来,避免多次加载影响效率;同时缓存模组会定时通知加载器去更新插件资源,如果发现有变动,会重新加载并自动刷新缓存。
+
+| 核心类 | 核心功能 |
+|-----------------------------|------------------------------|
+| EngineConnPluginCache | 缓存已经加载的引擎连接器实例 |
+| RefreshPluginCacheContainer | 定时刷新缓存的引擎连接器 |
+
+EngineConn-Plugin-Core:引擎连接器插件核心模组
+---------------------------------------------
+
+引擎连接器插件核心模块是引擎连接器插件的核心模块。包含引擎插件基本功能实现,如引擎连接器启动命令构建,引擎资源工厂构建和引擎连接器插件核心接口实现。
+
+| 核心类 | 核心功能 |
+|-------------------------|----------------------------------------------------------|
+| EngineConnLaunchBuilder | 构建引擎连接器启动请求 |
+| EngineConnFactory | 创建引擎连接器 |
+| EngineConnPlugin | 引擎连接器插件实现接口,包括资源,命令,实例的构建方法。 |
+| EngineResourceFactory | 引擎资源的创建工厂 |
+
+EngineConn-Plugins:引擎连接插件集合
+-----------------------------------
+
+引擎连接插件集合是用来放置已经基于我们定义的插件接口实现的默认引擎连接器插件库。提供了默认引擎连接器实现,如jdbc、spark、python、shell等。用户可以基于自己的需求参考已经实现的案例,实现更多的引擎连接器。
+
+| 核心类 | 核心功能 |
+|---------------------|------------------|
+| engineplugin-jdbc | jdbc引擎连接器 |
+| engineplugin-shell | shell引擎连接器 |
+| engineplugin-spark | spark引擎连接器 |
+| engineplugin-python | python引擎连接器 |
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/engine-conn.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/engine-conn.md
new file mode 100644
index 00000000000..331bf87243a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/engine/engine-conn.md
@@ -0,0 +1,141 @@
+---
+title: EngineConn 架构
+sidebar_position: 1
+---
+
+
+## 1.总述
+
+EngineConn:引擎连接器,用于连接底层的计算存储引擎,完成任务的执行、任务信息推送和结果返回等,是Linkis提供计算存储能力的基础。
+
+## 2. 总体设计
+
+ EngineConn的整体设计思路,启动的时候会完成底层引擎Session信息的获取和存储,完成EngineConn进程和底层引擎的连接,然后通过Executor执行器单元完成任务的调度到EngineConn存储的底层引擎Session中进行执行,并获取执行相关的信息。
+
+### 2.1 技术架构
+
+**关键名词介绍:**
+
+**EngineConn:** 用于存储底层引擎的Session信息。来完成和底层引擎的连接,例如Spark引擎存储的是SparkSession。
+
+**Executor:**用于接受调用方(如:Entrance)传过来的任务的调度执行器,并将任务最终提交给底层的引擎Session进行执行,不同的任务实现不同的Executor类。使用最多的是交互式ComputationExecutor,用于接受任务并实时推送任务信息给到调用方。以及非交互式的只接受一次任务的ManageableOnceExecutor,用于完成对EngineConn启动的任务的提交执行。
+
+![arc](/Images/Architecture/engine/ec_arc_01.png)
+
+### 2.2 业务架构
+
+|组件名|一级模块|二级模块|功能点|
+|:----|:----|:----|:----|
+|Linkis|EngineConn|linkis-engineconn-common|引擎连接器的通用模块,定义了引擎连接器中最基础的实体类和接口。|
+|Linkis|EngineConn|linkis-engineconn-core|引擎连接器的核心模块,定义了EngineConn的核心逻辑涉及的接口。|
+|Linkis|EngineConn|linkis-executor-core|执行器的核心模块,定义了执行器相关的核心类。|
+|Linkis|EngineConn|linkis-accessible-executor|能够被访问的Executor底层抽象。可以通过RPC请求与它交互,从而获取它的状态、负载、并发等基础指标Metrics数据|
+|Linkis|EngineConn|linkis-computation-engineconn|提供交互式计算任务能力的相关类。|
+
+## 3. 模块设计
+
+输入:调用方执行任务
+
+输出:返回执行状态、结果、日志等任务信息
+
+关键逻辑:任务执行的关键逻辑的时序图
+
+![time](/Images/Architecture/engine/ec_arc_02.png)
+
+关键说明:
+
+1. 如果是串行Executor,EngineConn接收到任务后就会将EngineConn标记为Busy状态,不能再接受其他任务,并且会判断任务的锁是否一致,防止EngineConn被多个调用方同时提交的情况。任务执行完变成Unlock状态
+2. 如果是并行的Executor,EngineConn接收到任务后,状态还是Unlock状态,可以继续接受任务,只有当达到任务并发数或者机器指标异常才会标记为Busy状态
+3. 如果是Once类型任务,EngineConn启动后就会自动执行任务,任务执行结束EngineConn进程退出
+
+## 4. 数据结构/存储设计
+
+不涉及
+
+## 5. 接口设计
+
+**其他类简要介绍:**
+
+linkis-engineconn-common引擎连接器的通用模块,定义了引擎连接器中最基础的实体类和接口。
+
+|核心Service|核心功能|
+|:----|:----|
+|EngineCreationContext|包含了EngineConn在启动期间的上下文信息|
+|EngineConn|包含了EngineConn的具体信息,如类型、与底层计算存储引擎的具体连接信息等|
+|EngineExecution|提供Executor的创建逻辑|
+|EngineConnHook|定义引擎启动各个阶段前后的操作|
+
+linkis-engineconn-core引擎连接器的核心模块,定义了EngineConn的核心逻辑涉及的接口。
+
+|核心类|核心功能|
+|:----|:----|
+|EngineConnManager|提供创建、获取EngineConn的相关接口|
+|ExecutorManager|提供创建、获取Executor的相关接口|
+|ShutdownHook|定义引擎关闭阶段的操作|
+|EngineConnServer|EngineConn微服务的启动类|
+
+linkis-executor-core执行器的核心模块,定义了执行器相关的核心类。执行器是真正的计算执行单元,负责将用户代码提交给EngineConn进行执行。
+
+|核心类|核心功能|
+|:----|:----|
+|Executor|是实际的计算逻辑执行单元,并提供对引擎各种能力的顶层抽象。|
+|EngineConnAsyncEvent|定义了EngineConn相关的异步事件|
+|EngineConnSyncEvent|定义了EngineConn相关的同步事件|
+|EngineConnAsyncListener|定义了EngineConn相关异步事件监听器|
+|EngineConnSyncListener|定义了EngineConn相关同步事件监听器|
+|EngineConnAsyncListenerBus|定义了EngineConn异步事件的监听器总线|
+|EngineConnSyncListenerBus|定义了EngineConn同步事件的监听器总线|
+|ExecutorListenerBusContext|定义了EngineConn事件监听器的上下文|
+|LabelService|提供标签上报功能|
+|ManagerService|提供与LinkisManager进行信息传递的功能|
+
+linkis-accessible-executor:能够被访问的Executor底层抽象。可以通过RPC请求与它交互,从而获取它的状态、负载、并发等基础指标Metrics数据。
+
+|核心类|核心功能|
+|:----|:----|
+|LogCache|提供日志缓存的功能|
+|AccessibleExecutor|能够被访问的Executor,可以通过RPC请求与它交互。|
+|NodeHealthyInfoManager|管理Executor的健康信息|
+|NodeHeartbeatMsgManager|管理Executor的心跳信息|
+|NodeOverLoadInfoManager|管理Executor的负载信息|
+|Listener相关|提供与Executor相关的事件以及对应的监听器定义|
+|EngineConnTimedLock|定义Executor级别的锁|
+|AccessibleService|提供Executor的启停、状态获取功能|
+|ExecutorHeartbeatService|提供Executor的心跳相关功能|
+|LockService|提供锁管理功能|
+|LogService|提供日志管理功能|
+|EngineConnCallback|定义EngineConn的回调逻辑|
+
+提供交互式计算任务能力的相关类。
+
+|核心类|核心功能|
+|:----|:----|
+|EngineConnTask|定义了提交给EngineConn的交互式计算任务|
+|ComputationExecutor|定义了交互式Executor,具备状态查询、任务kill等交互式能力,默认每次只能执行一次任务。|
+|ConcurrentComputationExecutor|交互式同步并发Executor,继承于ComputationExecutor,但是支持同时执行多个任务|
+|AsyncConcurrentComputationExecutor|交互式异步并发Executor,继承ComputationExecutor,支持同时执行多个任务,并且任务不占用执行线程采用异步通知的形式|
+|TaskExecutionService|提供对交互式计算任务的管理功能|
+
+
+## 6. 非功能性设计
+
+### 6.1 安全
+
+1. 任务所有相关的信息,只能提交用户才能进行查询
+2. EngineConn进程的默认启动用户为提交用户
+### 6.2 性能
+
+支持并发的EngineConn支持同时并发跑大量任务,如单个trino的EngineConn可以同时跑300多个trino任务
+
+### 6.3 容量
+
+不涉及
+
+### 6.4 高可用
+
+EngineConn是按需、按任务启动的进程。支持高可用
+
+### 6.5 数据质量
+
+不涉及
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/entrance.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/entrance.md
new file mode 100644
index 00000000000..84130e6aa51
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/entrance.md
@@ -0,0 +1,28 @@
+---
+title: 入口服务 Entrance 架构
+sidebar_position: 3
+---
+
+Linkis任务提交入口是用来负责计算任务的接收、调度、转发执行请求、生命周期管理的服务,并且能把计算结果、日志、进度返回给调用方,是从Linkis0.X的Entrance拆分出来的原生能力。
+
+一、Entrance架构图
+
+![](/Images-zh/Architecture/linkis-entrance-01.png)
+
+**二级模块介绍:**
+
+EntranceServer
+--------------
+
+EntranceServer计算任务提交入口服务是Entrance的核心服务,负责Linkis执行任务的接收、调度、执行状态跟踪、作业生命周期管理等。主要实现了把任务执行请求转成可调度的Job,调度、申请Executor执行,Job状态管理,结果集管理,日志管理等。
+
+| 核心类 | 核心功能 |
+|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
+| EntranceInterceptor | Entrance拦截器用来对传入参数task进行信息的补充,使得这个task的内容更加完整, 补充的信息包括: 数据库信息补充、自定义变量替换、代码检查、limit限制等 |
+| EntranceParser | Entrance解析器用来把请求参数Map解析成Task,也可以将Task转成可调度的Job,或者把Job转成可存储的Task。 |
+| EntranceExecutorManager | Entrance执行器管理为EntranceJob的执行创建Executor,并维护Job和Executor的关系,且支持Job请求的标签能力 |
+| PersistenceManager | 持久化管理负责作业相关的持久化操作,如结果集路径、作业状态变化、进度等存储到数据库。 |
+| ResultSetEngine | 结果集引擎负责作业运行后的结果集存储,以文件的形式保存到HDFS或者本地存储目录。 |
+| LogManager | 日志管理负责作业日志的存储并对接日志错误码管理。 |
+| Scheduler | 作业调度器负责所有Job的调度执行,主要通过调度作业队列实现。 |
+| | |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-cli.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-cli.md
new file mode 100644
index 00000000000..9ce64d01bd6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-cli.md
@@ -0,0 +1,38 @@
+---
+title: Linkis Client 架构设计
+sidebar_position: 2
+---
+
+为用户提供向Linkis提交执行任务的轻量级客户端。
+
+#### Linkis-Client架构图
+
+![img](/Images-zh/Architecture/linkis-client-01.png)
+
+
+
+#### 二级模块介绍
+
+##### Linkis-Computation-Client
+
+以SDK的形式为用户提供向Linkis提交执行任务的接口。
+
+| 核心类 | 核心功能 |
+| ---------- | ------------------------------------------------ |
+| Action | 定义了请求的属性,包含的方法和参数 |
+| Result | 定义了返回结果的属性,包含的方法和参数 |
+| UJESClient | 负责请求的提交,执行,状态、结果和相关参数的获取 |
+
+
+
+##### Linkis-Cli
+
+以shell命令端的形式为用户提供向Linkis提交执行任务的方式。
+
+| 核心类 | 核心功能 |
+| ----------- | ------------------------------------------------------------ |
+| Common | 定义了指令模板父类、指令解析实体类、任务提交执行各环节的父类和接口 |
+| Core | 负责解析输入、任务执行和定义输出方式 |
+| Application | 调用linkis-computation-client执行任务,并实时拉取日志和最终结果 |
+
+
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/_category_.json
new file mode 100644
index 00000000000..2682d5e9e76
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "Manager 架构",
+ "position": 4
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/app-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/app-manager.md
new file mode 100644
index 00000000000..a7ce769b7f9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/app-manager.md
@@ -0,0 +1,49 @@
+---
+title: AppManager 架构
+sidebar_position: 1
+---
+
+## 背景
+针对旧版本Linkis的Entrance模块负责太多的职责,对Engine的管理能力较弱,且不易于后续的扩展,新抽出了AppManager模块,完成
+以下职责:
+1. 新增AM模块将Entrance之前做的管理Engine的功能移动到AM模块
+2. AM需要支持操作Engine,包括:新增、复用、回收、预热、切换等功能
+3. 需要对接Manager模块对外提供Engine的管理功能:包括Engine状态维护、引擎列表维护、引擎信息等
+4. AM需要管理EM服务,需要完成EM的注册并将资源注册转发给RM进行EM的资源注册
+5. AM需要对接Label模块,包括EM/Engine的增删需要通知标签管理器进行标签更新
+6. AM另外需要对接标签模块进行标签解析,并需要通过一系列标签获取一些列打好分的serverInstance列表(EM和Engine怎么区分,1、标签完全不一样)
+7. 需要对外提供基础接口:包括引擎和引擎管理器的增删改,提供metric查询等
+
+## 架构图
+
+![](/Images-zh/Architecture/AppManager-03.png)
+
+如上图所示:AM在LinkisMaster中属于AppManager模块,作为一个Service提供服务
+
+新引擎申请流程图:
+![](/Images-zh/Architecture/AppManager-02.png)
+
+
+从上面的引擎生命周期流程图可知,Entrance已经不在做Engine的管理工作,engine的启动和管理都由AM控制。
+
+## 架构说明:
+
+AppManager主要包含了引擎服务和EM服务:
+引擎服务包含了所有和引擎EngineConn相关的操作,如引擎创建、引擎复用、引擎切换、引擎回收、引擎停止、引擎销毁等。
+EM服务负责所有EngineConnManager的信息管理,可以在线上对ECM进行服务管理,包括标签修改,暂停ECM服务,获取ECM实例信息,获取ECM运行的引擎信息,kill掉ECM操作,还可以根据EM Node的信息查询所有的EngineNode,也支持按用户查找,保存了EM Node的负载信息、节点健康信息、资源使用信息等。
+新的EngineConnManager和EngineConn都支持标签管理,引擎的类型也增加了离线、流式、交互式支持。
+
+引擎创建:专门负责LinkisManager服务的新建引擎功能,引擎启动模块完全负责一个新引擎的创建,包括获取ECM标签集合、资源申请、获得引擎启动命令,通知ECM新建引擎,更新引擎列表等。
+CreateEngienRequest->RPC/Rest -> MasterEventHandler ->CreateEngineService ->
+->LabelContext/EnginePlugin/RMResourcevice->(RcycleEngineService)EngineNodeManager->EMNodeManager->sender.ask(EngineLaunchRequest)->EngineManager服务->EngineNodeManager->EngineLocker->Engine->EngineNodeManager->EngineFactory=>EngineService=>ServerInstance
+在创建引擎是存在和RM交互的部分,EnginePlugin应该需要通过Lables返回具体的资源类型,然后AM向RM发送资源请求
+
+引擎复用:为了减少引擎启动所耗费的时间和资源,引擎使用必须优先考虑复用原则,复用一般是指复用用户已经创建好的引擎,引擎复用模块负责提供可复用引擎集合,选举并锁定引擎后开始使用,或者返回没有可以复用的引擎。
+ReuseEngienRequest->RPC/Rest -> MasterEventHandler ->ReuseEngineService ->abelContext->EngineNodeManager->EngineSelector->EngineLocker->Engine->EngineNodeManager->EngineReuser->EngineService=>ServerInstance
+
+引擎切换:主要是指对已有引擎进行标签切换,例如创建引擎的时候是由Creator1创建的,现在可以通过引擎切换改成Creator2。这个时候就可以允许当前引擎接收标签为Creator2的任务了。
+SwitchEngienRequest->RPC/Rest -> MasterEventHandler ->SwitchEngineService ->LabelContext/EnginePlugin/RMResourcevice->EngineNodeManager->EngineLocker->Engine->EngineNodeManager->EngineReuser->EngineService=>ServerInstance
+
+引擎管理器:引擎管理负责管理所有引擎的基本信息、元数据信息
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/engine-conn-history.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/engine-conn-history.md
new file mode 100644
index 00000000000..e0164797bfc
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/engine-conn-history.md
@@ -0,0 +1,89 @@
+---
+title: EngineConn 历史信息记录特性
+sidebar_position: 4
+tags: [Feature]
+---
+
+## 1. 功能需求
+### 1.1 需求背景
+ 1.1.3版本前,LinkisManager只记录了在运行中的EngineConn的信息和资源使用,但是在任务结束后这些信息就丢失了。如果需要做历史EC的一些统计和查看,或者要去查看已经结束的EC的日志,过于繁琐,因此对于历史EC的记录显得较为重要。
+
+### 1.2 目标
+- 完成EC信息和资源信息持久化到DB的存储
+- 支持通过restful接口完成历史EC信息的查看和搜索
+- 支持查看已经结束EC的日志
+
+## 2. 总体设计
+
+此次特性新增主要修改为LinkisManager下的RM和AM模块,并新增了一种信息记录表。
+
+### 2.1 技术架构
+因为此次的实现需要记录EC的信息和资源信息,而资源信息分为请求资源、真实使用资源、释放资源等三个概念,而且都需要进行记录。所以此次实现大体方案是:基于EC在ResourceManager的生命周期去进行实现,在EC完成以上三个阶段时,都加上EC信息的更新操作。整体如下图所示:
+
+![engineconn-history-01.png](/Images-zh/Architecture/EngineConn/engineconn-history-01.png)
+
+
+
+### 2.2 业务架构
+
+此次的特性主要是为了完成历史EC的信息记录和支持历史技术EC的日志查看。功能点设计的模块如下:
+
+| 一级模块 | 二级模块 | 功能点 |
+|---|---|---|
+| LinkisManager | ResourceManager| 在EC请求资源、上报使用资源、释放资源时完成EC信息的记录|
+| LinkisManager | AppManager| 提供list和搜索所有历史EC信息的接口|
+
+## 3. 模块设计
+### 核心执行流程
+
+- [输入端] 输入端主要为创建引擎时的请求资源、引擎启动后上报的真实使用资源、引擎退出时释放资源时输入的信息,主要包括请求的label、资源、EC唯一的ticketid、资源类型等.
+- [处理流程] 信息记录service,对输入的数据进行处理,通过标签会解析出对应的引擎信息、用户、creator,以及日志路径。通过资源类型确认是资源请求、使用、释放。接着将这些信息存储到DB中。
+
+调用时序图如下:
+![engineconn-history-02.png](/Images-zh/Architecture/EngineConn/engineconn-history-02.png)
+
+
+## 4. 数据结构:
+```sql
+# EC信息资源记录表
+DROP TABLE IF EXISTS `linkis_cg_ec_resource_info_record`;
+CREATE TABLE `linkis_cg_ec_resource_info_record` (
+ `id` INT(20) NOT NULL AUTO_INCREMENT,
+ `label_value` VARCHAR(255) NOT NULL COMMENT 'ec labels stringValue',
+ `create_user` VARCHAR(128) NOT NULL COMMENT 'ec create user',
+ `service_instance` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'ec instance info',
+ `ecm_instance` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'ecm instance info ',
+ `ticket_id` VARCHAR(100) NOT NULL COMMENT 'ec ticket id',
+ `log_dir_suffix` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'log path',
+ `request_times` INT(8) COMMENT 'resource request times',
+ `request_resource` VARCHAR(255) COMMENT 'request resource',
+ `used_times` INT(8) COMMENT 'resource used times',
+ `used_resource` VARCHAR(255) COMMENT 'used resource',
+ `release_times` INT(8) COMMENT 'resource released times',
+ `released_resource` VARCHAR(255) COMMENT 'released resource',
+ `release_time` datetime DEFAULT NULL COMMENT 'released time',
+ `used_time` datetime DEFAULT NULL COMMENT 'used time',
+ `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'create time',
+ PRIMARY KEY (`id`),
+ KEY (`ticket_id`),
+ UNIQUE KEY `label_value_ticket_id` (`ticket_id`,`label_value`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
+```
+
+## 5. 接口设计
+引擎历史管理页面API接口,参考文档 管理台添加历史引擎页面
+
+## 6. 非功能性设计
+
+### 6.1 安全
+不涉及安全问题,restful接口需要登录认证
+
+### 6.2 性能
+对引擎生命周期性能影响较小
+
+### 6.3 容量
+需要定期进行清理
+
+### 6.4 高可用
+不涉及
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/label-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/label-manager.md
new file mode 100644
index 00000000000..92b8392ab6a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/label-manager.md
@@ -0,0 +1,43 @@
+---
+title: LabelManager 架构
+sidebar_position: 3
+---
+
+#### 简述
+LabelManager是Linkis中对上层应用提供标签服务的功能模组,运用标签技术管理集群资源分配、服务节点选举、用户权限匹配以及网关路由转发;包含支持各种自定义Label标签的泛化解析处理工具,以及通用的标签匹配评分器。
+
+### 整体架构示意
+
+![整体架构示意图](/Images-zh/Architecture/LabelManager/label_manager_global.png)
+
+#### 架构说明
+- LabelBuilder: 承担着标签解析的工作,从输入的标签类型、关键字或者字符数值中解析得到具体的标签实体,有默认的泛化实现类也可做自定义扩展。
+- LabelEntities: 指代标签实体集合,有且包含集群标签,配置标签,引擎标签,节点标签,路由标签,搜索标签等。
+- NodeLabelService: 实例/节点与标签的关联服务接口类,定义对两者关联关系的增删改查以及根据标签匹配实例/节点的接口方法。
+- UserLabelService: 声明用户与标签的关联操作。
+- ResourceLabelService: 声明集群资源与标签的关联操作,涉及到对组合标签的资源管理,清理或设置标签关联的资源数值。
+- NodeLabelScorer: 节点标签评分器,对应不同的标签匹配算法的实现,使用评分表示节点的标签匹配度。
+
+### 一. LabelBuilder解析流程
+以泛化标签解析类GenericLabelBuilder为例,阐明整体流程:
+![泛化标签解析流程](/Images-zh/Architecture/LabelManager/label_manager_builder.png)
+标签解析/构建的流程概括包含几步:
+1. 根据输入选择要构建解析的合适标签类。
+2. 根据标签类的定义信息,递归解析泛型结构,得到具体的标签值类型。
+3. 转化输入值对象到标签值类型,运用隐式转化或正反解析框架。
+4. 根据1-3的返回,实例化标签,并根据不同的标签类进行一些后置操作。
+
+### 二. NodeLabelScorer打分流程
+为了根据Linkis用户执行请求中附带的标签列表挑选合适的引擎节点,需要对符合的引擎列表做择优,量化为引擎节点的标签匹配度即评分。
+在标签定义里,每个标签都有feature特征值,分别为CORE,SUITABLE,PRIORITIZED,OPTIONAL,每个特征值都有一个boost值,相当于权重和激励值,
+同时有些特征例CORE和SUITABLE为必须唯一特征即在匹配过程中需做强过滤,且一个节点只能分别关联一个CORE/SUITABLE标签。
+根据现有标签,节点,请求附带标签三者之间的关系,可以绘制出如下示意图:
+![标签打分](/Images-zh/Architecture/LabelManager/label_manager_scorer.png)
+
+自带的默认评分逻辑过程应大体包含以下几点步骤:
+1. 方法的输入应该为两组网络关系列表,分别是`Label -> Node` 和 `Node -> Label`, 其中`Node -> Label`关系里的Node节点必须具有请求里涉及到所有CORE以及SUITABLE特征的标签,这些节点也称为备选节点。
+2. 第一步遍历计算`Node -> Label`关系列表,遍历每个节点关联的标签Label,这一步先给标签打分,如果标签不是请求中附带的标签,打分为0,
+否则打分为: (基本分/该标签对应特征值在请求中的出现次数) * 对应特征值的激励值,其中基本分默认为1,节点的初始分为相关联的标签打分的总和;其中因为CORE/SUITABLE类型标签为必须唯一标签,出现次数恒定为1。
+3. 得到节点的初始分后,第二步遍历计算`Label -> Node`关系,由于第一步中忽略了非请求附带标签对评分的作用,但无关标签比重确实会对评分造成影响,对应这类的标签统一打上UNKNOWN的特征,同样该特征也有相对应的激励值;
+我们设定无关标签关联的备选节点占总关联节点的比重越高,对评分的影响越显著,以此可以对第一步得出的节点初始分做进一步累加。
+4. 对得到的备选节点的分数做标准差归一化,并排序。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/overview.md
new file mode 100644
index 00000000000..ef78d69c07d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/overview.md
@@ -0,0 +1,80 @@
+---
+title: Linkis Manager 服务架构
+sidebar_position: 5
+---
+
+
+LinkisManager架构设计
+====================
+
+LinkisManager作为Linkis的一个独立微服务,对外提供了AppManager(应用管理)、ResourceManager(资源管理)、LabelManager(标签管理)的能力,能够支持多活部署,具备高可用、易扩展的特性。
+
+## 一. 架构图
+
+![01](/Images-zh/Architecture/LinkisManager/LinkisManager-01.png)
+
+### 名词解释
+- EngineConnManager(ECM): 引擎管理器,用于启动和管理引擎
+- EngineConn(EC):引擎连接器,用于连接底层计算引擎
+- ResourceManager(RM):资源管理器,用于管理节点资源
+
+## 二. 二级模块介绍
+
+### 1. 应用管理模块 linkis-application-manager
+
+AppManager用于引擎的统一调度和管理
+
+| 核心接口/类 | 主要功能 |
+|------------|--------|
+|EMInfoService | 定义了EngineConnManager信息查询、修改功能 |
+|EMRegisterService| 定义了EngineConnManager注册功能 |
+|EMEngineService | 定义了EngineConnManager对EngineConn的创建、查询、关闭功能 |
+|EngineAskEngineService | 定义了查询EngineConn的功能 |
+|EngineConnStatusCallbackService | 定义了处理EngineConn状态回调的功能 |
+|EngineCreateService | 定义了创建EngineConn的功能 |
+|EngineInfoService | 定义了EngineConn查询功能 |
+|EngineKillService | 定义了EngineConn的停止功能 |
+|EngineRecycleService | 定义了EngineConn的回收功能 |
+|EngineReuseService | 定义了EngineConn的复用功能 |
+|EngineStopService | 定义了EngineConn的自毁功能 |
+|EngineSwitchService | 定义了引擎切换功能 |
+|AMHeartbeatService | 提供了EngineConnManager和EngineConn节点心跳处理功能 |
+
+
+通过AppManager申请引擎流程如下:
+![](/Images-zh/Architecture/LinkisManager/AppManager-01.png)
+
+
+### 2. 标签管理模块 linkis-label-manager
+
+LabelManager提供标签管理和解析能力
+
+| 核心接口/类 | 主要功能 |
+|------------|--------|
+|LabelService | 提供了标签增删改查功能 |
+|ResourceLabelService | 提供了资源标签管理功能 |
+|UserLabelService | 提供了用户标签管理功能 |
+
+LabelManager架构图如下:
+![](/Images-zh/Architecture/LinkisManager/LabelManager-01.png)
+
+
+
+### 3. 资源管理模块 linkis-resource-manager
+
+ResourceManager用于管理引擎和队列的所有资源分配
+
+| 核心接口/类 | 主要功能 |
+|------------|--------|
+|RequestResourceService | 提供了EngineConn资源申请功能 |
+|ResourceManagerService | 提供了EngineConn资源释放功能 |
+|LabelResourceService | 提供了标签对应资源管理功能 |
+
+
+ResourceManager架构图如下:
+
+![](/Images-zh/Architecture/LinkisManager/ResourceManager-01.png)
+
+### 4. 监控模块 linkis-manager-monitor
+
+Monitor提供了节点状态监控的功能
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/resource-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/resource-manager.md
new file mode 100644
index 00000000000..906f7886871
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/linkis-manager/resource-manager.md
@@ -0,0 +1,154 @@
+---
+title: ResourceManager 架构
+sidebar_position: 2
+---
+
+ResourceManager(简称RM),是Linkis的计算资源管理模块,所有的EngineConn(简称EC)、EngineConnManager(简称ECM),甚至包括Yarn在内的外部资源,都由RM负责统筹管理。RM能够基于用户、ECM或其它通过复杂标签定义的粒度对资源进行管控。
+
+### RM在Linkis中的作用
+![01](/Images-zh/Architecture/rm-01.png)
+![02](/Images-zh/Architecture/rm-02.png)
+
+RM作为Linkis Manager的一部分,主要作用为:维护ECM上报的可用资源信息,处理ECM提出的资源申请,记录成功申请后,EC在生命周期内实时上报的实际资源使用信息,并提供查询当前资源使用情况的相关接口。
+
+Linkis中,与RM产生交互的其它服务主要有:
+
+- **引擎管理器,简称ECM**:处理启动引擎连接器请求的微服务。ECM作为资源的提供者,负责向RM注册资源(register)和下线资源(unregister)。同时,ECM作为引擎的管理者,负责代替准备启动的新引擎连接器向RM申请资源。每一个ECM实例,均在RM中有一条对应的资源记录,包含它提供的总资源、保护资源等信息,并动态更新已使用资源。
+![03](/Images-zh/Architecture/rm-03.png)
+
+- **引擎连接器,简称EC**,是用户作业的实际执行单元。同时,EC作为资源的实际使用者,负责向RM上报实际使用资源。每一个EC,均在RM中有一条对应的资源记录:在启动过程中,体现为锁定资源;在运行过程中,体现为已使用资源;在被结束之后,该资源记录随之被删除。
+![04](/Images-zh/Architecture/rm-04.png)
+
+### 资源的类型与格式
+
+![05](/Images-zh/Architecture/rm-07.png)
+
+如上图所示,所有的资源类均实现一个顶层的Resource接口,该接口定义了所有资源类均需要支持的计算和比较的方法,并进行相应的数学运算符的重载,使得资源之间能够像数字一样直接被计算和比较。
+
+| 运算符 | 对应方法 | 运算符 | 对应方法 |
+|--------|-------------|--------|-------------|
+| \+ | add | \> | moreThan |
+| \- | minus | \< | lessThan |
+| \* | multiply | = | equals |
+| / | divide | \>= | notLessThan |
+| \<= | notMoreThan | | |
+
+当前支持的资源类型如下表所示,所有的资源都有对应的json序列化与反序列化方法,能够通过json格式进行存储和在网络间传递:
+
+| 资源类型 | 描述 |
+| --------------------------- | ---------------------------------------------------------- |
+| MemoryResource | 内存资源 |
+| CPUResource | CPU资源 |
+| LoadResource | 同时具备内存与CPU的资源 |
+| YarnResource | Yarn队列资源(队列,队列内存,队列CPU,队列实例数) |
+| KubernetesResource | K8S集群资源(Namespace,CPU,内存) |
+| LoadInstanceResource | 服务器资源(内存,CPU,实例数) |
+| DriverAndYarnResource | 驱动器与Yarn执行器资源(同时具备服务器资源,Yarn队列资源) |
+| DriverAndKubernetesResource | 驱动器与K8S执行器资源(同时具备服务器资源,K8S资源) |
+| SpecialResource | 其它自定义资源 |
+
+### 可用资源管理
+
+RM中的可用资源,主要有两个来源:ECM上报的可用资源,以及Configuration模块中根据标签配置的资源限制。
+**ECM资源上报**:
+
+1. ECM启动时,会广播ECM注册的消息,RM接收到消息后,根据消息中包含的内容进行资源注册,资源相关的内容包括:
+- 总资源:该ECM能够提供的资源总数。
+- 保护资源:当剩余资源小于该资源时,不再允许继续分配资源。
+- 资源类型:如LoadResource,DriverAndYarnResource等类型名称。
+- 实例信息:机器名加端口名。
+
+2. RM在收到资源注册请求后,在资源表中新增一条记录,内容与接口的参数信息一致,并通过实例信息找到代表该ECM的标签,在资源、标签关联表中新增一条关联记录。
+
+3. ECM在关闭时,会广播ECM关闭的消息,RM接收到消息后,根据消息中的ECM实例信息来进行资源的下线,即删除该ECM实例标签对应的资源和关联记录。
+
+**Configuration模块标签资源配置**:
+
+用户能够在Configuration模块中,根据不同的标签组合进行资源数量限制的配置,如限制User/Creator/EngineType组合的最大可用资源。
+
+RM通过RPC消息,以组合标签为查询条件,向Configuration模块查询资源信息,并转换成Resource对象参与后续的比较和记录。
+
+
+### 资源使用管理
+
+**接收用户的资源申请**
+
+1. LinkisManager在收到启动EngineConn的请求时,会调用RM的资源申请接口,进行资源申请。资源申请接口接受一个可选的时间参数,当申请资源的等待时间超出该时间参数的限制时,该资源申请将自动作为失败处理。
+
+**判断是否有足够的资源**
+
+即为判断剩余可用资源是否大于申请资源,如果大于或等于,则资源充足;否则资源不充足。
+
+1. RM预处理资源申请中附带的标签信息,根据规则将原始的标签进行过滤、组合和转换等操作(如将User/Creator标签和EngineType标签进行组合),这使得后续的资源判断的粒度更加灵活多变。
+
+2. 在每个转换后的标签上逐一加锁,使得它们所对应的资源记录在资源申请的处理期间保持不变。
+
+3. 根据每个标签:
+
+ 1. 通过Persistence模块从数据库中查询对应的资源记录,如果该记录包含剩余可用资源,则直接用来比较。
+
+ 2. 如果没有直接的剩余可用资源记录,则通过[剩余可用资源=最大可用资源-已用资源-已锁定资源-保护资源]公式进行计算得出。
+
+ 3. 如果没有最大可用资源记录,则请求Configuration模块,看是否有配置的资源信息,如果有则使用到公式中进行计算,如果没有则跳过针对这个标签的资源判断。
+
+ 4. 如果没有任何资源记录,则跳过针对这个标签的资源判断。
+
+4. 只要有一个标签被判断为资源不充足,则资源申请失败,对每个标签逐一解锁。
+
+5. 只有所有标签都判断为资源充足的情况下,才成功通过资源申请,进入下一步。
+
+**锁定申请通过的资源**
+
+1. 根据申请通过的资源数量,在资源表中生成一条新的记录,并与每个标签进行关联。
+
+2. 如果对应的标签有剩余可用资源记录,则扣减对应的数量。
+
+3. 生成一个定时任务,在一定时间后检查这批锁定的资源是否被实际使用,如果超时未使用,则强制回收。
+
+4. 对每个标签进行解锁。
+
+**上报实际使用资源**
+
+1. EngineConn启动后,广播资源使用消息。RM收到消息后,检查该EngineConn对应的标签是否有锁定资源记录,如果没有,则报错。
+
+2. 如果有锁定资源,则对该EngineConn有关联的所有标签进行加锁。
+
+3. 对每个标签,将对应的锁定资源记录转换为已使用资源记录。
+
+4. 解锁所有标签。
+
+**释放实际使用资源**
+
+1. EngineConn结束生命周期后,广播资源回收消息。RM收到消息后,检查该EngineConn对应的标签是否有已使用资源记录。
+
+2. 如果有,则对该EngineConn有关联的所有标签进行加锁。
+
+3. 对每个标签,在已使用资源记录中减去对应的数量。
+
+4. 如果对应的标签有剩余可用资源记录,则增加对应的数量。
+
+5. 对每个标签解锁
+
+
+### 外部资源管理
+
+在RM中,为了更加灵活并有拓展性对资源进行分类,支持多集群的资源管控的同时,使得接入新的外部资源更加便利,在设计上进行了以下几点的考虑:
+
+1. 通过标签来对资源进行统一管理。资源注册后,与标签进行关联,使得资源的属性能够无限拓展。同时,资源申请也都带上标签,实现灵活的匹配。
+
+2. 将集群抽象成一个或多个标签,并在外部资源管理模块中维护每个集群标签对应的环境信息,实现动态的对接。
+
+3. 抽象出通用的外部资源管理模块,如需接入新的外部资源类型,只要实现固定的接口,即可将不同类型的资源信息转换为RM中的Resource实体,实现统一管理。
+
+![06](/Images-zh/Architecture/rm-06.png)
+
+RM的其它模块,通过ExternalResourceService提供的接口来进行外部资源信息的获取。
+
+而ExternalResourceService通过资源类型和标签来获取外部资源的信息:
+
+1. 所有外部资源的类型、标签、配置等属性(如集群名称、Yarn的web
+ url、Hadoop版本等信息),都维护在linkis\_external\_resource\_provider表中。
+
+2. 针对每种资源类型,均有一个ExternalResourceProviderParser接口的实现,将外部资源的属性进行解析,将能够匹配到Label的信息转换成对应的Label,将能够作为参数去请求资源接口的都转换成params。最后构建成一个能够作为外部资源信息查询依据的ExternalResourceProvider实例。
+
+3. 根据ExternalResourceService方法的参数中的资源类型和标签信息,找到匹配的ExternalResourceProvider,根据其中的信息生成ExternalResourceRequest,正式调用外部资源提供的API,发起资源信息请求。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/overview.md
new file mode 100644
index 00000000000..503efc0bff1
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/computation-governance-services/overview.md
@@ -0,0 +1,57 @@
+---
+title: 总览
+sidebar_position: 1
+---
+
+
+## **总述**
+
+计算治理服务组,CGS:Computation Governance Services.完成计算任务和请求的提交、准备、执行、返回结果等主要步骤,是Linkis的核心模块
+
+## **架构图**
+![](/Images-zh/Architecture/linkis-computation-gov-01.png)
+
+**作业流程优化:**
+Linkis1.0将优化Job的整体执行流程,从提交 —\> 准备 —\>
+执行三个阶段,来全面升级Linkis的Job执行架构,如下图所示:
+
+![](/Images-zh/Architecture/linkis-computation-gov-02.png)
+
+## **架构说明**
+
+### 1、Entrance
+
+ Entrance作为计算类型任务的提交入口,提供任务的接收、调度和Job信息的转发能力,是从Linkis0.X的Entrance拆分出来的原生能力;
+
+ [进入Entrance架构设计](entrance.md)
+
+### 2、Orchestrator
+
+ Orchestrator 作为准备阶段的入口,从 Linkis0.X 的 Entrance 继承了解析Job、申请Engine和提交执行的能力;同时,Orchestrator将提供强大的编排和计算策略能力,满足多活、主备、事务、重放、限流、异构和混算等多种应用场景的需求。
+
+
+
+### 3、LinkisManager
+
+ LinkisManager作为Linkis的管理大脑,主要由AppManager、ResourceManager、LabelManager和EngineConnPlugin组成。
+
+ 1. ResourceManager 不仅具备 Linkis0.X 对 Yarn 和 Linkis EngineManager的资源管理能力,还将提供基于标签的多级资源分配和回收能力,让ResourceManager具备跨集群、跨计算资源类型的全资源管理能力;
+ 2. AppManager 将统筹管理所有的 EngineConnManager 和 EngineConn,EngineConn 的申请、复用、创建、切换、销毁等生命周期全交予 AppManager 进行管理;而 LabelManager 将基于多级组合标签,提供跨IDC、跨集群的 EngineConn 和 EngineConnManager 路由和管控能力;
+ 3. EngineConnPlugin 主要用于降低新计算存储的接入成本,真正做到让用户只需要实现一个类,就能接入一个全新的计算存储引擎。
+
+ [进入LinkisManager架构设计](linkis-manager/overview.md)
+
+### 4、EngineConnManager
+
+ EngineConnManager (简称ECM)是 Linkis0.X EngineManager 的精简升级版。Linkis1.0下的ECM去除了引擎的申请能力,整个微服务完全无状态,将聚焦于支持各类 EngineConn 的启动和销毁。
+
+ [进入EngineConnManager架构设计](engine-conn-manager.md)
+
+### 5、EngineConn
+
+EngineConn 是 Linkis0.X Engine 的优化升级版本,将提供 EngineConn 和 Executor 两大模块,其中 EngineConn 用于连接底层的计算存储引擎,提供一个打通了底层各计算存储引擎的 Session 会话;Executor 则基于这个 Session 会话,提供交互式计算、流式计算、离线计算、数据存储的全栈计算能力支持。
+
+[进入EngineConn架构设计](engine/engine-conn.md)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/_category_.json
new file mode 100644
index 00000000000..75425a8bf62
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "公共增强服务架构",
+ "position": 3
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/bml/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/bml/_category_.json
new file mode 100644
index 00000000000..98d0a1aaade
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/bml/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "BML 服务架构",
+ "position": 4
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/bml/engine-bml-dissect.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/bml/engine-bml-dissect.md
new file mode 100644
index 00000000000..923c4ca5219
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/bml/engine-bml-dissect.md
@@ -0,0 +1,294 @@
+---
+title: BML 引擎物料管理功能剖析
+sidebar_position: 1
+---
+
+> 导语:本文以引擎相关的物料管理流程为切入点,同时结合底层数据模型和源码,为大家详细剖析引擎物料管理功能的实现细节,期望能够帮助大家更好地理解BML(物料库)服务的架构。
+
+## 1. BML物料库服务
+
+BML物料库是Linkis中PublicEnhancementService(PS)——公共增强服务架构下的功能模块。
+
+![PS-BML](/Images/Architecture/Public_Enhancement_Service/engine_bml/PS-BML.png)
+
+在Linkis的架构体系里,`物料`的概念是指被统一存储托管起来的各种文件数据,包括脚本代码、资源文件、第三方jar、引擎启动时所需的相关类库和配置文件以及用于安全认证的keytab文件等。
+
+总之,任何以文件态存在的数据,都可以被集中托管在物料库之中,然后在各自所需的场景中被下载使用。
+
+物料服务是无状态的,可进行多实例部署,做到服务高可用,每个实例对外提供独立的服务,互不干扰,所有物料元数据及版本信息等在数据库中共享,底层物料数据可被存储到HDFS或本地(共享)文件系统之中,以及支持实现文件存储相关的接口,扩展其他文件存储系统等。
+
+物料服务提供精确的权限控制,对于引擎资源类型的物料,可被所有用户共享访问;对于一些含有敏感信息的物料数据,也可做到仅有限用户可读。
+
+物料文件采用追加的方式,可将多个版本的资源文件合并成一个大文件,避免产生过多的HDFS小文件,HDFS小文件过多会导致HDFS整体性能的下降。
+
+物料服务提供了文件上传、更新、下载等操作任务的生命周期管理。同时,使用物料服务的方式有rest接口和SDK两种形式,用户可以根据自己的需要进行选择。
+
+BML架构图如下:
+
+![BML架构](/Images/Architecture/Public_Enhancement_Service/engine_bml/bml-jiagou.png)
+
+上述关于BML架构的概述,有参考官网文档:https://linkis.apache.org/zh-CN/docs/latest/architecture/public-enhancement-services/bml
+
+## 2. BML物料库服务底层表模型
+
+在深入理解BML物料管理的流程细节之前,有必要先梳理下BML物料管理服务底层依赖的数据库表模型。
+
+![BML-Model](/Images/Architecture/Public_Enhancement_Service/engine_bml/BML-Model.png)
+
+可结合Linkis的`linkis_ddl.sql`文件以及下文内容阐述的引擎物料上传和更新流程来理解bml resources相关表的字段含义以及表与表之间的字段关系。
+
+## 3. BML物料库服务的使用场景
+
+目前在Linkis中,BML物料库服务的使用场景包括:
+
+- 引擎物料文件,包括引擎启动时所需的conf和lib中的文件
+- 存储脚本,比如工作流任务节点链接的Scripts中的脚本是存储在BML物料库中的
+- DSS中工作流内容版本管理
+- 任务运行时所需资源文件管理
+
+## 4. 引擎物料管理流程剖析
+
+`引擎物料`是Linkis物料概念中的一个子集,其作用是为引擎启动时提供最新版本的jar包资源和配置文件等。本小节主要从引擎物料管理功能为切入点,剖析引擎物料数据在BML中的流转细节。
+
+### 4.1 引擎物料说明
+
+对Linkis的安装包正常部署之后,在`LINKIS_INSTALL_HOME/lib/linkis-engineconn-plugins`目录之下可以看到所有的引擎物料目录,以jdbc引擎为例,引擎物料目录的结构如下:
+
+```shell
+jdbc
+├── dist
+│ └── v4
+│ ├── conf
+│ ├── conf.zip
+│ ├── lib
+│ └── lib.zip
+└── plugin
+ └── 4
+ └── linkis-engineplugin-jdbc-1.1.2.jar
+```
+
+物料目录构成:
+
+```shell
+jdbc/dist/版本号/conf.zip
+jdbc/dist/版本号/lib.zip
+
+jdbc/plugin/版本号(去v留数字)/linkis-engineplugin-引擎名称-1.1.x.jar
+```
+
+conf.zip和lib.zip会作为引擎物料被托管在物料管理服务中,本地每次对物料conf或lib进行修改之后,对应物料会产生一个新的版本号,物料文件数据会被重新上传。引擎启动时,会获取最新版本号的物料数据,加载lib和conf并启动引擎的java进程。
+
+### 4.2 引擎物料上传和更新流程
+
+在Linkis完成部署并首次启动时,会触发引擎物料(lib.zip和conf.zip)首次上传至物料库;当引擎lib下jar包或conf中引擎配置文件有修改时,则需要触发引擎物料的刷新机制来保证引擎启动时能够加载到最新的物料文件。
+
+以现在Linkis1.1.x版本为例,触发引擎物料刷新的两种方式有两种:
+
+通过命令`sh sbin/linkis-daemon.sh restart cg-engineplugin`重启engineplugin服务
+
+通过请求引擎物料刷新的接口
+
+```shell
+# 刷新所有引擎物料
+curl --cookie "linkis_user_session_ticket_id_v1=kN4HCk555Aw04udC1Npi4ttKa3duaCOv2HLiVea4FcQ=" http://127.0.0.1:9001/api/rest_j/v1/engineplugin/refreshAll
+# 指定引擎类型和版本刷新物料
+curl --cookie "linkis_user_session_ticket_id_v1=kN4HCk555Aw04udC1Npi4ttKa3duaCOv2HLiVea4FcQ=" http://127.0.0.1:9001/api/rest_j/v1/engineplugin/refresh?ecType=jdbc&version=4
+```
+
+这两种引擎物料的刷新方式,其底层的实现机制是一样的,都是调用了`EngineConnResourceService`类中的refreshAll()或refresh()方法。
+
+在抽象类`EngineConnResourceService`的默认实现类`DefaultEngineConnResourceService`中的init()方法内部,通过参数wds.linkis.engineconn.dist.load.enable(默认为true)来控制是否在每次启动engineplugin服务时都执行refreshAll(false)来检查所有引擎物料是否有更新(其中faslse代表异步获取执行结果)。
+
+> init()方法被注解@PostConstruct修饰,在DefaultEngineConnResourceService加载后,对象使用前执行,且只执行一次。
+
+手动调用engineplugin/refresh的接口,即手动执行了`EngineConnResourceService`类中的refreshAll或refresh方法。
+
+所以引擎物料检测更新的逻辑在`DefaultEngineConnResourceService`中的refreshAll和refresh方法内。
+
+其中refreshAll()的核心逻辑是:
+
+1)通过参数wds.linkis.engineconn.home获取引擎的安装目录,默认是:
+
+```scala
+getEngineConnsHome = Configuration.getLinkisHome() + "/lib/linkis-engineconn-plugins";
+```
+
+2)遍历引擎目录
+
+```scala
+getEngineConnTypeListFromDisk: Array[String] = new File(getEngineConnsHome).listFiles().map(_.getName)
+```
+
+3)`EngineConnBmlResourceGenerator`接口提供对各个引擎(版本)底层文件或目录的合法性检测。对应实现存在于抽象类`AbstractEngineConnBmlResourceGenerator`中。
+
+4)`DefaultEngineConnBmlResourceGenerator`类主要是为了生成`EngineConnLocalizeResource`。EngineConnLocalizeResource是对物料资源文件元数据和InputStream的封装,在后续的逻辑中EngineConnLocalizeResource会被作为物料参数来参与物料的上传过程。
+
+EngineConnBmlResourceGenerator、AbstractEngineConnBmlResourceGenerator、DefaultEngineConnBmlResourceGenerator这三个文件的代码细节暂不细说,可通过以下UML类图,大致了解其继承机制,并结合方法内的具体实现来理解这一部分的功能。
+
+![BML](/Images/Architecture/Public_Enhancement_Service/engine_bml/bml_uml.png)
+
+再重新回到`DefaultEngineConnResourceService`类中的refreshAll方法内,继续看refreshTask线程的核心流程:
+
+```scala
+engineConnBmlResourceGenerator.getEngineConnTypeListFromDisk foreach { engineConnType =>
+ Utils.tryCatch {
+ engineConnBmlResourceGenerator.generate(engineConnType).foreach {
+ case (version, localize) =>
+ logger.info(s" Try to initialize ${engineConnType}EngineConn-$version.")
+ refresh(localize, engineConnType, version)
+ }
+ }
+ ......
+}
+```
+
+扫描引擎的安装目录,可获得每个引擎物料目录的列表,对于每个引擎物料目录结构的合法性校验通过之后,可得到对应的`EngineConnLocalizeResource`,然后通过调用refresh(localize: Array[EngineConnLocalizeResource], engineConnType: String, version: String)来完成后续物料的上传工作。
+
+而在refresh()方法的内部,主要经过的流程有:
+
+从表`linkis_cg_engine_conn_plugin_bml_resources`中获取对应engineConnType和version的物料列表数据,赋值给变量engineConnBmlResources。
+
+```scala
+val engineConnBmlResources = asScalaBuffer(engineConnBmlResourceDao.getAllEngineConnBmlResource(engineConnType, version))
+```
+
+![ec数据](/Images/Architecture/Public_Enhancement_Service/engine_bml/ec-data.png)
+
+
+
+#### 4.2.1 引擎物料上传流程
+
+**引擎物料上传流程时序图**
+
+![引擎物料上传流程时序图](/Images/Architecture/Public_Enhancement_Service/engine_bml/bml-shixu.png)
+
+如果表`linkis_cg_engine_conn_plugin_bml_resources`中没有匹配到数据,则需要拿EngineConnLocalizeResource中的数据来构造EngineConnBmlResource对象,并保存至`linkis_cg_engine_conn_plugin_bml_resources`表中,此数据保存之前,需要先完成物料文件的上传操作,即执行`uploadToBml(localizeResource)`方法。
+
+在uploadToBml(localizeResource)方法内部,通过构造bmlClient来请求物料上传的接口。即:
+
+```scala
+private val bmlClient = BmlClientFactory.createBmlClient()
+bmlClient.uploadResource(Utils.getJvmUser, localizeResource.fileName, localizeResource.getFileInputStream)
+```
+
+在BML Server中,物料上传的接口位置在BmlRestfulApi类中的uploadResource接口方法内。主要经历的过程是:
+
+```scala
+ResourceTask resourceTask = taskService.createUploadTask(files, user, properties);
+```
+
+每一次物料上传,都会构造一个ResourceTask来完成文件上传的流程,并记录此次文件上传Task的执行记录。在createUploadTask方法内部,主要完成的操作如下:
+
+1)为此次上传的资源文件产生`一个全局唯一标识的resource_id`,String resourceId = UUID.randomUUID().toString();
+
+2)构建ResourceTask记录,并存储在表`linkis_ps_bml_resources_task`中,以及后续一系列的Task状态修改。
+
+```scala
+ResourceTask resourceTask = ResourceTask.createUploadTask(resourceId, user, properties);
+taskDao.insert(resourceTask);
+
+taskDao.updateState(resourceTask.getId(), TaskState.RUNNING.getValue(), new Date());
+```
+
+3)物料文件真正写入物料库的操作是由ResourceServiceImpl类中的upload方法完成的,在upload方法内部,会把一组`List files`对应的字节流持久化至物料库文件存储系统中;把物料文件的properties数据,存储到资源记录表(linkis_ps_bml_resources)和资源版本记录表(linkis_ps_bml_resources_version)中。
+
+```scala
+MultipartFile p = files[0]
+String resourceId = (String) properties.get("resourceId");
+String fileName =new String(p.getOriginalFilename().getBytes(Constant.ISO_ENCODE),
+ Constant.UTF8_ENCODE);
+fileName = resourceId;
+String path = resourceHelper.generatePath(user, fileName, properties);
+// generatePath目前支持Local和HDFS路径,路径的构成规则由LocalResourceHelper或HdfsResourceHelper
+// 中的generatePath方法实现
+StringBuilder sb = new StringBuilder();
+long size = resourceHelper.upload(path, user, inputStream, sb, true);
+// 文件size计算以及文件字节流写入文件由LocalResourceHelper或HdfsResourceHelper中的upload方法实现
+Resource resource = Resource.createNewResource(resourceId, user, fileName, properties);
+// 插入一条记录到resource表linkis_ps_bml_resources中
+long id = resourceDao.uploadResource(resource);
+// 新增一条记录到resource version表linkis_ps_bml_resources_version中,此时的版本号是onstant.FIRST_VERSION
+// 除了记录这个版本的元数据信息外,最重要的是记录了该版本的文件的存储位置,包括文件路径,起始位置,结束位置。
+String clientIp = (String) properties.get("clientIp");
+ResourceVersion resourceVersion = ResourceVersion.createNewResourceVersion(
+ resourceId, path, md5String, clientIp, size, Constant.FIRST_VERSION, 1);
+versionDao.insertNewVersion(resourceVersion);
+```
+
+上述流程执行成功之后,物料数据才算是真正完成,然后把UploadResult返回给客户端,并标记此次ResourceTask的状态为完成,如果有遇到上传文件报错,则标记此次ResourceTask的状态为失败,记录异常信息。
+
+![resource-task](/Images/Architecture/Public_Enhancement_Service/engine_bml/resource-task.png)
+
+
+
+#### 4.2.2 引擎物料更新流程
+
+**引擎物料更新流程时序图**
+
+![引擎物料更新流程时序图](/Images/Architecture/Public_Enhancement_Service/engine_bml/engine-bml-update-shixu.png)
+
+如果表`linkis_cg_engine_conn_plugin_bml_resources`中匹配到本地物料数据,则需要拿EngineConnLocalizeResource中的数据来构造EngineConnBmlResource对象,并更新`linkis_cg_engine_conn_plugin_bml_resources`表中原有物料文件的版本号、文件大小、修改时间等元数据信息,此数据更新前,需要先完成物料文件的更新上传操作,即执行`uploadToBml(localizeResource, engineConnBmlResource.getBmlResourceId)`方法。
+
+在uploadToBml(localizeResource, resourceId)方法内部,通过构造bmlClient来请求物料资源更新的接口。即:
+
+```scala
+private val bmlClient = BmlClientFactory.createBmlClient()
+bmlClient.updateResource(Utils.getJvmUser, resourceId, localizeResource.fileName, localizeResource.getFileInputStream)
+```
+
+在BML Server中,实现物料更新的接口位置在BmlRestfulApi类中的updateVersion接口方法内,主要经历的过程是:
+
+完成resourceId的有效性检测,即检测传入的resourceId是否在linkis_ps_bml_resources表中存在,如果此resourceId不存在,给客户端抛出异常,在接口层面此次物料更新操作失败。
+
+所以在表`linkis_cg_engine_conn_plugin_bml_resources`和`linkis_ps_bml_resources`中的资源数据的对应关系需要保证完整,否则会出现物料文件无法更新的报错。
+
+```scala
+resourceService.checkResourceId(resourceId)
+```
+
+resourceId如果存在于linkis_ps_bml_resources表中,会继续执行:
+
+```scala
+StringUtils.isEmpty(versionService.getNewestVersion(resourceId))
+```
+
+getNewestVersion方法是为了在表`linkis_ps_bml_resources_version`中获取该resourceId的最大版本号,如果resourceId对应的最大version为空,那么物料同样会更新失败,所以此处数据的对应关系完整性也需要严格保证。
+
+上述两处检查都通过之后,会创建ResourceUpdateTask来完成最终的文件写入和记录更新保存等工作。
+
+```scala
+ResourceTask resourceTask = null;
+synchronized (resourceId.intern()) {
+ resourceTask = taskService.createUpdateTask(resourceId, user, file, properties);
+}
+```
+
+而在createUpdateTask方法内部,主要实现的功能是:
+
+```scala
+// 为物料Resource生成新的version
+String lastVersion = getResourceLastVersion(resourceId);
+String newVersion = generateNewVersion(lastVersion);
+// 然后是对ResourceTask的构建,和状态维护
+ResourceTask resourceTask = ResourceTask.createUpdateTask(resourceId, newVersion, user, system, properties);
+// 物料更新上传的逻辑由versionService.updateVersion方法完成
+versionService.updateVersion(resourceTask.getResourceId(), user, file, properties);
+```
+
+在versionService.updateVersion方法内部,主要实现的功能是:
+
+```scala
+ResourceHelper resourceHelper = ResourceHelperFactory.getResourceHelper();
+InputStream inputStream = file.getInputStream();
+// 获取资源的path
+String newVersion = params.get("newVersion").toString();
+String path = versionDao.getResourcePath(resourceId) + "_" + newVersion;
+// getResourcePath的获取逻辑是从原有路径中limit一条,然后以_拼接newVersion
+// select resource from linkis_ps_bml_resources_version WHERE resource_id = #{resourceId} limit 1
+// 资源上传到hdfs或local
+StringBuilder stringBuilder = new StringBuilder();
+long size = resourceHelper.upload(path, user, inputStream, stringBuilder, OVER_WRITE);
+// 最后在linkis_ps_bml_resources_version表中插入一条新的资源版本记录
+ResourceVersion resourceVersion = ResourceVersion.createNewResourceVersion(resourceId, path, md5String, clientIp, size, newVersion, 1);
+versionDao.insertNewVersion(resourceVersion);
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/bml/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/bml/overview.md
new file mode 100644
index 00000000000..fe9efb703ad
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/bml/overview.md
@@ -0,0 +1,97 @@
+---
+title: 总览
+sidebar_position: 0
+---
+## 背景
+
+BML(物料库服务)是linkis的物料管理系统,主要用来存储用户的各种文件数据,包括用户脚本、资源文件、第三方Jar包等,也可以存储引擎运行时需要使用到的类库。
+
+具备以下功能点:
+
+1)、支持各种类型的文件。支持文本形式和二进制形式的文件,如果是在大数据领域的用户,可以将他们的脚本文件、物料压缩包都可以存储到本系统中。
+
+2)、服务无状态,多实例部署,做到服务高可用。本系统在部署的时候,可以进行多实例部署,每个实例对外独立提供服务,不会互相干扰,所有的信息都是存储在数据库中进行共享。
+
+3)、使用方式多样。提供Rest接口和SDK两种方式,用户可以根据自己的需要进行选择。
+
+4)、文件采用追加方式,避免过多的HDFS小文件。HDFS小文件多会导致HDFS整体性能的下降,我们采用了文件追加的方式,将多个版本的资源文件合成一个大文件,有效减少了HDFS的文件数量。
+
+5)、精确权限控制,用户资源文件内容安全存储。资源文件往往会有重要的内容,用户只希望自己可读
+
+6)、提供了文件上传、更新、下载等操作任务的生命周期管理。
+
+## 架构图
+
+![BML架构图](/Images-zh/Architecture/bml-02.png)
+
+## 架构说明
+
+1、Service层 包含资源管理、上传资源、下载资源、共享资源还有工程资源管理。
+
+资源管理负责资源的增删改查操作,访问权限控制,文件是否过期等基本操作。
+
+2、文件版本控制
+每个BML资源文件都是具有版本信息的,同一个资源每次更新操作都会产生一个新的版本,当然也支持历史版本的查询和下载操作。BML使用版本信息表记录了每个版本的资源文件HDFS存储的偏离位置和大小,可以在一个HDFS文件上存储多个版本的数据。
+
+3、资源文件存储
+主要使用HDFS文件作为实际的数据存储,HDFS文件可以有效保证物料库文件不被丢失,文件采用追加方式,避免过多的HDFS小文件。
+
+### 核心流程
+
+**上传文件:**
+
+1. 判断用户上传文件的操作类型,属于首次上传还是更新上传,如果是首次上传需要新增一条资源信息记录,系统已经为这个资源生成了一个全局唯一标识的resource_id和一个资源放置的位置resource_location。资源A的第一个版本A1需要在HDFS文件系统中resource_location位置进行存储。存储完之后,就可以得到第一个版本记为V00001,如果是更新上传需要查找上次最新的版本。
+
+2. 上传文件流到指定的HDFS文件,如果是更新则采用文件追加的方式加到上次内容的末尾。
+
+3. 新增一条版本记录,每次上传都会产生一条新的版本记录。除了记录这个版本的元数据信息外,最重要的是记录了该版本的文件的存储位置,包括文件路径,起始位置,结束位置。
+
+**下载文件:**
+
+1. 用户下载资源的时候,需要指定两个参数一个是resource_id,另外一个是版本version,如果不指定version的话,默认下载最新版本。
+
+2. 用户传入resource_id和version两个参数到系统之后,系统查询resource_version表,查到对应的resource_location和start_byte和end\_byte进行下载,通过流处理的skipByte方法,将resource\_location的前(start_byte-1)个字节跳过,然后读取到end_byte
+ 字节数。读取成功之后,将流信息返回给用户。
+
+3. 在resource_download_history中插入一条下载成功的记录
+
+## 数据库设计
+
+1、资源信息表(resource)
+
+| 字段名 | 作用 | 备注 |
+|-------------------|------------------------------|----------------------------------|
+| resource_id | 全局唯一标识一个资源的字符串 | 可以采用UUID进行标识 |
+| resource_location | 存放资源的位置 | 例如 hdfs:///tmp/bdp/\${用户名}/ |
+| owner | 资源的所属者 | 例如 zhangsan |
+| create_time | 记录创建时间 | |
+| is_share | 是否共享 | 0表示不共享,1表示共享 |
+| update\_time | 资源最后的更新时间 | |
+| is\_expire | 记录资源是否过期 | |
+| expire_time | 记录资源过期时间 | |
+
+2、资源版本信息表(resource_version)
+
+| 字段名 | 作用 | 备注 |
+|-------------------|--------------------|----------|
+| resource_id | 唯一标识资源 | 联合主键 |
+| version | 资源文件的版本 | |
+| start_byte | 资源文件开始字节数 | |
+| end\_byte | 资源文件结束字节数 | |
+| size | 资源文件大小 | |
+| resource_location | 资源文件放置位置 | |
+| start_time | 记录上传的开始时间 | |
+| end\_time | 记录上传的结束时间 | |
+| updater | 记录更新用户 | |
+
+3、资源下载历史表(resource_download_history)
+
+| 字段 | 作用 | 备注 |
+|-------------|---------------------------|--------------------------------|
+| resource_id | 记录下载资源的resource_id | |
+| version | 记录下载资源的version | |
+| downloader | 记录下载的用户 | |
+| start\_time | 记录下载时间 | |
+| end\_time | 记录结束时间 | |
+| status | 记录是否成功 | 0表示成功,1表示失败 |
+| err\_msg | 记录失败原因 | null表示成功,否则记录失败原因 |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/_category_.json
new file mode 100644
index 00000000000..ab3f408b8cd
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "上下文务架构",
+ "position": 3
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/content-service-cleanup.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/content-service-cleanup.md
new file mode 100644
index 00000000000..609c85b3ac5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/content-service-cleanup.md
@@ -0,0 +1,338 @@
+---
+title: CS 清理接口特性
+sidebar_position: 8
+tags: [Feature]
+---
+
+## 1. 功能需求
+### 1.1 背景
+1.1.3版本前,ContextService 统一上下文服务缺少清理机制,且缺少创建时间、更新时间字段以及批量清理的接口,
+在长期累积情况下可能出现百万级数据,影响查询效率。
+
+### 1.2 目标
+- 修改1ContextService`底层库表,添加创建时间、修改时间、最后访问时间字段,完成`ContextID`和`ContextMap`相关数据的更新时间入库
+- 添加清理清理的`restful`接口,支持按照时间范围、按照id列表的批零清理接口
+- 添加对应的`cs-client`的`java sdk`接口
+
+## 2. 总体设计
+本次需求涉及`ContextService`下的`cs-client`、`cs-persistence`以及`cs-server`模块。
+在`cs-persistence`模块添加已有表的3个字段;在`cs-server`模块添加3个`restful`接口,在`cs-client`模块添加3个`sdk api`。
+
+### 2.1 技术架构
+
+ContextService 整体架构可参考已有文档: [ContextService架构文档](overview.md)
+
+ContestService各模块访问关系如下图所示
+![linkis-contextservice-clean-01.png](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-clean-01.png)
+
+
+ 表变更均在`cs-persistence`模块。此次变更涉及5张表`context_id、 context_map 、context_id_listener 、context_key_listener 、 context_history`表,均需要添加`create_time,update_time,access_time` 3个字段。其中`context_id 、context_map` 表已启用,其它3张表未启用。`create_time` 在persistence模块执行insert操作前,添加时间。`update_time` 和 `access_time` 由上游接口主动调用,在update接口中,`update_time` 和 `access_time` 互斥更新,即当`access_time` 存在(不为null)则不更新`update_time`,否则更新update_time。
+
+`update_time`字段更新在cs-cache模块中,检测到从db加载新的`context_id`时的ADD消息,此时同步`access_time` 到db。
+表中仅记录`context_id` 表的`create_time、update_time、access_time`。后续搜索清理,也是从context_id 表进行清理。
+
+增加3个清理相关接口:`searchContextIDByTime、clearAllContextByID、clearAllContextByTime`
+- `searchContextIDByTime`按照3个时间起止范围搜索,返回contextID列表
+- `clearAllContextByID`清理输入的contextID列表中ID对应的context_map表和context_id表内容
+- `clearAllContextByTime` 按照3个时间起止范围搜索,并且清理所有搜索到的contextID对应的context_map表和context_id表的内容
+
+### 2.2 业务架构
+此次特性是给ContextService服务增加批量查询和清理的相关接口,以及增加底层数据表的更新时间等字段,便于根据访问情况清理过期数据。功能点涉及模块如下表。
+
+| 一级模块 | 二级模块 | 功能点 |
+| :------------ | :------------ | :------------ |
+| linkis-ps-cs | cs-client | 增加批量清理接口相关java sdk api接口 |
+| Linkis-ps-cs | cs-server | 增加批量清理接口相关restful接口 |
+| linkis-ps-cs | cs-persistence | 增加底层表的3个时间相关字段 |
+
+
+## 3. 模块设计
+### 主要执行流程
+- 创建ContextID。用户创建ContextID时,会记录create_time,后期不更新这个字段
+- 更新ContextID。用户更新ContextID时,会更新update_time字段。注意此时更新如果是从cache中更新,则不会更新access_time字段;如果从db加载到cache,再更新contextID,则会先更新access_time,然后单独更新update_time
+- 根据时间查询ContextID。用户查询对应时间范围的ContextID,仅会返回haid字符串列表。此接口有分页,默认仅限5000条数据
+- 批量清理ContextID。会批量清理传入的idList对应的所有contextMap数据和contextID数据。传入数组最大5000条
+- 查询并清理ContextID,先查询再批量清理
+
+上述对应时序图如下:
+![linkis-contextservice-clean-02.png](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-clean-02.png)
+
+其中有两处需要额外注意:
+①cs-server服务中restful api,会将请求封装成Job提交到队列并阻塞等待结果。新定义了CLEAR 的操作类型,便于匹配到清理相关接口。
+②处理①中Job的Service服务,需要将名称定义为不包含ContextID,来避免HighAvailable模块的动态代理转换,这个转换仅对于请求内只有一个ContextID的接口,对于批量清理和批量查询接口无意义且影响性能。
+
+## 4. 数据结构
+```
+# 主要涉及的context_id表结构如下,增加了create_time、update_time、expire_time字段
+CREATE TABLE `linkis_ps_cs_context_id` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `user` varchar(32) DEFAULT NULL,
+ `application` varchar(32) DEFAULT NULL,
+ `source` varchar(255) DEFAULT NULL,
+ `expire_type` varchar(32) DEFAULT NULL,
+ `expire_time` datetime DEFAULT NULL,
+ `instance` varchar(128) DEFAULT NULL,
+ `backup_instance` varchar(255) DEFAULT NULL,
+ `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'update unix timestamp',
+ `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'create time',
+ `access_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'last access time',
+ PRIMARY KEY (`id`),
+ KEY `instance` (`instance`(128)),
+ KEY `backup_instance` (`backup_instance`(191)),
+ KEY `instance_2` (`instance`(128),`backup_instance`(128))
+) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
+```
+
+## 5. 接口设计
+### 5.1 Restful接口
+
+
+#### 搜索文本Id执行时间
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/searchContextIDByTime`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:搜索文本Id执行时间
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|accessTimeEnd|访问结束时间|query|false|string|
+|accessTimeStart|访问开始时间|query|false|string|
+|createTimeEnd|创建结束时间|query|false|string|
+|createTimeStart|创建时间|query|false|string|
+|pageNow|页码|query|false|string|
+|pageSize|页面大小|query|false|string|
+|updateTimeEnd|更新结束时间|query|false|string|
+|updateTimeStart|更新时间|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/contextservice/searchContextIDByTime",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "contextIDs": [
+ "8-8--cs_1_devcs_2_dev10493",
+ "8-8--cs_1_devcs_2_dev10494",
+ "8-8--cs_1_devcs_2_dev10495",
+ "8-8--cs_1_devcs_2_dev10496",
+ "8-8--cs_1_devcs_2_dev10497",
+ "8-8--cs_2_devcs_2_dev10498"
+ ]
+ }
+}
+```
+
+
+#### 清理指定ID
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/clearAllContextByID`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:通过ID清除所以上下文
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|idList|上下文id集合|false|String|String|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/contextservice/clearAllContextByID",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "num": "1"
+ }
+}
+```
+
+
+## 通过时间清除所以上下文
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/clearAllContextByTime`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:通过时间清除所以上下文
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|accessTimeEnd|访问时间结束|false|String|String|
+|accessTimeStart|访问时间开始|false|String|String|
+|createTimeEnd|创建时间结束|false|String|String|
+|createTimeStart|创建时间|false|String|String|
+|updateTimeStart|更新开始时间|false|String|String|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+**输入参数示例**
+```javascript
+{
+ "createTimeStart": "2022-06-01 00:00:00",
+ "createTimeEnd": "2022-06-30 00:00:00"
+}
+```
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/contextservice/clearAllContextByTime",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "num": "1"
+ }
+}
+```
+
+### 5.2 JAVA SDK API
+```
+# 引入pom
+
+ org.apache.linkis
+ linkis-cs-client
+ 1.1.3
+
+
+# 代码参考如下
+
+ String createTimeStart = "2022-05-26 22:04:00";
+ String createTimeEnd = "2022-06-01 24:00:00";
+
+ ContextClient contextClient = ContextClientFactory.getOrCreateContextClient();
+
+ # 接口1 searchHAIDByTime
+ List idList =
+ contextClient.searchHAIDByTime(
+ createTimeStart, createTimeEnd, null, null, null, null, 0, 0);
+
+ for (String id : idList) {
+ System.out.println(id);
+ }
+
+ System.out.println("Got " + idList.size() + " ids.");
+
+ if (idList.size() > 0) {
+ String id1 = idList.get(0);
+ System.out.println("will clear context of id : " + id1);
+ }
+
+ # 接口2 batchClearContextByHAID
+ List tmpList = new ArrayList<>();
+ tmpList.add(id1);
+ int num = contextClient.batchClearContextByHAID(tmpList);
+ System.out.println("Succeed to clear " + num + " ids.");
+
+ # 接口3 batchClearContextByTime
+ int num1 =
+ contextClient.batchClearContextByTime(
+ createTimeStart, createTimeEnd, null, null, null, null);
+ System.out.println("Succeed to clear " + num1 + " ids by time.");
+
+```
+
+
+## 6. 非功能性设计
+### 6.1 安全
+resultful接口需要登录认证,且需要管理员才能操作,管理员用户配置在properties文件中
+
+### 6.2 性能
+- 查询ID接口searchContextIDByTime有分页,无性能影响
+- 清理指定ID接口clearAllContextByID限制操作数据量,无性能影响
+- 根据时间清理接口clearAllContextByTime,如果查询时间范围过大,可能会有查询超时,但不会任务失败。并且清理操作是单个操作,不会影响其他查询
+
+### 6.3 容量
+本需求提供了时间范围查询和批量清理接口,需要上层使用ContextService的应用主动清理数据。
+
+### 6.4 高可用
+接口复用ContextService微服务本身的高可用能力。
+
+
+
+
+
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-cache.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-cache.md
new file mode 100644
index 00000000000..936f667a882
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-cache.md
@@ -0,0 +1,101 @@
+---
+title: CS Cache 架构
+sidebar_position: 7
+---
+
+
+## **CSCache架构**
+### **需要解决的问题**
+
+### 1.1. 内存结构需要解决的问题:
+
+1. 支持按ContextType进行拆分:加快存储和查询性能
+
+2. 支持按不同的ContextID进行拆分:需要完成ContextID间元数据隔离
+
+3. 支持LRU:按照特定算法进行回收
+
+4. 支持按关键字进行检索:支持通过关键字进行索引
+
+5. 支持索引:支持直接通过ContextKey进行索引
+
+6. 支持遍历:需要支持通过按照ContextID、ContextType进行遍历
+
+### 1.2 加载与解析需要解决的问题:
+
+1. 支持将ContextValue解析成内存数据结构:需要完成对ContextKey和value解析出对应的关键字。
+
+2. 需要与与Persistence模块进行对接完成ContextID内容的加载与解析
+
+### 1.3 Metric和清理机制需要解决的问题:
+
+1. 当JVM内存不够时能够基于内存使用和使用频率的清理
+
+2. 支持统计每个ContextID的内存使用情况
+
+3. 支持统计每个ContextID的使用频率
+
+## **ContextCache架构**
+
+ContextCache的架构如下图展示:
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-cache-01.png)
+
+1. ContextService:完成对外接口的提供,包括增删改查;
+
+2. Cache:完成对上下文信息的存储,通过ContextKey和ContextValue进行映射存储
+
+3. Index:建立的关键字索引,存储的是上下文信息的关键字和ContextKey的映射;
+
+4. Parser:完成对上下文信息的关键字解析;
+
+5. LoadModule当ContextCache没有对应的ContextID信息时从持久层完成信息的加载;
+
+6. AutoClear:当Jvm内存不足时完成对ContextCache进行按需清理;
+
+7. Listener:用于监听ContextCache的Metric信息,如:内存占用、访问次数。
+
+## **ContextCache存储结构设计**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-cache-02.png)
+
+ContextCache的存储结构划分为了三层结构:
+
+**ContextCach:**存储了ContextID和ContextIDValue的映射关系,并能够完成ContextID按照LRU算法进行回收;
+
+**ContextIDValue:**拥有存储了ContextID的所有上下文信息和索引的CSKeyValueContext。并统计ContextID的内存和使用记录。
+
+**CSKeyValueContext:**包含了按照类型存储并支持关键词的CSInvertedIndexSet索引集,还包含了存储ContextKey和ContextValue的存储集CSKeyValueMapSet。
+
+CSInvertedIndexSet:通过CSType进行分类存储关键词索引
+
+CSKeyValueMapSet:通过CSType进行分类存储上下文信息
+
+## **ContextCache UML类图设计**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-cache-03.png)
+
+## **ContextCache 时序图**
+
+下面的图绘制了以ContextID、KeyWord、ContextType去ContextCache中查对应的ContextKeyValue的整体流程。
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-cache-04.png)
+
+说明:其中ContextIDValueGenerator会去持久层拉取ContextID的Array[ContextKeyValue],并通过ContextKeyValueParser解析ContextKeyValue的关键字存储索引和内容。
+
+ContextCacheService提供的其他接口流程类似,这里不再赘述。
+
+## **KeyWord解析逻辑**
+
+ContextValue具体的实体Bean需要在对应可以作为keyword的get方法上面使用注解\@keywordMethod,比如Table的getTableName方法必须加上\@keywordMethod注解。
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-cache-05.png)
+
+ContextKeyValueParser在解析ContextKeyValue的时候,会去扫描传入的具体对象的所有被KeywordMethod修饰的注解并调用该get方法获得返回对象toString并会通过用户可选的规则进行解析,存入keyword集合里面。规则有分隔符,和正则表达式
+
+注意事项:
+
+1. 该注解会定义到cs的core模块
+
+2. 被修饰的Get方法不能带参数
+
+3. Get方法的返回对象的toSting方法必须返回的是关键字
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-client.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-client.md
new file mode 100644
index 00000000000..b8a45b6c819
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-client.md
@@ -0,0 +1,65 @@
+---
+title: CS Client
+sidebar_position: 2
+---
+## **CSClient设计的思路和实现**
+
+
+CSClient是每一个微服务和CSServer组进行交互的客户端,CSClient需要满足下面的功能。
+
+1. 微服务向cs-server申请一个上下文对象的能力
+
+2. 微服务向cs-server注册上下文信息的能力
+
+3. 微服务能够向cs-server更新上下文信息的能力
+
+4. 微服务向cs-server获取上下文信息的能力
+
+5. 某一些特殊的微服务能够嗅探到cs-server中已经修改了上下文信息的操作
+
+6. CSClient在csserver集群都失败的情况下能够给出明确的指示
+
+7. CSClient需要提供复制csid1所有上下文信息为一个新的csid2用来提供给调度执行的
+
+> 总体的做法是通过的linkis自带的linkis-httpclient进行发送http请求,通过实现各种Action和Result的实体类进行发送请求和接收响应。
+
+### 1. 申请上下文对象的能力
+
+申请上下文对象,例如用户在前端新建了一条工作流,dss-server需要向dss-server申请一个上下文对象,申请上下文对象的时候,需要将工作流的标识信息(工程名、工作流名)通过CSClient发送到CSServer中(这个时候gateway应该是随机发送给一个的,因为此时没有携带csid的信息),申请上下文一旦反馈到正确的结果之后,就会返回一个csid和该工作流进行绑定。
+
+### 2. 注册上下文信息的能力
+
+> 注册上下文的能力,例如用户在前端页面上传了资源文件,文件内容上传到dss-server,dss-server将内容存储到bml中,然后需要将从bml中获得的resourceid和version注册到cs-server中,此时需要使用到csclient的注册的能力,注册的能力是通过传入csid,以及cskey
+> 和csvalue(resourceid和version)进行注册。
+
+### 3. 更新注册的上下文的能力
+
+> 更新上下文信息的能力。举一个例子,比如一个用户上传了一个资源文件test.jar,此时csserver已经有注册的信息,如果用户在编辑工作流的时候,将这个资源文件进行了更新,那么cs-server需要将这个内容进行更新。此时需要调用csclient的更新的接口
+
+### 4. 获取上下文的能力
+
+注册到csserver的上下文信息,在变量替换、资源文件下载、下游节点调用上游节点产生信息的时候,都是需要被读取的,例如engine端在执行代码的时候,需要进行下载bml的资源,此时需要通过csclient和csserver进行交互,获取到文件在bml中的resourceid和version然后再进行下载。
+
+### 5. 某一些特殊的微服务能够嗅探到cs-server中已经修改了上下文信息的操作
+
+这个操作是基于以下的例子,比如一个widget节点和上游的sql节点是有很强的联动性,用户在sql节点中写了一个sql,sql的结果集的元数据为a,b,c三个字段,后面的widget节点绑定了这个sql,能够在页面中进行对这三个字段的编辑,然后用户更改了sql的语句,元数据变成了a,b,c,d四个字段,此时用户需要手动刷新一下才行。我们希望做到如果脚本做到了改变,那么widget节点能够自动的进行将元数据进行更新。这个一般采用的是listener模式,为了简便,也可以采用心跳的机制进行轮询。
+
+### 6. CSClient需要提供复制csid1所有上下文信息为一个新的csid2用来提供给调度执行的
+
+用户一旦发布一个工程,就是希望对这个工程的所有信息进行类似于git打上一个tag,这里的资源文件、自定义变量这些都是不会再变的,但是有一些动态信息,如产生的结果集等还是会更新csid的内容。所以csclient需要提供一个csid1复制所有上下文信息的接口以供微服务进行调用
+
+## **ClientListener模块的实现**
+
+对于一个client而言,有时候会希望在尽快的时间内知道某一个csid和cskey在cs-server中发生了改变,例如visualis的csclient需要能够知道上一个sql节点进行了改变,那么需要被通知到,服务端有一个listener模块,而客户端也需要一个listener模块,例如一个client希望能够监听到某一个csid的某一个cskey的变化,那么他需要将该cskey注册到对应的csserver实例中的callbackEngine,后续的比如有另外一个client进行更改了该cskey的内容,第一个client进行了heatbeat的时候,callbackengine就需要将这个信息通知到已经client监听的所有cskey,这样的话,第一个client就知道了该cskey的内容已经发生了变化。当heatbeat返回数据的时候,我们就应该通知到注册到ContextClientListenerBus的所有的listener进行使用on方法
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-client-01.png)
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-client-02.png)
+
+## **GatewayRouter的实现**
+
+
+Gateway插件实现Context进行转发Gateway的插件的转发逻辑是通过的GatewayRouter进行的,需要分成两种方式进行,第一种是申请一个context上下文对象的时候,这个时候,CSClient携带的信息中是没有包含csid的信息的,此时的判断逻辑应该是通过eureka的注册信息,第一次发送的请求将会随机进入到一个微服务实例中。
+第二种情况是携带了ContextID的内容,我们需要将csid进行解析,解析的方式就是通过字符串切割的方法,获取到每一个instance的信息,然后通过instance的信息通过eureka判断是否还存在这个微服务,如果是存在的,就往这个微服务实例进行发送
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-client-03.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-highavailable.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-highavailable.md
new file mode 100644
index 00000000000..0ff23ddf098
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-highavailable.md
@@ -0,0 +1,90 @@
+---
+title: CS HA 架构设计
+sidebar_position: 3
+---
+## **CS HA架构设计**
+
+### 1,CS HA架构概要
+
+#### (1)CS HA架构图
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-ha-01.png)
+
+#### (2)要解决的问题
+
+- Context instance对象的HA
+
+- Client创建工作流时生成CSID请求
+
+- CS Server的别名列表
+
+- CSID统一的生成和解析规则
+
+#### (3)主要设计思路
+
+①负载均衡
+
+当客户端创建新的工作流时,等概率随机请求到某台Server的HA模块生成新的HAID,HAID信息包含该主Server信息(以下称主instance),和备选instance,其中备选instance为剩余Server中负载最低的instance,以及一个对应的ContextID。生成的HAID与该工作流绑定且被持久化到数据库,并且随后该工作流所有变更操作请求都将发送至主instance,实现负载的均匀分配。
+
+②高可用
+
+在后续操作中,当客户端或者gateway判定主instance不可用时,会将操作请求转发至备instance处理,从而实现服务的高可用。备instance的HA模块会根据HAID信息首先验证请求合法性。
+
+③别名机制
+
+对机器采用别名机制,HAID中包含的Instance信息采用自定义别名,后台维护别名映射队列。在客户端交互时采用HAID,而与后台其它组件交互则采用ContextID,在实现具体操作时采用动态代理机制,将HAID转换为ContextID进行处理。
+
+### 2,模块设计
+
+#### (1)模块图
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-ha-02.png)
+
+#### (2)具体模块
+
+①ContextHAManager模块
+
+提供接口供CS Server调用生成CSID及HAID,并提供基于动态代理的别名转换接口;
+
+调用持久化模块接口持久化CSID信息;
+
+②AbstractContextHAManager模块
+
+ContextHAManager的抽象,可支持实现多种ContextHAManager;
+
+③InstanceAliasManager模块
+
+RPC模块提供Instance与别名转换接口,维护别名映射队列,并提供别名与CS
+Server实例的查询;提供验证主机是否有效接口;
+
+④HAContextIDGenerator模块
+
+生成新的HAID,并且封装成客户端约定格式返回给客户端。HAID结构如下:
+
+\${第一个instance长度}\${第二个instance长度}{instance别名1}{instance别名2}{实际ID},实际ID定为ContextID
+Key;
+
+⑤ContextHAChecker模块
+
+提供HAID的校验接口。收到的每个请求会校验ID格式是否有效,以及当前主机是否为主Instance或备Instance:如果是主Instance,则校验通过;如果为备Instance,则验证主Instance是否失效,主Instance失效则验证通过。
+
+⑥BackupInstanceGenerator模块
+
+生成备用实例,附加在CSID信息里;
+
+⑦MultiTenantBackupInstanceGenerator接口
+
+(保留接口,暂不实现)
+
+### 3. UML类图
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-ha-03.png)
+
+### 4. HA模块操作时序图
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-ha-04.png)
+
+第一次生成CSID:
+由客户端发出请求,Gateway转发到任一Server,HA模块生成HAID,包含主Instance和备instance及CSID,完成工作流与HAID的绑定。
+
+当客户端发送变更请求时,Gateway判定主Instance失效,则将请求转发到备Instance进行处理。备Instance上实例验证HAID有效后,加载Instance并处理请求。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-listener.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-listener.md
new file mode 100644
index 00000000000..87ce94f0978
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-listener.md
@@ -0,0 +1,37 @@
+---
+title: CS Listener 架构
+sidebar_position: 4
+---
+## **Listener架构**
+
+在DSS中,当某个节点更改了它的元数据信息后,则整个工作流的上下文信息就发生了改变,我们期望所有的节点都能感知到变化,并自动进行元数据更新。我们采用监听模式来实现,并使用心跳机制进行轮询,保持上下文信息的元数据一致性。
+
+### **客户端 注册自己、注册CSKey及更新CSKey过程**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-listener-01.png)
+
+主要过程如下:
+
+1、注册操作:客户端client1、client2、client3、client4通过HTPP请求分别向csserver注册自己以及想要监听的CSKey,Service服务通过对外接口获取到callback引擎实例,注册客户端及其对应的CSKeys。
+
+2、更新操作:如ClientX节点更新了CSKey内容,Service服务则更新ContextCache缓存的CSKey,ContextCache将更新操作投递给ListenerBus,ListenerBus通知具体的listener进行消费(即ContextKeyCallbackEngine去更新Client对应的CSKeys),超时未消费的事件,会被自动移除。
+
+3、心跳机制:
+
+所有Client通过心跳信息探测ContextKeyCallbackEngine中CSKeys的值是否发生了变化。
+
+ContextKeyCallbackEngine通过心跳机制返回更新的CSKeys值给所有已注册的客户端。如果有客户端心跳超时,则移除该客户端。
+
+### **Listener UM类图**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-02.png)
+
+接口:ListenerManager
+
+对外:提供ListenerBus,用于投递事件。
+
+对内:提供 callback引擎,进行事件的具体注册、访问、更新,及心跳处理等逻辑
+
+## **Listener callbackengine时序图**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-03.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-persistence.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-persistence.md
new file mode 100644
index 00000000000..b19366084c8
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-persistence.md
@@ -0,0 +1,13 @@
+---
+title: CS Persistence 架构
+sidebar_position: 5
+---
+
+## **CSPersistence架构**
+
+### Persistence UML图
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-persistence-01.png)
+
+
+Persistence模块主要定义了ContextService持久化相关操作。实体主要包含CSID、ContextKeyValue相关、CSResource相关、CSTable相关。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-search.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-search.md
new file mode 100644
index 00000000000..18c1f8ed5e9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service-search.md
@@ -0,0 +1,131 @@
+---
+title: CS Search 架构
+sidebar_position: 6
+---
+## **CSSearch架构**
+### **总体架构**
+
+如下图所示:
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-01.png)
+
+1. ContextSearch:查询入口,接受Map形式定义的查询条件,根据条件返回相应的结果。
+
+2. 构建模块:每个条件类型对应一个Parser,负责将Map形式的条件转换成Condition对象,具体通过调用ConditionBuilder的逻辑实现。具有复杂逻辑关系的Condition会通过ConditionOptimizer进行基于代价的算法优化查询方案。
+
+3. 执行模块:从Cache中,筛选出与条件匹配的结果。根据查询目标的不同,分为Ruler、Fetcher和Match而三种执行模式,具体逻辑在后文描述。
+
+4. 评估模块:负责条件执行代价的计算和历史执行状况的统计。
+
+### **查询条件定义(ContextSearchCondition)**
+
+一个查询条件,规定了该如何从一个ContextKeyValue集合中,筛选出符合条件的那一部分。查询条件可以通过逻辑运算构成更加复杂的查询条件。
+
+1. 支持ContextType、ContextScope、KeyWord的匹配
+
+ 1. 分别对应一个Condition类型
+
+ 2. 在Cache中,这些都应该有相应的索引
+
+2. 支持对key的contains/regex匹配模式
+
+ 1. ContainsContextSearchCondition:包含某个字符串
+
+ 2. RegexContextSearchCondition:匹配某个正则表达式
+
+3. 支持or、and和not的逻辑运算
+
+ 1. 一元运算UnaryContextSearchCondition:
+
+> 支持单个参数的逻辑运算,比如NotContextSearchCondition
+
+1. 二元运算BinaryContextSearchCondition:
+
+> 支持两个参数的逻辑运算,分别定义为LeftCondition和RightCondition,比如OrContextSearchCondition和AndContextSearchCondition
+
+1. 每个逻辑运算均对应一个上述子类的实现类
+
+2. 该部分的UML类图如下:
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-02.png)
+
+### **查询条件的构建**
+
+1. 支持通过ContextSearchConditionBuilder构建:构建时,如果同时声明多项ContextType、ContextScope、KeyWord、contains/regex的匹配,自动以And逻辑运算连接
+
+2. 支持Condition之间进行逻辑运算,返回新的Condition:And,Or和Not(考虑condition1.or(condition2)的形式,要求Condition顶层接口定义逻辑运算方法)
+
+3. 支持通过每个底层实现类对应的ContextSearchParser从Map构建
+
+### **查询条件的执行**
+
+1. 查询条件的三种作用方式:
+
+ 1. Ruler:从一个Array中筛选出符合条件的ContextKeyValue子Array
+
+ 2. Matcher:判断单个ContextKeyValue是否符合条件
+
+ 3. Fetcher:从ContextCache里筛选出符合条件的ContextKeyValue的Array
+
+2. 每个底层的Condition都有对应的Execution,负责维护相应的Ruler、Matcher、Fetcher。
+
+### **查询入口ContextSearch**
+
+提供search接口,接收Map作为参数,从Cache中筛选出对应的数据。
+
+1. 通过Parser,将Map形式的条件转换为Condition对象
+
+2. 通过Optimizer,获取代价信息,并根据代价信息确定查询的先后顺序
+
+3. 通过对应的Execution,执行相应的Ruler/Fetcher/Matcher逻辑后,得到搜索结果
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-03.png)
+
+### **查询优化**
+
+1. OptimizedContextSearchCondition维护条件的Cost和Statistics信息:
+
+ 1. Cost信息:由CostCalculator负责判断某个Condition是否能够计算出Cost,如果可以计算,则返回对应的Cost对象
+
+ 2. Statistics信息:开始/结束/执行时间、输入行数、输出行数
+
+2. 实现一个CostContextSearchOptimizer,其optimize方法以Condition的代价为依据,对Condition进行调优,转换为一个OptimizedContextSearchCondition对象。具体逻辑描述如下:
+
+ 1. 将一个复杂的Condition,根据逻辑运算的组合,拆解成一个树形结构,每个叶子节点均为一个最基本的简单Condition;每个非叶子节点均为一个逻辑运算。
+
+> 如下图所示的树A,就是一个由ABCDE这五个简单条件,通过各种逻辑运算组合成的一个复杂条件。
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-04.png)
+(树A)
+
+1. 这些Condition的执行,事实上就是深度优先、从左到右遍历这个树。而且根据逻辑运算的交换规律,Condition树中一个节点的子节点的左右顺序可以互换,因此可以穷举出所有可能的执行顺序下的所有可能的树。
+
+> 如下图所示的树B,就是上述树A的另一个可能的顺序,与树A的执行结果完全一致,只是各部分的执行顺序有所调整。
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-05.png)
+(树B)
+
+1. 针对每一个树,从叶子节点开始计算代价,归集到根节点,即为该树的最终代价,最终得出代价最小的那个树,作为最优执行顺序。
+
+> 计算节点代价的规则如下:
+
+1. 针对叶子节点,每个节点有两个属性:代价(Cost)和权重(Weight)。Cost即为CostCalculator计算出的代价,Weight是根据节点执行先后顺序的不同赋予的,当前默认左边为1,右边为0.5,后续看如何调整(赋予权重的原因是,左边的条件在一些情况下已经可以直接决定整个组合逻辑的匹配与否,所以右边的条件并非所有情况下都要执行,实际开销就需要减少一定的比例)
+
+2. 针对非叶子节点,Cost=所有子节点的Cost×Weight的总和;Weight的赋予逻辑与叶子节点一致。
+
+> 以树A和树B为例子,分别计算出这两个树的代价,如下图所示,节点中的数字为Cost\|Weight,假设ABCDE这5个简单条件的Cost为10、100、50、10和100。由此可以得出,树B的代价小于树A,为更优方案。
+
+
+
+
+
+
+1. 用CostCalculator衡量简单条件的Cost的思路:
+
+ 1. 作用在索引上的条件:根据索引值的分布来确定代价。比如当条件A从Cache中get出来的Array长度是100,条件B为200,那么条件A的代价小于B。
+
+ 2. 需要遍历的条件:
+
+ 1. 根据条件本身匹配模式给出一个初始Cost:如Regex为100,Contains为10等(具体数值等实现时根据情况调整)
+
+ 2. 根据历史查询的效率,在初始Cost的基础上进行不断调整后,得到实时的Cost。单位时间吞吐量
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service.md
new file mode 100644
index 00000000000..628b09a2943
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/context-service.md
@@ -0,0 +1,60 @@
+---
+title: CS 架构
+sidebar_position: 1
+---
+
+## **ContextService架构**
+
+### **水平划分**
+
+从水平上划分为三个模块:Restful,Scheduler,Service
+
+#### Restful职责:
+
+ 将请求封装为httpjob提交到Scheduler
+
+#### Scheduler职责:
+
+ 通过httpjob的protocol的ServiceName找到相应的服务执行这个job
+
+#### Service职责:
+
+ 真正执行请求逻辑的模块,封装ResponseProtocol,并唤醒Restful中wait的线程
+
+### **垂直划分**
+从垂直上划分为4个模块:Listener,History,ContextId,Context:
+
+#### Listener职责:
+
+1. 负责Client端的注册和绑定(写入数据库和在CallbackEngine中进行注册)
+
+2. 心跳接口,通过CallbackEngine返回Array[ListenerCallback]
+
+#### History职责:
+创建和移除history,操作Persistence进行DB持久化
+
+#### ContextId职责:
+主要是对接Persistence进行ContextId的创建,更新移除等操作
+
+#### Context职责:
+
+1. 对于移除,reset等方法,先操作Persistence进行DB持久化,并更新ContextCache
+
+2. 封装查询condition去ContextSearch模块获取相应的ContextKeyValue数据
+
+请求访问步骤如下图:
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-service-01.png)
+
+## **UML类图**
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-service-02.png)
+
+## **Scheduler线程模型**
+
+需要保证Restful的线程池不被填满
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-service-03.png)
+
+时序图如下:
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-service-04.png)
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/overview.md
new file mode 100644
index 00000000000..68591cc5386
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/context-service/overview.md
@@ -0,0 +1,129 @@
+---
+title: 总览
+sidebar_position: 0
+---
+
+## **背景**
+
+### **什么是上下文Context?**
+
+保持某种操作继续进行的所有必需信息。如:同时看三本书,每本书已翻看的页码就是继续看这本书的上下文。
+
+### **为什么需要CS(Context Service)?**
+
+CS,用于解决一个数据应用开发流程,跨多个系统间的数据和信息共享问题。
+
+例如,B系统需要使用A系统产生的一份数据,通常的做法如下:
+
+1. B系统调用A系统开发的数据访问接口;
+
+2. B系统读取A系统写入某个共享存储的数据。
+
+有了CS之后,A和B系统只需要与CS交互,将需要共享的数据和信息写入到CS,需要读取的数据和信息从CS中读出即可,无需外部系统两两开发适配,极大降低了系统间信息共享的调用复杂度和耦合度,使各系统的边界更加清晰。
+
+## **产品范围**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-01.png)
+
+
+### 元数据上下文
+
+元数据上下文定义元数据规范。
+
+元数据上下文依托于数据中间件,主要功能如下:
+
+1. 打通与数据中间件的关系,能拿到所有的用户元数据信息(包括Hive表元数据、线上库表元数据、其他NOSQL如HBase、Kafka等元数据)
+
+2. 所有节点需要访问元数据时,包括已有元数据和应用模板内元数据,都必须经过元数据上下文。元数据上下文记录了应用模板所使用的所有元数据信息。
+
+3. 各节点所产生的新元数据,都必须往元数据上下文注册。
+
+4. 抽出应用模板时,元数据上下文为应用模板抽象(主要是将用到的多个库表做成\${db}.表形式,避免数据权限问题)和打包所有依赖的元数据信息。
+
+元数据上下文是交互式工作流的基础,也是应用模板的基础。设想:Widget定义时,如何知道DataWrangler定义的各指标维度?Qualitis如何校验Widget产生的图报表?
+
+### 数据上下文
+
+数据上下文定义数据规范。
+
+数据上下文依赖于数据中间件和Linkis计算中间件。主要功能如下:
+
+1. 打通数据中间件,拿到所有用户数据信息。
+
+2. 打通计算中间件,拿到所有节点的数据存储信息。
+
+3. 所有节点需要写临时结果时,必须通过数据上下文,由数据上下文统一分配。
+
+4. 所有节点需要访问数据时,必须通过数据上下文。
+
+5. 数据上下文会区分依赖数据和生成数据,在抽出应用模板时,为应用模板抽象和打包所有依赖的数据。
+
+### 资源上下文
+
+资源上下文定义资源规范。
+
+资源上下文主要与Linkis计算中间件交互。主要功能如下:
+
+1. 用户资源文件(如Jar、Zip文件、properties文件等)
+
+2. 用户UDF
+
+3. 用户算法包
+
+4. 用户脚本
+
+### 环境上下文
+
+环境上下文定义环境规范。
+
+主要功能如下:
+
+1. 操作系统
+
+2. 软件,如Hadoop、Spark等
+
+3. 软件包依赖,如Mysql-JDBC。
+
+### 对象上下文
+
+运行时上下文为应用模板(工作流)在定义和执行时,所保留的所有上下文信息。
+
+它用于协助定义工作流/应用模板,在工作流/应用模板执行时提示和完善所有必要信息。
+
+运行时工作流主要是Linkis使用。
+
+
+## **CS架构图**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-02.png)
+
+## **架构说明:**
+
+### 1. Client
+外部访问CS的入口,Client模块提供HA功能;
+[进入Client架构设计](context-service-client.md)
+
+### 2. Service模块
+提供Restful接口,封装和处理客户端提交的CS请求;
+[进入Service架构设计](context-service.md)
+
+### 3. ContextSearch
+上下文查询模块,提供丰富和强大的查询能力,供客户端查找上下文的Key-Value键值对;
+[进入ContextSearch架构设计](context-service-search.md)
+
+### 4. Listener
+CS的监听器模块,提供同步和异步的事件消费能力,具备类似Zookeeper的Key-Value一旦更新,实时通知Client的能力;
+[进入Listener架构设计](context-service-listener.md)
+
+### 5. ContextCache
+上下文的内存缓存模块,提供快速检索上下文的能力和对JVM内存使用的监听和清理能力;
+[进入ContextCache架构设计](context-service-cache.md)
+
+### 6. HighAvailable
+提供CS高可用能力;
+[进入HighAvailable架构设计](context-service-highavailable.md)
+
+### 7. Persistence
+CS的持久化功能;
+[进入Persistence架构设计](context-service-persistence.md)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/datasource-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/datasource-manager.md
new file mode 100644
index 00000000000..66fc3b7fc69
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/datasource-manager.md
@@ -0,0 +1,140 @@
+---
+title: 数据源管理服务架构
+sidebar_position: 5
+---
+## 背景
+
+早期版本中的Exchangis0.x和Linkis0.x都有整合数据源模块,为复用数据源的管理能力,Linkis以linkis-datasource为蓝本(可以参阅相关的文档)重构数据源模块,将数据源管理拆封成数据源管理服务与元数据查询服务。
+
+本文主要涉及DataSource Manager Server数据源管理服务,提供如下功能:
+
+1)、Linkis统一管理服务启动与部署,不增加运维成本,复用Linkis服务能力;
+
+2)、通过Linkis Web提供图形界面的管理服务,界面提供了新增数据源,数据源查询、数据源更新,连通性测试等管理服务;
+
+3)、服务无状态,多实例部署,做到服务高可用。本系统在部署的时候,可以进行多实例部署,每个实例对外独立提供服务,不会互相干扰,所有的信息都是存储在数据库中进行共享。
+
+4)、提供数据源全生命周期管理,包括新建、查询、更新、测试、过期管理。
+
+5)、多版本数据源管理,历史数据源会保存在数据库中,并提供数据源过期管理。
+
+6)、Restful接口提供功能,详细列表:数据源类型查询、数据源详细信息查询、基于版本进行数据源信息查询、数据源版本查询、获取数据源参数列表、多维度数据源搜索、获数据源环境查询及更新、新增数据源、数据源参数配置、数据源过期设置、数据源连通性测试。
+
+## 架构图
+
+![datasource结构图](/Images-zh/Architecture/datasource/linkis-datasource-server.png)
+
+## 架构说明
+
+1、服务登记在Linkis-Eureak-Service服务中,与Linkis其他微服务统一管理,客户端可以通过连接Linkis-GateWay-Service服务与服务名 data-source-manager获取数据源管理服务。
+
+2、接口层,通过Restful接口向其他应用,提供了针对数据源、数据源环境的增删查改、数据源链接与双链接测试、数据源版本管理及过期操作;
+
+3、Service层,主要针对数据库与物料库的服务管理,永久保留数据源相关信息;
+
+4、数据源的链接测试都是通过linkis metastore server服务完成的,该服务现在提供mysql\es\kafka\hive服务
+
+### 核心流程
+
+1、 新建数据源,首先会从请求中获取新建数据源的用户,判断用户是否有效,下一步会对数据源相关字段信息进行校验,数据源名称和数据源类型不能为空,再下一步会根据数据源名称进行确认该数据源是否存在,如果不存在则将在数据库中进行插入,同时数据源ID号返回。
+
+2、 更新数据源,首先会从请求中获取新建数据源的用户,判断用户是否有效,下一步会对新的数据源相关字段信息进行校验,数据源名称和数据源类型不能为空,再下一步会根据数据源ID号进行确认该数据源是否存在,如果不存在返回异常,如果存在将进一步判断该用户是否对该数据源有更新权限,用户是管理员或者数据源owner才有权限更新,如果有权限则将更新该数据源,并返回数据源ID。
+
+3、 更新数据源参数,首先会从请求中获取新建数据源的用户,判断用户是否有效,根据所传参数数据源ID获取详细的数据源信息,接着会判断用户是否是改数据源的owner后者是否为管理员,如果有则进一步校验修改的参数,通过后则会更新参数,并返回versionId。
+
+## 实体对象
+
+| 类名 | 作用 |
+| ---------------------------- | -------------------------------------------- |
+| DataSourceType | 表示数据源的类型 |
+| DataSourceParamKeyDefinition | 声明数据源属性配置定义 |
+| DataSource | 数据源对象实体类,包含权限标签和属性配置定义 |
+| DataSourceEnv | 数据源环境对象实体类,也包含属性配置定义 |
+| DataSourceParameter | 数据源具体参数配置 |
+| DatasourceVersion | 数据源版本详细信息 |
+
+## **数据库设计**
+
+##### 数据库关系图:
+
+![](/Images-zh/Architecture/datasource/dn-db.png)
+
+##### 数据表定义:
+
+表名:linkis_ps_dm_datatsource <-->实体:DataSource
+
+| 序号 | 字段 | 字段描述 |
+| ---- | -------------------- | ---------------- |
+| 1 | id | 数据源ID |
+| 2 | datasource_name | 数据源名称 |
+| 3 | datasource_desc | 数据源详细描述 |
+| 4 | datasource_type_id | 数据源类型ID |
+| 5 | create_identify | 标识 |
+| 6 | create_system | 创建数据源的系统 |
+| 7 | parameter | 数据源参数,注意 不做存储,实体类parameter字段通过linkis_ps_dm_datasource_version的parameter获取 |
+| 8 | create_time | 数据源创建时间 |
+| 9 | modify_time | 数据源修改时间 |
+| 10 | create_user | 数据源创建用户 |
+| 11 | modify_user | 数据源修改用户 |
+| 12 | labels | 数据源标签 |
+| 13 | version_id | 数据源版本ID |
+| 14 | expire | 数据源是否过期 |
+| 15 | published_version_id | 数据源发布版本号 |
+
+表名:linkis_ps_dm_datasource_type <-->实体:DataSourceType
+
+| 序号 | 字段 | 字段描述 |
+| ---- | ----------- | ------------------ |
+| 1 | id | 数据源类型ID |
+| 2 | name | 数据源类型名称 |
+| 3 | description | 数据源类型描述 |
+| 4 | option | 数据源所属类型 |
+| 5 | classifier | 数据源类型分类词 |
+| 6 | icon | 数据源图片显示路径 |
+| 7 | layers | 数据源类型层次 |
+
+表名:linkis_ps_dm_datasource_env <-->实体:DataSourceEnv
+
+| 序号 | 字段 | 字段描述 |
+| ---- | ------------------ | ------------------ |
+| 1 | id | 数据源环境ID |
+| 2 | env_name | 数据源环境名称 |
+| 3 | env_desc | 数据源环境描述 |
+| 4 | datasource_type_id | 数据源类型ID |
+| 5 | parameter | 数据源环境参数 |
+| 6 | create_time | 数据源环境创建时间 |
+| 7 | create_user | 数据源环境创建用户 |
+| 8 | modify_time | 数据源修改时间 |
+| 9 | modify_user | 数据源修改用户 |
+
+表名:linkis_ps_dm_datasource_type_key <-->实体:DataSourceParamKeyDefinition
+
+| 序号 | 字段 | 字段描述 |
+| ---- | ------------------- | ------------------ |
+| 1 | id | 键值类型ID |
+| 2 | data_source_type_id | 数据源类型ID |
+| 3 | key | 数据源参数key值 |
+| 4 | name | 数据源参数名称 |
+| 5 | default_value | 数据源参数默认值 |
+| 6 | value_type | 数据源参数类型 |
+| 7 | scope | 数据源参数范围 |
+| 8 | require | 数据源参数是否必须 |
+| 9 | description | 数据源参数描述 |
+| 10 | value_regex | 数据源参数正则 |
+| 11 | ref_id | 数据源参数关联ID |
+| 12 | ref_value | 数据源参数关联值 |
+| 13 | data_source | 数据源 |
+| 14 | update_time | 更新时间 |
+| 15 | create_time | 创建时间 |
+
+表名:linkis_ps_dm_datasource_version <-->实体:DatasourceVersion
+
+| 序号 | 字段 | 字段描述 |
+| ---- | ------------- | ---------------- |
+| 1 | version_id | 数据源版本ID |
+| 2 | datasource_id | 数据源ID |
+| 3 | parameter | 数据源该版本参数 |
+| 4 | comment | 内容 |
+| 5 | create_time | 创建时间 |
+| 6 | create_user | 创建用户 |
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/metadata-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/metadata-manager.md
new file mode 100644
index 00000000000..5d1eed0b683
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/metadata-manager.md
@@ -0,0 +1,39 @@
+---
+title: 元数据管理服务架构
+sidebar_position: 3
+---
+## 背景
+
+早期版本中的Exchangis0.x和Linkis0.x都有整合数据源模块,为复用数据源的管理能力,Linkis以linkis-datasource为蓝本(可以参阅相关的文档)重构数据源模块,将数据源管理拆封成数据源管理服务与元数据查询服务。
+
+本文主要涉及MetaData Manager Server数据源管理服务,提供如下功能:
+
+1)、Linkis统一管理服务启动与部署,不增加运维成本,复用Linkis服务能力;
+
+2)、服务无状态,多实例部署,做到服务高可用。本系统在部署的时候,可以进行多实例部署,每个实例对外独立提供服务,不会互相干扰,所有的信息都是存储在数据库中进行共享。
+
+3)、提供数据源全生命周期管理,包括新建、查询、更新、测试、过期管理。
+
+4)、多版本数据源管理,历史数据源会保存在数据库中,并提供数据源过期管理。
+
+5)、Restful接口提供功能,详细列表:数据库信息查询、数据库表信息查询、数据库表参数信息查询、数据分区信息查询。
+
+## 架构图
+
+![BML架构图](/Images-zh/Architecture/datasource/meta-server.png)
+
+## 架构说明
+
+1、服务登记在Linkis-Eureak-Service服务中,与Linkis其他微服务统一管理,客户端可以通过连接Linkis-GateWay-Service服务与服务名 metamanager获取数据源管理服务。
+
+2、接口层,通过Restful接口向其他应用,提供了数据库\表\分区信息查询;
+
+3、Service层,通过数据源ID号在数据源管理服务中获取到数据源类型,通过类型获取具体支持的服务,支持的服务为mysql\es\kafka\hive;
+
+### 核心流程
+
+1、 客户端输入指定的数据源ID,通过restful接口获取信息,如查询数据源ID为1的数据库列表,,则url为`http:///metadatamanager/dbs/1`,
+
+2、 根据数据源ID,通过RPC访问数据源服务``获取到数据源类型
+
+3、 根据数据源类型,加载对应的Service服务[hive\es\kafka\mysql],执行对应的操作,然后返回;
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/overview.md
new file mode 100644
index 00000000000..c1e2aff2188
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/overview.md
@@ -0,0 +1,96 @@
+---
+title: 总览
+sidebar_position: 1
+---
+
+PublicEnhencementService(PS)架构设计
+======================================
+
+PublicEnhancementService(PS):公共增强服务,为其他微服务模块提供统一配置管理、上下文服务、物料库、数据源管理、微服务管理和历史任务查询等功能的模块。
+
+![](/Images-zh/Architecture/PublicEnhencement架构图.png)
+
+二级模块介绍:
+==============
+
+BML物料库
+---------
+
+是linkis的物料管理系统,主要用来存储用户的各种文件数据,包括用户脚本、资源文件、第三方Jar包等,也可以存储引擎运行时需要使用到的类库。
+
+| 核心类 | 核心功能 |
+|-----------------|------------------------------------|
+| UploadService | 提供资源上传服务 |
+| DownloadService | 提供资源下载服务 |
+| ResourceManager | 提供了上传、下载资源的统一管理入口 |
+| VersionManager | 提供了资源版本标记和版本管理功能 |
+| ProjectManager | 提供了项目级的资源管控能力 |
+
+Configuration统一配置管理
+-------------------------
+
+Configuration提供了“用户—引擎—应用”三级配置管理方案,实现了为用户提供配置各种接入应用下自定义引擎参数的功能。
+
+| 核心类 | 核心功能 |
+|----------------------|--------------------------------|
+| CategoryService | 提供了应用和引擎目录的管理服务 |
+| ConfigurationService | 提供了用户配置统一管理服务 |
+
+ContextService上下文服务
+------------------------
+
+ContextService用于解决一个数据应用开发流程,跨多个系统间的数据和信息共享问题。
+
+| 核心类 | 核心功能 |
+|---------------------|------------------------------------------|
+| ContextCacheService | 提供对上下文信息缓存服务 |
+| ContextClient | 提供其他微服务和CSServer组进行交互的能力 |
+| ContextHAManager | 为ContextService提供高可用能力 |
+| ListenerManager | 提供消息总线的能力 |
+| ContextSearch | 提供了查询入口 |
+| ContextService | 实现了上下文服务总体的执行逻辑 |
+
+Datasource数据源管理
+--------------------
+
+Datasource为其他微服务提供不同数据源连接的能力。
+
+| 核心类 | 核心功能 |
+|-------------------|--------------------------|
+| datasource-server | 提供不同数据源连接的能力 |
+
+InstanceLabel微服务管理
+-----------------------
+
+InstanceLabel为其他接入linkis的微服务提供注册和标签功能。
+
+| 核心类 | 核心功能 |
+|-----------------|--------------------------------|
+| InsLabelService | 提供微服务注册和标签管理的功能 |
+
+Jobhistory历史任务管理
+----------------------
+
+Jobhistory为用户提供了linkis历史任务查询、进度、日志展示的相关功能,为管理员提供统一历史任务视图。
+
+| 核心类 | 核心功能 |
+|------------------------|----------------------|
+| JobHistoryQueryService | 提供历史任务查询服务 |
+
+Variable用户自定义变量管理
+--------------------------
+
+Variable为用户提供自定义变量存储和使用的相关功能。
+
+| 核心类 | 核心功能 |
+|-----------------|------------------------------------|
+| VariableService | 提供自定义变量存储和使用的相关功能 |
+
+UDF用户自定义函数管理
+---------------------
+
+UDF为用户提供自定义函数的功能,用户可以在在编写代码时自行引入。
+
+| 核心类 | 核心功能 |
+|------------|------------------------|
+| UDFService | 提供用户自定义函数服务 |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/public-service.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/public-service.md
new file mode 100644
index 00000000000..2ca0ea2e92e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/feature/public-enhancement-services/public-service.md
@@ -0,0 +1,27 @@
+---
+title: 公共服务架构
+sidebar_position: 2
+---
+## **背景**
+为什么在我们将Linkis作为统一网关或JobServer后,还要为其增加公共增强的能力呢?这个是在我们实际去开发了多个上层应用工具后,发现如在IDE工具里面定义了一个UDF、变量调试通过后,在发布到调度工具的时候,这些UDF和变量又需要重现定义一遍。当依赖的一些jar包、配置文件等发生变化时,也需要修改两个地方。
+针对这些类似跨上层应用工具的公共上下文的问题,在我们实现任务统一入口为Linkis后,我们就在想是不是可以由Linkis去提供这个公共增强的能力,提供一些公共可以被多个应用工具去复用的能力。所以在Linkis层设计了一层公共增强服务PES
+
+
+## **架构图**
+
+![](/Images/Architecture/Public_Enhancement_Service/pes_arc.png)
+
+## **架构说明**
+
+现在已经提供了以下能力:
+- 提供统一的数据源能力:数据源在Linkis层进行统一定义和管理,应用工具只需要通过数据源名字来进行使用,不再需要去维护对应数据源的连接信息。而且在不同的工具间数据源的含义都是一样的。并提供了相应的数据源的元数据的查询能力。
+- 提供公共的UDF能力:统一UDF、小函数的定义规范和语义,做到一处定义多个工具都可使用。
+- 提供统一上下文的能力:支持任务间传递信息,包括变量、结果集、资源文件的多任务间传递,提供任务间传递上下文的能力。
+- 提供统一物料的能力:提供统一的物料,在多个工具间支持共享访问这些物料,并且物料支持存储多种的文件类型,并支持版本控制。
+- 提供统一配置和变量的能力:提供了统一的配置能力支持模板化的配置不同的引擎参数模版,支持自定义变量、内置常用的系统变量和时间格式变量等。
+- 提供公共错误码的能力:提供统一的错误码能力,对常用计算存储引擎的作物进行分类编码以及知识库的能力,并提供了方便的SDK进行调用。
+
+通过Linkis的公共增强服务,可以打破上层应用工具间的孤岛,做到变量、函数、文件、结果集等上下文的共享,就像下图所暂时的一样,并且大大减少应用工具间的重复开发工作。
+![](/Images/Architecture/Public_Enhancement_Service/pes_arc_demo.png)
+
+[详细介绍可以参考](https://mp.weixin.qq.com/s/UfUB8AGZtusbFmmtiZfK1A)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/overview.md
new file mode 100644
index 00000000000..334314da502
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/overview.md
@@ -0,0 +1,26 @@
+---
+title: 总览
+sidebar_position: 1
+---
+
+Linkis 1.0 将所有微服务总体划分为三大类:公共增强服务、计算治理服务、微服务治理服务。如下图所示为Linkis 1.0 的架构图。
+
+![Linkis1.0架构图](/Images-zh/Architecture/Linkis1.0-architecture.png)
+
+
+各大类的具体职责如下:
+
+1. 公共增强服务为 Linkis 0.X 已经提供的物料库服务、上下文服务、数据源服务和公共服务等。
+
+2. 微服务治理服务为 Linkis 0.X 已经提供的 Spring Cloud Gateway、Eureka 和 Open Feign。
+
+3. 计算治理服务是 Linkis 1.0 的核心重点,从 提交 —> 准备 —> 执行三个阶段,来全面升级 Linkis 对 用户任务的执行管控能力。
+
+以下是 Linkis1.0 架构文档的目录列表:
+
+1. Linkis1.0公共增强服务相关文档,请阅读[公共增强服务](feature/public-enhancement-services/overview.md)。
+
+2. Linkis1.0微服务治理相关文档,请阅读[微服务治理](service-architecture/overview.md)。
+
+3. Linkis1.0提出的计算治理服务相关文档,请阅读 [计算治理服务](feature/computation-governance-services/overview.md)。
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/_category_.json
new file mode 100644
index 00000000000..87ec81471d2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "微服务架构",
+ "position": 3
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/gateway.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/gateway.md
new file mode 100644
index 00000000000..ca13c7470e2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/gateway.md
@@ -0,0 +1,34 @@
+---
+title: 网关架构
+sidebar_position: 1
+---
+## Gateway 架构设计
+
+#### 简述
+Gateway网关是Linkis接受客户端以及外部请求的首要入口,例如接收作业执行请求,而后将执行请求转发到具体的符合条件的Entrance服务中去。
+整个架构底层基于SpringCloudGateway做扩展实现,上层叠加了与Http请求解析,会话权限,标签路由和WebSocket多路转发等相关的模组设计,整体架构可见如下。
+
+### 整体架构示意图
+
+![Gateway整体架构示意图](/Images-zh/Architecture/Gateway/gateway_server_global.png)
+
+#### 架构说明
+- gateway-core: Gateway的核心接口定义模块,主要定义了GatewayParser和GatewayRouter接口,分别对应请求的解析和根据请求进行路由选择;同时还提供了SecurityFilter的权限校验工具类。
+- spring-cloud-gateway: 该模块集成了所有与SpringCloudGateway相关的依赖,对HTTP和WebSocket两种协议类型的请求分别进行了处理转发。
+- gateway-server-support: Gateway的服务驱动模块,依赖spring-cloud-gateway模块,对GatewayParser、GatewayRouter分别做了实现,其中DefaultLabelGatewayRouter提供了请求标签路由的功能。
+- gateway-httpclient-support: 提供了Http访问Gateway服务的客户端通用类。
+- instance-label: 外联的实例标签模块,提供InsLabelService服务接口,用于路由标签的创建以及与应用实例关联。
+
+涉及的详细设计如下:
+
+#### 一、请求路由转发(带标签信息)
+请求的链路首先经SpringCloudGateway的Dispatcher分发后,进入网关的过滤器链表,进入GatewayAuthorizationFilter 和 SpringCloudGatewayWebsocketFilter 两大过滤器逻辑,过滤器集成了DefaultGatewayParser和DefaultGatewayRouter。
+从Parser到Router,执行相应的parse和route方法,DefaultGatewayParser和DefaultGatewayRouter内部还包含了自定义的Parser和Router,按照优先级顺序执行。最后由DefaultGatewayRouter输出路由选中的服务实例ServiceInstance,交由上层进行转发。
+现我们以具有标签信息的作业执行请求转发为例子,绘制如下流程图:
+![Gateway请求路由转发](/Images-zh/Architecture/Gateway/gateway_server_dispatcher.png)
+
+
+#### 二、WebSocket连接转发管理
+默认情况下SpringCloudGateway对WebSocket请求只做一次路由转发,无法做动态的切换,而在Linkis Gateway架构下,每次信息的交互都会附带相应的uri地址,引导路由到不同的后端服务。
+除了负责与前端、客户端连接的webSocketService以及负责和后台服务连接的webSocketClient, 中间会缓存一系列GatewayWebSocketSessionConnection列表,一个GatewayWebSocketSessionConnection代表一个session会话与多个后台ServiceInstance的连接。
+![Gateway的WebSocket转发管理](/Images-zh/Architecture/Gateway/gatway_websocket.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/overview.md
new file mode 100644
index 00000000000..ef33e8fea28
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/overview.md
@@ -0,0 +1,27 @@
+---
+title: 总览
+sidebar_position: 0
+---
+## **背景**
+
+微服务治理包含了Gateway、Eureka、Open Feign等三个主要的微服务。用来解决Linkis的服务发现与注册、统一网关、请求转发、服务间通信、负载均衡等问题。整个Linkis是一个完全的微服务架构,每个业务流程都是需要多个微服务协同完成的。
+
+## **架构图**
+
+![](/Images-zh/Architecture/linkis-microservice-gov-01.png)
+
+## **架构描述**
+
+1. Linkis Gateway作为Linkis的网关入口,主要承担了请求转发、用户访问认证、WebSocket通信等职责。Linkis1.0的Gateway还新增了基于Label的路由转发能力。Linkis在Spring
+Cloud Gateway中,实现了WebSocket路由转发器,用于与客户端建立WebSocket连接,建立连接成功后,会自动分析客户端的WebSocket请求,通过规则判断出请求该转发给哪个后端微服务,从而将WebSocket请求转发给对应的后端微服务实例。
+
+ [进入Linkis Gateway](gateway.md)
+
+2. Linkis Eureka
+主要负责服务注册与发现,Eureka由多个instance(服务实例)组成,这些服务实例可以分为两种:Eureka Server和Eureka Client。为了便于理解,我们将Eureka client再分为Service
+Provider和Service Consumer。Eureka Server 提供服务注册和发现,Service Provider服务提供方,将自身服务注册到Eureka,从而使服务消费方能够找到Service
+Consumer服务消费方,从Eureka获取注册服务列表,从而能够消费服务。
+
+3. Linkis基于Feign实现了一套自己的底层RPC通信方案。Linkis RPC作为底层的通信方案,将提供SDK集成到有需要的微服务之中。一个微服务既可以作为请求调用方,也可以作为请求接收方。作为请求调用方时,将通过Sender请求目标接收方微服务的Receiver,作为请求接收方时,将提供Receiver用来处理请求接收方Sender发送过来的请求,以便完成同步响应或异步响应。
+
+ ![](/Images-zh/Architecture/linkis-microservice-gov-03.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/service_isolation.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/service_isolation.md
new file mode 100644
index 00000000000..f0a51748f1f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/service-architecture/service_isolation.md
@@ -0,0 +1,196 @@
+---
+title: 微服务租户隔离架构设计
+sidebar_position: 9
+---
+
+## 1. 总述
+### 1.1 需求背景
+ Linkis在Gateway进行服务转发时是基于ribbon进行负载均衡的,但是有些情况下存在一些重要业务的任务希望做到服务级别的隔离,如果基于ribbon进行服务在均衡就会存在问题。比如租户A希望他的任务都路由到特定的Linkis-CG-Entrance服务,这样当其他的实例出现异常时可以不会影响到A服务的Entrance。另外支持服务的租户及隔离也可以做到快速隔离某个异常服务,支持灰度升级等场景。
+
+### 1.2 目标
+1. 支持通过解析请求的标签按照路由标签对服务进行转发
+2. 支持服务的标签注册和修改
+
+## 2. 总体设计
+ 此次特性新增主要修改点位linkis-mg-gateway和instance-label两个模块,设计到新增Gateway的转发逻辑,以及instance-label支持服务和标签的注册。
+
+### 2.1 技术架构
+ 整体技术架构主要修改点位RestFul请求需要带上路由标签等标签参数信息,然后在Gateway进行转发时会解析对应的标签完成接口的路由转发。整体如下图所示
+![arc](/Images/Architecture/Gateway/service_isolation_arc.png)
+
+几点说明:
+1. 如果存在多个对应的服务打上了同一个roteLabel则随机转发
+2. 如果对应的routeLabel没有对应的服务,则接口直接失败
+3. 如果接口没有routeLabel则基于原有的转发逻辑,不会路由到打上了特定标签的服务
+
+### 2.2 业务架构
+ 此次的特性主要是为了完成Restful租户隔离转发功能。功能点设计的模块如下:
+
+| 组件名| 一级模块 | 二级模块 | 功能点 |
+|---|---|---|---|
+| Linkis | MG | Gateway| 解析restful请求参数中的路由标签,完成接口按照路由标签的转发功能|
+| Linkis | PS | InstanceLabel| InstanceLabel服务,完成服务和标签的关联|
+
+## 3. 模块设计
+### 3.1 核心执行流程
+- [输入端] 输入端为请求Gatway的restful请求,且是参数中待用roure label的请求才会进行处理
+- [处理流程] Gateway会判断请求是否带有对应的RouteLabel,如果存在则基于RouteLabel来进行转发。
+调用时序图如下:
+
+![Time](/Images/Architecture/Gateway/service_isolation_time.png)
+
+
+
+## 4. 数据结构:
+```sql
+DROP TABLE IF EXISTS `linkis_ps_instance_label`;
+CREATE TABLE `linkis_ps_instance_label` (
+ `id` int(20) NOT NULL AUTO_INCREMENT,
+ `label_key` varchar(32) COLLATE utf8_bin NOT NULL COMMENT 'string key',
+ `label_value` varchar(255) COLLATE utf8_bin NOT NULL COMMENT 'string value',
+ `label_feature` varchar(16) COLLATE utf8_bin NOT NULL COMMENT 'store the feature of label, but it may be redundant',
+ `label_value_size` int(20) NOT NULL COMMENT 'size of key -> value map',
+ `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'update unix timestamp',
+ `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'update unix timestamp',
+ PRIMARY KEY (`id`),
+ UNIQUE KEY `label_key_value` (`label_key`,`label_value`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
+
+DROP TABLE IF EXISTS `linkis_ps_instance_info`;
+CREATE TABLE `linkis_ps_instance_info` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `instance` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'structure like ${host|machine}:${port}',
+ `name` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'equal application name in registry',
+ `update_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'update unix timestamp',
+ `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'create unix timestamp',
+ PRIMARY KEY (`id`),
+ UNIQUE KEY `instance` (`instance`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
+
+DROP TABLE IF EXISTS `linkis_ps_instance_label_relation`;
+CREATE TABLE `linkis_ps_instance_label_relation` (
+ `id` int(20) NOT NULL AUTO_INCREMENT,
+ `label_id` int(20) DEFAULT NULL COMMENT 'id reference linkis_ps_instance_label -> id',
+ `service_instance` varchar(128) NOT NULL COLLATE utf8_bin COMMENT 'structure like ${host|machine}:${port}',
+ `update_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'update unix timestamp',
+ `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'create unix timestamp',
+ PRIMARY KEY (`id`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
+
+```
+## 5. 如何使用:
+
+### 5.1 add route label for entrance
+```
+echo "spring.eureka.instance.metadata-map.route=et1" >> $LINKIS_CONF_DIR/linkis-cg-entrance.properties
+sh $LINKIS_HOME/sbin/linkis-damemon.sh restart cg-entrance
+```
+![Time](/Images/Architecture/Gateway/service_isolation_time.png)
+
+### 5.2 Use route label
+submit task:
+```
+url:/api/v1/entrance/submit
+{
+ "executionContent": {"code": "echo 1", "runType": "shell"},
+ "params": {"variable": {}, "configuration": {}},
+ "source": {"scriptPath": "ip"},
+ "labels": {
+ "engineType": "shell-1",
+ "userCreator": "peacewong-IDE",
+ "route": "et1"
+ }
+}
+```
+will be routed to a fixed service:
+```
+{
+ "method": "/api/entrance/submit",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "taskID": 45158,
+ "execID": "exec_id018030linkis-cg-entrancelocalhost:9205IDE_peacewong_shell_0"
+ }
+}
+```
+
+or linkis-cli:
+
+```
+sh bin/linkis-cli -submitUser hadoop -engineType shell-1 -codeType shell -code "whoami" -labelMap route=et1 --gatewayUrl http://127.0.0.1:9101
+```
+
+### 5.3 Use non-existing label
+submit task:
+```
+url:/api/v1/entrance/submit
+{
+ "executionContent": {"code": "echo 1", "runType": "shell"},
+ "params": {"variable": {}, "configuration": {}},
+ "source": {"scriptPath": "ip"},
+ "labels": {
+ "engineType": "shell-1",
+ "userCreator": "peacewong-IDE",
+ "route": "et1"
+ }
+}
+```
+will get the error
+```
+{
+ "method": "/api/rest_j/v1/entrance/submit",
+ "status": 1,
+ "message": "GatewayErrorException: errCode: 11011 ,desc: Cannot route to the corresponding service, URL: /api/rest_j/v1/entrance/submit RouteLabel: [{\"stringValue\":\"et2\",\"labelKey\":\"route\",\"feature\":null,\"modifiable\":true,\"featureKey\":\"feature\",\"empty\":false}] ,ip: localhost ,port: 9101 ,serviceKind: linkis-mg-gateway",
+ "data": {
+ "data": "{\r\n \"executionContent\": {\"code\": \"echo 1\", \"runType\": \"shell\"},\r\n \"params\": {\"variable\": {}, \"configuration\": {}},\r\n \"source\": {\"scriptPath\": \"ip\"},\r\n \"labels\": {\r\n \"engineType\": \"shell-1\",\r\n \"userCreator\": \"peacewong-IDE\",\r\n \"route\": \"et2\"\r\n }\r\n}"
+ }
+}
+```
+
+### 5.4 without label
+submit task:
+```
+url:/api/v1/entrance/submit
+{
+ "executionContent": {"code": "echo 1", "runType": "shell"},
+ "params": {"variable": {}, "configuration": {}},
+ "source": {"scriptPath": "ip"},
+ "labels": {
+ "engineType": "shell-1",
+ "userCreator": "peacewong-IDE"
+ }
+}
+```
+
+```
+
+will route to untagged entranceservices
+{
+ "method": "/api/entrance/submit",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "taskID": 45159,
+ "execID": "exec_id018018linkis-cg-entrancelocalhost2:9205IDE_peacewong_shell_0"
+ }
+}
+
+```
+
+## 6. 非功能性设计:
+
+### 6.1 安全
+不涉及安全问题,restful需要登录认证
+
+### 6.2 性能
+对Gateway转发性能影响较小,有缓存相应的label和instance的数据
+
+### 6.3 容量
+不涉及
+
+### 6.4 高可用
+不涉及
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/task-flow.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/task-flow.md
new file mode 100644
index 00000000000..0dd9d2a3ede
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/architecture/task-flow.md
@@ -0,0 +1,187 @@
+---
+title: 任务流转流程介绍
+sidebar_position: 2
+---
+
+> Linkis任务执行是Linkis的核心功能,调用到Linkis的计算治理服务、公共增强服务,微服务治理的三层服务,现在已经支持了OLAP、OLTP、Streaming等引擎类型的任务执行,本文将对OLAP类型引擎的任务提交、准备、执行、结果返回等流程进行介绍。
+
+## 关键名词:
+LinkisMaster:Linkis的计算治理服务层架中的管理服务,主要包含了AppManager、ResourceManager、LabelManager等几个管控服务。原名LinkisManager服务。
+
+Entrance:计算治理服务层架中的入口服务,完成任务的调度、状态管控、任务信息推送等功能。
+
+Orchestrator:Linkis的编排服务,提供强大的编排和计算策略能力,满足多活、主备、事务、重放、限流、异构和混算等多种应用场景的需求。现阶段Orchestrator被Entrance服务所依赖。
+
+EngineConn(EC):引擎连接器,负责接受任务并提交给底层引擎如Spark、hive、Flink、Presto、trino等进行执行。
+
+EngineConnManager(ECM):Linkis 的EC进程管理服务,负责管控EngineConn的生命周期(启动、停止)。
+
+LinkisEnginePluginServer:该服务负责管理各个引擎的启动物料和配置,另外提供每个EngineConn的启动命令获取,以及每个EngineConn所需要的资源。
+
+PublicEnhencementService(PES): 公共增强服务,为其他微服务模块提供统一配置管理、上下文服务、物料库、数据源管理、微服务管理和历史任务查询等功能的模块。
+
+## 一、Linkis交互式任务执行架构
+### 1.1、任务执行思考
+ 在现有Linkis1.0任务执行架构之前,也经历了多次演变,从最开始用户一多起来就各种FullGC导致服务崩溃,到用户开发的脚本如何支持多平台、多租户、强管控、高并发运行,我们遇见了如下几个问题:
+1. 如何支持租户户的上万并发并互相隔离?
+2. 如何支持上下文统一 ,用户定义的UDF、自定义变量等支持多个系统使用?
+3. 如何支持高可用,做到用户提交的任务能够正常运行完?
+4. 如何支持任务的底层引擎日志、进度、状态能够实时推送给前端?
+5. 如何支持多种类型的任务提交sql、python、shell、scala、java等
+
+### 1.2、Linkis任务执行设计
+ 基于以上5个问题出发,Linkis将OLTP任务分成了四个阶段,分别是:
+1. 提交阶段:APP提交到Linkis的CG-Entrance服务到完成任务的持久化(PS-JobHistory)以及任务的各种拦截器处理(危险语法、变量替换、参数检查)等步骤,并做生产者消费者的并发控制;
+2. 准备阶段:任务在Entrance被Scheduler消费调度给Orchestrator模块进行任务的编排、并向LinkisMaster完成EngineConn的申请,在这过程中会对租户的资源进行管控;
+3. 执行阶段:任务从Orchestrator提交给EngineConn执行,EngineConn具体提交底层引擎进行执行,并实时将任务的信息推送给调用方;
+4. 结果返回阶段:向调用方返回结果,支持json和io流返回结果集
+ Linkis的整体任务执行架构如下图所示:
+ ![arc](/Images/Architecture/Job_submission_preparation_and_execution_process/linkis_job_arc.png)
+
+## 二、任务执行流程介绍
+ 首先我们先对OLAP型任务的处理流程进行一个简要介绍,任务整体的一个执行流程如下图所示:
+![flow](/Images/Architecture/Job_submission_preparation_and_execution_process/linkis_job_flow.png)
+
+ 整个任务涉及到了所有的计算治理的所有服务,任务通过Gateway转发到Linkis的人口服务Entrance后,会通过对任务的标签进行多级调度(生产者消费者模式)通过FIFO的模式完成任务的调度执行,Entrance接着将任务提交给Orchestrator进行任务编排和提交,Orchestrator会向LinkisMaster完成EC的申请,在这过程中会通过任务的Label进行资源管控和引擎版本选择申请不同的EC。接着Orchestrator将编排后的任务提交给EC进行执行,EC会将job的日志、进度、资源使用等信息推动给Entrance服务,并推送给调用方。下面我们基于上图和结合任务的四个阶段(提交、准备、执行、返回)对任务的执行流程进行一个简要介绍。
+
+
+### 2.1 Job提交阶段
+ Job提交阶段Linkis支持多种类型的任务:SQL, Python, Shell, Scala, Java等,支持不同的提交接口,支持Restful/JDBC/Python/Shell等提交接口。提交任务主要包含任务代码、标签、参数等信息即可,下面是一个RestFul的示例:
+通过Restfu接口发起一个Spark Sql任务
+```JSON
+ "method": "/api/rest_j/v1/entrance/submit",
+ "data": {
+ "executionContent": {
+ "code": "select * from table01",
+ "runType": "sql"
+ },
+ "params": {
+ "variable": {// task variable
+ "testvar": "hello"
+ },
+ "configuration": {
+ "runtime": {// task runtime params
+ "jdbc.url": "XX"
+ },
+ "startup": { // ec start up params
+ "spark.executor.cores": "4"
+ }
+ }
+ },
+ "source": { //task source information
+ "scriptPath": "file:///tmp/hadoop/test.sql"
+ },
+ "labels": {
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+1. 任务首先会提交给Linkis的网关linkis-mg-gateway服务,Gateway会通过任务中是否带有routeLabel来转发给对应的Entrance服务,如果没有RouteLabel则随机转发给一个Entrance服务
+2. Entrance接受到对应的Job后,会调用PES中JobHistory模块的RPC对Job的信息进行持久化,并对参数和代码进性解析对自定义变量进行替换,并提交给调度器(默认FIFO调度)调度器会通过任务的标签进行分组,标签不同的任务互相不影响调度。
+3. Entrance在通过FIFO调度器消费后会提交给Orchestrator进行编排执行,就完成了任务的提交阶段
+ 主要涉及的类简单说明:
+```
+EntranceRestfulApi: 入口服务的Controller类,任务提交、状态、日志、结果、job信息、任务kill等操作
+EntranceServer:任务的提交入口,完成任务的持久化、任务拦截解析(EntranceInterceptors)、提交给调度器
+EntranceContext:Entrance的上下文持有类,包含获取调度器、任务解析拦截器、logManager、持久化、listenBus等方法
+FIFOScheduler: FIFO调度器,用于调度任务
+EntranceExecutor:调度的执行器,任务调度后会提交给EntranceExecutor进行执行
+EntranceJob:调度器调度的job任务,通过EntranceParser解析用户提交的JobRequest进行生成和JobRequest一一对应
+```
+此时任务状态为排队状态
+
+### 2.2 Job准备阶段
+ Entrance的调度器,会按照Job中的Label生成不同的消费器去消费任务,任务被消费修改状态为Running时开始进入准备状态,到对应的任务后就是任务的准备阶段开始了。主要涉及以下几个服务:Entrance、LinkisMaster、EnginepluginServer、EngineConnManager、EngineConn,下面将对以下服务进行分开介绍。
+### 2.2.1 Entrance步骤:
+1. 消费器(FIFOUserConsumer)通过对应标签配置的支持并发数进行消费将任务消费调度给编排器(Orchestrator)进行执行
+2. 首先是Orchestrator对提交的任务进行编排,对于普通的hive和Spark单引擎的任务主要是任务的解析、label检查和校验,对于多数据源混算的场景会拆分不同的任务提交给不同的数据源进行执行等
+3. 在准备阶段,编排器Orchestrator另外一个重要的事情是通过请求LinkisMaster获取用于执行任务的EngineConn。如果LinkisMaster有对应的EngineConn可以复用则直接返回,如果没有则创建EngineConn。
+4. Orchestrator拿到任务后提交给EngineConn进行执行,准备阶段结束,进入Job执行阶段
+ 主要涉及的类简单说明:
+
+```
+## Entrance
+FIFOUserConsumer: 调度器的消费器,会根据标签生成不同的消费器,如IDE-hadoop、spark-2.4.3生成不同的消费器。消费提交的任务。并控制同时运行的任务个数,通过对应标签配置的并发数:wds.linkis.rm.instance
+DefaultEntranceExecutor:任务执行的入口,发起编排器的调用:callExecute
+JobReq: 编排器接受的任务对象,通过EntranceJob转换而来,主要包括代码、标签信息、参数等
+OrchestratorSession:类似于SparkSession,是编排器的入口。正常单例。
+Orchestration:JobReq被OrchestratorSession编排后的返回对象,支持执行和打印执行计划等
+OrchestrationFuture: Orchestration选择异步执行的返回,包括cancel、waitForCompleted、getResponse等常用方法
+Operation:用于扩展操作任务的接口,现在已经实现了用于获取日志的LogOperation、获取进度的ProgressOperation等
+
+## Orchestrator
+CodeLogicalUnitExecTask: 代码类型任务的执行入口,任务最终编排运行后会调用该类的execute方法,首先会向LinkisMaster请求EngineConn再提交执行
+DefaultCodeExecTaskExecutorManager:负责管控代码类型的EngineConn,包括请求和释放EngineConn
+ComputationEngineConnManager:负责LinkisMaster进行对接,请求和释放ENgineConn
+```
+
+### 2.2.2 LinkisMaster步骤:
+
+1.LinkisMaster接受到Entrance服务发出的请求EngineConn请求进行处理
+2.判断是否有对应Label可以复用的EngineConn,有则直接返回
+3.如果没有则进入创建EngineConn流程:
+- 首先通过Label选择合适的EngineConnManager服务。
+- 接着通过调用EnginePluginServer获取本次请求EngineConn的资源类型和资源使用,
+- 通过资源类型和资源,判断对应的Label是否还有资源,如果有则进入创建,否则抛出重试异常
+- 请求第一步的EngineConnManager启动EngineConn
+- 等待EngineConn空闲,返回创建的EngineConn,否则判断异常是否可以重试
+
+4.锁定创建的EngineConn返回给Entrance,注意这里为异步请求Entrance发出EC请求后会接受到对应的请求ID,LinkisMaster请求完毕后主动通过给对应的Entrance服务
+
+主要涉及的类简单说明:
+```
+## LinkisMaster
+EngineAskEngineService: LinkisMaster负责处理引擎请求的处理类,主要逻辑通过调用EngineReuseService判断是否有EngineConn可以复用,否则调用EngineCreateService创建EngineConn
+EngineCreateService:负责创建EngineConn,主要几个步骤:
+
+
+## LinkisEnginePluginServer
+EngineConnLaunchService:提供ECM获取对应引擎类型EngineConn的启动信息
+EngineConnResourceFactoryService:提供给LinkisMaster获取对应本次任务所需要启动EngineConn需要的资源
+EngineConnResourceService: 负责管理引擎物料,包括刷新和刷新所有
+
+## EngineConnManager
+AbstractEngineConnLaunchService:负责启动接受LinkisMaster请求启动EngineConn的请求,并完成EngineConn引擎的启动
+ECMHook: 用于处理EngineConn启动前后的前置后置操作,如hive UDF Jar加入到EngineConn启动的classPath中
+```
+
+
+这里需要说明的是如果用户存在一个可用空闲的引擎,则会跳过1,2,3,4 四个步骤;
+
+### 2.3 Job执行阶段
+ 当Entrance服务中的编排器拿到EngineConn后就进入了执行阶段,CodeLogicalUnitExecTask会将任务提交给EngineConn进行执行,EngineConn会通过对应的CodeLanguageLabel创建不同的执行器进行执行。主要步骤如下:
+1. CodeLogicalUnitExecTask通过RPC提交任务给到EngineConn
+2. EngineConn判断是否有对应的CodeLanguageLabel的执行器,如果没有则创建
+3. 提交给Executor进行执行,通过链接到具体底层的引擎执行进行执行,如Spark通过sparkSession提交sql、pyspark、scala任务
+4. 任务状态流转实时推送给Entrance服务
+5. 通过实现log4jAppender,SendAppender通过RPC将日志推送给Entrance服务
+6. 通过定时任务实时推送任务进度和资源信息给到Entrance
+
+主要涉及的类简单说明:
+```
+ComputationTaskExecutionReceiver:Entrance服务端编排器用于接收EngineConn所有RPC请求的服务类,负责接收进度、日志、状态、结果集在通过ListenerBus的模式推送给上次调用方
+TaskExecutionServiceImpl:EngineConn接收Entrance所有RPC请求的服务类,包括任务执行、状态查询、任务Kill等
+ComputationExecutor:具体的任务执行父类,比如Spark分为SQL/Python/Scala Executor
+ComputationExecutorHook: 用于Executor创建前后的Hook,比如初始化UDF、执行默认的UseDB等
+EngineConnSyncListener: ResultSetListener/TaskProgressListener/TaskStatusListener 用于监听Executor执行任务过程中的进度、结果集、和进度等信息
+SendAppender: 负责推送EngineConn端的日志给到Entrance
+```
+### 2.4 Job结果推送阶段
+ 该阶段比较简单,主要用于将任务在EngineConn产生的结果集返回给Client,主要步骤如下:
+1. 首先在EngineConn执行任务过程中会进行结果集写入,写入到文件系统中获取到对应路径。当然也支持内存缓存,默认写文件
+2. EngineConn将对应的结果集路径和结果集个数返回给Entrance
+3. Entrance调用JobHistory将结果集路径信息更新到任务表中
+4. Client通过任务信息获取到结果集路径并读取结果集
+ 主要涉及的类简单说明:
+```
+EngineExecutionContext:负责创建结果集和推送结果集给到Entrance服务
+ResultSetWriter:负责写结果集到文件系统中支持linkis-storage支持的文件系统,现在以及支持本地和HDFS。支持的结果集类型,表格、文本、HTML、图片等
+JobHistory:存储有任务的所有信息包括状态、结果路径、指标信息等对应DB中的实体类
+ResultSetReader:读取结果集的关键类
+```
+
+## 三、总结
+ 上面我们主要介绍了Linkis计算治理服务组CGS的OLAP任务的整个执行流程,按照任务请求的处理过程对任务拆分成了提交、准备、执行、返回结果四个阶段。CGS主要就是遵循这4个阶段来设计实现的,服务于这4个阶段,且为每个阶段提供了强大和灵活的能力。在提交阶段,主要提供通用的接口,接收上层应用工具提交过来的任务,并能提供基础的解析和拦截能力;在准备阶段,主要通过编排器Orchestrator和LinkisMaster完成对任务的解析编排,并且做资源控制和完成EngineConn的创建;执行阶段,通过引擎连接器EngineConn来去实际完成和底层引擎的对接,通常每个用户要连接不同的底层引擎,就得先启动一个对应的底层引擎连接器EC。计算任务通过EC来提交给底层引擎做实际的执行和状态、日志、结果等信息的获取,及在结果返回阶段,返回任务执行的结果信息,支持按照多种返回模式,如:文件流、JSON、JDBC等。整体的时序图如下:
+
+![time](/Images/Architecture/Job_submission_preparation_and_execution_process/linkis_job_time.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/_category_.json
new file mode 100644
index 00000000000..0ab705787e5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "安全认证",
+ "position": 6
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/kerberos.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/kerberos.md
new file mode 100644
index 00000000000..49ee593d7cf
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/kerberos.md
@@ -0,0 +1,99 @@
+---
+title: Kerberos
+sidebar_position: 5
+---
+
+## Kerberos 认证
+
+## 场景1 HDFS 存储
+
+如果使用到的hadoop集群,如用来存储的结果集的文件
+```shell script
+# 结果集日志等文件路径,用于存储Job的结果集文件 wds.linkis.filesystem.hdfs.root.path(linkis.properties)
+HDFS_USER_ROOT_PATH=hdfs:///tmp/linkis
+```
+并且 开启了kerberos认证,需要进行对应的kerberos配置
+
+修改`linkis.properties` 对应的配置如下
+```properties
+#是否开启了kerberos认证模式
+wds.linkis.keytab.enable=true
+#keytab放置目录,该目录存储的是多个用户的username.keytab的文件
+wds.linkis.keytab.file=/appcom/keytab/
+#是否带上principle客户端认证 默认值false
+wds.linkis.keytab.host.enabled=false
+#principle认证需要带上的客户端IP
+wds.linkis.keytab.host=127.0.0.1
+```
+修改后重启服务
+
+## 场景2 HDFS 存储 kerberos 代理认证
+
+Hadoop2.0版本开始支持ProxyUser的机制。含义是使用User A的用户认证信息,以User B的名义去访问hadoop集群。
+对于服务端来说就认为此时是User B在访问集群,相应对访问请求的鉴权(包括HDFS文件系统的权限,YARN提交任务队列的权限)都以用户User B来进行。
+User A被认为是superuser。
+
+和场景1主要区别是,可以解决每个用户都需要生成一个keytab文件的问题,如果设置了 kerberos 代理认证,可以使用代理用户的keytab文件进行认证。
+修改`linkis.properties` 对应的配置如下
+
+```properties
+#是否开启了kerberos认证模式
+wds.linkis.keytab.enable=true
+#keytab放置目录,该目录存储的是多个用户的username.keytab的文件
+wds.linkis.keytab.file=/appcom/keytab/
+#是否带上principle客户端认证 默认值false
+wds.linkis.keytab.host.enabled=false
+#principle认证需要带上的客户端IP
+wds.linkis.keytab.host=127.0.0.1
+
+#开启kerberos的代理认证
+wds.linkis.keytab.proxyuser.enable=true
+
+#使用superuser 来验证用户认证信息的
+wds.linkis.keytab.proxyuser.superuser=hadoop
+
+
+
+```
+修改后重启服务
+
+## 场景3 队列管理器查看yarn资源信息
+![yarn-normal](/Images-zh/auth/yarn-normal.png)
+会访问访问Yarn提供了ResourceManager的REST API 接口
+如果yarn的ResourceManager 开启了kerberos认证,需要配置kerberos相关的认证信息
+
+数据库表 `linkis_cg_rm_external_resource_provider`
+插入yarn数据信息
+```sql
+INSERT INTO `linkis_cg_rm_external_resource_provider`
+(`resource_type`, `name`, `labels`, `config`) VALUES
+('Yarn', 'default', NULL,
+'
+ {
+ "rmWebAddress": "http://xx.xx.xx.xx:8088",
+ "hadoopVersion": "2.7.2",
+ "authorEnable":false,
+ "user":"hadoop","pwd":"123456",
+ "kerberosEnable":@YARN_KERBEROS_ENABLE,
+ "principalName":"@YARN_PRINCIPAL_NAME",
+ "keytabPath":"@YARN_KEYTAB_PATH"
+ "krb5Path":"@YARN_KRB5_PATH"
+ }
+'
+);
+
+```
+更新后,因为程序中有使用到缓存,想要立即生效,需要重启`linkis-cg-linkismanager`服务
+
+```shell script
+sh sbin/linkis-daemon.sh restart cg-linkismanager
+```
+
+
+
+## 场景4 数据源功能中 HIVE 数据源
+
+如果需要连接的hive数据源,对应的 hive 集群环境,有开启kerberos认证,需要在配置集群环境时,将kerberos以及keytab认证文件信息上传。
+![](/Images-zh/auth/dsm-kerberos.png)
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/ldap.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/ldap.md
new file mode 100644
index 00000000000..2fcfb991175
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/ldap.md
@@ -0,0 +1,51 @@
+---
+title: LDAP
+sidebar_position: 1
+---
+> LDAP(Lightweight Directory Access Protocol)配置,默认安装部署后,只支持配置的静态用户和密码登录(只能配置一个),如果需要支持多用户登录可以使用LDAP
+
+## 1. 实现逻辑介绍
+
+默认方式的配置`linkis-mg-gateway.properties`
+
+```properties
+#默认用户名
+wds.linkis.admin.user=hadoop
+#默认密码
+wds.linkis.admin.password=123456
+```
+
+登陆请求处理时`org.apache.linkis.gateway.security.UserPwdAbstractUserRestful#tryLogin`,
+如果登陆用户名/用户密码和配置的默认值不一致,会走LDAP模式。
+LDAP核心处理 `org.apache.linkis.gateway.security.LDAPUserRestful#login` 通过调用jdk通用的ldap工具类进行认证。
+`javax.naming.ldap.InitialLdapContext#InitialLdapContext(java.util.Hashtable,?>, javax.naming.ldap.Control[])`
+
+
+## 2. 使用方式
+
+> 前提是有可用的LADP服务
+
+### 2.1 Step1 开启ladp登陆验密方式
+
+修改`linkis-mg-gateway.properties`配置
+
+将LDAP相关参数填入
+```properties
+##LDAP
+#ldap服务地址
+wds.linkis.ldap.proxy.url=ldap://localhost:1389/
+#Directory Name(DN) ldap的目录构成
+wds.linkis.ldap.proxy.baseDN==dc=linkis,dc=org
+#用户名格式化 一般无需要配置
+wds.linkis.ldap.proxy.userNameFormat=
+```
+### 2.2 Step2 重启linkis-mg-gateway 的服务
+
+修改配置后,需要重启`linkis-mg-gateway`服务 `sh sbin/linkis-daemon.sh start mg-mgtaeway`,才能生效
+
+## 3 注意事项
+
+- 认证类型使用的是`java.naming.security.authentication`(安全类型,三个值:none,simple或strong。)中的simple模式
+
+- 关于ldap的介绍可以参考[LDAP目录服务器介绍](https://juejin.cn/post/6844903857311449102)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/proxy.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/proxy.md
new file mode 100644
index 00000000000..2d32ae8bd14
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/proxy.md
@@ -0,0 +1,59 @@
+---
+title: 代理认证
+sidebar_position: 4
+---
+
+
+> 这种方式允许登录用户和实际使用的用户不同,主要作用:控制用户登录时必须为实名用户,但是实际使用大数据平台时,是非实名用户,方便进行权限的校验和管控。
+> 比如:linkis在执行用户提交的任务时,linkis主要进程服务会通过sudo -u ${submit user} 切换到对应用户下,然后执行对应的引擎启动命令,
+> 这就需要为每个${submit user} 提前创建对应的系统用户,并且配置好相关的环境变量。 对于新用户,需要一系列的环境的初始化准备工作,
+> 如果频繁的用户变化,会增大运维成本,而且用户过多,没法针对单个用户配置资源,资源之间无法很好的管控。如果能够实现A代理给指定的代理用户执行,可以将执行入口统一收敛,解决需要初始化环境的问题。
+
+## 1. 实现逻辑介绍
+
+
+- 登陆用户:通过用户名密码直接登陆系统的用户
+- 代理用户:作为登陆用户实际执行操作的用户称之为代理用户,代理登陆用户的执行相关操作
+
+对于登陆cookie处理,解析出登录用户和代理用户
+
+```html
+代理用户的cookie的key为:linkis_user_session_proxy_ticket_id_v1
+登录用户的cookie: linkis_user_session_ticket_id_v1
+
+```
+linkis的相关接口能在基于UserName信息,识别出代理用户信息,使用代理用户进行各项操作。并记录审计日志,包含用户的任务执行操作,下载操作
+任务提交执行的时候,entrance入口服务修改执行的用户为代理用户
+
+## 2. 使用方式
+
+### 2.1 Step1 开启代理模式
+在 `linkis.properties` 指定如下参数:
+```shell script
+# 打开代理模式
+ wds.linkis.gateway.conf.enable.proxy.user=true
+ # 指定代理配置文件
+ wds.linkis.gateway.conf.proxy.user.config=proxy.properties
+```
+
+
+在 conf 目录下,创建`proxy.properties` 文件,内容如下:
+```shell script
+# 格式如下:
+ ${LOGIN_USER}=${PROXY_USER}
+ # 例如:
+ enjoyyin=hadoop
+```
+如果现有的代理模式不能满足您的需求,也可以对:`org.apache.linkis.gateway.security.ProxyUserUtils`进一步改造。
+
+### 2.2 Step2 重启linkis-mg-gateway 的服务
+
+修改配置后,需要重启`linkis-mg-gateway`服务 `sh sbin/linkis-daemon.sh start mg-mgtaeway`,才能生效
+
+## 3 注意事项
+
+- 用户分为代理用户和非代理用户,代理类型的用户不能进行再次代理到其他用户执行
+- 需要控制登陆用户与可代理的系统用户列表,禁止出现任意代理的情况,避免权限不可控。最好支持数据库表来配置,并可以直接修改生效,不需要重启服务
+- 单独记录日志文件包含代理用户的操作,如代理执行、函数更新等PublicService的代理用户操作全部记录到日志中,方便审计
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/test.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/test.md
new file mode 100644
index 00000000000..68375772e85
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/test.md
@@ -0,0 +1,76 @@
+---
+title: 免密认证
+sidebar_position: 3
+---
+> 在有些场景下,为了方便开发调试,能够方便的访问页面和接口,可以开启测试模式配置,进行免密认证
+
+## 1. 实现逻辑介绍
+
+通过统一的认证处理filter:`org.apache.linkis.server.security.SecurityFilter` 来控制
+
+配置项
+```properties
+#是否开启测试模式
+wds.linkis.test.mode=true
+#测试模式的模拟用户名
+wds.linkis.test.user=hadoop
+```
+实现的伪代码
+```scala
+val BDP_TEST_USER = CommonVars("wds.linkis.test.user", "")
+val IS_TEST_MODE = CommonVars("wds.linkis.test.mode", false)
+
+if (IS_TEST_MODE.getValue) {
+ logger.info("test mode! login for uri: " + request.getRequestURI)
+ // 设置登陆用户信息为配置指定的用户
+ SecurityFilter.setLoginUser(response, BDP_TEST_USER)
+ true
+}
+```
+
+## 2. 使用方式
+
+### 2.1 Step1 开启测试模式
+直接修改配置文件 `linkis.properties`(对linkis所有服务生效), 修改对应的配置如下
+```shell script
+#是否开启测试模式
+wds.linkis.test.mode=true
+#测试模式的模拟用户名
+wds.linkis.test.user=hadoop
+```
+
+如果只需要开启某个服务的测试模式,可以修改对应的服务配置项。
+如 只开启 `entrance` 服务的测试模式
+直接修改配置文件 `linkis-cg-entrance.properties`(对linkis的entrance服务生效), 修改对应的配置如下
+```shell script
+#是否开启测试模式
+wds.linkis.test.mode=true
+#测试模式的模拟用户名
+wds.linkis.test.user=hadoop
+```
+
+### 2.2 Step2 重启对应的服务
+
+修改配置后,需要重启对应的服务(如果是所有服务都开启,重启所有服务),才能生效
+
+
+### 2.3 Step3 请求验证
+
+重启服务成功后,可以直接请求原来需要认证的http接口,无需额外的认证,便能正常请求.
+管理台也无需登陆认证,就可以访问内容页面
+
+
+## 3 注意事项
+
+### 3.1 wds.linkis.test.user的值设置
+因为部分接口会进行用户角色的权限校验,如: 【搜索历史EC信息】的接口:`/api/rest_j/v1/linkisManager/ecinfo/ecrHistoryList`
+角色有:
+
+|角色名 | 权限说明| 配置项 | 默认值 |
+| -------- | -------- | ----- |----- |
+|管理员角色|最高权限,拥有所有权限操作|`wds.linkis.governance.station.admin`|`hadoop`|
+|历史任务角色|相对普通用户,还可以查看其他用户的所有任务列表信息|`wds.linkis.jobhistory.admin`|`hadoop`|
+|普通角色|默认的角色|||
+
+对于不同场景的测试,设置的`wds.linkis.test.user`的值,会有不同,需要按实际场景进行设置。
+如果需要访问所有接口,需要配置为和`wds.linkis.governance.station.admin`一样的值,一般是`hadoop`
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/token.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/token.md
new file mode 100644
index 00000000000..9cce5e2e4a5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/auth/token.md
@@ -0,0 +1,111 @@
+---
+title: Token
+sidebar_position: 2
+---
+
+> 通常第三方系统调用linkis服务时,一般是通过token的方式进行认证
+
+## 1. 实现逻辑介绍
+
+通过统一的认证处理filter:`org.apache.linkis.server.security.SecurityFilter` 来控制
+
+实现的伪代码
+```scala
+
+val TOKEN_KEY = "Token-Code"
+val TOKEN_USER_KEY = "Token-User"
+
+/* TokenAuthentication.isTokenRequest 通过判断请求request中:
+ 1.请求头是否包含TOKEN_KEY和TOKEN_USER_KEY :getHeaders.containsKey(TOKEN_KEY) && getHeaders.containsKey(TOKEN_USER_KEY)
+ 2.或则请求cookies中是否包含TOKEN_KEY和TOKEN_USER_KEY:getCookies.containsKey(TOKEN_KEY) &&getCookies.containsKey(TOKEN_USER_KEY)
+*/
+
+if (TokenAuthentication.isTokenRequest(gatewayContext)) {
+ /* 进行token认证
+ 1. 确认是否开启token认证 配置项 `wds.linkis.gateway.conf.enable.token.auth`
+ 2. 提取token tokenUser host信息进行认证,校验合法性
+ */
+ TokenAuthentication.tokenAuth(gatewayContext)
+ } else {
+ //普通的用户名密码认证
+}
+```
+可用的token以及对应可使用的ip相关信息数据存储在表`linkis_mg_gateway_auth_token`中,
+详细见[表解析说明](../development/table/all#16-linkis_mg_gateway_auth_token),非实时更新,
+会定期`wds.linkis.token.cache.expire.hour`(默认间隔12小时)刷新到服务内存中
+
+
+## 2. 使用方式
+
+### 2.1 新增 Token
+
+管理台 `基础数据管理> 令牌管理`进行新增
+
+```text
+名称:token名称 对应 Token-Code,如:TEST-AUTH
+用户:该token对应的用户名,即感知到的请求用户,日志审计会使用到。如果不做限制可以配置为 *
+主机:可访问的主机,会进行请求方的ip校验过滤。如果不做限制可以配置为 *
+有效天数:如果永久有效,配置为-1
+```
+
+### 2.2 原生的方式
+构建的http请求方式,需要在请求头中添加`Token-Code`,`Token-User`参数,
+
+#### 示例
+
+请求地址:
+`http://127.0.0.1:9001/api/rest_j/v1/entrance/submit`
+
+body参数:
+```json
+{
+ "executionContent": {"code": "sleep 5s;echo pwd", "runType": "shell"},
+ "params": {"variable": {}, "configuration": {}},
+ "source": {"scriptPath": "file:///mnt/bdp/hadoop/1.hql"},
+ "labels": {
+ "engineType": "shell-1",
+ "userCreator": "hadoop-IDE",
+ "executeOnce":"false "
+ }
+}
+```
+
+请求头header:
+```text
+Content-Type:application/json
+Token-Code:BML-AUTH
+Token-User:hadoop
+```
+
+### 2.3 客户端使用token认证
+
+linkis 提供的客户端认证方式都支持Token策略模式`new TokenAuthenticationStrategy()`
+
+详细可以参考[SDK 方式](../user-guide/sdk-manual)
+
+#### 示例
+```java
+// 1. build config: linkis gateway url
+ DWSClientConfig clientConfig = ((DWSClientConfigBuilder) (DWSClientConfigBuilder.newBuilder()
+ .addServerUrl("http://127.0.0.1:9001/") //set linkis-mg-gateway url: http://{ip}:{port}
+ .connectionTimeout(30000) //connectionTimeOut
+ .discoveryEnabled(false) //disable discovery
+ .discoveryFrequency(1, TimeUnit.MINUTES) // discovery frequency
+ .loadbalancerEnabled(true) // enable loadbalance
+ .maxConnectionSize(5) // set max Connection
+ .retryEnabled(false) // set retry
+ .readTimeout(30000) //set read timeout
+ .setAuthenticationStrategy(new TokenAuthenticationStrategy()) // AuthenticationStrategy Linkis auth Token
+ .setAuthTokenKey("Token-Code") // set token key
+ .setAuthTokenValue("DSM-AUTH") // set token value
+ .setDWSVersion("v1") //linkis rest version v1
+ .build();
+```
+
+## 3 注意事项
+
+### 3.1 token的配置
+支持的token,对应的可用的用户/可使用请求方ip 是通过表`linkis_mg_gateway_auth_token`来控制,加载是非实时更新,使用了缓存机制
+
+### 3.2 管理员权限token
+对于高危操作的限制,需要管理员角色的token才能操作,管理员token,格式为 `admin-xxx`
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/_category_.json
new file mode 100644
index 00000000000..2c333deaa77
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "关于 Linkis",
+ "position": 1.0
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/configuration.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/configuration.md
new file mode 100644
index 00000000000..fa6358f012b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/configuration.md
@@ -0,0 +1,179 @@
+---
+title: 建议配置
+sidebar_position: 0.2
+---
+
+## 1 软硬件环境建议配置
+
+Linkis 在上层应用程序和底层引擎之间构建了一层计算中间件。 作为一款开源分布式计算中间件,可以很好地部署和运行在 Intel 架构服务器及主流虚拟化环境下,并支持主流的Linux操作系统环境
+
+### 1.1 Linux 操作系统版本要求
+
+| 操作系统 | 版本 |
+| --- | --- |
+| Red Hat Enterprise Linux | 7.0 及以上 |
+| CentOS | 7.0 及以上 |
+| Oracle Enterprise Linux | 7.0 及以上 |
+| Ubuntu LTS | 16.04 及以上 |
+
+> **注意:** 以上 Linux 操作系统可运行在物理服务器以及 VMware、KVM、XEN 主流虚拟化环境上
+
+### 1.2 服务器建议配置
+
+Linkis 支持运行在 Intel x86-64 架构的 64 位通用硬件服务器平台。对生产环境的服务器硬件配置有以下建议:
+
+#### 生产环境
+
+| **CPU** | **内存** | **硬盘类型** | **网络** | **实例数量** |
+| --- | --- | --- | --- | --- |
+| 16核+ | 32GB+ | SAS | 千兆网卡 | 1+ |
+
+> **注意:**
+>
+> - 以上建议配置为部署 Linkis的最低配置,生产环境强烈推荐使用更高的配置
+> - 硬盘大小配置建议 50GB+ ,系统盘和数据盘分开
+
+### 1.3 软件要求
+
+Linkis二进制包基于以下软件版本进行编译:
+
+| 组件 | 版本 | 说明 |
+| --- | --- | --- |
+| Hadoop | 3.3.4 | |
+| Hive | 3.1.3 | |
+| Spark | 3.2.1 | |
+| Flink | 1.12.2 | |
+| openLooKeng | 1.5.0 | |
+| Sqoop | 1.4.6 | |
+| ElasticSearch | 7.6.2 | |
+| Presto | 0.234 | |
+| Python | Python2 | |
+
+> **注意:**
+> 如果本地安装组件版本与上述不一致,需要进行修改对应组件版本,自行编译二进制包进行安装。
+
+### 1.4 客户端 Web 浏览器要求
+
+Linkis推荐 Chrome 73版本进行前端访问
+
+
+## 2 常用场景
+
+### 2.1 开启测试模式
+开发过程需要免密接口,可在`linkis.properties`替换或追加此配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.test.mode | false | 是否打开调试模式,如果设置为 true,所有微服务都支持免密登录,且所有EngineConn打开远程调试端口 |
+| wds.linkis.test.user | hadoop | 当wds.linkis.test.mode=true时,免密登录的默认登录用户 |
+
+![](./images/test-mode.png)
+
+
+### 2.2 登录用户设置
+Apache Linkis 默认使用配置文件来管理admin用户,可以在`linkis-mg-gateway.properties`替换或追加此配置。如需多用户可接入LDAP实现。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.admin.user | hadoop | 管理员用户名 |
+| wds.linkis.admin.password | 123456 | 管理员用户密码 |
+
+![](./images/login-user.png)
+
+
+### 2.3 LDAP设置
+Apache Linkis 可以通过参数接入LDAP实现多用户管理,可以在`linkis-mg-gateway.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.ldap.proxy.url | 无 | LDAP URL地址 |
+| wds.linkis.ldap.proxy.baseDN | 无 | LDAP baseDN地址 |
+| wds.linkis.ldap.proxy.userNameFormat | 无 | |
+
+![](./images/ldap.png)
+
+### 2.4 关闭资源检查
+Apache Linkis 提交任务时有时会调试异常,如:资源不足;可以在`linkis-cg-linkismanager.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.manager.rm.request.enable | true | 资源检查 |
+
+![](./images/resource-enable.png)
+
+### 2.5 开启引擎调试
+Apache Linkis EC可以开启调试模式,可以在`linkis-cg-linkismanager.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.engineconn.debug.enable | true | 是否开启引擎调试 |
+
+![](./images/engine-debug.png)
+
+### 2.6 Hive元数据配置
+Apache Linkis 的public-service服务需要读取hive的元数据;可以在`linkis-ps-publicservice.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| hive.meta.url | 无 | HiveMetaStore数据库的URL。 |
+| hive.meta.user | 无 | HiveMetaStore数据库的user |
+| hive.meta.password | 无 | HiveMetaStore数据库的password |
+
+![](./images/hive-meta.png)
+
+### 2.7 Linkis 数据库配置
+Apache Linkis 访问默认使用Mysql作为数据存储,可以在`linkis.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.server.mybatis.datasource.url | 无 | 数据库连接字符串,例如:jdbc:mysql://127.0.0.1:3306/dss?characterEncoding=UTF-8 |
+| wds.linkis.server.mybatis.datasource.username | 无 | 数据库用户名,例如:root |
+| wds.linkis.server.mybatis.datasource.password | 无 | 数据库密码,例如:root |
+
+![](./images/linkis-db.png)
+
+### 2.8 Linkis Session 缓存配置
+Apache Linkis 支持使用redis进行session的共享;可以在`linkis.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| linkis.session.redis.cache.enabled | None | 是否开启 |
+| linkis.session.redis.host | 127.0.0.1 | 主机名 |
+| linkis.session.redis.port | 6379 | 端口,例如 |
+| linkis.session.redis.password | None | 密码 |
+
+![](./images/redis.png)
+
+### 2.9 Linkis 模块开发配置
+Apache Linkis 开发时可通过此参数,自定义加载模块的数据库、Rest接口、实体对象;可以在`linkis-ps-publicservice.properties`进行修改,多个模块之间使用逗号分割。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.server.restful.scan.packages | 无 | restful 扫描包,例如:org.apache.linkis.basedatamanager.server.restful |
+| wds.linkis.server.mybatis.mapperLocations | 无 | mybatis mapper文件路径,例如: classpath*:org/apache/linkis/basedatamanager/server/dao/mapper/*.xml|
+| wds.linkis.server.mybatis.typeAliasesPackage | 无 | 实体别名扫描包,例如:org.apache.linkis.basedatamanager.server.domain |
+| wds.linkis.server.mybatis.BasePackage | 无 | 数据库dao层扫描,例如:org.apache.linkis.basedatamanager.server.dao |
+
+![](./images/deverlop-conf.png)
+
+### 2.10 Linkis 模块开发配置
+Apache Linkis 开发时可通过此参数,自定义加载模块的路由;可以在`linkis.properties`进行修改,多个模块之间使用逗号分割。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.gateway.conf.publicservice.list | cs,contextservice,data-source-manager,metadataQuery,metadatamanager,query,jobhistory,application,configuration,filesystem,udf,variable,microservice,errorcode,bml,datasource,basedata-manager | publicservice服务支持路由的模块 |
+
+![](./images/list-conf.png)
+
+### 2.11 Linkis 文件系统及物料存放路径
+Apache Linkis 开发时可通过此参数,自定义加载模块的路由;可以在`linkis.properties`进行修改,多个模块之间使用逗号分割。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.filesystem.root.path | file:///tmp/linkis/ | 本地用户目录,需在该目录下建立以用户名为名称的文件夹 |
+| wds.linkis.filesystem.hdfs.root.path | hdfs:///tmp/ | HDFS用户目录 |
+| wds.linkis.bml.is.hdfs | true | 是否启用hdfs |
+| wds.linkis.bml.hdfs.prefix | /apps-data | hdfs路径 |
+| wds.linkis.bml.local.prefix | /apps-data | 本地路径 |
+
+![](./images/fs-conf.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/glossary.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/glossary.md
new file mode 100644
index 00000000000..76ed35f4abc
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/glossary.md
@@ -0,0 +1,105 @@
+---
+title: 名词解释和服务介绍
+sidebar_position: 0.3
+---
+
+## 1.名词解释
+
+Linkis 基于微服务架构开发,其服务可以分为3类服务群(组):计算治理服务组、公共增强服务组和微服务治理服务组。
+- 计算治理服务组(Computation Governance Services):处理任务的核心服务,支持计算任务/请求处理流程的4个主要阶段(提交->准备->执行->结果);
+- 公共增强服务组(Public Enhancement Services):提供基础的支撑服务,包括上下文服务、引擎/udf物料的管理服务、历史任务等公共服务及数据源的管理服务等;
+- 微服务治理服务组(Microservice Governance Services):定制化的Spring Cloud Gateway、Eureka。提供微服务的基础底座
+
+下面将对这三组服务的关键名词和服务进行介绍:
+
+### 1.1 关键模块名词
+
+首先我们了解下关键模块的名词
+
+| 简称 | 全称 | 主要功能 |
+|-------- |------------------------- |---------------------|
+| MG/mg | Microservice Governance | 微服务治理 |
+| CG/cg | Computation Governance | 计算治理 |
+| EC/ec | EngineConn | 引擎连接器 |
+| - | Engine | 底层计算存储引擎,如spark、hive、shell |
+| ECM/ecm | EngineConnManager | 引擎连接器的管理 |
+| ECP/ecp | EngineConnPlugin | 引擎连接器插件 |
+| RM/rm | ResourceManager | 资源管理器,用于管控任务资源和用户资源使用和控制 |
+| AM/am | AppManager | 应用管理器,用于管控EngineConn和ECM服务 |
+| LM/lm | LinkisManager | Linkis管理器服务,包含了:RM、AM、LabelManager等模块 |
+| PES/pes | Public Enhancement Services | 公共增强服务 |
+| - | Orchestrator | 编排器,用于Linkis任务编排,任务多活、混算、AB等策略支持 |
+| UJES | Unified Job Execute Service | 统一作业执行服务 |
+| DDL/ddl | Data Definition Language | 数据库定义语言 |
+| DML/dml | Data Manipulation Language | 数据操纵语言 |
+
+### 1.2 任务关键名词
+
+- JobRequest: 任务请求,对应Client提交给Linkis的任务,包含任务的执行内容、用户、标签等信息
+- RuntimeMap: 任务运行时参数,任务的运行时参数,任务级别生效,如放置多数据源的数据源信息
+- StartupMap: 引擎连接器启动参数,用于EngineConn连机器启动的参数,EngineConn进程生效,如设置spark.executor.memory=4G
+- UserCreator: 任务创建者信息:包含用户信息User和Client提交的应用信息Creator,用于任务和资源的租户隔离
+- submitUser: 任务提交用户
+- executeUser: 任务真实执行用户
+- JobSource: 任务来源信息,记录任务的IP或者脚本地址
+- errorCode: 错误码,任务错误码信息
+- JobHistory: 任务历史持久化模块,提供任务的历史信息查询
+- ResultSet: 结果集,任务对应的结果集,默认以.dolphin文件后缀进行保存
+- JobInfo: 任务运行时信息,如日志、进度、资源信息等
+- Resource: 资源信息,每个任务都会消耗资源
+- RequestTask: EngineConn的最小执行单元,传输给EngineConn执行的任务单元
+
+
+
+## 2. 服务介绍
+
+本节主要对Linkis的服务进行介绍,了解Linkis启动后会有哪些服务,以及服务的作用。
+
+### 2.1 服务列表
+
+Linkis启动后各个服务群(组)下包括的微服务如下:
+
+| 归属的微服务群(组) | 服务名 | 主要功能 |
+| ---- | ---- | ---- |
+| MGS | linkis-mg-eureka | 负责服务注册与发现,上游其他组件也会复用linkis的注册中心,如dss|
+| MGS | linkis-mg-gateway | 作为Linkis的网关入口,主要承担了请求转发、用户访问认证 |
+| CGS | linkis-cg-entrance | 任务提交入口是用来负责计算任务的接收、调度、转发执行请求、生命周期管理的服务,并且能把计算结果、日志、进度返回给调用方 |
+| CGS | linkis-cg-linkismanager|提供了AppManager(应用管理)、ResourceManager(资源管理)、LabelManager(标签管理)、引擎连接器插件管理的能力 |
+| CGS | linkis-cg-engineconnmanager | EngineConn的管理器,提供引擎的生命周期管理 |
+| CGS | linkis-cg-engineconn| 引擎连接器服务,是与底层计算存储引擎(Hive/Spark)的实际连接的服务,包含了与实际引擎的会话信息。对于底层计算存储引擎来说 它充当了一个客户端的角色,由任务触发启动|
+| PES | linkis-ps-publicservice|公共增强服务组模块服务,为其他微服务模块提供统一配置管理、上下文服务、BML物料库、数据源管理、微服务管理和历史任务查询等功能 |
+
+启动后开源看到的所有服务如下图:
+![Linkis_Eureka](/Images/deployment/Linkis_combined_eureka.png)
+
+### 2.1 公共增强服务详解
+公共增强服务组(PES)在1.3.1版本后默认将相关模块服务合并为一个服务linkis-ps-publicservice提供相关功能,当然如果你希望分开部署也支持的。您只需要将对应模块的服务打包部署即可。
+合并后的公共增强服务,主要包含了以下功能:
+
+| 简称 | 全称 | 主要功能 |
+|-------- |------------------------- |---------------------|
+| CS/cs | Context Service | 上下文服务,用于任务间传递结果集、变量、文件等 |
+| UDF/udf | UDF | UDF管理模块,提供UDF和函数的管理功能,支持共享和版本控制 |
+| variable | Variable | 全局自定义模块,提供全局自定变量的管理功能 |
+| script | Script-dev | 脚本文件操作服务,提供脚本编辑保存、脚本目录管理功能 |
+| jobHistory | JobHistory | 任务历史持久化模块,提供任务的历史信息查询 |
+| BML/bml | BigData Material library | 大数据物料库 |
+| - | Configuration | 配置管理,提供配置参数的管理和查看的功能 |
+| - | instance-label | 微服务管理服务,提供微服务和路由标签的映射管理功能 |
+| - | error-code | 错误码管理,提供通过错误码管理的功能 |
+| DMS/dms | Data Source Manager Service | 数据源管理服务 |
+| MDS/mds | MetaData Manager Service | 元数据管理服务 |
+| - | linkis-metadata | 提供Hive元数据信息查看功能,后续将会合并到到MDS |
+| - | basedata-manager | 基础数据管理,用于管理Linkis自身的基础元数据信息 |
+
+## 3 模块介绍
+本节主要对Linkis的大模块和功能进行主要介绍
+
+- linkis-commons: linkis的公共模块,包含了公共的工具类模块、RPC模块、微服务基础等模块
+- linkis-computation-governance: 计算治理模块,包含了计算治理多个服务的模块:Entrance、LinkisManager、EngineConnManager、EngineConn等
+- linkis-engineconn-plugins: 引擎连接器插件模块,包含了所有的引擎连接器插件实现
+- linkis-extensions: Linkis的扩展增强模块,不是必要功能模块,现在主要包含了文件代理操作的IO模块
+- linkis-orchestrator: 编排模块,用于Linkis任务编排,任务多活、混算、AB等高级策略支持
+- linkis-public-enhancements: 公共增强模块,包含了所有的公共服务用于给到linkis内部和上层应用组件进行调用
+- linkis-spring-cloud-services: spring cloud相关的服务模块,包含了gateway、注册中心等
+- linkis-web: 前端模块
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/deverlop-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/deverlop-conf.png
new file mode 100644
index 00000000000..3d5fc8af601
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/deverlop-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/engine-debug.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/engine-debug.png
new file mode 100644
index 00000000000..788bd2b58f0
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/engine-debug.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/fs-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/fs-conf.png
new file mode 100644
index 00000000000..85c4234a9b4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/fs-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/hive-meta.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/hive-meta.png
new file mode 100644
index 00000000000..50c02906a77
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/hive-meta.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/ldap.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/ldap.png
new file mode 100644
index 00000000000..9625ae20be0
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/ldap.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/linkis-db.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/linkis-db.png
new file mode 100644
index 00000000000..35f7f5573df
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/linkis-db.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/list-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/list-conf.png
new file mode 100644
index 00000000000..d19c194a023
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/list-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/login-user.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/login-user.png
new file mode 100644
index 00000000000..477c634f1d4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/login-user.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/redis.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/redis.png
new file mode 100644
index 00000000000..3a064640613
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/redis.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/resource-enable.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/resource-enable.png
new file mode 100644
index 00000000000..973fcee8409
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/resource-enable.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/test-mode.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/test-mode.png
new file mode 100644
index 00000000000..3466b1b8857
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/images/test-mode.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/introduction.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/introduction.md
new file mode 100644
index 00000000000..d28a99ba891
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/about/introduction.md
@@ -0,0 +1,115 @@
+---
+title: 简述
+sidebar_position: 0
+---
+## 关于 Linkis
+
+Linkis 在上层应用程序和底层引擎之间构建了一层计算中间件。通过使用Linkis 提供的REST/WebSocket/JDBC 等标准接口,上层应用可以方便地连接访问MySQL/Spark/Hive/Presto/Flink 等底层引擎,同时实现统一变量、脚本、用户定义函数和资源文件等用户资源的跨上层应用互通,以及通过REST标准接口提供了数据源管理和数据源对应的元数据查询服务。
+作为计算中间件,Linkis 提供了强大的连通、复用、编排、扩展和治理管控能力。通过将应用层和引擎层解耦,简化了复杂的网络调用关系,降低了整体复杂度,同时节约了整体开发和维护成本。
+Linkis 自2019年开源发布以来,已累计积累了700多家试用企业和1000多位沙盒试验用户,涉及金融、电信、制造、互联网等多个行业。许多公司已经将Linkis 作为大数据平台底层计算存储引擎的统一入口,和计算请求/任务的治理管控利器。
+
+![没有Linkis 之前](/Images-zh/before_linkis_cn.png)
+
+![有了Linkis 之后](/Images-zh/after_linkis_cn.png)
+
+## 核心特点
+- **丰富的底层计算存储引擎支持**:Spark、Hive、Python、Shell、Flink、JDBC、Pipeline、Sqoop、OpenLooKeng、Presto、ElasticSearch、Trino、SeaTunnel 等;
+- **丰富的语言支持**:SparkSQL、HiveSQL、Python、Shell、Pyspark、Scala、JSON 和 Java 等;
+- **强大的计算治理能力**: 能够提供基于多级标签的任务路由、负载均衡、多租户、流量控制、资源控制等能力;
+- **全栈计算存储引擎架构支持**: 能够接收、执行和管理针对各种计算存储引擎的任务和请求,包括离线批量任务、交互式查询任务、实时流式任务和数据湖任务;
+- **统一上下文服务**:支持跨用户、系统、计算引擎去关联管理用户和系统的资源文件(JAR、ZIP、Properties 等),结果集、参数变量、函数、UDF等,一处设置,处处自动引用;
+- **统一物料**: 提供了系统和用户级物料管理,可分享和流转,跨用户、跨系统共享物料;
+- **统一数据源管理**: 提供了Hive、ElasticSearch、Mysql、Kafka、MongoDB 等类型数据源信息的增删查改、版本控制、连接测试和对应数据源的元数据信息查询能力;
+- **错误码能力**:提供了任务常见错误的错误码和解决方案,方便用户自助定位问题;
+
+## 支持的引擎类型
+| **引擎名** | **支持底层组件版本 (默认依赖版本)** | **Linkis 1.X 版本要求** | **是否默认包含在发布包中** | **说明** |
+|:---- |:---- |:---- |:---- |:---- |
+|Spark|Apache 2.0.0~2.4.7, CDH >= 5.4.0, (默认Apache Spark 2.4.3)|\>=1.0.0_rc1|是|Spark EngineConn, 支持SQL, Scala, Pyspark 和R 代码。|
+|Hive|Apache >= 1.0.0, CDH >= 5.4.0, (默认Apache Hive 2.3.3)|\>=1.0.0_rc1|是|Hive EngineConn, 支持HiveQL 代码。|
+|Python|Python >= 2.6, (默认Python2*)|\>=1.0.0_rc1|是|Python EngineConn, 支持python 代码。|
+|Shell|Bash >= 2.0|\>=1.0.0_rc1|是|Shell EngineConn, 支持Bash shell 代码。|
+|JDBC|MySQL >= 5.0, Hive >=1.2.1, (默认Hive-jdbc 2.3.4)|\>=1.0.0_rc1|否|JDBC EngineConn, 已支持Mysql,Oracle,KingBase,PostgreSQL,SqlServer,DB2,Greenplum,DM,Doris,ClickHouse,TiDB,Starrocks,GaussDB和OceanBase, 可快速扩展支持其他有JDBC Driver 包的引擎, 如SQLite|
+|Flink |Flink >= 1.12.2, (默认Apache Flink 1.12.2)|\>=1.0.2|否|Flink EngineConn, 支持FlinkSQL 代码,也支持以Flink Jar 形式启动一个新的Yarn 应用程序。|
+|Pipeline|-|\>=1.0.2|否|Pipeline EngineConn, 支持文件的导入和导出。|
+|openLooKeng|openLooKeng >= 1.5.0, (默认openLookEng 1.5.0)|\>=1.1.1|否|openLooKeng EngineConn, 支持用Sql查询数据虚拟化引擎openLooKeng。|
+|Sqoop| Sqoop >= 1.4.6, (默认Apache Sqoop 1.4.6)|\>=1.1.2|否|Sqoop EngineConn, 支持 数据迁移工具 Sqoop 引擎。|
+|Presto|Presto >= 0.180|\>=1.2.0|否|Presto EngineConn, 支持Presto SQL 代码。|
+|ElasticSearch|ElasticSearch >=6.0|\>=1.2.0|否|ElasticSearch EngineConn, 支持SQL 和DSL 代码。|
+|Trino | Trino >=371 | >=1.3.1 | 否 | Trino EngineConn, 支持Trino SQL 代码 |
+|Seatunnel | Seatunnel >=2.1.2 | >=1.3.1 | 否 | Seatunnel EngineConn, 支持Seatunnel SQL 代码 |
+
+
+
+## 下载
+请前往[Linkis releases 页面](https://linkis.apache.org/zh-CN/download/main) 下载Linkis 已编译的部署安装包或源码包。
+
+## 安装部署
+
+请参考[编译指南](../development/build.md)来编译Linkis源代码。
+请参考[安装部署文档](../deployment/deploy-quick.md) 来部署Linkis 。
+
+## 示例和使用指引
+- [各引擎使用指引](../engine-usage/overview.md)
+- [API 文档](../api/overview.md)
+
+## 文档
+完整的Linkis文档代码存放在[linkis-website仓库中](https://github.com/apache/linkis-website)
+
+## 架构概要
+Linkis 基于微服务架构开发,其服务可以分为3类:计算治理服务、公共增强服务和微服务治理服务。
+- 计算治理服务,支持计算任务/请求处理流程的3个主要阶段:提交->准备->执行。
+- 公共增强服务,包括上下文服务、物料管理服务及数据源服务等。
+- 微服务治理服务,包括定制化的Spring Cloud Gateway、Eureka、Open Feign。
+
+下面是Linkis的架构概要图,更多详细架构文档请见 [Linkis/Architecture](../architecture/overview.md)。
+![architecture](/Images/Linkis_1.0_architecture.png)
+
+基于Linkis 计算中间件,我们在大数据平台套件[WeDataSphere](https://github.com/WeBankFinTech/WeDataSphere) 中构建了许多应用和工具系统,下面是目前可用的开源项目。
+
+![wedatasphere_stack_Linkis](/Images/wedatasphere_stack_Linkis.png)
+
+- [**DataSphere Studio** - 数据应用集成开发框架](https://github.com/WeBankFinTech/DataSphereStudio)
+
+- [**Scriptis** - 数据研发IDE工具](https://github.com/WeBankFinTech/Scriptis)
+
+- [**Visualis** - 数据可视化工具](https://github.com/WeBankFinTech/Visualis)
+
+- [**Schedulis** - 工作流调度工具](https://github.com/WeBankFinTech/Schedulis)
+
+- [**Qualitis** - 数据质量工具](https://github.com/WeBankFinTech/Qualitis)
+
+- [**MLLabis** - 容器化机器学习notebook 开发环境](https://github.com/WeBankFinTech/prophecis)
+
+更多项目开源准备中,敬请期待。
+
+## 贡献
+我们非常欢迎和期待更多的贡献者参与共建Linkis, 不论是代码、文档或是其他能够帮助到社区的贡献形式。
+
+代码和文档相关的贡献请参照[贡献指引](/community/how-to-contribute)。
+
+
+## 联系我们
+
+**方式1 邮件列表**
+
+|名称|描述|订阅|取消订阅|存档|
+|:-----|:--------|:-----|:------|:-----|
+| [dev@linkis.apache.org](mailto:dev@linkis.apache.org) | 社区活动信息 | [订阅](mailto:dev-subscribe@linkis.apache.org) | [取消订阅](mailto:dev-unsubscribe@linkis.apache.org) | [存档](http://mail-archives.apache.org/mod_mbox/linkis-dev) |
+
+**方式2 Issue**
+
+通过github提交[issue](https://github.com/apache/linkis/issues/new/choose),以便跟踪处理和经验沉淀共享
+
+**方式2 微信助手**
+
+|微信小助手|微信公众号|
+|:---|---|
+| | |
+
+
+Meetup 视频 [Bilibili](https://space.bilibili.com/598542776?from=search&seid=14344213924133040656)。
+
+## 谁在使用 Linkis
+我们创建了[一个 issue](https://github.com/apache/linkis/issues/23) 以便用户反馈和记录谁在使用Linkis。
+Linkis 自2019年开源发布以来,累计已有700多家试验企业和1000+沙盒试验用户,涉及金融、电信、制造、互联网等多个行业。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/_category_.json
new file mode 100644
index 00000000000..02d23f945ae
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "API 文档",
+ "position": 7
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/_category_.json
new file mode 100644
index 00000000000..803138a2024
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "Http API",
+ "position": 6
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-engineplugin-api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-engineplugin-api/_category_.json
new file mode 100644
index 00000000000..8f625f20e9e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-engineplugin-api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "引擎插件管理服务",
+ "position": 4
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-engineplugin-api/engine-plugin-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-engineplugin-api/engine-plugin-api.md
new file mode 100644
index 00000000000..1c83e70e2a6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-engineplugin-api/engine-plugin-api.md
@@ -0,0 +1,576 @@
+---
+title: 引擎插件API
+sidebar_position: 3
+---
+
+** EnginePluginRestful 类 **
+
+## 刷新
+
+
+**接口地址**:`/api/rest_j/v1/engineplugin/refresh`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:刷新单个资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|ecType|类型|query|false|string|
+|version|版本|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 刷新所有
+
+
+**接口地址**:`/api/rest_j/v1/engineplugin/refreshAll`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:刷新所有ec resource
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 回滚
+
+**接口地址**:`/api/rest_j/v1/engineplugin/rollBack`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+回滚当前引擎插件的物料版本
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| --------------------- | ------------------------- | -------- | -------- | --------------------- | ------ |
+| engineConnBmlResource | EngineConnBmlResource实体 | body | true | EngineConnBmlResource | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+## 获取引擎在物料中的所有版本
+
+**接口地址**:/api/rest_j/v1/engineplugin/getVersionList
+
+**请求方式**:GET
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+获取引擎插件在物料管理系统中的所有版本
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| ------------- | ---------------- | -------- | -------- | --------------------- | ------ |
+| bmlResourceId | 引擎的物料资源id | body | true | EngineConnBmlResource | |
+| ecType | 引擎名称 | body | false | String | |
+| version | 引擎版本 | body | false | String | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+
+
+## 获取所有引擎名称
+
+**接口地址**:/api/rest_j/v1/engineplugin/getTypeList
+
+**请求方式**:GET
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+获取所有类型的引擎名称
+
+**请求参数**
+
+
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "typeList": [
+ "hive",
+ "io_file",
+ "jdbc",
+ "openlookeng",
+ "python",
+ "shell",
+ "spark"
+ ]
+ }
+}
+```
+
+
+
+## 获取引擎的所有版本
+
+**接口地址**:/api/rest_j/v1/engineplugin/getTypeVersionList/{type}
+
+**请求方式**:GET
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+获取所有类型的引擎名称
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------------- | -------- | -------- | -------- | ------ |
+| type | 引擎的类型名称 | path | true | String | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "queryList": [
+ "v4"
+ ]
+ }
+}
+```
+
+
+
+## 更新引擎插件
+
+**接口地址**:/api/rest_j/v1/engineplugin/updateEnginePluginBML
+
+**请求方式**:POST
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+更新指定引擎插件
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | ------------ | -------- | -------- | ------------- | ------ |
+| file | 引擎物料文件 | body | true | MultipartFile | |
+| ecType | 引擎类型名称 | body | true | String | |
+| version | 引擎版本 | body | true | String | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "mes": "upload file success"
+ }
+}
+```
+
+
+
+## 引擎插件
+
+**接口地址**:/api/rest_j/v1/engineplugin/list
+
+**请求方式**:GET
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+请求所有引擎插件信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| ----------- | ------------ | -------- | -------- | -------------- | ------ |
+| currentPage | 当前页面 | qurey | true | integer(int32) | |
+| ecType | 引擎类型名称 | qurey | false | String | |
+| version | 引擎版本 | qurey | false | String | |
+| pageSize | 页面大小 | qurey | true | integer(int32) | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "totalPage": 17,
+ "queryList": [
+ {
+ "id": 239,
+ "engineConnType": "python",
+ "version": "python2",
+ "fileName": "lib.zip",
+ "lastModified": 1661950452000,
+ "fileSize": 6093507,
+ "bmlResourceId": "8edb8e88-fc75-4ce3-a330-3ece9ec533cb",
+ "bmlResourceVersion": "v000001",
+ "createTime": "2022-08-31 20:56:59",
+ "lastUpdateTime": "2022-08-31 20:56:59"
+ },
+ {
+ "id": 238,
+ "engineConnType": "python",
+ "version": "python2",
+ "fileName": "conf.zip",
+ "lastModified": 1661950450000,
+ "fileSize": 43841,
+ "bmlResourceId": "a46beb9b-7368-4900-a2a6-241f1ec49002",
+ "bmlResourceVersion": "v000001",
+ "createTime": "2022-08-31 20:56:54",
+ "lastUpdateTime": "2022-08-31 20:56:54"
+ }
+ ]
+ }
+}
+```
+
+
+
+## 新增引擎插件
+
+**接口地址**:/api/rest_j/v1/engineplugin/uploadEnginePluginBML
+
+**请求方式**:POST
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+上传新增一个引擎插件
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | ------------------ | -------- | -------- | ------------- | ------ |
+| file | 引擎物料文件压缩包 | body | true | MultipartFile | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "mes": "upload file success"
+ }
+}
+```
+
+
+
+## 删除引擎插件
+
+**接口地址**:/api/rest_j/v1/engineplugin/deleteEnginePluginBML
+
+**请求方式**:GET
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:
+
+删除指定引擎插件
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | ------------ | -------- | -------- | -------- | ------ |
+| ecType | 引擎类型名称 | qurey | true | String | |
+| version | 引擎版本 | qurey | false | String | |
+
+**响应状态**:
+
+| 状态码 | 说明 | schema |
+| ------ | ------------ | ------- |
+| 200 | OK | Message |
+| 401 | Unauthorized | |
+| 403 | Forbidden | |
+| 404 | Not Found | |
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | -------------- | -------------- |
+| data | 数据集 | object | |
+| message | 描述 | string | |
+| method | 请求url | string | |
+| status | 状态 | integer(int32) | integer(int32) |
+
+**响应示例**:
+
+```
+{"method":null,"status":0,"message":"OK","data":{"msg":"delete successfully"}}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-engineplugin-api/engineconn-plugin-refresh.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-engineplugin-api/engineconn-plugin-refresh.md
new file mode 100644
index 00000000000..ad77d066d23
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-engineplugin-api/engineconn-plugin-refresh.md
@@ -0,0 +1,108 @@
+---
+title: 引擎物料刷新API
+sidebar_position: 2
+---
+>主要用于引擎的物料资源({LINKIS_INSTALL_HOME}/lib/linkis-engineconn-plugin 下,引擎的jar包/配置文件 )更新至BML中。
+
+## refresh
+
+**接口地址**:`/api/rest_j/v1/engineplugin/refresh`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新指定引擎的物料资源
+
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|ecType|引擎类型|query|true|string||
+|version|版本 可以为空或则*|query|false|string||
+
+**请求示例**:
+```
+#url
+http://ip:port/api/rest_j/v1/engineplugin/refresh?ecType=hive&version=2.3.3
+
+#请求头部
+Content-Type:application/json
+Token-Code:BML-AUTH
+Token-User:hadoop
+```
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data||object||
+|message||string||
+|method||string||
+|status||integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "msg": "Refresh successfully"
+ }
+}
+```
+
+
+## refreshAll
+
+
+**接口地址**:`/api/rest_j/v1/engineplugin/refreshAll`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新所有引擎的物料资源
+
+
+**请求参数**:
+无
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data||object||
+|message||string||
+|method||string||
+|status||integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "msg": "Refresh successfully"
+ }
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-entrance-api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-entrance-api/_category_.json
new file mode 100644
index 00000000000..2efa3b26626
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-entrance-api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "Entrnace 服务",
+ "position": 5
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-entrance-api/task-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-entrance-api/task-management-api.md
new file mode 100644
index 00000000000..acb362e570d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-entrance-api/task-management-api.md
@@ -0,0 +1,129 @@
+---
+title: 任务管理
+sidebar_position: 2
+---
+** EntranceMetricRestfulApi 类 **
+
+
+# 任务管理
+
+
+## 启动任务
+
+
+**接口地址**:`/api/rest_j/v1/entrance/api/metrics/runningtask`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:启动任务
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 任务信息
+
+
+**接口地址**:`/api/rest_j/v1/entrance/api/metrics/taskinfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:任务信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|创建者|query|false|string|
+|engineTypeLabel|引擎类型标签|query|false|string|
+|user|user|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-entrance-api/task-operation-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-entrance-api/task-operation-api.md
new file mode 100644
index 00000000000..11064238525
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-entrance-api/task-operation-api.md
@@ -0,0 +1,569 @@
+---
+title: 任务操作
+sidebar_position: 1
+---
+** EntranceRestfulApi 类 **
+
+
+## 处理任务请求
+
+
+**接口地址**:`/api/rest_j/v1/entrance/execute`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:execute函数处理的是用户提交执行任务的请求
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|json|json|body|true|object|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 提交execute函数
+
+
+**接口地址**:`/api/rest_j/v1/entrance/submit`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:提交execute函数
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|Submit|json|body|true|Submit|Submit|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 结束任务
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/kill`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:kill任务
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|ID|path|false|string|
+|taskID|任务ID|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 结束Jobs
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/killJobs`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:结束Jobs
+
+**请求示例**:
+```javascript
+{
+ "taskIDList": [],
+ "idList": []
+}
+```
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|id请求路径生成|path|true|string|
+|taskIDList|任务ID集合|false|String|String|
+|idList|ID集合|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/entrance/#id/killJobs",
+ "status": 0,
+ "message": "success",
+ "data": {
+ "messages": [{
+ "method": "",
+ "status": 0,
+ "message": "",
+ "data": {
+ "execID": ""
+ }
+ }]
+ }
+}
+```
+
+
+## 任务日志
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/log`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取任务日志
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|任务ID|path|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 暂停任务
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/pause`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:暂停任务
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|任务ID|path|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 任务进展
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/progress`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:任务进展
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|任务ID|path|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 资源进展
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/progressWithResource`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:资源进展
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|ID|path|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 任务状态
+
+
+**接口地址**:`/api/rest_j/v1/entrance/{id}/status`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:任务状态
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|ID|path|false|string|
+|taskID|任务ID|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/_category_.json
new file mode 100644
index 00000000000..ad07bddc12e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "LinkisManager 服务",
+ "position": 2
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/ec-resource-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/ec-resource-management-api.md
new file mode 100644
index 00000000000..c10e93d3f03
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/ec-resource-management-api.md
@@ -0,0 +1,291 @@
+---
+title: EC资源信息管理
+sidebar_position: 4
+---
+** ECResourceInfoRestfulApi 类 **
+
+
+
+
+## 删除EC信息
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/ecinfo/delete/{ticketid}}`
+
+
+**请求方式**:`DELETE`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:删除EC信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|ticketid|ticketid|path|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|204|No Content|
+|401|Unauthorized|
+|403|Forbidden|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取EC信息
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/ecinfo/get`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:获取EC信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|ticketid|ticketid|query|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+## 搜索历史EC信息
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/ecinfo/ecrHistoryList`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:获取EC信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|instance|instance|query|false|string|
+|creator|creator|query|false|string|
+|startDate|startDate|query|false|string|
+|endDate|endDate|query|false|string|
+|engineType|engineType|query|false|string|
+|pageNow|pageNow|query|false|Int|
+|pageSize|pageSize|query|false|Int|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ {
+ "message": "",
+ "status": 0,
+ "data": {
+ "engineList": [
+ {
+ "id": -94209540.07806732,
+ "requestResource": "consectetur dolor eiusmod ipsum",
+ "releasedResource": "est in id Ut",
+ "usedTimes": -51038117.02855969,
+ "ticketId": "adipisicing in nostrud do",
+ "ecmInstance": "id magna Lorem eiusmod",
+ "engineType": "dolor",
+ "usedTime": -38764910.74278392,
+ "logDirSuffix": "sunt eiusmod aute et",
+ "releaseTime": -33417043.232267484,
+ "usedResource": "in amet veniam velit",
+ "requestTimes": -15643696.319572791,
+ "labelValue": "veniam incididunt magna",
+ "releaseTimes": 96384811.3484546,
+ "createTime": 38434279.49900183,
+ "serviceInstance": "consequat aliqua in enim",
+ "createUser": "Lorem Ut occaecat amet"
+ },
+ {
+ "labelValue": "adipisicing deserunt do",
+ "usedTimes": 49828407.223826766,
+ "usedResource": "mollit laboris cupidatat enim",
+ "releaseTimes": -73400915.22672182,
+ "releasedResource": "est qui id ipsum mollit",
+ "requestResource": "deserunt reprehenderit ut",
+ "serviceInstance": "do laborum",
+ "requestTimes": -33074164.700212136,
+ "ecmInstance": "dolore",
+ "logDirSuffix": "ea incididunt",
+ "createUser": "Ut exercitation officia dolore ipsum",
+ "usedTime": 25412456.522457644,
+ "createTime": -93227549.70578489,
+ "id": -84032815.0589972,
+ "ticketId": "eu in mollit do",
+ "engineType": "non Ut eu",
+ "releaseTime": 34923394.9602966
+ },
+ {
+ "releaseTime": -91057731.93164417,
+ "usedTime": 99226623.97199354,
+ "id": 59680041.603043556,
+ "requestResource": "officia Ut enim nulla",
+ "usedTimes": -14680356.219609797,
+ "logDirSuffix": "proident amet reprehenderit tempor",
+ "ticketId": "minim esse",
+ "releaseTimes": 37270921.94107443,
+ "serviceInstance": "enim adipisicing cupidatat",
+ "createUser": "culpa",
+ "requestTimes": -33504917.797325186,
+ "releasedResource": "et dolore quis",
+ "ecmInstance": "elit dolor adipisicing id",
+ "createTime": -38827280.78902944,
+ "engineType": "ullamco in eiusmod reprehenderit aute",
+ "labelValue": "dolore qui labore nulla laboris",
+ "usedResource": "irure sint nostrud Excepteur sunt"
+ },
+ {
+ "requestResource": "deserunt incididunt enim",
+ "releaseTimes": -16708903.732444778,
+ "id": 80588551.12419662,
+ "ecmInstance": "et veniam",
+ "releaseTime": -50240956.63233949,
+ "usedTimes": -5348294.728038415,
+ "labelValue": "incididunt tempor reprehenderit quis eu",
+ "createUser": "in in",
+ "serviceInstance": "minim sit",
+ "ticketId": "in dolore",
+ "usedTime": -30138563.761232898,
+ "logDirSuffix": "quis laborum ea",
+ "createTime": 65920455.93896958,
+ "requestTimes": 38810152.0160971,
+ "engineType": "est in Ut proident",
+ "usedResource": "nulla laboris Ut",
+ "releasedResource": "cupidatat irure"
+ },
+ {
+ "usedResource": "Lorem adipisicing dolor",
+ "createTime": -11906770.11266476,
+ "labelValue": "et id magna",
+ "releaseTimes": 32546901.20497243,
+ "id": -90442428.4679744,
+ "logDirSuffix": "aute ut eu commodo",
+ "ticketId": "cillum sint non deserunt",
+ "requestResource": "non velit sunt consequat culpa",
+ "requestTimes": -75282512.0022062,
+ "usedTime": 6378131.554130778,
+ "releasedResource": "Duis in",
+ "serviceInstance": "dolore ut officia",
+ "usedTimes": 70810503.51038182,
+ "createUser": "voluptate sed",
+ "ecmInstance": "laboris do sit dolore ipsum",
+ "engineType": "id",
+ "releaseTime": 37544575.30154848
+ }
+ ]
+ }
+ }
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/ecm-resource-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/ecm-resource-management-api.md
new file mode 100644
index 00000000000..0acd06d3b4f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/ecm-resource-management-api.md
@@ -0,0 +1,462 @@
+---
+title: ECM资源管理
+sidebar_position: 3
+---
+** EMRestfulApi 类 **
+
+
+
+## 执行ECM操作
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/executeECMOperation`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 执行ECM操作开始
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/executeECMOperationByEC`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## ECM管理中状态列表
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/listAllECMHealthyStatus`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:获取状态列表清单
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|onlyEditable|是否仅可编辑|query|false|boolean|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/listAllECMHealthyStatus",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "nodeHealthy": []
+ }
+}
+```
+
+
+## ECM资源清单
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/listAllEMs`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:获取所有ECM资源详细清单列表可根据条件查询,默认查询所有
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|instance|实例名称|query|false|string|
+|nodeHealthy|状态,状态有以下枚举类型 ‘Healthy‘, ‘UnHealthy‘, ‘WARN‘, ’StockAvailable’, ‘StockUnavailable’|query|false|string|
+|owner|创建者|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/listAllEMs",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "EMs": [{
+ "labels": [{
+ "stringValue": "",
+ "labelKey": "",
+ "feature": "",
+ "instance": "",
+ "serviceInstance": {
+ "instance": "",
+ "applicationName": ""
+ },
+ "serviceName": "",
+ "featureKey": "",
+ "empty":
+ }],
+ "applicationName": "",
+ "instance": ":",
+ "resourceType": "",
+ "maxResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "minResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "usedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "lockedResource": {
+ "memory": 0,
+ "cores": 0,
+ "instance": 0
+ },
+ "expectedResource": {
+ "memory": 0,
+ "cores": 0,
+ "instance": 0
+ },
+ "leftResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "owner": "",
+ "runningTasks": null,
+ "pendingTasks": null,
+ "succeedTasks": null,
+ "failedTasks": null,
+ "maxMemory": ,
+ "usedMemory": ,
+ "systemCPUUsed": null,
+ "systemLeftMemory": ,
+ "nodeHealthy": "",
+ "msg": "",
+ "startTime":
+ }]
+ }
+}
+```
+
+
+## 编辑EMC实例
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/modifyEMInfo`
+
+
+**请求方式**:`PUT`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:编辑或修改下编辑EMC管理下的实例
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|引擎标签|false|String|String|
+|emStatus|实例状态,状态有以下枚举类型 ‘Healthy‘, ‘UnHealthy‘, ‘WARN‘, ’StockAvailable’, ‘StockUnavailable’|false|String|String|
+|instance|引擎实例名称|false|String|String|
+|labelKey|添加内容里面的标签,属于labels集合 内 map里的key|false|String|String|
+|labels|引擎实例更新参数内容,集合存放的是map类型的|false|List|List|
+|stringValue|添加内容里面的标签对于的值,属于labels集合 内 map里的value|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/modifyEMInfo",
+ "status": 0,
+ "message": "success",
+ "data": {}
+}
+```
+
+
+## 打开引擎日志
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/openEngineLog`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:打开引擎日志,默认打开stdout类型的引擎日志
+
+**请求示例**:
+```javascript
+{
+ applicationName: ""
+ emInstance: ""
+ instance: ""
+ parameters: {
+ pageSize: ,
+ fromLine: ,
+ logType: ""
+ }
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|引擎标签|String|false|String|
+|emInstance|实例名称|String|false|String|
+|fromLine|来自线路|String|false|String|
+|instance|引擎实例名称|String|false|String|
+|logType|日志类型,默认stdout类型,属于parameters|String|false|String|
+|pageSize|页面大小|String|false|String|
+|parameters|分页信息|Map|false|Map|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/openEngineLog",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "result": {
+ "logPath": "",
+ "logs": [""],
+ "endLine": ,
+ "rows":
+ },
+ "isError": false,
+ "errorMsg": ""
+ }
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/engine-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/engine-management-api.md
new file mode 100644
index 00000000000..405cebd174f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/engine-management-api.md
@@ -0,0 +1,585 @@
+---
+title: 引擎管理
+sidebar_position: 2
+---
+** EngineRestfulApi 类 **
+
+
+
+
+## 创建引擎连接
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/createEngineConn`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:创建引擎连接
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 执行引擎连接操作
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/executeEngineConnOperation`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:执行引擎连接操作
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取引擎连接
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/getEngineConn`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:获取引擎连接
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## kill引擎连接
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/killEngineConn`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:kill引擎连接
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 所有节点状态
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/listAllNodeHealthyStatus`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:所有节点状态
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|onlyEditable|onlyEditable|query|false|boolean|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/listAllNodeHealthyStatus",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "nodeStatus": []
+ }
+}
+```
+
+
+## 列表引擎
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/listEMEngines`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:列表引擎
+
+**请求示例**:
+```javascript
+{
+ em: {
+ serviceInstance: {
+ applicationName: "linkis-cg-engineconnmanager",
+ instance: "localhost110003:9102"
+ }
+ }
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|引擎标签名称,属于serviceInstance中的值|String|false|String|
+|em|入参最外层|Map|false|Map|
+|emInstance|引擎实例名称跟‘em’一个级别属于最外层|String|false|String|
+|engineType|引擎类型跟‘em’一个级别属于最外层|String|false|String|
+|instance|实例名称|String|false|String|
+|nodeStatus|状态跟‘em’一个级别属于最外层,状态有以下枚举类型 ‘Healthy‘, ‘UnHealthy‘, ‘WARN‘, ’StockAvailable’, ‘StockUnavailable’|String|false|String|
+|owner|创建者跟‘em’一个级别属于最外层|String|false|String|
+|serviceInstance|入参属于‘’em|Map|false|Map|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/linkisManager/listEMEngines",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "engines": []
+ }
+}
+```
+
+
+## 引擎用户集合
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/listUserEngines`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:引擎用户集合
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 编辑引擎实例
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/modifyEngineInfo`
+
+
+**请求方式**:`PUT`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:编辑引擎实例内容
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|引擎标签|false|String|String|
+|emStatus|运行状态|false|String|String|
+|instance|引擎实例名称|false|String|String|
+|labelKey|添加内容里面的标签,属于labels集合 内 map里的key|false|String|String|
+|labels|引擎实例更新参数内容,集合存放的是map类型的|false|List|List|
+|stringValue|添加内容里面的标签对于的值,属于labels集合 内 map里的value|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## kill引擎
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/enginekill`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`application/json`
+
+
+**接口描述**:关闭引擎,可关闭一个也可关闭多个
+
+
+**请求示例**:
+```javascript
+ [
+ {
+ engineInstance: "",
+ applicationName:""
+ }
+ ]
+
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|应用名称,最外层是个数组和engineInstance参数是一个级别|false|String|String|
+|engineInstance|引擎实例名称,最外层是个数组和applicationName参数是一个级别|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/resource-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/resource-management-api.md
new file mode 100644
index 00000000000..660b769e06f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-cg-linkismanager-api/resource-management-api.md
@@ -0,0 +1,612 @@
+---
+title: 资源管理
+sidebar_position: 1
+---
+** RMMonitorRest 类 **
+
+
+
+
+## 所有用户资源
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/allUserResource`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:所有用户资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|creator|query|false|string|
+|engineType|engineType|query|false|string|
+|page|page|query|false|integer(int32)|
+|size|size|query|false|integer(int32)|
+|username|username|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "total": 34,
+ "resources": [{
+ "id": ,
+ "username": "",
+ "creator": "",
+ "engineTypeWithVersion": "",
+ "resourceType": "",
+ "maxResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "minResource": {
+ "memory": ,
+ "cores":
+ "instance": 0
+ },
+ "usedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "lockedResource": {
+ "memory": 0,
+ "cores": 0,
+ "instance": 0
+ },
+ "expectedResource": null,
+ "leftResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "createTime": ,
+ "updateTime": ,
+ "loadResourceStatus": "",
+ "queueResourceStatus":
+ }]
+ }
+}
+```
+
+
+## 应用列表
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/applicationlist`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取资源管理中的应用引擎列表清单
+
+**请求示例**:
+```javascript
+{
+ userCreator: ""
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|userCreator|userCreator|query|true|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": ,
+ "status": ,
+ "message": "",
+ "data": {
+ "applications": [{
+ "creator": "",
+ "applicationList": {
+ "usedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "maxResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "lockedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "minResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "engineInstances": [{
+ "resource": {
+ "resourceType": "",
+ "maxResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "minResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "usedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "lockedResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ },
+ "expectedResource": null,
+ "leftResource": {
+ "memory": ,
+ "cores": ,
+ "instance":
+ }
+ },
+ "engineType": "",
+ "owner": "",
+ "instance": "",
+ "creator": "",
+ "startTime": "",
+ "status": "",
+ "label": ""
+ }]
+ }
+ }]
+ }
+}
+```
+
+
+## 引擎类型
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/engineType`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:引擎类型
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 引擎管理器
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/engines`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:引擎管理器
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|param|param|body|false|object|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 队列管理器
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/queueresources`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:队列管理器
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|param|param|body|true|object|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 队列
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/queues`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:队列
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|param|param|body|false|object|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 重置资源
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/resetResource`
+
+
+**请求方式**:`DELETE`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:重置资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|resourceId|query|false|integer(int32)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|204|No Content|
+|401|Unauthorized|
+|403|Forbidden|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 资源信息
+
+
+**接口地址**:`/api/rest_j/v1/linkisManager/rm/userresources`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:查询资源列表清单及资源详细数据如使用百分比
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|param|param|body|false|object|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "userResources": [{
+ "userCreator": "",
+ "engineTypes": [{
+ "engineType": "",
+ "percent": ""
+ }],
+ "percent": ""
+ }]
+ }
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/_category_.json
new file mode 100644
index 00000000000..59702fc1d1a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "上下文服务",
+ "position": 3
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-history-service-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-history-service-api.md
new file mode 100644
index 00000000000..2abed90e746
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-history-service-api.md
@@ -0,0 +1,317 @@
+---
+title: 上下文历史记录服务
+sidebar_position: 14
+---
+** ContextHistoryRestfulApi 类 **
+
+
+
+## 创建历史记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/createHistory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:创建历史记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextHistory|历史上下文|false|String|String|
+|contextID|上下文id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取多个历史记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/getHistories`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取多个历史记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|String|false|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取历史记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/getHistory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取历史记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文Id|false|String|String|
+|source|上下文源|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除历史记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeHistory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除历史记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextHistory|历史上下文|false|String|String|
+|contextID|上下文id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 搜索历史记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/searchHistory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:搜索历史记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文Id|false|String|String|
+|keywords|关键词|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-listening-service-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-listening-service-api.md
new file mode 100644
index 00000000000..aa8cd645fe1
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-listening-service-api.md
@@ -0,0 +1,189 @@
+---
+title: 上下文监听服务
+sidebar_position: 16
+---
+** ContextListenerRestfulApi 类 **
+
+
+# 上下文监听服务
+
+
+## heartbeat
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/heartbeat`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## onBindIDListener
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/onBindIDListener`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## onBindKeyListener
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/onBindKeyListener`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-logging-service-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-logging-service-api.md
new file mode 100644
index 00000000000..ef207bc1cfd
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-logging-service-api.md
@@ -0,0 +1,380 @@
+---
+title: 上下文记录服务
+sidebar_position: 17
+---
+** ContextIDRestfulApi 类 **
+
+
+## 创建文本记录
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/createContextID`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:创建文本记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文Id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取文本ID
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/getContextID`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取文本ID
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextId|上下文Id|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除文本ID
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeContextID`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除文本ID
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextId|上下文Id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 重置文本ID
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/resetContextID`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:重置文本ID
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextId|上下文Id|String|false|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 搜索文本Id执行时间
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/searchContextIDByTime`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:搜索文本Id执行时间
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|accessTimeEnd|访问结束时间|query|false|string|
+|accessTimeStart|访问开始时间|query|false|string|
+|createTimeEnd|创建结束时间|query|false|string|
+|createTimeStart|创建时间|query|false|string|
+|pageNow|页码|query|false|string|
+|pageSize|页面大小|query|false|string|
+|updateTimeEnd|更新结束时间|query|false|string|
+|updateTimeStart|更新时间|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 修改文本ID
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/updateContextID`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:修改文本ID
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextId|上下文Id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-service-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-service-api.md
new file mode 100644
index 00000000000..9ee466ecaef
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-cs-api/context-service-api.md
@@ -0,0 +1,692 @@
+---
+title: 上下文API
+sidebar_position: 15
+---
+** ContextRestfulApi 类 **
+
+
+
+## 通过ID清除所以上下文
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/clearAllContextByID`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:通过ID清除所以上下文
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|idList|上下文id集合|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 通过时间清除所以上下文
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/clearAllContextByTime`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:通过时间清除所以上下文
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|accessTimeEnd|访问时间结束|false|String|String|
+|accessTimeStart|访问时间开始|false|String|String|
+|createTimeEnd|创建时间结束|false|String|String|
+|createTimeStart|创建时间|false|String|String|
+|updateTimeStart|更新开始时间|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取上下文内容
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/getContextValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取上下文内容
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKey|contextKey|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除所有value
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeAllValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除所有value
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKey|contextKey|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 通过value前缀删除所有值
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeAllValueByKeyPrefix`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:通过前缀和上下文类型删除所有值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|contextID|false|String|String|
+|keyPrefix|keyPrefix|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 通过key前缀和上下文类型删除所有值
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeAllValueByKeyPrefixAndContextType`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:通过前缀和上下文类型删除所有值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextKeyType|contextKeyType|false|String|String|
+|keyPrefix|keyPrefix|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除value
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/removeValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除value
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKey|contextKey|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 重置value
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/resetValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:重置value
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKey|contextKey|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 搜索上下文内容
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/searchContextValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:搜索上下文内容
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|condition|condition|false|String|String|
+|contextID|上下文id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 设置value
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/setValue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:设置value
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKeyValue|contextKeyValue|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 设置key
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/setValueByKey`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:给value设置key
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|contextID|上下文id|false|String|String|
+|contextKey|contextKey|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/_category_.json
new file mode 100644
index 00000000000..f6d702cc1dc
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "公共服务",
+ "position": 1
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/bm-operation-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/bm-operation-management-api.md
new file mode 100644
index 00000000000..7e2ec8ce12d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/bm-operation-management-api.md
@@ -0,0 +1,449 @@
+---
+title: BM项目操作管理
+sidebar_position: 15
+---
+** BmlProjectRestful 类 **
+
+
+
+
+## 附件资源项目
+
+
+**接口地址**:`/api/rest_j/v1/bml/attachResourceAndProject`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:附件资源项目
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|projectName|项目名称|false|String|String|
+|resourceId|资源名称|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 创建Bml项目
+
+
+**接口地址**:`/api/rest_j/v1/bml/createBmlProject`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:创建Bml项目
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+|accessUsers|访问用户|false|String|String|
+|editUsers|编辑用户|false|String|String|
+|projectName|项目名称|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 下载共享资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/downloadShareResource`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:下载共享资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源ID|query|false|string|
+|version|版本|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 项目信息
+
+
+**接口地址**:`/api/rest_j/v1/bml/getProjectInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取项目信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|projectName|项目名称|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 更新项目用户
+
+
+**接口地址**:`/api/rest_j/v1/bml/updateProjectUsers`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新项目用户
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|jsonNode|jsonNode|body|true|JsonNode|JsonNode|
+|accessUsers|访问用户|false|String|String|
+|editUsers|编辑用户|false|String|String|
+|projectName|项目名称|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 更新共享资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/updateShareResource`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`multipart/form-data`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新共享资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|file|文件|formData|false|ref|
+|resourceId|资源ID|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 上载共享资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/uploadShareResource`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:上载共享资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|expireTime|失效时间|query|false|string|
+|expireType|失效类型|query|false|string|
+|file|文件集合|formData|false|ref|
+|isExpire|是否失效|query|false|string|
+|maxVersion|mav版本|query|false|ref|
+|projectName|项目名称|query|false|string|
+|resourceHeader|资源标头|query|false|string|
+|system|系统|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/bml-resource-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/bml-resource-management-api.md
new file mode 100644
index 00000000000..7e857c0253b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/bml-resource-management-api.md
@@ -0,0 +1,812 @@
+---
+title: BML资源管理
+sidebar_position: 14
+---
+** BmlRestfulApi 类 **
+
+
+
+## 更新owner
+
+
+**接口地址**:`/api/rest_j/v1/bml/changeOwner`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新owner
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|newOwner|旧Owner|false|String|String|
+|oldOwner|新Owner|false|String|String|
+|resourceId|资源Id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 复制资源到其他用户
+
+
+**接口地址**:`/api/rest_j/v1/bml/copyResourceToAnotherUser`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:复制资源到指定用户
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|anotherUser|指定用户|false|String|String|
+|resourceId|资源Id|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/deleteResource`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除版本
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|true|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除多个资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/deleteResources`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除多个资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceIds|资源Id集合,删除多个资源|true|List|List|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除版本
+
+
+**接口地址**:`/api/rest_j/v1/bml/deleteVersion`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除版本
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|true|String|String|
+|version|版本|true|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 下载资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/download`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:通过resourceId 和 version两个参数获取下载对应的资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|query|false|string|
+|version|资源版本,如果不指定,默认为最新|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取Basic
+
+
+**接口地址**:`/api/rest_j/v1/bml/getBasic`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取Basic
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|query|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取资源信息
+
+
+**接口地址**:`/api/rest_j/v1/bml/getResourceInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取资源信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取资源信息
+
+
+**接口地址**:`/api/rest_j/v1/bml/getResources`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取资源信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|currentPage|页码|query|false|string|
+|pageSize|页面大小|query|false|string|
+|system|系统|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取版本信息
+
+
+**接口地址**:`/api/rest_j/v1/bml/getVersions`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取bml版本信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|currentPage|页码|query|false|string|
+|pageSize|页面大小|query|false|string|
+|resourceId|资源ID|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 回滚版本
+
+
+**接口地址**:`/api/rest_j/v1/bml/rollbackVersion`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:回滚版本
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|resourceId|资源Id|false|String|String|
+|version|回滚版本|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 更新资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/updateVersion`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`multipart/form-data`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:用户通过http的方式更新资源文件
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|file|file文件|formData|true|ref|
+|resourceId|用户希望更新资源的resourceId|query|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 上传资源
+
+
+**接口地址**:`/api/rest_j/v1/bml/upload`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:上传资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|file|file|formData|true|array|file|
+|expireTime|expireTime|query|false|string|
+|expireType|expireType|query|false|string|
+|isExpire|isExpire|query|false|string|
+|maxVersion|maxVersion|query|false|integer(int32)|
+|resourceHeader|resourceHeader|query|false|string|
+|system|system|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/bmlfs-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/bmlfs-management-api.md
new file mode 100644
index 00000000000..46172201166
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/bmlfs-management-api.md
@@ -0,0 +1,201 @@
+---
+title: BMLFS管理
+sidebar_position: 13
+---
+** BMLFsRestfulApi 类 **
+
+
+
+## 打开ScriptFromBML
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/openScriptFromBML`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:openScriptFromBML
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|fileName|文件名称|query|true|string|
+|creator|创建者|query|false|string|
+|projectName|项目名称|query|false|string|
+|resourceId|资源Id|query|false|string|
+|version|版本|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 打开来自BML的script
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/product/openScriptFromBML`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:/product/openScriptFromBML
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|fileName|文件名称|query|true|string|
+|creator|创建者|query|false|string|
+|resourceId|资源Id|query|false|string|
+|version|版本|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 保存来自BML的script
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/saveScriptToBML`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:保存来自BML的script
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|创建者|true|String|String|
+|fileName|文件名称|true|String|String|
+|metadata|元数据|true|String|String|
+|projectName|项目名称|true|String|String|
+|resourceId|资源ID|true|String|String|
+|scriptContent|内容|true|String|String|
+|SaveScriptToBML|json|body|true|SaveScriptToBML|SaveScriptToBML|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/currency-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/currency-api.md
new file mode 100644
index 00000000000..799e15cf3f5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/currency-api.md
@@ -0,0 +1,62 @@
+---
+title: 通用API
+sidebar_position: 12
+---
+** CommonRestfulApi 类 **
+
+## 下线某个服务
+
+
+**接口地址**:`/api/rest_j/v1/offline`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:下线某个服务
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/data-source-manager-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/data-source-manager-api.md
new file mode 100644
index 00000000000..a59787377f8
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/data-source-manager-api.md
@@ -0,0 +1,1500 @@
+---
+title: 数据源API
+sidebar_position: 11
+---
+
+
+** DataSourceAdminRestfulApi 类 **
+
+## queryDataSourceEnv
+**接口地址**:`/api/rest_j/v1/data-source-manager/env`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 查询数据源配置的集群环境信息列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|currentPage|currentPage|query|false|integer(int32)|
+|name|name|query|false|string|
+|pageSize|pageSize|query|false|integer(int32)|
+|typeId|typeId|query|false|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/env",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "queryList": [
+ {
+ "id": 2,
+ "envName": "测试环境UAT",
+ "envDesc": "测试环境UAT",
+ "dataSourceTypeId": 4,
+ "connectParams": {
+ "hadoopConf": {
+ "hive.metastore.execute.setugi": "true"
+ },
+ "uris": "thrift://localhost:9083"
+ },
+ "createTime": 1647249913000,
+ "modifyTime": 1647249913000
+ },
+ {
+ "id": 3,
+ "envName": "开源测试环境",
+ "envDesc": "开源测试环境",
+ "dataSourceTypeId": 4,
+ "connectParams": {
+ "keytab": "4dd408ad-a2f9-4501-83b3-139290977ca2",
+ "uris": "thrift://bdpclustername:9083",
+ "principle": "hadoop@WEBANK.COM"
+ },
+ "createTime": 1647249913000,
+ "modifyTime": 1647249913000
+ }
+ ]
+ }
+}
+```
+## getAllEnvListByDataSourceType
+**接口地址**:`/api/rest_j/v1/data-source-manager/env-list/all/type/{typeId}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 查询某种数据源配置的集群信息列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|typeId|typeId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/env-list/all/type/4",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "envList": [
+ {
+ "id": 1,
+ "envName": "测试环境SIT"
+ },
+ {
+ "id": 2,
+ "envName": "测试环境UAT"
+ },
+ {
+ "id": 3,
+ "envName": "开源测试环境"
+ }
+ ]
+ }
+}
+```
+## insertJsonEnv
+**接口地址**:`/api/rest_j/v1/data-source-manager/env/json`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求示例**:
+```javascript
+{
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "envDesc": "",
+ "envName": "",
+ "id": 0,
+ "modifyTime": "",
+ "modifyUser": ""
+}
+```
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceEnv|dataSourceEnv|body|true|DataSourceEnv|DataSourceEnv|
+| connectParams||false|object|
+| createTime||false|string(date-time)|
+| createUser||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer(int64)|
+| envDesc||false|string|
+| envName||false|string|
+| id||false|integer(int64)|
+| modifyTime||false|string(date-time)|
+| modifyUser||false|string|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+## getEnvEntityById
+**接口地址**:`/api/rest_j/v1/data-source-manager/env/{envId}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:查询某环境详细信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|envId|envId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/env/1",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "env": {
+ "id": 1,
+ "envName": "测试环境SIT",
+ "envDesc": "测试环境SIT",
+ "connectParams": {
+ "hadoopConf": {
+ "hive.metastore.execute.setugi": "true"
+ },
+ "uris": "thrift://localhost:9083"
+ },
+ "createTime": 1647249913000,
+ "modifyTime": 1647249913000
+ }
+ }
+}
+```
+## removeEnvEntity
+**接口地址**:`/api/rest_j/v1/data-source-manager/env/{envId}`
+
+**请求方式**:`DELETE`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|envId|envId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+## updateJsonEnv
+**接口地址**:`/api/rest_j/v1/data-source-manager/env/{envId}/json`
+
+**请求方式**:`PUT`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求示例**:
+```javascript
+{
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "envDesc": "",
+ "envName": "",
+ "id": 0,
+ "modifyTime": "",
+ "modifyUser": ""
+}
+```
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceEnv|dataSourceEnv|body|true|DataSourceEnv|DataSourceEnv|
+| connectParams||false|object|
+| createTime||false|string(date-time)|
+| createUser||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer(int64)|
+| envDesc||false|string|
+| envName||false|string|
+| id||false|integer(int64)|
+| modifyTime||false|string(date-time)|
+| modifyUser||false|string|
+|envId|envId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+------
+** DataSourceCoreRestfulApi类**
+
+## queryDataSource
+**接口地址**:`/api/rest_j/v1/data-source-manager/info`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:查询数据源具体信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|currentPage|currentPage|query|false|integer(int32)|
+|identifies|identifies|query|false|string|
+|name|name|query|false|string|
+|pageSize|pageSize|query|false|integer(int32)|
+|system|system|query|false|string|
+|typeId|typeId|query|false|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "totalPage": 12,
+ "queryList": [
+ {
+ "id": 11,
+ "dataSourceName": "test1256",
+ "dataSourceTypeId": 4,
+ "createSystem": "Linkis",
+ "createTime": 1647909291000,
+ "createUser": "hadoop",
+ "versionId": 1,
+ "expire": false,
+ "dataSourceType": {
+ "id": "11",
+ "name": "hive",
+ "layers": 0
+ }
+ },
+ {
+ "id": 10,
+ "dataSourceName": "hive-test",
+ "dataSourceDesc": "hive test",
+ "dataSourceTypeId": 4,
+ "createSystem": "Linkis",
+ "createTime": 1647862455000,
+ "modifyTime": 1647930476000,
+ "modifyUser": "hadoop",
+ "createUser": "hadoop",
+ "versionId": 3,
+ "publishedVersionId": 1,
+ "expire": false,
+ "dataSourceType": {
+ "id": "10",
+ "name": "hive",
+ "layers": 0
+ }
+ }
+
+ ]
+ }
+}
+```
+## removeDataSource
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/delete/{dataSourceId}`
+
+**请求方式**:`DELETE`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:删除某条数据源数据
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info/delete/1",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "removeId": 1
+ }
+}
+```
+## insertJsonInfo
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/json`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求示例**:
+```javascript
+{
+ "connectParams": {},
+ "createIdentify": "",
+ "createSystem": "",
+ "createTime": "",
+ "createUser": "",
+ "dataSourceDesc": "",
+ "dataSourceEnv": {
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "envDesc": "",
+ "envName": "",
+ "id": 0,
+ "modifyTime": "",
+ "modifyUser": ""
+ },
+ "dataSourceEnvId": 0,
+ "dataSourceName": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "expire": true,
+ "id": 0,
+ "labels": "",
+ "modifyTime": "",
+ "modifyUser": "",
+ "publishedVersionId": 0,
+ "versionId": 0,
+ "versions": [
+ {
+ "comment": "",
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "datasourceId": 0,
+ "parameter": "",
+ "versionId": 0
+ }
+ ]
+}
+```
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSource|dataSource|body|true|DataSource|DataSource|
+| connectParams||false|object|
+| createIdentify||false|string|
+| createSystem||false|string|
+| createTime||false|string(date-time)|
+| createUser||false|string|
+| dataSourceDesc||false|string|
+| dataSourceEnv||false|DataSourceEnv|DataSourceEnv|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer|
+| envDesc||false|string|
+| envName||false|string|
+| id||false|integer|
+| modifyTime||false|string|
+| modifyUser||false|string|
+| dataSourceEnvId||false|integer(int64)|
+| dataSourceName||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer(int64)|
+| expire||false|boolean|
+| id||false|integer(int64)|
+| labels||false|string|
+| modifyTime||false|string(date-time)|
+| modifyUser||false|string|
+| publishedVersionId||false|integer(int64)|
+| versionId||false|integer(int64)|
+| versions||false|array|DatasourceVersion|
+| comment||false|string|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| datasourceId||false|integer|
+| parameter||false|string|
+| versionId||false|integer|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+## getInfoByDataSourceName
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/name/{dataSourceName}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:通过datsourceName查询数据源信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info/name/hive-test",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "info": {
+ "id": 10,
+ "dataSourceName": "hive-test",
+ "dataSourceDesc": "hive test",
+ "dataSourceTypeId": 4,
+ "createSystem": "Linkis",
+ "connectParams": {
+ "envId": "3"
+ },
+ "createTime": 1647862455000,
+ "modifyTime": 1647930476000,
+ "modifyUser": "hadoop",
+ "createUser": "hadoop",
+ "versionId": 3,
+ "publishedVersionId": 1,
+ "expire": false,
+ "dataSourceType": {
+ "name": "hive",
+ "layers": 0
+ }
+ }
+ }
+}
+```
+## getInfoByDataSourceId
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/{dataSourceId}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info/1",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "info": {
+ "id": 1,
+ "dataSourceName": "开源共建环境",
+ "dataSourceDesc": "123",
+ "dataSourceTypeId": 1,
+ "createSystem": "Linkis",
+ "connectParams": {
+ "host": "127.0.0.1",
+ "password": "xxxxx",
+ "port": "9600",
+ "username": "linkis"
+ },
+ "createTime": 1647258360000,
+ "modifyTime": 1647437692000,
+ "modifyUser": "hadoop",
+ "createUser": "hadoop",
+ "versionId": 1,
+ "publishedVersionId": 1,
+ "expire": false,
+ "dataSourceType": {
+ "name": "mysql",
+ "icon": "https://uat.dongcha.weoa.com/static/img/logo.770c1525.png",
+ "layers": 0
+ }
+ }
+ }
+}
+```
+## expireDataSource
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/{dataSourceId}/expire`
+
+**请求方式**:`PUT`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info/1/expire",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "expireId": 1
+ }
+}
+```
+## updateDataSourceInJson
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/{dataSourceId}/json`
+
+**请求方式**:`PUT`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求示例**:
+```javascript
+{
+ "connectParams": {},
+ "createIdentify": "",
+ "createSystem": "",
+ "createTime": "",
+ "createUser": "",
+ "dataSourceDesc": "",
+ "dataSourceEnv": {
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "envDesc": "",
+ "envName": "",
+ "id": 0,
+ "modifyTime": "",
+ "modifyUser": ""
+ },
+ "dataSourceEnvId": 0,
+ "dataSourceName": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "expire": true,
+ "id": 0,
+ "labels": "",
+ "modifyTime": "",
+ "modifyUser": "",
+ "publishedVersionId": 0,
+ "versionId": 0,
+ "versions": [
+ {
+ "comment": "",
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "datasourceId": 0,
+ "parameter": "",
+ "versionId": 0
+ }
+ ]
+}
+```
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSource|dataSource|body|true|DataSource|DataSource|
+| connectParams||false|object|
+| createIdentify||false|string|
+| createSystem||false|string|
+| createTime||false|string(date-time)|
+| createUser||false|string|
+| dataSourceDesc||false|string|
+| dataSourceEnv||false|DataSourceEnv|DataSourceEnv|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer|
+| envDesc||false|string|
+| envName||false|string|
+| id||false|integer|
+| modifyTime||false|string|
+| modifyUser||false|string|
+| dataSourceEnvId||false|integer(int64)|
+| dataSourceName||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer(int64)|
+| expire||false|boolean|
+| id||false|integer(int64)|
+| labels||false|string|
+| modifyTime||false|string(date-time)|
+| modifyUser||false|string|
+| publishedVersionId||false|integer(int64)|
+| versionId||false|integer(int64)|
+| versions||false|array|DatasourceVersion|
+| comment||false|string|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| datasourceId||false|integer|
+| parameter||false|string|
+| versionId||false|integer|
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+## getInfoByDataSourceIdAndVersion
+**接口地址**:`/api/rest_j/v1/data-source-manager/info/{dataSourceId}/{version}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+|version|version|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/info/1/1",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "info": {
+ "id": 1,
+ "dataSourceName": "开源共建环境",
+ "dataSourceDesc": "123",
+ "dataSourceTypeId": 1,
+ "createSystem": "Linkis",
+ "connectParams": {
+ "host": "127.0.0.1",
+ "password": "xxxxx",
+ "port": "9600",
+ "username": "linkis"
+ },
+ "createTime": 1647258360000,
+ "modifyTime": 1647437692000,
+ "modifyUser": "hadoop",
+ "createUser": "hadoop",
+ "versionId": 1,
+ "publishedVersionId": 1,
+ "expire": false,
+ "dataSourceType": {
+ "name": "mysql",
+ "icon": "https://uat.dongcha.weoa.com/static/img/logo.770c1525.png",
+ "layers": 0
+ }
+ }
+ }
+}
+```
+## getKeyDefinitionsByType
+**接口地址**:`/api/rest_j/v1/data-source-manager/key-define/type/{typeId}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|typeId|typeId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/key-define/type/4",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "keyDefine": [
+ {
+ "id": 6,
+ "key": "envId",
+ "description": "集群环境",
+ "name": "集群环境",
+ "valueType": "SELECT",
+ "require": true,
+ "dataSource": "/data-source-manager/env-list/all/type/4"
+ },
+ {
+ "id": 7,
+ "key": "keyTabFile",
+ "description": "KeyTab文件",
+ "name": "keyTab文件",
+ "valueType": "FILE",
+ "require": false,
+ "dataSource": "http://127.0.0.1:9001/api/rest_j/v1/bml/upload"
+ }
+ ]
+ }
+}
+```
+## getConnectParams
+**接口地址**:`/api/rest_j/v1/data-source-manager/name/{dataSourceName}/connect-params`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/name/linkis_test256/connect-params",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "connectParams": {
+ "host": "127.0.0.1",
+ "password": "xxxxx",
+ "port": "9600",
+ "username": "linkis"
+ }
+ }
+}
+```
+## insertJsonParameter
+**接口地址**:`/api/rest_j/v1/data-source-manager/parameter/{dataSourceId}/json`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+|params|params|body|true|object|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+## publishByDataSourceId
+**接口地址**:`/api/rest_j/v1/data-source-manager/publish/{dataSourceId}/{versionId}`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+|versionId|versionId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/publish/3/2",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+## getAllDataSourceTypes
+**接口地址**:`/api/rest_j/v1/data-source-manager/type/all`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+暂无
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/type/all",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "typeList": [
+ {
+ "id": "1",
+ "name": "mysql",
+ "description": "mysql数据库",
+ "option": "mysql数据库",
+ "classifier": "关系型数据库",
+ "icon": "https://uat.dongcha.weoa.com/static/img/logo.770c1525.png",
+ "layers": 3
+ },
+
+ {
+ "id": "4",
+ "name": "hive",
+ "description": "hive数据库",
+ "option": "hive",
+ "classifier": "大数据存储",
+ "layers": 3
+ }
+
+ ]
+ }
+}
+```
+## getConnectParams
+**接口地址**:`/api/rest_j/v1/data-source-manager/{dataSourceId}/connect-params`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/3/connect-params",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "connectParams": {
+ "host": "127.0.0.1",
+ "password": "xxxxx",
+ "port": "9600",
+ "username": "linkis"
+ }
+ }
+}
+```
+## getVersionList
+**接口地址**:`/api/rest_j/v1/data-source-manager/{dataSourceId}/versions`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/1/versions",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "versions": [
+ {
+ "versionId": 1,
+ "datasourceId": 1,
+ "connectParams": {
+ "host": "127.0.0.1",
+ "password": "xxxxx",
+ "port": "9600",
+ "username": "linkis"
+ },
+ "parameter": "{\"host\":\"127.0.0.1\",\"port\":\"9600\",\"username\":\"linkis\",\"password\":\"rO0ABXQACUFiY2RAMjAyMg==\"}",
+ "comment": "初始化版本",
+ "createUser": "hadoop"
+ }
+ ]
+ }
+}
+```
+## connectDataSource
+**接口地址**:`/api/rest_j/v1/data-source-manager/{dataSourceId}/{version}/op/connect`
+
+**请求方式**:`PUT`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|integer(int64)|
+|version|version|path|true|integer(int64)|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/data-source-manager/1/1/op/connect",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "ok": true
+ }
+}
+```
+
+-----
+** DataSourceOperateRestfulApi类 **
+
+## connect
+**接口地址**:`/api/rest_j/v1/data-source-manager/op/connect/json`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求示例**:
+```javascript
+{
+ "connectParams": {},
+ "createIdentify": "",
+ "createSystem": "",
+ "createTime": "",
+ "createUser": "",
+ "dataSourceDesc": "",
+ "dataSourceEnv": {
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "envDesc": "",
+ "envName": "",
+ "id": 0,
+ "modifyTime": "",
+ "modifyUser": ""
+ },
+ "dataSourceEnvId": 0,
+ "dataSourceName": "",
+ "dataSourceType": {
+ "classifier": "",
+ "description": "",
+ "icon": "",
+ "id": "",
+ "layers": 0,
+ "name": "",
+ "option": ""
+ },
+ "dataSourceTypeId": 0,
+ "expire": true,
+ "id": 0,
+ "labels": "",
+ "modifyTime": "",
+ "modifyUser": "",
+ "publishedVersionId": 0,
+ "versionId": 0,
+ "versions": [
+ {
+ "comment": "",
+ "connectParams": {},
+ "createTime": "",
+ "createUser": "",
+ "datasourceId": 0,
+ "parameter": "",
+ "versionId": 0
+ }
+ ]
+}
+```
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSource|dataSource|body|true|DataSource|DataSource|
+| connectParams||false|object|
+| createIdentify||false|string|
+| createSystem||false|string|
+| createTime||false|string(date-time)|
+| createUser||false|string|
+| dataSourceDesc||false|string|
+| dataSourceEnv||false|DataSourceEnv|DataSourceEnv|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer|
+| envDesc||false|string|
+| envName||false|string|
+| id||false|integer|
+| modifyTime||false|string|
+| modifyUser||false|string|
+| dataSourceEnvId||false|integer(int64)|
+| dataSourceName||false|string|
+| dataSourceType||false|DataSourceType|DataSourceType|
+| classifier||false|string|
+| description||false|string|
+| icon||false|string|
+| id||false|string|
+| layers||false|integer|
+| name||false|string|
+| option||false|string|
+| dataSourceTypeId||false|integer(int64)|
+| expire||false|boolean|
+| id||false|integer(int64)|
+| labels||false|string|
+| modifyTime||false|string(date-time)|
+| modifyUser||false|string|
+| publishedVersionId||false|integer(int64)|
+| versionId||false|integer(int64)|
+| versions||false|array|DatasourceVersion|
+| comment||false|string|
+| connectParams||false|object|
+| createTime||false|string|
+| createUser||false|string|
+| datasourceId||false|integer|
+| parameter||false|string|
+| versionId||false|integer|
+
+**响应参数**:
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|object|
+|message|string|
+|method|string|
+|status|integer(int32)|integer(int32)|
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/file-system-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/file-system-api.md
new file mode 100644
index 00000000000..34e3a4b71e8
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/file-system-api.md
@@ -0,0 +1,1041 @@
+---
+title: 文件系统
+sidebar_position: 10
+---
+** FsRestfulApi 类 **
+
+
+
+
+
+## 创建新的Dir
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/createNewDir`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:创建新的Dir
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|路径|true|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 创建新的文件
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/createNewFile`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:创建新的文件
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|路径|true|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除dir文件或者文件
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/deleteDirOrFile`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除dir文件或者文件
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|true|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 下载
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/download`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:下载
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|charset|字符集|true|String|String|
+|path|地址|true|String|String|
+|json|json|body|true||
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 文件信息
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/fileInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:文件信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|query|true|string|
+|pageSize|页面大小|query|false|ref|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## formate
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/formate`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:resultsets转换成Excel
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|encoding|编码|query|true|string|
+|escapeQuotes|escapeQuotes|query|true|string|
+|fieldDelimiter|字段分隔符|query|true|string|
+|hasHeader|哈希值|query|true|boolean|
+|quote|引用|query|true|string|
+|path|地址|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 函数列表
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/getDirFileTrees`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取udf函数列表
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|请求路径|query|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/filesystem/getDirFileTrees",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "dirFileTrees": {
+ "name": "",
+ "path": "",
+ "properties": null,
+ "children": [{
+ "name": "",
+ "path": "",
+ "properties": {
+ "size": "",
+ "modifytime": ""
+ },
+ "children": ,
+ "isLeaf": ,
+ "parentPath": ""
+ }],
+ "isLeaf": ,
+ "parentPath":
+ }
+ }
+}
+```
+
+
+## 根路径
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/getUserRootPath`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取根路径
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|pathType|文件类型|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 是否存在
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/isExist`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:是否存在
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|query|true|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 打开文件
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/openFile`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:打开文件
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|query|true|string|
+|charset|字符集|query|false|string|
+|page|页码|query|false|ref|
+|pageSize|页面大小|query|false|ref|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/filesystem/openFile",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "metadata": [{
+ "columnName": "_c0",
+ "comment": "NULL",
+ "dataType": ""
+ }],
+ "totalPage": ,
+ "totalLine": ,
+ "page": ,
+ "type": "",
+ "fileContent": [
+ [""]
+ ]
+ }
+}
+```
+
+
+## 打开日志记录
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/openLog`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:打开日志记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|query|false|string|
+|proxyUser|代理用户|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/filesystem/openLog",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "log": ["", ""]
+ }
+}
+```
+
+
+## 重新命名
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/rename`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:重新给文件命名
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|newDest|新名称|false|String|String|
+|oldDest|旧名称|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 结果集转换成Excel
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/resultsetToExcel`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:结果集转换成Excel
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|autoFormat|是否自动|query|false|boolean|
+|charset|结果集|query|false|string|
+|csvSeperator|csv分隔栏|query|false|string|
+|limit|限度|query|false|ref|
+|nullValue|空值|query|false|string|
+|outputFileName|输出文件名称|query|false|string|
+|outputFileType|输出文件类型|query|false|string|
+|path|地址|query|false|string|
+|quoteRetouchEnable|是否引用修饰|query|false|boolean|
+|sheetName|sheet名称|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## resultsets转换成Excel
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/resultsetsToExcel`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:resultsets转换成Excel
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|autoFormat|是否自动|query|true|boolean|
+|limit|限度|query|true|ref|
+|nullValue|空值|query|true|string|
+|outputFileName|输出文件名称|query|true|string|
+|path|地址|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 保存脚本
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/saveScript`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:保存脚本
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|地址|true|String|String|
+|SaveScript|json|body|true|SaveScript|SaveScript|
+|charset|字符集|false|String|String|
+|params|页面大小|false|Object|Object|
+|scriptContent|页码|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 上传
+
+
+**接口地址**:`/api/rest_j/v1/filesystem/upload`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:上传文件,可传多个文件
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|file|文件|formData|false|ref|
+|path|地址|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/global-variable-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/global-variable-api.md
new file mode 100644
index 00000000000..00a153ce779
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/global-variable-api.md
@@ -0,0 +1,137 @@
+---
+title: 添加全局变量
+sidebar_position: 8
+---
+** VariableRestfulApi 类 **
+
+
+## 全局变量列表
+
+
+**接口地址**:`/api/rest_j/v1/variable/listGlobalVariable`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取全局变量清单
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized||
+|403|Forbidden||
+|404|Not Found||
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object||
+|message|描述|string||
+|method|请求url|string||
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 添加全局变量
+
+
+**接口地址**:`/api/rest_j/v1/variable/saveGlobalVariable`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:添加全局变量
+
+**请求示例**:
+```javascript
+{
+ globalVariables: [{
+ keyID: ,
+ key: "",
+ valueID: ,
+ value: ""
+ }]
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|globalVariables|新增参数数据一对多key:globalVariables,value:List||Map|true|Map|
+|key|参数名称,属于globalVariables||String|true|String|
+|value|变量值,跟key属于键值对 属于被globalVariables包含||List|true|List|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created||
+|401|Unauthorized||
+|403|Forbidden||
+|404|Not Found||
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object||
+|message|描述|string||
+|method|请求url|string||
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/variable/saveGlobalVariable",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/homepage-function-interface-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/homepage-function-interface-api.md
new file mode 100644
index 00000000000..eac4f43bded
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/homepage-function-interface-api.md
@@ -0,0 +1,327 @@
+---
+title: 管理台首页API
+sidebar_position: 7
+---
+** QueryRestfulApi 类 **
+
+
+## 管理员验证
+
+
+**接口地址**:`/api/rest_j/v1/jobhistory/governanceStationAdmin`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:用来验证是否为管理员,如果是则返回true不是则false
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ data: {solution: null, admin: true}
+ message: "OK"
+ method: "/api/jobhistory/governanceStationAdmin"
+ status: 0
+}
+```
+
+
+## 全局历史
+
+
+**接口地址**:`/api/rest_j/v1/jobhistory/list`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:根据条件获取全局历史数据列表默认获取全部
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|创建者|query|false|string|
+|endDate|结束时间|query|false|integer(int64)|
+|executeApplicationName|操作人|query|false|string|
+|isAdminView|是否为管理员模式或者普通模式|query|false|boolean|
+|pageSize|页面数量|query|false|ref|
+|proxyUser|代理用户|query|false|string|
+|startDate|开始时间|query|false|integer(int64)|
+|status|结束时间|query|false|string|
+|taskID|ID|query|false|integer(int64)|
+|tpageNow|页码|query|false|ref|
+|pageNow|pageNow|query|false|integer(int32)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ {
+ "method": "/api/jobhistory/list",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "solution": null,
+ "totalPage": 90,
+ "tasks": [{
+ "taskID": ,
+ "instance": ",
+ "execId": "",
+ "umUser": "",
+ "engineInstance": null,
+ "executionCode": "",
+ "progress": "",
+ "logPath": "",
+ "resultLocation": "",
+ "status": "",
+ "createdTime": ,
+ "updatedTime": ,
+ "engineType": "",
+ "errCode": 0,
+ "errDesc": "",
+ "executeApplicationName": "",
+ "requestApplicationName": "",
+ "runType": "datachecker",
+ "paramsJson": "",
+ "costTime": 1000,
+ "strongerExecId": "",
+ "sourceJson": "",
+ "sourceTailor": "",
+ "engineStartTime": null,
+ "labels": [],
+ "canRetry": ,
+ "subJobs":
+ }]
+ }
+}
+}
+```
+
+
+## 获取未完成任务列表
+
+
+**接口地址**:`/api/rest_j/v1/jobhistory/listundone`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取未完成任务列表
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|creator|query|false|string|
+|endDate|结束时间|query|false|integer(int64)|
+|engineType|engineType|query|false|string|
+|pageNow|pageNow|query|false|ref|
+|pageSize|pageSize|query|false|ref|
+|startDate|开始时间|query|false|ref|
+|startTaskID|startTaskID|query|false|integer(int64)|
+|status|status|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## job任务详细记录
+
+
+**接口地址**:`/api/rest_j/v1/jobhistory/{id}/get`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:job任务详细记录
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|历史记录Id|query|false|integer(int64)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/jobhistory/1928730/get",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "task": {
+ "taskID": ,
+ "instance": "",
+ "execId": "",
+ "umUser": "",
+ "engineInstance": "",
+ "executionCode": "",
+ "progress": "",
+ "logPath": "",
+ "resultLocation": "",
+ "status": "",
+ "createdTime":,
+ "updatedTime": ,
+ "engineType": "",
+ "errCode": ,
+ "errDesc": "",
+ "executeApplicationName": "",
+ "requestApplicationName": "",
+ "runType": "hql",
+ "paramsJson": "",
+ "costTime": ,
+ "strongerExecId": "",
+ "sourceJson": "",
+ "sourceTailor": "",
+ "engineStartTime": null,
+ "labels": [""],
+ "canRetry": false,
+ "subJobs": null
+ }
+ }
+}
+```
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/instance-management-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/instance-management-api.md
new file mode 100644
index 00000000000..20db12d0883
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/instance-management-api.md
@@ -0,0 +1,288 @@
+---
+title: 实例管理
+sidebar_position: 6
+---
+** InstanceRestful 类 **
+
+
+
+
+## 微服务实例列表
+
+
+**接口地址**:`/api/rest_j/v1/microservice/allInstance`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取微服务管理模块实例列表可获取单个或多个默认全部
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "instances": [{
+ "id": ,
+ "updateTime": ,
+ "createTime": ,
+ "applicationName": ",
+ "instance": "",
+ "labels": [{
+ "stringValue": "",
+ "labelKey": "",
+ "feature": "",
+ "id": 5,
+ "labelValueSize": 0,
+ "modifiable": true,
+ "updateTime": ,
+ "createTime": ,
+ "featureKey": "",
+ "empty":
+ }]
+ }]
+ }
+}
+```
+
+
+## 获取eurekaURL
+
+
+**接口地址**:`/api/rest_j/v1/microservice/eurekaURL`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:返回eurekaURL
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "url": ""
+ }
+}
+```
+
+
+## 编辑微服务实例
+
+
+**接口地址**:`/api/rest_j/v1/microservice/instanceLabel`
+
+
+**请求方式**:`PUT`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:编辑或修改下微服务管理中的实例
+
+**请求示例**:
+```javascript
+{
+ applicationName: "linkis-ps-cs"
+ instance: "localhost110004:9108"
+ labels: [{
+ labelKey: "route",
+ stringValue: "cs_2_dev"
+}]}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|applicationName|引擎标签|String|false|String|
+|instance|引擎实例名称|String|String|String|
+|labelKey|添加内容里面的标签,属于labels集合 内 map里的key|String|String|String|
+|labels|引擎实例更新参数内容,集合存放的是map类型的|List|String|List|
+|stringValue|添加内容里面的标签对于的值,属于labels集合 内 map里的value|String|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "success",
+ "data": {
+ "labels": [{
+ "stringValue": "",
+ "labelKey": "",
+ "feature": null,
+ "modifiable": ,
+ "featureKey": "",
+ "empty":
+ }]
+ }
+}
+```
+
+
+## 可以修改的label 类型
+
+
+**接口地址**:`/api/rest_j/v1/microservice/modifiableLabelKey`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取可以修改的label类型列表,列表数据如‘userCreator,route’
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "keyList": []
+ }
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/jobhistory-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/jobhistory-api.md
new file mode 100644
index 00000000000..e74ae07e3ce
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/jobhistory-api.md
@@ -0,0 +1,251 @@
+---
+title: 历史作业API
+sidebar_position: 1
+---
+
+** QueryRestfulApi 类 **
+
+## 判断用户是否是管理员
+**接口地址**:`/api/rest_j/v1/jobhistory/governanceStationAdmin`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 判断用户是否是管理员
+
+**请求参数**:
+无
+
+**响应示例**:
+
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "admin": true
+ }
+}
+```
+
+
+## 获取数据源的数据库名称列表
+**接口地址**:`/api/rest_j/v1/jobhistory/{id}/get`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:获取数据源的数据库名称列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|id|path|true|string||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "task": {
+ "taskID": 1,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "FAILED",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ }
+ }
+}
+```
+
+## 历史任务列表
+**接口地址**:`/api/rest_j/v1/jobhistory/list`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:历史任务列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|startDate|startDate|path|false|Long||
+|endDate|endDate|path|false|Long||
+|status|status|path|false|string||
+|pageNow|pageNow|path|false|Integer||
+|pageSize|pageSize|path|false|Integer||
+|taskID|taskID|path|false|Long||
+|executeApplicationName|executeApplicationName|path|false|string||
+|creator|creator|path|false|string||
+|proxyUser|proxyUser|path|false|string||
+|isAdminView|isAdminView|path|false|Boolean||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "tasks": [{
+ "taskID": 1,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "FAILED",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ },
+ {
+ "taskID": 2,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "FAILED",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ }],
+ "totalPage": 1
+ }
+}
+```
+
+## 未完成的历史任务列表
+**接口地址**:`/api/rest_j/v1/jobhistory/listundone`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:未完成的历史任务列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|startDate|startDate|path|false|Long||
+|endDate|endDate|path|false|Long||
+|status|status|path|false|string||
+|pageNow|pageNow|path|false|Integer||
+|pageSize|pageSize|path|false|Integer||
+|startTaskID|startTaskID|path|false|Long||
+|engineType|engineType|path|false|string||
+|creator|creator|path|false|string||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "tasks": [{
+ "taskID": 1,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "Running",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ },
+ {
+ "taskID": 2,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "Running",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ }],
+ "totalPage": 1
+ }
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/link-error-code.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/link-error-code.md
new file mode 100644
index 00000000000..5b8daff94a3
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/link-error-code.md
@@ -0,0 +1,65 @@
+---
+title: Linkis错误代码
+sidebar_position: 5
+---
+** LinkisErrorCodeRestful 类 **
+
+
+
+## 获取Linkis错误代码
+
+
+**接口地址**:`/api/rest_j/v1/errorcode/getAllErrorCodes`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取Linkis错误代码列表
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/mdq-table-interface-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/mdq-table-interface-api.md
new file mode 100644
index 00000000000..75c153c7f5a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/mdq-table-interface-api.md
@@ -0,0 +1,317 @@
+---
+title: Mdq表API
+sidebar_position: 4
+---
+** MdqTableRestfulApi 类 **
+
+
+## 生成新建库表的DDL语句
+
+
+**接口地址**:`/api/rest_j/v1/datasource/displaysql`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:生成新建库表的DDL语句
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|table|表|String|false|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取分区统计信息
+
+
+**接口地址**:`/api/rest_j/v1/datasource/getPartitionStatisticInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取分区统计信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|database|数据源|query|false|string|
+|partitionSort|分区排序|String|false|String|
+|tableName|表名称|query|false|string|
+|partitionPath|partitionPath|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取表信息
+
+
+**接口地址**:`/api/rest_j/v1/datasource/getTableBaseInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取表信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|database|数据源|query|false|string|
+|tableName|表名称|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取表格字段信息
+
+
+**接口地址**:`/api/rest_j/v1/datasource/getTableFieldsInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取表格字段信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|database|数据源|query|false|string|
+|tableName|表名称|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取表统计信息
+
+
+**接口地址**:`/api/rest_j/v1/datasource/getTableStatisticInfo`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取表统计信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|database|数据源|query|false|string|
+|pageNow|页码|query|false|string|
+|pageSize|页面大小|query|false|string|
+|partitionSort|分区排序|query|false|string|
+|tableName|表名称|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/metadatamanager-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/metadatamanager-api.md
new file mode 100644
index 00000000000..c23802ccfc5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/metadatamanager-api.md
@@ -0,0 +1,331 @@
+---
+title: 元数据查询API
+sidebar_position: 3
+---
+> 本接口为已废弃的老接口,请使用新接口[元数据查询新API](./metadatamanager-api.md)
+
+** MetadataCoreRestful 类 **
+
+## getColumns
+**接口地址**:`/api/rest_j/v1/metadatamanager/columns/{dataSourceId}/db/{database}/table/{table}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 获取数据表的column信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|database|database|path|true|string|
+|system|system|query|true|string|
+|table|table|path|true|string|
+
+**响应示例**:
+
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "columns": [
+ {
+ "index": 1,
+ "primaryKey": true,
+ "name": "id",
+ "type": "INT"
+ },
+ {
+ "index": 2,
+ "primaryKey": false,
+ "name": "datasource_name",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 3,
+ "primaryKey": false,
+ "name": "datasource_desc",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 4,
+ "primaryKey": false,
+ "name": "datasource_type_id",
+ "type": "INT"
+ },
+ {
+ "index": 5,
+ "primaryKey": false,
+ "name": "create_identify",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 6,
+ "primaryKey": false,
+ "name": "create_system",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 7,
+ "primaryKey": false,
+ "name": "parameter",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 8,
+ "primaryKey": false,
+ "name": "create_time",
+ "type": "DATETIME"
+ },
+ {
+ "index": 9,
+ "primaryKey": false,
+ "name": "modify_time",
+ "type": "DATETIME"
+ },
+ {
+ "index": 10,
+ "primaryKey": false,
+ "name": "create_user",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 11,
+ "primaryKey": false,
+ "name": "modify_user",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 12,
+ "primaryKey": false,
+ "name": "labels",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 13,
+ "primaryKey": false,
+ "name": "version_id",
+ "type": "INT"
+ },
+ {
+ "index": 14,
+ "primaryKey": false,
+ "name": "expire",
+ "type": "TINYINT"
+ },
+ {
+ "index": 15,
+ "primaryKey": false,
+ "name": "published_version_id",
+ "type": "INT"
+ }
+ ]
+ }
+}
+```
+
+
+## getDatabases
+**接口地址**:`/api/rest_j/v1/metadatamanager/dbs/{dataSourceId}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:获取数据源的数据库名称列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|system|system|query|true|string|
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "dbs": [
+ "information_schema",
+ "linkis",
+ "linkis_sit"
+ ]
+ }
+}
+```
+
+
+## getPartitions
+**接口地址**:`/api/rest_j/v1/metadatamanager/partitions/{dataSourceId}/db/{database}/table/{table}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|database|database|path|true|string|
+|system|system|query|true|string|
+|table|table|path|true|string|
+|traverse|traverse|query|false|boolean|
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "props": {
+ "partKeys": [
+ "ds"
+ ],
+ "root": {}
+ }
+ }
+}
+```
+
+## getTableProps
+**接口地址**:`/api/rest_j/v1/metadatamanager/props/{dataSourceId}/db/{database}/table/{table}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|database|database|path|true|string|
+|system|system|query|true|string|
+|table|table|path|true|string|
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "props": {
+ "skip.header.line.count": "1",
+ "columns.types": "int:int:string:string:string:string:string:string:string:string:string:string:string:string:string:string:string:string",
+ "columns": "id,age,job,marital,education,default,balance,housing,loan,contact,day,month,duration,campaign,pdays,previous,poutcome,y",
+ "field.delim": ",",
+ "transient_lastDdlTime": "1646732554",
+ "partition_columns.types": "string",
+ "columns.comments": "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000",
+ "bucket_count": "-1",
+ "serialization.ddl": "struct demo_data { i32 id, i32 age, string job, string marital, string education, string default, string balance, string housing, string loan, string contact, string day, string month, string duration, string campaign, string pdays, string previous, string poutcome, string y}",
+ "file.outputformat": "org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat",
+ "partition_columns": "ds",
+ "colelction.delim": "-",
+ "serialization.lib": "org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe",
+ "name": "dss_autotest.demo_data",
+ "location": "hdfs://bdpdev01/user/hive/warehouse/hadoop/dss_autotest.db/demo_data",
+ "mapkey.delim": ":",
+ "file.inputformat": "org.apache.hadoop.mapred.TextInputFormat",
+ "serialization.format": ",",
+ "column.name.delimiter": ","
+ }
+ }
+}
+```
+
+
+## getPartitionProps
+**接口地址**:`/api/rest_j/v1/metadatamanager/props/{dataSourceId}/db/{database}/table/{table}/partition/{partition}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|database|database|path|true|string|
+|partition|partition|path|true|string|
+|system|system|query|true|string|
+|table|table|path|true|string|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## getTables
+**接口地址**:`/api/rest_j/v1/metadatamanager/tables/{dataSourceId}/db/{database}`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 获取数据源的某个数据库的数据表列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceId|dataSourceId|path|true|string|
+|database|database|path|true|string|
+|system|system|query|true|string|
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "tables": [
+ "test",
+ "test_0317a",
+ "test_import_sqoop_1",
+ "test_linkis_sqoop_1",
+ "test_linkis_sqoop_2",
+ "test_linkis_sqoop_3",
+ "upload_test"
+ ]
+ }
+}
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/metadataquery-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/metadataquery-api.md
new file mode 100644
index 00000000000..0274ae27d77
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/metadataquery-api.md
@@ -0,0 +1,266 @@
+---
+title: 元数据查询API(新)
+sidebar_position: 3
+---
+> 元数据查询接口优化之后的新接口,已废弃的旧接口见[元数据查询API](./metadatamanager-api.md),相对于旧接口,主要调整请求的路径和接口参数命名
+
+** MetadataQueryRestful 类 **
+
+## getColumns
+
+**接口地址**:`/api/rest_j/v1/metadataQuery/getColumns`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 获取数据表的column信息
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string||
+|envId|envId|path| false |string||
+|database|database|path|true|string||
+|system|system|query|true|string||
+|table|table|path|true|string||
+
+**响应示例**:
+
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "columns": [
+ {
+ "index": 1,
+ "primaryKey": true,
+ "name": "id",
+ "type": "INT"
+ },
+ {
+ "index": 2,
+ "primaryKey": false,
+ "name": "datasource_name",
+ "type": "VARCHAR"
+ },
+ {
+ "index": 3,
+ "primaryKey": false,
+ "name": "datasource_desc",
+ "type": "VARCHAR"
+ },
+ ]
+ }
+}
+```
+
+
+## getDatabases
+**接口地址**:`/api/rest_j/v1/metadataQuery/getDatabases`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:获取数据源的数据库名称列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- |-------| -------- | ------ |
+|dataSourceName|dataSourceName|path| true |string||
+|envId|envId|path| false |string||
+|system|system|query| true |string||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "dbs": [
+ "information_schema",
+ "linkis",
+ "linkis_sit"
+ ]
+ }
+}
+```
+
+
+## getPartitions
+
+> 返回值调整为 props -> partitions
+
+**接口地址**:`/api/rest_j/v1/metadataQuery/getPartitions`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string||
+|database|database|path|true|string||
+|system|system|query|true|string||
+|table|table|path|true|string||
+|traverse|traverse|query|false|boolean||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "partitions": {
+ "partKeys": [
+ "ds"
+ ],
+ "root": {}
+ }
+ }
+}
+```
+
+## getTableProps
+**接口地址**:`/api/rest_j/v1/metadataQuery/getTableProps`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string||
+|database|database|path|true|string||
+|system|system|query|true|string||
+|table|table|path|true|string||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "props": {
+ "skip.header.line.count": "1",
+ "columns.types": "int:int:string:string:string:string:string:string:string:string:string:string:string:string:string:string:string:string",
+ "columns": "id,age,job,marital,education,default,balance,housing,loan,contact,day,month,duration,campaign,pdays,previous,poutcome,y",
+ "field.delim": ",",
+ "transient_lastDdlTime": "1646732554",
+ "partition_columns.types": "string",
+ "columns.comments": "\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000",
+ "bucket_count": "-1",
+ "serialization.ddl": "struct demo_data { i32 id, i32 age, string job, string marital, string education, string default, string balance, string housing, string loan, string contact, string day, string month, string duration, string campaign, string pdays, string previous, string poutcome, string y}",
+ "file.outputformat": "org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat",
+ "partition_columns": "ds",
+ "colelction.delim": "-",
+ "serialization.lib": "org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe",
+ "name": "dss_autotest.demo_data",
+ "location": "hdfs://localhost01/user/hive/warehouse/hadoop/dss_autotest.db/demo_data",
+ "mapkey.delim": ":",
+ "file.inputformat": "org.apache.hadoop.mapred.TextInputFormat",
+ "serialization.format": ",",
+ "column.name.delimiter": ","
+ }
+ }
+}
+```
+
+
+## getPartitionProps
+**接口地址**:`/api/rest_j/v1/metadataQuery/getPartitionProps`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**:
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string||
+|database|database|path|true|string||
+|partition|partition|path|true|string||
+|system|system|query|true|string||
+|table|table|path|true|string||
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## getTables
+**接口地址**:`/api/rest_j/v1/metadataQuery/getTables`
+
+**请求方式**:`GET`
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+**响应数据类型**:`application/json`
+
+**接口描述**: 获取数据源的某个数据库的数据表列表
+
+**请求参数**:
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|dataSourceName|dataSourceName|path|true|string||
+|envId|envId|path| false |string||
+|database|database|path|true|string||
+|system|system|query|true|string||
+
+**响应示例**:
+```javascript
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "tables": [
+ "test",
+ "test_0317a",
+ "test_import_sqoop_1",
+ "test_linkis_sqoop_1",
+ "test_linkis_sqoop_2",
+ "test_linkis_sqoop_3",
+ "upload_test"
+ ]
+ }
+}
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/parameter-configuration-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/parameter-configuration-api.md
new file mode 100644
index 00000000000..89a3288ba5d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/parameter-configuration-api.md
@@ -0,0 +1,891 @@
+---
+title: 参数配置
+sidebar_position: 3
+---
+** ConfigurationRestfulApi 类 **
+
+
+
+
+## 添加KeyForEngine
+
+
+**接口地址**:`/api/rest_j/v1/configuration/addKeyForEngine`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:添加KeyForEngine
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|engineType|engineType|query|false|string|
+|keyJson|keyJson|query|false|string|
+|token|token|query|false|string|
+|version|version|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 新增应用类型
+
+
+**接口地址**:`/api/rest_j/v1/configuration/createFirstCategory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:新增应用类型标签
+
+**请求示例**:
+```javascript
+{
+ "categoryName": “”,
+ "description": ""
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|categoryName|引用类型标签名称|String|false|String|
+|description|描述|String|false|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/createFirstCategory",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+
+## 新增参数配置
+
+
+**接口地址**:`/api/rest_j/v1/configuration/createSecondCategory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:添加参数配置
+
+**请求示例**:
+```javascript
+{
+ categoryId: ,
+ description: "",
+ engineType: "",
+ version: ""
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|categoryId|参数配置Id|String|true|String|
+|description|描述|String|true|String|
+|engineType|引擎类型|String|true|String|
+|version|版本号|String|true|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/createSecondCategory",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+
+## 删除配置
+
+
+**接口地址**:`/api/rest_j/v1/configuration/deleteCategory`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除参数配置
+
+**请求示例**:
+```javascript
+{
+ categoryId:
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|categoryId|参数配置Id|String|true|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/deleteCategory",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+
+## 引擎类型列表
+
+
+**接口地址**:`/api/rest_j/v1/configuration/engineType`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取引擎类型列表
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/engineType",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "engineType": []
+ }
+}
+```
+
+
+## 应用类型
+
+
+**接口地址**:`/api/rest_j/v1/configuration/getCategory`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:参数配置中应用类型标签
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/getCategory",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "Category": [{
+ "categoryId": ,
+ "labelId": ,
+ "categoryName": "",
+ "childCategory": [],
+ "description": null,
+ "tag": null,
+ "createTime": ,
+ "updateTime": ,
+ "level": ,
+ "fatherCategoryName": ""
+ }],
+ "description": null,
+ "tag": null,
+ "createTime": ,
+ "updateTime": ,
+ "level": ,
+ "fatherCategoryName":
+ }]
+ }
+}
+```
+
+
+## 队列资源
+
+
+**接口地址**:`/api/rest_j/v1/configuration/getFullTreesByAppName`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:参数配置中的队列资源模块返回队列资源的列及值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|标签名称|query|false|string|
+|engineType|engineType|query|false|string|
+|version|version|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/getFullTreesByAppName",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "fullTree": [{
+ "name": "队列资源",
+ "description": null,
+ "settings": [{
+ "id": ,
+ "key": "",
+ "description": "",
+ "name": "",
+ "defaultValue": "",
+ "validateType": "",
+ "validateRange": "[]",
+ "level": 1,
+ "engineType": ,
+ "treeName": "",
+ "valueId": ,
+ "configValue": "",
+ "configLabelId": ,
+ "unit": null,
+ "isUserDefined": ,
+ "hidden": ,
+ "advanced":
+ }]
+ }]
+ }
+}
+```
+
+
+## 获取键值
+
+
+**接口地址**:`/api/rest_j/v1/configuration/keyvalue`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取键值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|configKey|configKey|query|true|string|
+|creator|creator|query|false|string|
+|engineType|engineType|query|false|string|
+|version|version|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 保存键值
+
+
+**接口地址**:`/api/rest_j/v1/configuration/keyvalue`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:保存键值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|configKey|configKey|true|String|String|
+|configValue|configValue|true|String|String|
+|creator|creator|true|String|String|
+|engineType|engineType|true|String|String|
+|version|version|true|String|String|
+|SaveKeyValue|json|body|true|SaveKeyValue|SaveKeyValue|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除键值
+
+
+**接口地址**:`/api/rest_j/v1/configuration/keyvalue`
+
+
+**请求方式**:`DELETE`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除键值
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|configKey|configKey|true|String|String|
+|creator|creator|true|String|String|
+|engineType|engineType|true|String|String|
+|version|version|true|String|String|
+|DeleteKeyValue|json|body|true|DeleteKeyValue|DeleteKeyValue|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|204|No Content|
+|401|Unauthorized|
+|403|Forbidden|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## rpc测试
+
+
+**接口地址**:`/api/rest_j/v1/configuration/rpcTest`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:rpc测试
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|creator|query|false|string|
+|engineType|engineType|query|false|string|
+|username|username|query|false|string|
+|version|version|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 保存队列资源
+
+
+**接口地址**:`/api/rest_j/v1/configuration/saveFullTree`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:保存队列资源
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|creator|应用类型名称|String|true|String|
+|description|描述,属于fullTree中的内容|String|true|String|
+|engineType|引擎类型|String|true|String|
+|fullTree|应用类型下的详细信息|List|true|List|
+|name|队列资源名称,属于fullTree中的内容|String|true|String|
+|settings|队列资源中的详细内容,属于fullTree中的内容|List|true|List|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/saveFullTree",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
+
+
+## 更新类别信息
+
+
+**接口地址**:`/api/rest_j/v1/configuration/updateCategoryInfo`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:更新类别信息
+
+
+**响应示例**:
+```javascript
+{
+ description: "",
+ categoryId:
+}
+```
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|categoryId|categoryId|String|true|String|
+|description|description|String|true|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/configuration/updateCategoryInfo",
+ "status": 0,
+ "message": "OK",
+ "data": {}
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/udf-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/udf-api.md
new file mode 100644
index 00000000000..97f07f1b7e1
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/http/linkis-ps-publicservice-api/udf-api.md
@@ -0,0 +1,1395 @@
+---
+title: UDF操作管理
+sidebar_position: 16
+---
+
+** UDFApi 类 **
+
+## 新增
+
+**接口地址**:`/api/rest_j/v1/udf/add`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:新增
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|clusterName|clusterName|false|String|String|
+|createTime|创建时间|false|Date|Date|
+|createUser|创建者|false|String|String|
+|description|描述|false|String|String|
+|directory|分类,个人函数一级目录|false|String|String|
+|isExpire|是否失效|false|Boolean|Boolean|
+|isLoad|是否负载|false|Boolean|Boolean|
+|isShared|是否共享|false|Boolean|Boolean|
+|path|仅存储用户上一次上传的路径 作提示用|false|String|String|
+|registerFormat|注册执行地址|false|String|String|
+|sys|sys|false|String|String|
+|treeId|treeId|false|Long|Long|
+|udfName|udfName|false|String|String|
+|udfType|udfType|false|Integer|Integer|
+|updateTime|更新时间|false|Date|Date|
+|useFormat|使用格式|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## udf树形菜单
+
+
+**接口地址**:`/api/rest_j/v1/udf/all`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取udf树形菜单详细信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|请求路径|false|String|String|
+|jsonString|jsonString|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取udf用户列表
+
+
+**接口地址**:`/api/rest_j/v1/udf/allUdfUsers`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取udf用户列表
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|json|json|body|true|JsonNode|JsonNode|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 证实
+
+
+**接口地址**:`/api/rest_j/v1/udf/authenticate`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:证明…是真实的
+
+
+
+**请求参数**:
+
+
+暂无
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 删除
+
+
+**接口地址**:`/api/rest_j/v1/udf/delete/{id}`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:删除
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|id|path|false|integer(int64)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## udf文件下载到本地
+
+
+**接口地址**:`/api/rest_j/v1/udf/downloadToLocal`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:根据版本参数下载UDF文件到本地
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|integer|
+|version|version|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## UDF查看源码
+
+
+**接口地址**:`/api/rest_j/v1/udf/downloadUdf`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**: UDF查看源码
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|integer|
+|version|version|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## UDF共享用户列表
+
+
+**接口地址**:`/api/rest_j/v1/udf/getSharedUsers`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:UDF共享用户列表
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|integer|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## UDF移交
+
+
+**接口地址**:`/api/rest_j/v1/udf/handover`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:UDF移交
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|handoverUser|切换用户|false|String|String|
+|udfId|udfId|false|integer|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 是否负载
+
+
+**接口地址**:`/api/rest_j/v1/udf/isload`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:是否负载
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|isLoad|是否负载|query|false|boolean|
+|udfId|udfId|query|false|integer(int64)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 函数列表
+
+
+**接口地址**:`/api/rest_j/v1/udf/list`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取函数列表
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|ListUDF|json|body|true|ListUDF|ListUDF|
+|category|类别|false|String|String|
+|treeId|树形菜单Id|false|String|String|
+|type|函数类型,比如expire,self,share等类型|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 基本信息
+
+
+**接口地址**:`/api/rest_j/v1/udf/managerPages`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:基本信息
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|curPage|页码|false|Integer|Integer|
+|pageSize|页面大小|false|Integer|Integer|
+|udfName|udf名称|false|String|String|
+|udfType|udf类型|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 出版
+
+
+**接口地址**:`/api/rest_j/v1/udf/publish`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:UDF版本发布
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|integer|
+|version|version|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 回退版本
+
+
+**接口地址**:`/api/rest_j/v1/udf/rollback`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:回退版本
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|integer|
+|version|version|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 设置过期
+
+
+**接口地址**:`/api/rest_j/v1/udf/setExpire`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:设置过期
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|false|Long|Long|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## UDF共享
+
+
+**接口地址**:`/api/rest_j/v1/udf/shareUDF`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:UDF共享
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|sharedUsers|sharedUsers|false|List|List|
+|udfInfo|udfInfo|false|UDFInfo|UDFInfo|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## tree新增
+
+
+**接口地址**:`/api/rest_j/v1/udf/tree/add`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:tree新增
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|category|category|false|String|String|
+|childrens|childrens|false|List|List|
+|clusterName|clusterName|false|String|String|
+|createTime|createTime|false|Date|Date|
+|description|description|false|String|String|
+|id|id|false|Long|Long|
+|name|name|false|String|String|
+|parent|parent|false|Long|Long|
+|udfInfos|udfInfos|false|List|List|
+|updateTime|updateTime|false|Date|Date|
+|userName|userName|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## tree删除
+
+
+**接口地址**:`/api/rest_j/v1/udf/tree/delete/{id}`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:tree删除
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|id|path|false|integer(int64)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## tree更新
+
+
+**接口地址**:`/api/rest_j/v1/udf/tree/update`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:tree更新
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|category|category|false|String|String|
+|childrens|childrens|false|List|List|
+|clusterName|clusterName|false|String|String|
+|createTime|createTime|false|Date|Date|
+|description|description|false|String|String|
+|id|id|false|Long|Long|
+|name|name|false|String|String|
+|parent|parent|false|Long|Long|
+|udfInfos|udfInfos|false|List|List|
+|updateTime|updateTime|false|Date|Date|
+|userName|userName|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 更新
+
+
+**接口地址**:`/api/rest_j/v1/udf/update`
+
+
+**请求方式**:`POST`
+
+
+**请求数据类型**:`application/json`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:UDF修改
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|description|描述|false|String|String|
+|id|id|false|Long|Long|
+|isLoad|是否负载|false|Boolean|Boolean|
+|path|仅存储用户上一次上传的路径 作提示用|false|String|String|
+|registerFormat|注册执行地址|false|String|String|
+|udfName|udfName|false|String|String|
+|udfType|udfType|false|Integer|Integer|
+|useFormat|使用格式|false|String|String|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|201|Created|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 获取用户目录
+
+
+**接口地址**:`/api/rest_j/v1/udf/userDirectory`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:获取用户个人函数的一级分类
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|category|获取指定集合类型用户目录,如类型为UDF即获取该类型下的用户目录|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
+
+
+## 版本列表
+
+
+**接口地址**:`/api/rest_j/v1/udf/versionList`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:版本列表查看
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|udfId|udfId|query|false|integer(int64)|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "data": {},
+ "message": "",
+ "method": "",
+ "status": 0
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/jdbc-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/jdbc-api.md
new file mode 100644
index 00000000000..fbfef1539ea
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/jdbc-api.md
@@ -0,0 +1,59 @@
+---
+title: JDBC Driver 文档
+sidebar_position: 4
+---
+## 1. 引入依赖模块:
+第一种方式在pom里面依赖JDBC模块:
+```xml
+
+ org.apache.linkis
+ linkis-jdbc-driver
+ ${linkis.version}
+
+```
+**注意:** 该模块还没有deploy到中央仓库,需要在linkis-computation-governance/linkis-jdbc-driver目录里面执行`mvn install -Dmaven.test.skip=true`进行本地安装。
+
+**第二种方式通过打包和编译:**
+1. 在Linkis项目中进入到linkis-computation-governance/linkis-jdbc-driver目录然后在终端输入指令进行打包`mvn assembly:assembly -Dmaven.test.skip=true`
+该打包指令会跳过单元测试的运行和测试代码的编译,并将JDBC模块需要的依赖一并打包进Jar包之中。
+2. 打包完成后在JDBC的target目录下会生成两个Jar包,Jar包名称中包含dependencies字样的那个就是我们需要的驱动包
+
+## 2. 建立测试类:
+建立Java的测试类LinkisJDBCTest,具体接口含义可以见注释:
+
+```java
+package org.apache.linkis.jdbc.test;
+
+import java.sql.*;
+
+public class LinkisJDBCTest {
+
+ public static void main(String[] args) throws SQLException, ClassNotFoundException {
+
+ //1. load driver:org.apache.linkis.ujes.jdbc.UJESSQLDriver
+ Class.forName("org.apache.linkis.ujes.jdbc.UJESSQLDriver");
+
+ //2. Get Connection:jdbc:linkis://gatewayIP:gatewayPort/dbName?EngineType=hive&creator=test, user/password
+ Connection connection = DriverManager.getConnection("jdbc:linkis://127.0.0.1:9001/default?EngineType=hive&creator=test","hadoop","hadoop");
+ //3. Create statement
+ Statement st= connection.createStatement();
+ ResultSet rs=st.executeQuery("show tables");
+ //4.get result
+ while (rs.next()) {
+ ResultSetMetaData metaData = rs.getMetaData();
+ for (int i = 1; i <= metaData.getColumnCount(); i++) {
+ System.out.print(metaData.getColumnName(i) + ":" +metaData.getColumnTypeName(i)+": "+ rs.getObject(i) + " ");
+ }
+ System.out.println();
+ }
+ //close resource
+ rs.close();
+ st.close();
+ connection.close();
+ }
+}
+```
+
+备注:
+1. 其中EngineType为指定对应的引擎类型:支持Spark/hive/presto/shell等
+2. 其中creator为指定对应的应用类型,用于应用间的资源隔离
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/linkis-task-operator.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/linkis-task-operator.md
new file mode 100644
index 00000000000..ecc10804201
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/linkis-task-operator.md
@@ -0,0 +1,402 @@
+---
+title: 任务提交执行 Rest API 文档
+sidebar_position: 3
+---
+- Linkis Restful接口的返回,都遵循以下的标准返回格式:
+
+```json
+{
+ "method": "",
+ "status": 0,
+ "message": "",
+ "data": {}
+}
+```
+
+**约定**:
+
+ - method:返回请求的Restful API URI,主要是 WebSocket 模式需要使用。
+ - status:返回状态信息,其中:-1表示没有登录,0表示成功,1表示错误,2表示验证失败,3表示没该接口的访问权限。
+ - data:返回具体的数据。
+ - message:返回请求的提示信息。如果status非0时,message返回的是错误信息,其中data有可能存在stack字段,返回具体的堆栈信息。
+
+更多关于 Linkis Restful 接口的规范,请参考:[Linkis Restful 接口规范](../development/development-specification/api)
+
+### 1. 提交执行
+
+- 接口 `/api/rest_j/v1/entrance/submit`
+
+- 提交方式 `POST`
+
+```json
+{
+ "executionContent": {
+ "code": "show tables",
+ "runType": "sql"
+ },
+ "params": {
+ "variable": {// task variable
+ "testvar": "hello"
+ },
+ "configuration": {
+ "runtime": {// task runtime params
+ "jdbc.url": "XX"
+ },
+ "startup": { // ec start up params
+ "spark.executor.cores": "4"
+ }
+ }
+ },
+ "source": { //task source information
+ "scriptPath": "file:///tmp/hadoop/test.sql"
+ },
+ "labels": {
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+- 返回示例
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/submit",
+ "status": 0,
+ "message": "请求执行成功",
+ "data": {
+ "execID": "030418IDEhivelocalhost010004:10087IDE_hadoop_21",
+ "taskID": "123"
+ }
+}
+```
+
+- execID是用户任务提交到 Linkis 之后,为该任务生成的唯一标识执行ID,为 String 类型,这个ID只在任务运行时有用,类似PID的概念。ExecID 的设计为`(requestApplicationName长度)(executeAppName长度)(Instance长度)${requestApplicationName}${executeApplicationName}${entranceInstance信息ip+port}${requestApplicationName}_${umUser}_${index}`
+
+- taskID 是表示用户提交task的唯一ID,这个ID由数据库自增生成,为 Long 类型
+
+
+### 2. 获取状态
+
+- 接口 `/api/rest_j/v1/entrance/${execID}/status`
+
+- 提交方式 `GET`
+
+- 返回示例
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/{execID}/status",
+ "status": 0,
+ "message": "获取状态成功",
+ "data": {
+ "execID": "${execID}",
+ "status": "Running"
+ }
+}
+```
+
+### 3. 获取日志
+
+- 接口 `/api/rest_j/v1/entrance/${execID}/log?fromLine=${fromLine}&size=${size}`
+
+- 提交方式 `GET`
+
+- 请求参数fromLine是指从第几行开始获取,size是指该次请求获取几行日志
+
+- 返回示例,其中返回的fromLine需要作为下次请求该接口的参数
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/${execID}/log",
+ "status": 0,
+ "message": "返回日志信息",
+ "data": {
+ "execID": "${execID}",
+ "log": ["error日志","warn日志","info日志", "all日志"],
+ "fromLine": 56
+ }
+}
+```
+
+### 4. 获取进度
+
+- 接口 `/api/rest_j/v1/entrance/${execID}/progress`
+
+- 提交方式 `GET`
+
+- 返回示例
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/{execID}/progress",
+ "status": 0,
+ "message": "返回进度信息",
+ "data": {
+ "execID": "${execID}",
+ "progress": 0.2,
+ "progressInfo": [
+ {
+ "id": "job-1",
+ "succeedTasks": 2,
+ "failedTasks": 0,
+ "runningTasks": 5,
+ "totalTasks": 10
+ },
+ {
+ "id": "job-2",
+ "succeedTasks": 5,
+ "failedTasks": 0,
+ "runningTasks": 5,
+ "totalTasks": 10
+ }
+ ]
+ }
+}
+```
+
+### 5. kill任务
+
+- 接口 `/api/rest_j/v1/entrance/${execID}/kill`
+
+- 提交方式 `GET`
+
+- 返回示例
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/{execID}/kill",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "execID":"${execID}"
+ }
+}
+```
+
+### 6. 获取任务信息
+
+- 接口 `/api/rest_j/v1/jobhistory/{id}/get`
+
+- 提交方式 `GET`
+
+- 请求参数
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|id|id|path|true|string||
+
+
+- 返回示例
+
+```json
+{
+ "method": null,
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "task": {
+ "taskID": 1,
+ "instance": "xxx",
+ "execId": "exec-id-xxx",
+ "umUser": "test",
+ "engineInstance": "xxx",
+ "progress": "10%",
+ "logPath": "hdfs://xxx/xxx/xxx",
+ "resultLocation": "hdfs://xxx/xxx/xxx",
+ "status": "FAILED",
+ "createdTime": "2019-01-01 00:00:00",
+ "updatedTime": "2019-01-01 01:00:00",
+ "engineType": "spark",
+ "errorCode": 100,
+ "errDesc": "Task Failed with error code 100",
+ "executeApplicationName": "hello world",
+ "requestApplicationName": "hello world",
+ "runType": "xxx",
+ "paramJson": "{\"xxx\":\"xxx\"}",
+ "costTime": 10000,
+ "strongerExecId": "execId-xxx",
+ "sourceJson": "{\"xxx\":\"xxx\"}"
+ }
+ }
+}
+```
+
+### 7. 获取结果集信息
+
+支持多结果集信息
+
+- 接口 `/api/rest_j/v1/filesystem/getDirFileTrees`
+
+- 提交方式 `GET`
+
+- 请求参数
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|结果集目录路径|query|true|string||
+
+
+- 返回示例
+
+```json
+{
+ "method": "/api/filesystem/getDirFileTrees",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "dirFileTrees": {
+ "name": "1946923",
+ "path": "hdfs:///tmp/hadoop/linkis/2022-07-06/211446/IDE/1946923",
+ "properties": null,
+ "children": [
+ {
+ "name": "_0.dolphin",
+ "path": "hdfs:///tmp/hadoop/linkis/2022-07-06/211446/IDE/1946923/_0.dolphin",//result set 1
+ "properties": {
+ "size": "7900",
+ "modifytime": "1657113288360"
+ },
+ "children": null,
+ "isLeaf": true,
+ "parentPath": "hdfs:///tmp/hadoop/linkis/2022-07-06/211446/IDE/1946923"
+ },
+ {
+ "name": "_1.dolphin",
+ "path": "hdfs:///tmp/hadoop/linkis/2022-07-06/211446/IDE/1946923/_1.dolphin",//result set 2
+ "properties": {
+ "size": "7900",
+ "modifytime": "1657113288614"
+ },
+ "children": null,
+ "isLeaf": true,
+ "parentPath": "hdfs:///tmp/hadoop/linkis/2022-07-06/211446/IDE/1946923"
+ }
+ ],
+ "isLeaf": false,
+ "parentPath": null
+ }
+ }
+}
+```
+
+### 8. 获取结果集内容
+
+- 接口 `/api/rest_j/v1/filesystem/openFile`
+
+- 提交方式 `GET`
+
+- 请求参数
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|path|结果集文件|query|true|string||
+|charset|字符集|query|false|string||
+|page|页码|query|false|ref||
+|pageSize|页面大小|query|false|ref||
+
+
+- 返回示例
+
+```json
+{
+ "method": "/api/filesystem/openFile",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "metadata": [
+ {
+ "columnName": "count(1)",
+ "comment": "NULL",
+ "dataType": "long"
+ }
+ ],
+ "totalPage": 0,
+ "totalLine": 1,
+ "page": 1,
+ "type": "2",
+ "fileContent": [
+ [
+ "28"
+ ]
+ ]
+ }
+}
+```
+
+### 9. 获取结果集按照文件流的方式
+
+获取结果集为CSV和Excel按照流的方式
+
+- 接口 `/api/rest_j/v1/filesystem/resultsetToExcel`
+
+- 提交方式 `GET`
+
+- 请求参数
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|autoFormat|是否自动转换格式|query|false|boolean||
+|charset|字符集|query|false|string||
+|csvSeperator|csv分隔栏|query|false|string||
+|limit|获取行数|query|false|ref||
+|nullValue|空值转换|query|false|string||
+|outputFileName|输出文件名称|query|false|string||
+|outputFileType|输出文件类型 csv 或者Excel|query|false|string||
+|path|结果集路径|query|false|string||
+
+- 返回示例
+
+```json
+文件流
+```
+
+### 10. 兼容0.X的任务执行接口
+
+- 接口 `/api/rest_j/v1/entrance/execute`
+
+- 提交方式 `POST`
+
+```json
+{
+ "executeApplicationName": "hive", //Engine type
+ "requestApplicationName": "dss", //Client service type
+ "executionCode": "show tables",
+ "params": {
+ "variable": {// task variable
+ "testvar": "hello"
+ },
+ "configuration": {
+ "runtime": {// task runtime params
+ "jdbc.url": "XX"
+ },
+ "startup": { // ec start up params
+ "spark.executor.cores": "4"
+ }
+ }
+ },
+ "source": { //task source information
+ "scriptPath": "file:///tmp/hadoop/test.sql"
+ },
+ "labels": {
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ },
+ "runType": "hql", //The type of script to run
+ "source": {"scriptPath":"file:///tmp/hadoop/1.hql"}
+}
+```
+
+- Sample Response
+
+```json
+{
+ "method": "/api/rest_j/v1/entrance/execute",
+ "status": 0,
+ "message": "Request executed successfully",
+ "data": {
+ "execID": "030418IDEhivelocalhost010004:10087IDE_hadoop_21",
+ "taskID": "123"
+ }
+}
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/login-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/login-api.md
new file mode 100644
index 00000000000..aa896f0ebde
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/login-api.md
@@ -0,0 +1,133 @@
+---
+title: 登录文档
+sidebar_position: 2
+---
+
+
+
+## 1.对接LDAP服务
+
+进入/conf目录,执行命令:
+
+```bash
+ vim linkis-mg-gateway.properties
+```
+
+添加LDAP相关配置:
+```bash
+wds.linkis.ldap.proxy.url=ldap://127.0.0.1:1389/ # 您的LDAP服务URL
+wds.linkis.ldap.proxy.baseDN=dc=webank,dc=com # 您的LDAP服务的配置
+```
+
+## 2.免登录配置
+
+如何打开测试模式,实现免登录?进入/conf目录,执行命令:
+
+```bash
+ vim linkis-mg-gateway.properties
+```
+
+将测试模式打开,参数如下:
+
+```shell
+ wds.linkis.test.mode=true # 打开测试模式
+ wds.linkis.test.user=hadoop # 指定测试模式下,所有请求都代理给哪个用户
+```
+
+## 3.登录接口汇总
+
+我们提供以下几个与登录相关的接口:
+
+ - 登录
+ - 登出
+ - 心跳
+
+
+## 4.接口详解
+
+- Linkis Restful接口的返回,都遵循以下的标准返回格式:
+
+```json
+{
+ "method": "",
+ "status": 0,
+ "message": "",
+ "data": {}
+}
+```
+
+**约定**:
+
+ - method:返回请求的Restful API URI,主要是 WebSocket 模式需要使用。
+ - status:返回状态信息,其中:-1表示没有登录,0表示成功,1表示错误,2表示验证失败,3表示没该接口的访问权限。
+ - data:返回具体的数据。
+ - message:返回请求的提示信息。如果status非0时,message返回的是错误信息,其中data有可能存在stack字段,返回具体的堆栈信息。
+
+更多关于 Linkis Restful 接口的规范,请参考:[Linkis Restful 接口规范](../development/development-specification/api)
+
+### 4.1 登录
+
+- 接口 `/api/rest_j/v1/user/login`
+
+- 提交方式 `POST`
+
+```json
+ {
+ "userName": "",
+ "password": ""
+ }
+```
+
+- 返回示例
+
+```json
+ {
+ "method": null,
+ "status": 0,
+ "message": "login successful(登录成功)!",
+ "data": {
+ "isAdmin": false,
+ "userName": ""
+ }
+ }
+```
+
+其中:
+
+ - isAdmin: Linkis只有admin用户和非admin用户,admin用户的唯一特权,就是支持在Linkis管理台查看所有用户的历史任务。
+
+### 4.2 登出
+
+- 接口 `/api/rest_j/v1/user/logout`
+
+- 提交方式 `POST`
+
+ 无参数
+
+- 返回示例
+
+```json
+ {
+ "method": "/api/rest_j/v1/user/logout",
+ "status": 0,
+ "message": "退出登录成功!"
+ }
+```
+
+### 4.3 心跳
+
+- 接口 `/api/rest_j/v1/user/heartbeat`
+
+- 提交方式 `POST`
+
+ 无参数
+
+- 返回示例
+
+```json
+ {
+ "method": "/api/rest_j/v1/user/heartbeat",
+ "status": 0,
+ "message": "维系心跳成功!"
+ }
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/overview.md
new file mode 100644
index 00000000000..a4d0d3889aa
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/api/overview.md
@@ -0,0 +1,13 @@
+---
+title: 总览
+sidebar_position: 1
+---
+
+## 1. 文档说明
+Linkis1.0 在Linkix0.x版本的基础上进行了重构优化,同时也兼容了0.x的接口,但是为了防止在使用1.0版本时存在兼容性问题,需要您仔细阅读以下文档:
+
+1. 使用Linkis1.0定制化开发时,需要使用到Linkis的权限认证接口,请仔细阅读 [登录API文档](login-api.md)。
+
+2. Linkis1.0提供JDBC的接口,需要使用JDBC的方式接入Linkis,请仔细阅读[任务提交执行JDBC API文档](jdbc-api.md)。
+
+3. Linkis1.0提供了Rest接口,如果需要在Linkis的基础上开发上层应用,请仔细阅读[任务提交执行Rest API文档](linkis-task-operator.md)。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/_category_.json
new file mode 100644
index 00000000000..33d9cbb6e4d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "架构设计",
+ "position": 7
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/_category_.json
new file mode 100644
index 00000000000..35d4ecf92fb
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "关键特性架构",
+ "position": 4
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/_category_.json
new file mode 100644
index 00000000000..1b0f37a1f69
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "公共模块",
+ "position": 1
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/proxy-user.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/proxy-user.md
new file mode 100644
index 00000000000..3284e323f7b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/proxy-user.md
@@ -0,0 +1,38 @@
+---
+title: Linkis 支持代理用户提交架构设计
+sidebar_position: 6
+---
+
+## 1 背景
+目前linkis在执行用户提交的任务时,linkis主要进程服务会通过sudo -u ${submit user} 切换到对应用户下,然后执行对应的引擎启动命令,
+这就需要为每个${submit user} 提前创建对应的系统用户,并且配置好相关的环境变量。
+对于新用户,需要一系列的环境的初始化准备工作,如果频繁的用户变化,会增大运维成本,而且用户过多,没法针对单个用户配置资源,资源之间无法很好的管控。如果能够实现A代理给指定的代理用户执行,可以将执行入口统一收敛,解决需要初始化环境的问题。
+
+## 2 基本概念
+- 登陆用户:通过用户名密码直接登陆系统的用户
+- 代理用户:作为登陆用户实际执行操作的用户称之为代理用户,代理登陆用户的相关操作
+
+## 3 实现的目标
+- 登陆用户A可以进行代理用户的选择,决定代理给哪个代理用户
+- 登陆用户A可以将任务代理给代理用户B执行
+- 登陆用户A代理到代理用户B时,可以查看B相关的执行记录,任务结果等数据
+- 一个代理用户同时可以代理多个登陆用户,但是一个登陆用户同一时刻只能关联某一个代理用户
+
+## 4 实现大体思路
+
+修改现有接口cookie处理,需要能在cookie中解析出登录用户和代理用户
+```html
+代理用户的cookie的key为:linkis_user_session_proxy_ticket_id_v1
+登录用户的cookie: linkis_user_session_ticket_id_v1
+
+```
+
+- linkis的相关接口需要 在原来获取UserName的基础上,要能识别出代理用户信息,使用代理用户进行各项操作。并记录审计日志,包含用户的任务执行操作,下载操作
+- 任务提交执行的时候,entrance入口服务需要修改执行的用户为代理用户
+
+## 5 需要考虑&注意的事项
+
+- 用户分为代理用户和非代理用户,代理类型的用户不能进行再次代理到其他用户执行
+- 需要控制登陆用户与可代理的系统用户列表,禁止出现任意代理的情况,避免权限不可控。最好支持数据库表来配置,并可以直接修改生效,不需要重启服务
+- 单独记录日志文件包含代理用户的操作,如代理执行、函数更新等PublicService的代理用户操作全部记录到日志中,方便审计
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/rpc.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/rpc.md
new file mode 100644
index 00000000000..1a310f51705
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/rpc.md
@@ -0,0 +1,137 @@
+---
+title: RPC 模块
+sidebar_position: 2
+---
+
+基于Feign的微服务之间HTTP接口调用,只能满足简单的A微服务实例根据简单的规则随机访问B微服务之中的某个服务实例,而这个B微服务实例如果想异步回传信息给调用方,是根本无法实现的。
+同时,由于Feign只支持简单的服务选取规则,无法做到将请求转发给指定的微服务实例,无法做到将一个请求广播给接收方微服务的所有实例。
+Linkis RPC是基于Spring Cloud + Feign实现的一套微服务间的异步请求和广播通信服务,可以独立于Linkis而使用。
+
+
+
+## 1. 简介
+Linkis RPC作为底层的通信方案,将提供SDK集成到有需要的微服务之中。
+一个微服务既可以作为请求调用方,也可以作为请求接收方。
+
+作为请求调用方时,将通过Sender请求目标接收方微服务的Receiver,作为请求接收方时,将提供Receiver用来处理请求接收方Sender发送过来的请求,以便完成同步响应或异步响应。
+![](/Images/Architecture/RPC-01.png)
+
+```
+org.apache.linkis.rpc.Sender
+org.apache.linkis.rpc.Receiver
+```
+
+### 1.1. 架构设计图
+![Linkis RPC架构图](/Images-zh/Architecture/Commons/linkis-rpc.png)
+### 1.2. 模块说明
+主要模块的功能介绍如下:
+* Eureka:服务注册中心,用户管理服务,服务发现。
+* Sender发送器:服务请求接口,发送端使用Sender向接收端请求服务。
+* Receiver接收器:服务请求接收相应接口,接收端通过该接口响应服务。
+* Interceptor拦截器:Sender发送器会将使用者的请求传递给拦截器。拦截器拦截请求,对请求做额外的功能性处理,分别是广播拦截器用于对请求广播操作、重试拦截器用于对失败请求重试处理、缓存拦截器用于简单不变的请求读取缓存处理、和提供默认实现的默认拦截器。
+* Decoder,Encoder:用于请求的编码和解码。
+* Feign:是一个http请求调用的轻量级框架,声明式WebService客户端程序,用于Linkis-RPC底层通信。
+* Listener:监听模块,主要用于监听广播请求。
+
+
+
+## 2. 实现
+
+基于请求调用方的Sender体系和请求接收方的Receiver体系,构成了Linkis RPC的全部架构。
+![](/Images/Architecture/RPC-01.png)
+
+### 2.1 发送端
+Linkis RPC作为底层的通信层,发送端无需调用者写任何的实际代码。
+
+- 调用者通过调用Linkis RPC提供的SDK,通过微服务名(Service Name)或指定微服务实例(微服务名+微服务实例的IP和端口),获取一个Sender发送器。
+
+Sender提供的可使用方法,见如下伪代码:
+```
+abstract class Sender {
+ Object ask(Object message);
+ Object ask(Object message, Duration timeout);
+ void send(Object message);
+ void deliver(Object message);
+}
+
+其中:
+1. ask方法为同步请求响应方法,要求接收端必须同步返回响应;
+2. send方法为同步请求方法,只负责同步将请求发送给接收端,不要求接收端给出答复;
+3. deliver则为异步请求方法,只要发送端的进程不异常退出,在稍后会通过其它线程将请求发送给接收端。
+```
+
+- 调用者作为发送端,通过Sender发送器提供的请求方法,发送请求给接收端。
+- Sender发送器会将调用者的请求传递给拦截器,进行一系列发送前的逻辑处理。
+
+拦截器拦截请求,开始对请求做额外的功能性处理:
+
+**广播拦截器**
+```
+org.apache.linkis.rpc.interceptor.common.BroadcastRPCInterceptor
+```
+广播拦截器只对需要进行广播的请求生效。
+广播拦截器会提供特殊的广播接口,如果本次请求实现了该广播接口,且该请求不是正在广播中,广播拦截器则认为本次请求需要进行广播,这时会触发广播操作。
+
+**重试拦截器**
+
+```
+org.apache.linkis.rpc.interceptor.common.RetryableRPCInterceptor
+```
+
+重试拦截器会对接下来的所有步骤提供重试功能。
+如果接收端要求重试,或者发送请求时出现了ConnectException(连接异常),或者调用者指定某些异常需要重试,这时重试拦截器会自动进行重试。
+
+
+**缓存拦截器**
+```
+org.apache.linkis.rpc.interceptor.common.CacheableRPCInterceptor
+```
+
+缓存拦截器是针对一些响应内容不大可能经常变动的同步请求而设定的。
+缓存拦截器也会提供特殊的缓存接口,如果本次请求实现了缓存接口,会首先在缓存拦截器中寻找缓存,不存在缓存才会继续请求,并在拿到响应后,先将响应缓存起来,再将响应返回。
+
+**公共默认拦截器**
+```
+org.apache.linkis.rpc.interceptor.common.CommonRPCInterceptor
+```
+
+
+公共默认拦截器用于调用接下来的处理步骤(示例参考:org.apache.linkis.rpc.BaseRPCSender#ask)
+
+
+- 请求编码器会先将用户请求的数据(实体Bean)转换成序列化的JSON字符串,然后传递给Feign客户端生成器。
+- Feign客户端生成器,生成可访问接收端Restful请求接收器的Feign客户端。
+- 生成的Feign客户端,会调用Eureka客户端,获取所有微服务列表,通过服务选择器,如果调用者指定微服务名,则通过Feign的负载均衡策略,
+ 选择一个合适的接收方微服务实例进行请求转发,否则服务选择器会重写Spring Cloud Feign的FeignLoadBalancer(Feign负载均衡器),
+ 在创建LoadBalancerCommand时,请求调用者指定的微服务实例(微服务名+微服务实例address)。
+ 调用Feign客户端,开始请求接收端的Restful请求接收器。
+
+**自定义拦截器**
+
+调用者也可以自己实现自定义拦截器(在linkis-commons/linkis-rpc/src/main/scala/org/apache/linkis/rpc/interceptor/common下实现RPCInterceptor接口,并通过@Component注入),用于实现一些特定的功能。
+
+### 2.2 接收端
+接收端需要调用者**实现Receiver接口**,用于处理真正的业务逻辑。
+- 1. RPCReceiveRestful请求接收器作为Linkis RPC内嵌的HTTP请求Web Service服务,负责接收发送端的请求
+- 2. RPCReceiveRestful请求接收器接收到请求后,先调用请求解码器对请求进行解码,解析出实际的请求信息和发送端微服务信息(微服务名+微服务实例的IP和端口),如果解析失败,会直接响应解析请求失败。
+- 3. 将解析后的请求信息和发送端微服务信息放入请求消息队列;
+- 4. 请求消费器会消费请求消息队列里,已经解码的发送端请求。
+- 5. 通过调用Receiver管理器获取一个合适的Receiver;同时通过发送端微服务信息,使用Sender生成器生成一个指向发送端的Sender。 然后请求消费器将实际的请求信息和生成的发送端Sender,传给Receiver进行处理。
+- 6. Receiver作为用户请求的实际处理单元,要求调用者必须实现Receiver接口,完成对调用端请求的实际处理逻辑。
+```
+Receiver的伪代码如下:
+public interface Receiver {
+ void receive(Object message, Sender sender);
+ Object receiveAndReply(Object message, Sender sender);
+ Object receiveAndReply(Object message, Duration duration, Sender sender);
+}
+```
+Receiver提供了处理同步请求和异步请求的方法。
+- 如果本次请求是异步请求,则调用Receiver的receive方法,由上层业务决定是否需要通过发送端的Sender回传响应。
+- 如果本次请求是同步请求,则调用 Receiver的receiveAndReply方法,将返回值作为响应结果,回传发送端。
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/variable.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/variable.md
new file mode 100644
index 00000000000..ebcca3464c6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/commons/variable.md
@@ -0,0 +1,102 @@
+---
+title: 自定义变量设计
+sidebar_position: 1
+---
+
+## 1. 总述
+### 需求
+1. 用户希望Linkis能够提供一些公共变量然后执行的时候进行替换,比如用户每天都会批量跑同一段sql,需要指定上一天的分区时间,如果基于sql去写会比较复杂如果系统提供一个run_date的变量将会非常方便使用。
+2. 用户希望Linkis支持date pattern计算,支持在代码中写&{YYYY-MM-DD}等变量计算时间变量
+3. 用户希望自己定义变量,比如定一个一个float变量,然后在代码中进行使用
+
+### 目标
+1. 支持任务代码的变量替换
+2. 支持自定义变量,支持用户在脚本和提交给Linkis的任务参数定义自定义变量,支持简单的+,-等计算
+3. 预设置系统变量:run_date,run_month,run_today等系统变量
+4. 支持date pattern变量,支持pattern的+,-操作
+
+## 2. 总体设计
+ 在Linkis任务执行过程中自定义变量在Entrance进行,主要通过Entrance在任务提交执行前的拦截器进行拦截替换实现,通过正则表达式获取到任务代码中使用到的变量和定义的变量,并通过任务传入的自定义变量初始值完成代码的替换,变成最终可以执行的代码。
+
+### 2.1 技术架构
+ 自定义变量整体架构如下,用于任务提交过来后,会经过变量替换拦截器。首先会解析出所有代码中用到的变量和表达式,然后通过和系统以及用户自定义的变量初始值进行替换,最终将解析后的代码提交给EngineConn执行。所以到底层引擎已经是替换好的代码。
+
+![arc](/Images/Architecture/Commons/var_arc.png)
+
+备注:变量和解析的功能因为比较通用,抽成工具类定义在linkis-commons中:org.apache.linkis.common.utils.VariableUtils
+
+### 2.2 业务架构
+ 此次的特性主要是为了完成变量替换的解析、计算、替换功能,主要涉及到linkis的Entrance模块做代码拦截和Linkis-commons模块定义的变量替换的工具类:
+
+| 组件名| 一级模块 | 二级模块 | 功能点 |
+|---|---|---|---|
+| Linkis | CG | Entrance|拦截任务的代码并调用linkis-common的VariableUtils进行代码替换|
+| Linkis | Linkis-commons | linkis-common|提供变量、解析、计算的工具类VariableUtils|
+
+## 3. 模块设计
+### 3.1核心执行流程
+[输入端] 输入端为代码和代码类型(python/sql/scala/sh).
+[处理流程] Entrance在接受到任务后会首先进过拦截器,启动变量拦截器会完成变量的解析、替换、计算
+整体时序图如下:
+
+![time](/Images/Architecture/Commons/var_time.png)
+
+这里需要说明的是:
+1. 自定义变量和系统变量使用方式为${},如${run_date}
+2. date pattern变量的使用方式为&{},如&{yyyy-01-01} 值为2022-01-01。
+ 之所以分成两种不同的方式是为了防止自定义变量定义的字符串中包含pattern字符,如定义了一个y=1的自定义变量可能代表不同的含义,会被pattern任务是年变量
+
+
+### 3.2具体细节:
+1、run_date为核心自带日期变量,支持用户自定义日期,如果不指定默认为当前系统时间的前一天。
+2、其他衍生内置日期变量定义:其他日期内置变量都是相对run_date计算出来的,一旦run_date变化,其他变量值也会自动跟着变化,其他日期变量不支持设置初始值,只能通过修改run_date进行修改。
+3、内置变量支持更加丰富的使用场景:${run_date-1}为run_data的前一天;${run_month_begin-1}为run_month_begin的上个月的第一天,这里的-1表示减一个月。
+4、Pattern类型变量也是基于run_date进行计算,然后再进行替换和+—
+
+### 3.3 变量作用域
+在linkis中自定义变量也有作用域,优先级为脚本中定义的变量大于在任务参数中定义的Variable大于内置的run_date变量。任务参数中定义如下:
+```
+## restful
+{
+ "executionContent": {"code": "select \"${f-1}\";", "runType": "sql"},
+ "params": {
+ "variable": {f: "20.1"},
+ "configuration": {
+ "runtime": {
+ "linkis.openlookeng.url":"http://127.0.0.1:9090"
+ }
+ }
+ },
+ "source": {"scriptPath": "file:///mnt/bdp/hadoop/1.sql"},
+ "labels": {
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+## java SDK
+JobSubmitAction.builder
+ .addExecuteCode(code)
+ .setStartupParams(startupMap)
+ .setUser(user) //submit user
+ .addExecuteUser(user) //execute user
+ .setLabels(labels)
+ .setVariableMap(varMap) //setVar
+ .build
+```
+
+## 4. 接口设计:
+主要工具类为:
+```
+VariableUtils:
+def replace(replaceStr: String): String 替换代码中的变量返回替换后的代码
+def replace(replaceStr: String, variables: util.Map[String, Any]): String 支持传入自定义变量的值,进行替换
+def replace(code: String, runtType: String, variables: util.Map[String, String]): String 支持传入代码类型,按照不同的类型进行替换解析
+```
+
+
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/_category_.json
new file mode 100644
index 00000000000..883115fccbc
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "计算治理服务架构",
+ "position": 2
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine-conn-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine-conn-manager.md
new file mode 100644
index 00000000000..535a47e8d33
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine-conn-manager.md
@@ -0,0 +1,51 @@
+---
+title: EngineConnManager 架构
+sidebar_position: 2
+---
+
+EngineConnManager(ECM):EngineConn的管理器,提供引擎的生命周期管理,同时向RM汇报负载信息和自身的健康状况。
+
+### 一、ECM架构
+
+![](/Images-zh/Architecture/engine/ecm-01.png)
+
+### 二、二级模块介绍
+
+**Linkis-engineconn-linux-launch**
+
+引擎启动器,核心类为LinuxProcessEngineConnLauch,用于提供执行命令的指令。
+
+**Linkis-engineconn-manager-core**
+
+ECM的核心模块,包含ECM健康上报、EngineConn健康上报功能的顶层接口,定义了ECM服务的相关指标,以及构造EngineConn进程的核心方法。
+
+| 核心顶层接口/类 | 核心功能 |
+|---------------------|------------------------------------------|
+| EngineConn | 定义了EngineConn的属性,包含的方法和参数 |
+| EngineConnLaunch | 定义了EngineConn的启动方法和停止方法 |
+| ECMEvent | 定义了ECM相关事件 |
+| ECMEventListener | 定义了ECM相关事件监听器 |
+| ECMEventListenerBus | 定义了ECM的监听器总线 |
+| ECMMetrics | 定义了ECM的指标信息 |
+| ECMHealthReport | 定义了ECM的健康上报信息 |
+| NodeHealthReport | 定义了节点的健康上报信息 |
+
+**Linkis-engineconn-manager-server**
+
+ECM的服务端,定义了ECM健康信息处理服务、ECM指标信息处理服务、ECM注册服务、EngineConn启动服务、EngineConn停止服务、EngineConn回调服务等顶层接口和实现类,主要用于ECM对自己和EngineConn的生命周期管理以及健康信息上报、发送心跳等。
+
+模块中的核心Service和功能简介如下:
+
+| 核心service | 核心功能 |
+|---------------------------------|-------------------------------------------------|
+| EngineConnLaunchService | 包含生成EngineConn和启动进程的核心方法 |
+| BmlResourceLocallizationService | 用于将BML的引擎相关资源下载并生成本地化文件目录 |
+| ECMHealthService | 向AM定时上报自身的健康心跳 |
+| ECMMetricsService | 向AM定时上报自身的指标状况 |
+| EngineConnKillSerivce | 提供停止引擎的相关功能 |
+| EngineConnListService | 提供缓存和管理引擎的相关功能 |
+| EngineConnCallBackService | 提供回调引擎的功能 |
+
+ECM构建EngineConn启动流程:
+
+![](/Images-zh/Architecture/engine/engineconn-01.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/_category_.json
new file mode 100644
index 00000000000..7d5b0b6f6b9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "引擎连接器架构",
+ "position": 5
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/add-an-engine-conn.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/add-an-engine-conn.md
new file mode 100644
index 00000000000..f5ae4c565a5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/add-an-engine-conn.md
@@ -0,0 +1,114 @@
+---
+title: EngineConn 启动流程
+sidebar_position: 3
+---
+
+EngineConn的新增,是Linkis计算治理的计算任务准备阶段的核心流程之一。它主要包括了Client端(Entrance或用户客户端)向LinkisManager发起一个新增EngineConn的请求,LinkisManager为用户按需、按标签规则,向EngineConnManager发起一个启动EngineConn的请求,并等待EngineConn启动完成后,将可用的EngineConn返回给Client的整个流程。
+
+如下图所示,接下来我们来详细说明一下整个流程:
+
+![EngineConn新增流程](/Images-zh/Architecture/EngineConn新增流程/EngineConn新增流程.png)
+
+## 1. LinkisManager接收客户端请求
+
+**名词解释**:
+
+- LinkisManager:是Linkis计算治理能力的管理中枢,主要的职责为:
+ 1. 基于多级组合标签,为用户提供经过复杂路由、资源管控和负载均衡后的可用EngineConn;
+
+ 2. 提供EC和ECM的全生命周期管理能力;
+
+ 3. 为用户提供基于多级组合标签的多Yarn集群资源管理功能。主要分为 AppManager(应用管理器)、ResourceManager(资源管理器)、LabelManager(标签管理器)三大模块,能够支持多活部署,具备高可用、易扩展的特性。
+
+ AM模块接收到Client的新增EngineConn请求后,首先会对请求做参数校验,判断请求参数的合法性;其次是通过复杂规则选中一台最合适的EngineConnManager(ECM),以用于后面的EngineConn启动;接下来会向RM申请启动该EngineConn需要的资源;最后是向ECM请求创建EngineConn。
+
+下面将对四个步骤进行详细说明。
+
+### 1.1 请求参数校验
+
+ AM模块在接受到引擎创建请求后首先会做参数判断,首先会做请求用户和创建用户的权限判断,接着会对请求带上的Label进行检查。因为在AM后续的创建流程当中,Label会用来查找ECM和进行资源信息记录等,所以需要保证拥有必须的Label,现阶段一定需要带上的Label有UserCreatorLabel(例:hadoop-IDE)和EngineTypeLabel(例:spark-2.4.3)。
+
+### 1.2 EngineConnManager(ECM)选择
+
+ ECM选择主要是完成通过客户端传递过来的Label去选择一个合适的ECM服务去启动EngineConn。这一步中首先会通过LabelManager去通过客户端传递过来的Label去注册的ECM中进行查找,通过按照标签匹配度进行顺序返回。在获取到注册的ECM列表后,会对这些ECM进行规则选择,现阶段已经实现有可用性检查、资源剩余、机器负载等规则。通过规则选择后,会将标签最匹配、资源最空闲、负载低的ECM进行返回。
+
+### 1.3 EngineConn资源申请
+
+1. 在获取到分配的ECM后,AM接着会通过调用EngineConnPluginServer服务请求本次客户端的引擎创建请求会使用多少的资源,这里会通过封装资源请求,主要包含Label、Client传递过来的EngineConn的启动参数、以及从Configuration模块获取到用户配置参数,通过RPC调用ECP服务去获取本次的资源信息。
+
+2. EngineConnPluginServer服务在接收到资源请求后,会先通过传递过来的标签找到对应的引擎标签,通过引擎标签选择对应引擎的EngineConnPlugin。然后通过EngineConnPlugin的资源生成器,对客户端传入的引擎启动参数进行计算,算出本次申请新EngineConn所需的资源,然后返回给LinkisManager。
+
+ **名词解释:**
+- EgineConnPlugin:是Linkis对接一个新的计算存储引擎必须要实现的接口,该接口主要包含了这种EngineConn在启动过程中必须提供的几个接口能力,包括EngineConn资源生成器、EngineConn启动命令生成器、EngineConn引擎连接器。具体的实现可以参考Spark引擎的实现类:[SparkEngineConnPlugin](https://github.com/apache/linkis/blob/master/linkis-engineconn-plugins/spark/src/main/scala/com/webank/wedatasphere/linkis/engineplugin/spark/SparkEngineConnPlugin.scala)。
+
+- EngineConnPluginServer:是加载了所有的EngineConnPlugin,对外提供EngineConn的所需资源生成能力和EngineConn的启动命令生成能力的微服务。
+
+- EngineConnPlugin资源生成器(EngineConnResourceFactory):通过传入的参数,计算出本次EngineConn启动时需要的总资源。
+
+- EngineConn启动命令生成器(EngineConnLaunchBuilder):通过传入的参数,生成该EngineConn的启动命令,以提供给ECM去启动引擎。
+3. AM在获取到引擎资源后,会接着调用RM服务去申请资源,RM服务会通过传入的Label、ECM、本次申请的资源,去进行资源判断。首先会判断客户端对应Label的资源是否足够,然后再会判断ECM服务的资源是否足够,如果资源足够,则本次资源申请通过,并对对应的Label进行资源的加减。
+
+### 1.4 请求ECM创建引擎
+
+1. 在完成引擎的资源申请后,AM会封装引擎启动的请求,通过RPC发送给对应的ECM进行服务启动,并获取到EngineConn的实例对象;
+2. AM接着会去通过EngineConn的上报信息判断EngineConn是否启动成功变成可用状态,如果是就会将结果进行返回,本次新增引擎的流程也就结束。
+
+## 2. ECM启动EngineConn
+
+名词解释:
+
+- EngineConnManager(ECM):EngineConn的管理器,提供引擎的生命周期管理,同时向RM汇报负载信息和自身的健康状况。
+
+- EngineConnBuildRequest:LinkisManager传递给ECM的启动引擎命令,里面封装了该引擎的所有标签信息、所需资源和一些参数配置信息。
+
+- EngineConnLaunchRequest:包含了启动一个EngineConn所需的BML物料、环境变量、ECM本地必需环境变量、启动命令等信息,让ECM可以依此构建出一个完整的EngineConn启动脚本。
+
+ECM接收到LinkisManager传递过来的EngineConnBuildRequest命令后,主要分为三步来启动EngineConn:1. 请求EngineConnPluginServer,获取EngineConnPluginServer封装出的EngineConnLaunchRequest;2. 解析EngineConnLaunchRequest,封装成EngineConn启动脚本;3. 执行启动脚本,启动EngineConn。
+
+### 2.1 EngineConnPluginServer封装EngineConnLaunchRequest
+
+通过EngineConnBuildRequest的标签信息,拿到实际需要启动的EngineConn类型和对应版本,从EngineConnPluginServer的内存中获取到该EngineConn类型的EngineConnPlugin,通过该EngineConnPlugin的EngineConnLaunchBuilder,将EngineConnBuildRequest转换成EngineConnLaunchRequest。
+
+### 2.2 封装EngineConn启动脚本
+
+ECM获取到EngineConnLaunchRequest之后,将EngineConnLaunchRequest中的BML物料下载到本地,并检查EngineConnLaunchRequest要求的本地必需环境变量是否存在,校验通过后,将EngineConnLaunchRequest封装成一个EngineConn启动脚本
+
+### 2.3 执行启动脚本
+
+目前ECM只对Unix系统做了Bash命令的支持,即只支持Linux系统执行该启动脚本。
+
+启动前,会通过sudo命令,切换到对应的请求用户去执行该脚本,确保启动用户(即JVM用户)为Client端的请求用户。
+
+执行该启动脚本后,ECM会实时监听脚本的执行状态和执行日志,一旦执行状态返回非0,则立马向LinkisManager汇报EngineConn启动失败,整个流程完成;否则则一直监听启动脚本的日志和状态,直到该脚本执行完成。
+
+## 3. EngineConn初始化
+
+ECM执行了EngineConn的启动脚本后,EngineConn微服务正式启动。
+
+名词解释:
+
+- EngineConn微服务:指包含了一个EngineConn、一个或多个Executor,用于对计算任务提供计算能力的实际微服务。我们说的新增一个EngineConn,其实指的就是新增一个EngineConn微服务。
+
+- EngineConn:引擎连接器,是与底层计算存储引擎的实际连接单元,包含了与实际引擎的会话信息。它与Executor的差别,是EngineConn只是起到一个连接、一个客户端的作用,并不真正的去执行计算。如SparkEngineConn,其会话信息为SparkSession。
+
+- Executor:执行器,作为真正的计算存储场景执行器,是实际的计算存储逻辑执行单元,对EngineConn各种能力的具体抽象,提供交互式执行、订阅式执行、响应式执行等多种不同的架构能力。
+
+EngineConn微服务的初始化一般分为三个阶段:
+
+1. 初始化具体引擎的EngineConn。先通过Java main方法的命令行参数,封装出一个包含了相关标签信息、启动信息和参数信息的EngineCreationContext,通过EngineCreationContext初始化EngineConn,完成EngineConn与底层Engine的连接建立,如:SparkEngineConn会在该阶段初始化一个SparkSession,用于与一个Spark application建立了连通关系。
+
+2. 初始化Executor。EngineConn初始化之后,接下来会根据实际的使用场景,初始化对应的Executor,为接下来的用户使用,提供服务能力。比如:交互式计算场景的SparkEngineConn,会初始化一系列可以用于提交执行SQL、PySpark、Scala代码能力的Executor,支持Client往该SparkEngineConn提交执行SQL、PySpark、Scala等代码。
+
+3. 定时向LinkisManager汇报心跳,并等待EngineConn结束退出。当EngineConn对应的底层引擎异常、或是超过最大空闲时间、或是Executor执行完成、或是用户手动kill时,该EngineConn自动结束退出。
+
+----
+
+到了这里,EngineConn的新增流程就基本结束了,最后我们再来总结一下EngineConn的新增流程:
+
+- 客户端向LinkisManager发起新增EngineConn的请求;
+
+- LinkisManager校验参数合法性,先是根据标签选择合适的ECM,再根据用户请求确认本次新增EngineConn所需的资源,向LinkisManager的RM模块申请资源,申请通过后要求ECM按要求启动一个新的EngineConn;
+
+- ECM先请求EngineConnPluginServer获取一个包含了启动一个EngineConn所需的BML物料、环境变量、ECM本地必需环境变量、启动命令等信息的EngineConnLaunchRequest,然后封装出EngineConn的启动脚本,最后执行启动脚本,启动该EngineConn;
+
+- EngineConn初始化具体引擎的EngineConn,然后根据实际的使用场景,初始化对应的Executor,为接下来的用户使用,提供服务能力。最后定时向LinkisManager汇报心跳,等待正常结束或被用户终止。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/engine-conn-metrics.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/engine-conn-metrics.md
new file mode 100644
index 00000000000..e5fa561def5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/engine-conn-metrics.md
@@ -0,0 +1,77 @@
+---
+title: EngineConn Metrics 上报特性
+sidebar_position: 5
+tags: [Feature]
+---
+
+
+## 1. 功能需求
+### 1.1 需求背景
+ 上报信息缺少引擎信息、以及上报的资源和进度接口有冗余,降低了性能,需要对其进行优化调整,并且在上报协议中增加扩展模块。
+
+### 1.2 目标
+- 增加了包含资源、进度、额外信息的RPC 协议,支持在一次请求中上报这些信息
+- 重构已有的资源、进度上报的链路,将上报相关信息的动作合并为一个请求
+
+## 2. 总体设计
+
+本次需求涉及`linkis-entrance、linkis-computation-orchestrator、linkis-orchestrator-ecm-plugin、linkis-computation-engineconn`模块。在`computation-engineconn`模块添加和重构上报信息,并且在entrance端解析这些信息和入库。
+
+### 2.1 技术架构
+
+引擎信息上报架构如图所示。用户提交任务到entrance后,entrance向linkismanager申请引擎。
+申请到引擎后,向EngineConn提交任务,并接收任务的定时上报(资源、进度、状态)。直到任务执行完毕,entrance在用户查询时返回最终结果。
+本次需求修改,需要在entrance中新增引擎metrics信息入库;
+在Orchestrator中将Resource和Progress接口信息合并,并且增加metrics等额外信息;
+在交互式引擎ComputationEngineConn端将上报的资源和进度信息合并,并且额外上报引擎统计信息。
+
+![engineconn-mitrics-1.png](/Images-zh/Architecture/EngineConn/engineconn-mitrics-1.png)
+
+
+### 2.2 业务架构
+此次特性涉及功能点模块如下:
+
+| 一级模块 | 二级模块 | 功能点 |
+| :------------ | :------------ | :------------ |
+| Entrance | | 合并资源和进度接口;解析新增引擎metrics |
+| Orchestrator | orchestrator-core | 合并资源和进度接口;处理TaskRunningInfo消息 |
+| Orchestrator | orchestrator-plugin-ecm | 合并监听引擎信息的资源和进度接口 |
+| Orchestrator | computation-engineconn | 合并资源和进度的上报接口;新增上报引擎示例metrics |
+
+
+## 3. 模块设计
+### 核心执行流程
+- [输入端]输入端为交互式引擎端`computation-engineconn`。引擎在执行任务时,上报运行信息`TaskRunningInfo`,包含原有的`TaskProgressInfo`和`TaskResourceInfo`,新增了引擎示例信息和引擎现有任务数信息。
+- [处理流程]`orchestrator-plugin-ecm`负责监听引擎运行任务时的上报信息,接收上报信息,并生成`TaskRunningInfoEvent`异步消息,
+发给`OrchestratorAsyncListenerBus`处理。注册到`OrchestratorAsyncListener`的`TaskRunningInfoListener`收到消息,触发`listener`方法,回调到`Entrance`的Job的`TaskRunningInfo`回调方法。
+回调方法解析出`TaskRunningInfo`中的资源、进度、引擎`metrancs`信息,分别进行持久化。
+
+![engineconn-mitrics-2.png](/Images-zh/Architecture/EngineConn/engineconn-mitrics-2.png)
+
+## 4. 数据结构
+
+需求新增了`RPC protocol TaskRunningInfo` ,无新增db表
+
+## 5. 接口设计
+无对外接口
+
+## 6. 非功能性设计:
+### 6.1 安全
+RPC接口内部鉴权,不涉及对外安全问题
+
+### 6.2 性能
+合并了两个RPC接口,减少上报次数,提升了性能
+
+### 6.3 容量
+metrics信息较少,无影响
+
+### 6.4 高可用
+不涉及
+
+
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/engine-conn-plugin.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/engine-conn-plugin.md
new file mode 100644
index 00000000000..1ab526636e9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/engine-conn-plugin.md
@@ -0,0 +1,73 @@
+---
+title: EngineConnPlugin 服务架构
+sidebar_position: 6
+---
+
+引擎连接器插件是一种能够动态加载引擎连接器并减少版本冲突发生的实现,具有方便扩展、快速刷新、选择加载的特性。为了能让开发用户自由扩展Linkis的Engine引擎,并动态加载引擎依赖避免版本冲突,设计研发了EngineConnPlugin,允许以实现既定的插件化接口的方式引入新引擎到计算中间件的执行生命周期里,
+插件化接口对引擎的定义做了拆解,包括参数初始化、分配引擎资源,构建引擎连接以及设定引擎默认标签。
+
+一、ECP架构图
+
+![](/Images-zh/Architecture/linkis-engineConnPlugin-01.png)
+
+二级模块介绍:
+==============
+
+EngineConn-Plugin-Server
+------------------------
+
+引擎连接器插件服务是对外提供注册插件、管理插件,以及插件资源构建的入口服务。成功注册加载的引擎插件会包含资源分配和启动参数配置的逻辑,在引擎初始化过程中,EngineConn
+Manager等其他服务通过RPC请求调用Plugin Server里对应插件的逻辑。
+
+| 核心类 | 核心功能 |
+|----------------------------------|---------------------------------------|
+| EngineConnLaunchService | 负责构建引擎连接器启动请求 |
+| EngineConnResourceFactoryService | 负责生成引擎资源 |
+| EngineConnResourceService | 负责从BML下载引擎连接器使用的资源文件 |
+
+
+EngineConn-Plugin-Loader 引擎连接器插件加载器
+---------------------------------------
+
+引擎连接器插件加载器是用来根据请求参数动态加载引擎连接器插件的加载器,并具有缓存的特性。具体加载流程主要由两部分组成:1)插件资源例如主程序包和程序依赖包等加载到本地(未开放)。2)插件资源从本地动态加载入服务进程环境中,例如通过类加载器加载入JVM虚拟机。
+
+| 核心类 | 核心功能 |
+|---------------------------------|----------------------------------------------|
+| EngineConnPluginsResourceLoader | 加载引擎连接器插件资源 |
+| EngineConnPluginsLoader | 加载引擎连接器插件实例,或者从缓存加载已有的 |
+| EngineConnPluginClassLoader | 动态从jar中实例化引擎连接器实例 |
+
+EngineConn-Plugin-Cache 引擎插件缓存模组
+----------------------------------------
+
+引擎连接器插件缓存是专门用来缓存已经加载的引擎连接器的缓存服务,并支持读取、更新、移除的能力。已经加载进服务进程的插件会被连同其类加载器一起缓存起来,避免多次加载影响效率;同时缓存模组会定时通知加载器去更新插件资源,如果发现有变动,会重新加载并自动刷新缓存。
+
+| 核心类 | 核心功能 |
+|-----------------------------|------------------------------|
+| EngineConnPluginCache | 缓存已经加载的引擎连接器实例 |
+| RefreshPluginCacheContainer | 定时刷新缓存的引擎连接器 |
+
+EngineConn-Plugin-Core:引擎连接器插件核心模组
+---------------------------------------------
+
+引擎连接器插件核心模块是引擎连接器插件的核心模块。包含引擎插件基本功能实现,如引擎连接器启动命令构建,引擎资源工厂构建和引擎连接器插件核心接口实现。
+
+| 核心类 | 核心功能 |
+|-------------------------|----------------------------------------------------------|
+| EngineConnLaunchBuilder | 构建引擎连接器启动请求 |
+| EngineConnFactory | 创建引擎连接器 |
+| EngineConnPlugin | 引擎连接器插件实现接口,包括资源,命令,实例的构建方法。 |
+| EngineResourceFactory | 引擎资源的创建工厂 |
+
+EngineConn-Plugins:引擎连接插件集合
+-----------------------------------
+
+引擎连接插件集合是用来放置已经基于我们定义的插件接口实现的默认引擎连接器插件库。提供了默认引擎连接器实现,如jdbc、spark、python、shell等。用户可以基于自己的需求参考已经实现的案例,实现更多的引擎连接器。
+
+| 核心类 | 核心功能 |
+|---------------------|------------------|
+| engineplugin-jdbc | jdbc引擎连接器 |
+| engineplugin-shell | shell引擎连接器 |
+| engineplugin-spark | spark引擎连接器 |
+| engineplugin-python | python引擎连接器 |
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/engine-conn.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/engine-conn.md
new file mode 100644
index 00000000000..331bf87243a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/engine/engine-conn.md
@@ -0,0 +1,141 @@
+---
+title: EngineConn 架构
+sidebar_position: 1
+---
+
+
+## 1.总述
+
+EngineConn:引擎连接器,用于连接底层的计算存储引擎,完成任务的执行、任务信息推送和结果返回等,是Linkis提供计算存储能力的基础。
+
+## 2. 总体设计
+
+ EngineConn的整体设计思路,启动的时候会完成底层引擎Session信息的获取和存储,完成EngineConn进程和底层引擎的连接,然后通过Executor执行器单元完成任务的调度到EngineConn存储的底层引擎Session中进行执行,并获取执行相关的信息。
+
+### 2.1 技术架构
+
+**关键名词介绍:**
+
+**EngineConn:** 用于存储底层引擎的Session信息。来完成和底层引擎的连接,例如Spark引擎存储的是SparkSession。
+
+**Executor:**用于接受调用方(如:Entrance)传过来的任务的调度执行器,并将任务最终提交给底层的引擎Session进行执行,不同的任务实现不同的Executor类。使用最多的是交互式ComputationExecutor,用于接受任务并实时推送任务信息给到调用方。以及非交互式的只接受一次任务的ManageableOnceExecutor,用于完成对EngineConn启动的任务的提交执行。
+
+![arc](/Images/Architecture/engine/ec_arc_01.png)
+
+### 2.2 业务架构
+
+|组件名|一级模块|二级模块|功能点|
+|:----|:----|:----|:----|
+|Linkis|EngineConn|linkis-engineconn-common|引擎连接器的通用模块,定义了引擎连接器中最基础的实体类和接口。|
+|Linkis|EngineConn|linkis-engineconn-core|引擎连接器的核心模块,定义了EngineConn的核心逻辑涉及的接口。|
+|Linkis|EngineConn|linkis-executor-core|执行器的核心模块,定义了执行器相关的核心类。|
+|Linkis|EngineConn|linkis-accessible-executor|能够被访问的Executor底层抽象。可以通过RPC请求与它交互,从而获取它的状态、负载、并发等基础指标Metrics数据|
+|Linkis|EngineConn|linkis-computation-engineconn|提供交互式计算任务能力的相关类。|
+
+## 3. 模块设计
+
+输入:调用方执行任务
+
+输出:返回执行状态、结果、日志等任务信息
+
+关键逻辑:任务执行的关键逻辑的时序图
+
+![time](/Images/Architecture/engine/ec_arc_02.png)
+
+关键说明:
+
+1. 如果是串行Executor,EngineConn接收到任务后就会将EngineConn标记为Busy状态,不能再接受其他任务,并且会判断任务的锁是否一致,防止EngineConn被多个调用方同时提交的情况。任务执行完变成Unlock状态
+2. 如果是并行的Executor,EngineConn接收到任务后,状态还是Unlock状态,可以继续接受任务,只有当达到任务并发数或者机器指标异常才会标记为Busy状态
+3. 如果是Once类型任务,EngineConn启动后就会自动执行任务,任务执行结束EngineConn进程退出
+
+## 4. 数据结构/存储设计
+
+不涉及
+
+## 5. 接口设计
+
+**其他类简要介绍:**
+
+linkis-engineconn-common引擎连接器的通用模块,定义了引擎连接器中最基础的实体类和接口。
+
+|核心Service|核心功能|
+|:----|:----|
+|EngineCreationContext|包含了EngineConn在启动期间的上下文信息|
+|EngineConn|包含了EngineConn的具体信息,如类型、与底层计算存储引擎的具体连接信息等|
+|EngineExecution|提供Executor的创建逻辑|
+|EngineConnHook|定义引擎启动各个阶段前后的操作|
+
+linkis-engineconn-core引擎连接器的核心模块,定义了EngineConn的核心逻辑涉及的接口。
+
+|核心类|核心功能|
+|:----|:----|
+|EngineConnManager|提供创建、获取EngineConn的相关接口|
+|ExecutorManager|提供创建、获取Executor的相关接口|
+|ShutdownHook|定义引擎关闭阶段的操作|
+|EngineConnServer|EngineConn微服务的启动类|
+
+linkis-executor-core执行器的核心模块,定义了执行器相关的核心类。执行器是真正的计算执行单元,负责将用户代码提交给EngineConn进行执行。
+
+|核心类|核心功能|
+|:----|:----|
+|Executor|是实际的计算逻辑执行单元,并提供对引擎各种能力的顶层抽象。|
+|EngineConnAsyncEvent|定义了EngineConn相关的异步事件|
+|EngineConnSyncEvent|定义了EngineConn相关的同步事件|
+|EngineConnAsyncListener|定义了EngineConn相关异步事件监听器|
+|EngineConnSyncListener|定义了EngineConn相关同步事件监听器|
+|EngineConnAsyncListenerBus|定义了EngineConn异步事件的监听器总线|
+|EngineConnSyncListenerBus|定义了EngineConn同步事件的监听器总线|
+|ExecutorListenerBusContext|定义了EngineConn事件监听器的上下文|
+|LabelService|提供标签上报功能|
+|ManagerService|提供与LinkisManager进行信息传递的功能|
+
+linkis-accessible-executor:能够被访问的Executor底层抽象。可以通过RPC请求与它交互,从而获取它的状态、负载、并发等基础指标Metrics数据。
+
+|核心类|核心功能|
+|:----|:----|
+|LogCache|提供日志缓存的功能|
+|AccessibleExecutor|能够被访问的Executor,可以通过RPC请求与它交互。|
+|NodeHealthyInfoManager|管理Executor的健康信息|
+|NodeHeartbeatMsgManager|管理Executor的心跳信息|
+|NodeOverLoadInfoManager|管理Executor的负载信息|
+|Listener相关|提供与Executor相关的事件以及对应的监听器定义|
+|EngineConnTimedLock|定义Executor级别的锁|
+|AccessibleService|提供Executor的启停、状态获取功能|
+|ExecutorHeartbeatService|提供Executor的心跳相关功能|
+|LockService|提供锁管理功能|
+|LogService|提供日志管理功能|
+|EngineConnCallback|定义EngineConn的回调逻辑|
+
+提供交互式计算任务能力的相关类。
+
+|核心类|核心功能|
+|:----|:----|
+|EngineConnTask|定义了提交给EngineConn的交互式计算任务|
+|ComputationExecutor|定义了交互式Executor,具备状态查询、任务kill等交互式能力,默认每次只能执行一次任务。|
+|ConcurrentComputationExecutor|交互式同步并发Executor,继承于ComputationExecutor,但是支持同时执行多个任务|
+|AsyncConcurrentComputationExecutor|交互式异步并发Executor,继承ComputationExecutor,支持同时执行多个任务,并且任务不占用执行线程采用异步通知的形式|
+|TaskExecutionService|提供对交互式计算任务的管理功能|
+
+
+## 6. 非功能性设计
+
+### 6.1 安全
+
+1. 任务所有相关的信息,只能提交用户才能进行查询
+2. EngineConn进程的默认启动用户为提交用户
+### 6.2 性能
+
+支持并发的EngineConn支持同时并发跑大量任务,如单个trino的EngineConn可以同时跑300多个trino任务
+
+### 6.3 容量
+
+不涉及
+
+### 6.4 高可用
+
+EngineConn是按需、按任务启动的进程。支持高可用
+
+### 6.5 数据质量
+
+不涉及
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/entrance.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/entrance.md
new file mode 100644
index 00000000000..84130e6aa51
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/entrance.md
@@ -0,0 +1,28 @@
+---
+title: 入口服务 Entrance 架构
+sidebar_position: 3
+---
+
+Linkis任务提交入口是用来负责计算任务的接收、调度、转发执行请求、生命周期管理的服务,并且能把计算结果、日志、进度返回给调用方,是从Linkis0.X的Entrance拆分出来的原生能力。
+
+一、Entrance架构图
+
+![](/Images-zh/Architecture/linkis-entrance-01.png)
+
+**二级模块介绍:**
+
+EntranceServer
+--------------
+
+EntranceServer计算任务提交入口服务是Entrance的核心服务,负责Linkis执行任务的接收、调度、执行状态跟踪、作业生命周期管理等。主要实现了把任务执行请求转成可调度的Job,调度、申请Executor执行,Job状态管理,结果集管理,日志管理等。
+
+| 核心类 | 核心功能 |
+|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
+| EntranceInterceptor | Entrance拦截器用来对传入参数task进行信息的补充,使得这个task的内容更加完整, 补充的信息包括: 数据库信息补充、自定义变量替换、代码检查、limit限制等 |
+| EntranceParser | Entrance解析器用来把请求参数Map解析成Task,也可以将Task转成可调度的Job,或者把Job转成可存储的Task。 |
+| EntranceExecutorManager | Entrance执行器管理为EntranceJob的执行创建Executor,并维护Job和Executor的关系,且支持Job请求的标签能力 |
+| PersistenceManager | 持久化管理负责作业相关的持久化操作,如结果集路径、作业状态变化、进度等存储到数据库。 |
+| ResultSetEngine | 结果集引擎负责作业运行后的结果集存储,以文件的形式保存到HDFS或者本地存储目录。 |
+| LogManager | 日志管理负责作业日志的存储并对接日志错误码管理。 |
+| Scheduler | 作业调度器负责所有Job的调度执行,主要通过调度作业队列实现。 |
+| | |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-cli.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-cli.md
new file mode 100644
index 00000000000..9ce64d01bd6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-cli.md
@@ -0,0 +1,38 @@
+---
+title: Linkis Client 架构设计
+sidebar_position: 2
+---
+
+为用户提供向Linkis提交执行任务的轻量级客户端。
+
+#### Linkis-Client架构图
+
+![img](/Images-zh/Architecture/linkis-client-01.png)
+
+
+
+#### 二级模块介绍
+
+##### Linkis-Computation-Client
+
+以SDK的形式为用户提供向Linkis提交执行任务的接口。
+
+| 核心类 | 核心功能 |
+| ---------- | ------------------------------------------------ |
+| Action | 定义了请求的属性,包含的方法和参数 |
+| Result | 定义了返回结果的属性,包含的方法和参数 |
+| UJESClient | 负责请求的提交,执行,状态、结果和相关参数的获取 |
+
+
+
+##### Linkis-Cli
+
+以shell命令端的形式为用户提供向Linkis提交执行任务的方式。
+
+| 核心类 | 核心功能 |
+| ----------- | ------------------------------------------------------------ |
+| Common | 定义了指令模板父类、指令解析实体类、任务提交执行各环节的父类和接口 |
+| Core | 负责解析输入、任务执行和定义输出方式 |
+| Application | 调用linkis-computation-client执行任务,并实时拉取日志和最终结果 |
+
+
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/_category_.json
new file mode 100644
index 00000000000..2682d5e9e76
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "Manager 架构",
+ "position": 4
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/app-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/app-manager.md
new file mode 100644
index 00000000000..a7ce769b7f9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/app-manager.md
@@ -0,0 +1,49 @@
+---
+title: AppManager 架构
+sidebar_position: 1
+---
+
+## 背景
+针对旧版本Linkis的Entrance模块负责太多的职责,对Engine的管理能力较弱,且不易于后续的扩展,新抽出了AppManager模块,完成
+以下职责:
+1. 新增AM模块将Entrance之前做的管理Engine的功能移动到AM模块
+2. AM需要支持操作Engine,包括:新增、复用、回收、预热、切换等功能
+3. 需要对接Manager模块对外提供Engine的管理功能:包括Engine状态维护、引擎列表维护、引擎信息等
+4. AM需要管理EM服务,需要完成EM的注册并将资源注册转发给RM进行EM的资源注册
+5. AM需要对接Label模块,包括EM/Engine的增删需要通知标签管理器进行标签更新
+6. AM另外需要对接标签模块进行标签解析,并需要通过一系列标签获取一些列打好分的serverInstance列表(EM和Engine怎么区分,1、标签完全不一样)
+7. 需要对外提供基础接口:包括引擎和引擎管理器的增删改,提供metric查询等
+
+## 架构图
+
+![](/Images-zh/Architecture/AppManager-03.png)
+
+如上图所示:AM在LinkisMaster中属于AppManager模块,作为一个Service提供服务
+
+新引擎申请流程图:
+![](/Images-zh/Architecture/AppManager-02.png)
+
+
+从上面的引擎生命周期流程图可知,Entrance已经不在做Engine的管理工作,engine的启动和管理都由AM控制。
+
+## 架构说明:
+
+AppManager主要包含了引擎服务和EM服务:
+引擎服务包含了所有和引擎EngineConn相关的操作,如引擎创建、引擎复用、引擎切换、引擎回收、引擎停止、引擎销毁等。
+EM服务负责所有EngineConnManager的信息管理,可以在线上对ECM进行服务管理,包括标签修改,暂停ECM服务,获取ECM实例信息,获取ECM运行的引擎信息,kill掉ECM操作,还可以根据EM Node的信息查询所有的EngineNode,也支持按用户查找,保存了EM Node的负载信息、节点健康信息、资源使用信息等。
+新的EngineConnManager和EngineConn都支持标签管理,引擎的类型也增加了离线、流式、交互式支持。
+
+引擎创建:专门负责LinkisManager服务的新建引擎功能,引擎启动模块完全负责一个新引擎的创建,包括获取ECM标签集合、资源申请、获得引擎启动命令,通知ECM新建引擎,更新引擎列表等。
+CreateEngienRequest->RPC/Rest -> MasterEventHandler ->CreateEngineService ->
+->LabelContext/EnginePlugin/RMResourcevice->(RcycleEngineService)EngineNodeManager->EMNodeManager->sender.ask(EngineLaunchRequest)->EngineManager服务->EngineNodeManager->EngineLocker->Engine->EngineNodeManager->EngineFactory=>EngineService=>ServerInstance
+在创建引擎是存在和RM交互的部分,EnginePlugin应该需要通过Lables返回具体的资源类型,然后AM向RM发送资源请求
+
+引擎复用:为了减少引擎启动所耗费的时间和资源,引擎使用必须优先考虑复用原则,复用一般是指复用用户已经创建好的引擎,引擎复用模块负责提供可复用引擎集合,选举并锁定引擎后开始使用,或者返回没有可以复用的引擎。
+ReuseEngienRequest->RPC/Rest -> MasterEventHandler ->ReuseEngineService ->abelContext->EngineNodeManager->EngineSelector->EngineLocker->Engine->EngineNodeManager->EngineReuser->EngineService=>ServerInstance
+
+引擎切换:主要是指对已有引擎进行标签切换,例如创建引擎的时候是由Creator1创建的,现在可以通过引擎切换改成Creator2。这个时候就可以允许当前引擎接收标签为Creator2的任务了。
+SwitchEngienRequest->RPC/Rest -> MasterEventHandler ->SwitchEngineService ->LabelContext/EnginePlugin/RMResourcevice->EngineNodeManager->EngineLocker->Engine->EngineNodeManager->EngineReuser->EngineService=>ServerInstance
+
+引擎管理器:引擎管理负责管理所有引擎的基本信息、元数据信息
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/engine-conn-history.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/engine-conn-history.md
new file mode 100644
index 00000000000..e0164797bfc
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/engine-conn-history.md
@@ -0,0 +1,89 @@
+---
+title: EngineConn 历史信息记录特性
+sidebar_position: 4
+tags: [Feature]
+---
+
+## 1. 功能需求
+### 1.1 需求背景
+ 1.1.3版本前,LinkisManager只记录了在运行中的EngineConn的信息和资源使用,但是在任务结束后这些信息就丢失了。如果需要做历史EC的一些统计和查看,或者要去查看已经结束的EC的日志,过于繁琐,因此对于历史EC的记录显得较为重要。
+
+### 1.2 目标
+- 完成EC信息和资源信息持久化到DB的存储
+- 支持通过restful接口完成历史EC信息的查看和搜索
+- 支持查看已经结束EC的日志
+
+## 2. 总体设计
+
+此次特性新增主要修改为LinkisManager下的RM和AM模块,并新增了一种信息记录表。
+
+### 2.1 技术架构
+因为此次的实现需要记录EC的信息和资源信息,而资源信息分为请求资源、真实使用资源、释放资源等三个概念,而且都需要进行记录。所以此次实现大体方案是:基于EC在ResourceManager的生命周期去进行实现,在EC完成以上三个阶段时,都加上EC信息的更新操作。整体如下图所示:
+
+![engineconn-history-01.png](/Images-zh/Architecture/EngineConn/engineconn-history-01.png)
+
+
+
+### 2.2 业务架构
+
+此次的特性主要是为了完成历史EC的信息记录和支持历史技术EC的日志查看。功能点设计的模块如下:
+
+| 一级模块 | 二级模块 | 功能点 |
+|---|---|---|
+| LinkisManager | ResourceManager| 在EC请求资源、上报使用资源、释放资源时完成EC信息的记录|
+| LinkisManager | AppManager| 提供list和搜索所有历史EC信息的接口|
+
+## 3. 模块设计
+### 核心执行流程
+
+- [输入端] 输入端主要为创建引擎时的请求资源、引擎启动后上报的真实使用资源、引擎退出时释放资源时输入的信息,主要包括请求的label、资源、EC唯一的ticketid、资源类型等.
+- [处理流程] 信息记录service,对输入的数据进行处理,通过标签会解析出对应的引擎信息、用户、creator,以及日志路径。通过资源类型确认是资源请求、使用、释放。接着将这些信息存储到DB中。
+
+调用时序图如下:
+![engineconn-history-02.png](/Images-zh/Architecture/EngineConn/engineconn-history-02.png)
+
+
+## 4. 数据结构:
+```sql
+# EC信息资源记录表
+DROP TABLE IF EXISTS `linkis_cg_ec_resource_info_record`;
+CREATE TABLE `linkis_cg_ec_resource_info_record` (
+ `id` INT(20) NOT NULL AUTO_INCREMENT,
+ `label_value` VARCHAR(255) NOT NULL COMMENT 'ec labels stringValue',
+ `create_user` VARCHAR(128) NOT NULL COMMENT 'ec create user',
+ `service_instance` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'ec instance info',
+ `ecm_instance` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'ecm instance info ',
+ `ticket_id` VARCHAR(100) NOT NULL COMMENT 'ec ticket id',
+ `log_dir_suffix` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'log path',
+ `request_times` INT(8) COMMENT 'resource request times',
+ `request_resource` VARCHAR(255) COMMENT 'request resource',
+ `used_times` INT(8) COMMENT 'resource used times',
+ `used_resource` VARCHAR(255) COMMENT 'used resource',
+ `release_times` INT(8) COMMENT 'resource released times',
+ `released_resource` VARCHAR(255) COMMENT 'released resource',
+ `release_time` datetime DEFAULT NULL COMMENT 'released time',
+ `used_time` datetime DEFAULT NULL COMMENT 'used time',
+ `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'create time',
+ PRIMARY KEY (`id`),
+ KEY (`ticket_id`),
+ UNIQUE KEY `label_value_ticket_id` (`ticket_id`,`label_value`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
+```
+
+## 5. 接口设计
+引擎历史管理页面API接口,参考文档 管理台添加历史引擎页面
+
+## 6. 非功能性设计
+
+### 6.1 安全
+不涉及安全问题,restful接口需要登录认证
+
+### 6.2 性能
+对引擎生命周期性能影响较小
+
+### 6.3 容量
+需要定期进行清理
+
+### 6.4 高可用
+不涉及
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/label-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/label-manager.md
new file mode 100644
index 00000000000..92b8392ab6a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/label-manager.md
@@ -0,0 +1,43 @@
+---
+title: LabelManager 架构
+sidebar_position: 3
+---
+
+#### 简述
+LabelManager是Linkis中对上层应用提供标签服务的功能模组,运用标签技术管理集群资源分配、服务节点选举、用户权限匹配以及网关路由转发;包含支持各种自定义Label标签的泛化解析处理工具,以及通用的标签匹配评分器。
+
+### 整体架构示意
+
+![整体架构示意图](/Images-zh/Architecture/LabelManager/label_manager_global.png)
+
+#### 架构说明
+- LabelBuilder: 承担着标签解析的工作,从输入的标签类型、关键字或者字符数值中解析得到具体的标签实体,有默认的泛化实现类也可做自定义扩展。
+- LabelEntities: 指代标签实体集合,有且包含集群标签,配置标签,引擎标签,节点标签,路由标签,搜索标签等。
+- NodeLabelService: 实例/节点与标签的关联服务接口类,定义对两者关联关系的增删改查以及根据标签匹配实例/节点的接口方法。
+- UserLabelService: 声明用户与标签的关联操作。
+- ResourceLabelService: 声明集群资源与标签的关联操作,涉及到对组合标签的资源管理,清理或设置标签关联的资源数值。
+- NodeLabelScorer: 节点标签评分器,对应不同的标签匹配算法的实现,使用评分表示节点的标签匹配度。
+
+### 一. LabelBuilder解析流程
+以泛化标签解析类GenericLabelBuilder为例,阐明整体流程:
+![泛化标签解析流程](/Images-zh/Architecture/LabelManager/label_manager_builder.png)
+标签解析/构建的流程概括包含几步:
+1. 根据输入选择要构建解析的合适标签类。
+2. 根据标签类的定义信息,递归解析泛型结构,得到具体的标签值类型。
+3. 转化输入值对象到标签值类型,运用隐式转化或正反解析框架。
+4. 根据1-3的返回,实例化标签,并根据不同的标签类进行一些后置操作。
+
+### 二. NodeLabelScorer打分流程
+为了根据Linkis用户执行请求中附带的标签列表挑选合适的引擎节点,需要对符合的引擎列表做择优,量化为引擎节点的标签匹配度即评分。
+在标签定义里,每个标签都有feature特征值,分别为CORE,SUITABLE,PRIORITIZED,OPTIONAL,每个特征值都有一个boost值,相当于权重和激励值,
+同时有些特征例CORE和SUITABLE为必须唯一特征即在匹配过程中需做强过滤,且一个节点只能分别关联一个CORE/SUITABLE标签。
+根据现有标签,节点,请求附带标签三者之间的关系,可以绘制出如下示意图:
+![标签打分](/Images-zh/Architecture/LabelManager/label_manager_scorer.png)
+
+自带的默认评分逻辑过程应大体包含以下几点步骤:
+1. 方法的输入应该为两组网络关系列表,分别是`Label -> Node` 和 `Node -> Label`, 其中`Node -> Label`关系里的Node节点必须具有请求里涉及到所有CORE以及SUITABLE特征的标签,这些节点也称为备选节点。
+2. 第一步遍历计算`Node -> Label`关系列表,遍历每个节点关联的标签Label,这一步先给标签打分,如果标签不是请求中附带的标签,打分为0,
+否则打分为: (基本分/该标签对应特征值在请求中的出现次数) * 对应特征值的激励值,其中基本分默认为1,节点的初始分为相关联的标签打分的总和;其中因为CORE/SUITABLE类型标签为必须唯一标签,出现次数恒定为1。
+3. 得到节点的初始分后,第二步遍历计算`Label -> Node`关系,由于第一步中忽略了非请求附带标签对评分的作用,但无关标签比重确实会对评分造成影响,对应这类的标签统一打上UNKNOWN的特征,同样该特征也有相对应的激励值;
+我们设定无关标签关联的备选节点占总关联节点的比重越高,对评分的影响越显著,以此可以对第一步得出的节点初始分做进一步累加。
+4. 对得到的备选节点的分数做标准差归一化,并排序。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/overview.md
new file mode 100644
index 00000000000..ef78d69c07d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/overview.md
@@ -0,0 +1,80 @@
+---
+title: Linkis Manager 服务架构
+sidebar_position: 5
+---
+
+
+LinkisManager架构设计
+====================
+
+LinkisManager作为Linkis的一个独立微服务,对外提供了AppManager(应用管理)、ResourceManager(资源管理)、LabelManager(标签管理)的能力,能够支持多活部署,具备高可用、易扩展的特性。
+
+## 一. 架构图
+
+![01](/Images-zh/Architecture/LinkisManager/LinkisManager-01.png)
+
+### 名词解释
+- EngineConnManager(ECM): 引擎管理器,用于启动和管理引擎
+- EngineConn(EC):引擎连接器,用于连接底层计算引擎
+- ResourceManager(RM):资源管理器,用于管理节点资源
+
+## 二. 二级模块介绍
+
+### 1. 应用管理模块 linkis-application-manager
+
+AppManager用于引擎的统一调度和管理
+
+| 核心接口/类 | 主要功能 |
+|------------|--------|
+|EMInfoService | 定义了EngineConnManager信息查询、修改功能 |
+|EMRegisterService| 定义了EngineConnManager注册功能 |
+|EMEngineService | 定义了EngineConnManager对EngineConn的创建、查询、关闭功能 |
+|EngineAskEngineService | 定义了查询EngineConn的功能 |
+|EngineConnStatusCallbackService | 定义了处理EngineConn状态回调的功能 |
+|EngineCreateService | 定义了创建EngineConn的功能 |
+|EngineInfoService | 定义了EngineConn查询功能 |
+|EngineKillService | 定义了EngineConn的停止功能 |
+|EngineRecycleService | 定义了EngineConn的回收功能 |
+|EngineReuseService | 定义了EngineConn的复用功能 |
+|EngineStopService | 定义了EngineConn的自毁功能 |
+|EngineSwitchService | 定义了引擎切换功能 |
+|AMHeartbeatService | 提供了EngineConnManager和EngineConn节点心跳处理功能 |
+
+
+通过AppManager申请引擎流程如下:
+![](/Images-zh/Architecture/LinkisManager/AppManager-01.png)
+
+
+### 2. 标签管理模块 linkis-label-manager
+
+LabelManager提供标签管理和解析能力
+
+| 核心接口/类 | 主要功能 |
+|------------|--------|
+|LabelService | 提供了标签增删改查功能 |
+|ResourceLabelService | 提供了资源标签管理功能 |
+|UserLabelService | 提供了用户标签管理功能 |
+
+LabelManager架构图如下:
+![](/Images-zh/Architecture/LinkisManager/LabelManager-01.png)
+
+
+
+### 3. 资源管理模块 linkis-resource-manager
+
+ResourceManager用于管理引擎和队列的所有资源分配
+
+| 核心接口/类 | 主要功能 |
+|------------|--------|
+|RequestResourceService | 提供了EngineConn资源申请功能 |
+|ResourceManagerService | 提供了EngineConn资源释放功能 |
+|LabelResourceService | 提供了标签对应资源管理功能 |
+
+
+ResourceManager架构图如下:
+
+![](/Images-zh/Architecture/LinkisManager/ResourceManager-01.png)
+
+### 4. 监控模块 linkis-manager-monitor
+
+Monitor提供了节点状态监控的功能
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/resource-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/resource-manager.md
new file mode 100644
index 00000000000..906f7886871
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/linkis-manager/resource-manager.md
@@ -0,0 +1,154 @@
+---
+title: ResourceManager 架构
+sidebar_position: 2
+---
+
+ResourceManager(简称RM),是Linkis的计算资源管理模块,所有的EngineConn(简称EC)、EngineConnManager(简称ECM),甚至包括Yarn在内的外部资源,都由RM负责统筹管理。RM能够基于用户、ECM或其它通过复杂标签定义的粒度对资源进行管控。
+
+### RM在Linkis中的作用
+![01](/Images-zh/Architecture/rm-01.png)
+![02](/Images-zh/Architecture/rm-02.png)
+
+RM作为Linkis Manager的一部分,主要作用为:维护ECM上报的可用资源信息,处理ECM提出的资源申请,记录成功申请后,EC在生命周期内实时上报的实际资源使用信息,并提供查询当前资源使用情况的相关接口。
+
+Linkis中,与RM产生交互的其它服务主要有:
+
+- **引擎管理器,简称ECM**:处理启动引擎连接器请求的微服务。ECM作为资源的提供者,负责向RM注册资源(register)和下线资源(unregister)。同时,ECM作为引擎的管理者,负责代替准备启动的新引擎连接器向RM申请资源。每一个ECM实例,均在RM中有一条对应的资源记录,包含它提供的总资源、保护资源等信息,并动态更新已使用资源。
+![03](/Images-zh/Architecture/rm-03.png)
+
+- **引擎连接器,简称EC**,是用户作业的实际执行单元。同时,EC作为资源的实际使用者,负责向RM上报实际使用资源。每一个EC,均在RM中有一条对应的资源记录:在启动过程中,体现为锁定资源;在运行过程中,体现为已使用资源;在被结束之后,该资源记录随之被删除。
+![04](/Images-zh/Architecture/rm-04.png)
+
+### 资源的类型与格式
+
+![05](/Images-zh/Architecture/rm-07.png)
+
+如上图所示,所有的资源类均实现一个顶层的Resource接口,该接口定义了所有资源类均需要支持的计算和比较的方法,并进行相应的数学运算符的重载,使得资源之间能够像数字一样直接被计算和比较。
+
+| 运算符 | 对应方法 | 运算符 | 对应方法 |
+|--------|-------------|--------|-------------|
+| \+ | add | \> | moreThan |
+| \- | minus | \< | lessThan |
+| \* | multiply | = | equals |
+| / | divide | \>= | notLessThan |
+| \<= | notMoreThan | | |
+
+当前支持的资源类型如下表所示,所有的资源都有对应的json序列化与反序列化方法,能够通过json格式进行存储和在网络间传递:
+
+| 资源类型 | 描述 |
+| --------------------------- | ---------------------------------------------------------- |
+| MemoryResource | 内存资源 |
+| CPUResource | CPU资源 |
+| LoadResource | 同时具备内存与CPU的资源 |
+| YarnResource | Yarn队列资源(队列,队列内存,队列CPU,队列实例数) |
+| KubernetesResource | K8S集群资源(Namespace,CPU,内存) |
+| LoadInstanceResource | 服务器资源(内存,CPU,实例数) |
+| DriverAndYarnResource | 驱动器与Yarn执行器资源(同时具备服务器资源,Yarn队列资源) |
+| DriverAndKubernetesResource | 驱动器与K8S执行器资源(同时具备服务器资源,K8S资源) |
+| SpecialResource | 其它自定义资源 |
+
+### 可用资源管理
+
+RM中的可用资源,主要有两个来源:ECM上报的可用资源,以及Configuration模块中根据标签配置的资源限制。
+**ECM资源上报**:
+
+1. ECM启动时,会广播ECM注册的消息,RM接收到消息后,根据消息中包含的内容进行资源注册,资源相关的内容包括:
+- 总资源:该ECM能够提供的资源总数。
+- 保护资源:当剩余资源小于该资源时,不再允许继续分配资源。
+- 资源类型:如LoadResource,DriverAndYarnResource等类型名称。
+- 实例信息:机器名加端口名。
+
+2. RM在收到资源注册请求后,在资源表中新增一条记录,内容与接口的参数信息一致,并通过实例信息找到代表该ECM的标签,在资源、标签关联表中新增一条关联记录。
+
+3. ECM在关闭时,会广播ECM关闭的消息,RM接收到消息后,根据消息中的ECM实例信息来进行资源的下线,即删除该ECM实例标签对应的资源和关联记录。
+
+**Configuration模块标签资源配置**:
+
+用户能够在Configuration模块中,根据不同的标签组合进行资源数量限制的配置,如限制User/Creator/EngineType组合的最大可用资源。
+
+RM通过RPC消息,以组合标签为查询条件,向Configuration模块查询资源信息,并转换成Resource对象参与后续的比较和记录。
+
+
+### 资源使用管理
+
+**接收用户的资源申请**
+
+1. LinkisManager在收到启动EngineConn的请求时,会调用RM的资源申请接口,进行资源申请。资源申请接口接受一个可选的时间参数,当申请资源的等待时间超出该时间参数的限制时,该资源申请将自动作为失败处理。
+
+**判断是否有足够的资源**
+
+即为判断剩余可用资源是否大于申请资源,如果大于或等于,则资源充足;否则资源不充足。
+
+1. RM预处理资源申请中附带的标签信息,根据规则将原始的标签进行过滤、组合和转换等操作(如将User/Creator标签和EngineType标签进行组合),这使得后续的资源判断的粒度更加灵活多变。
+
+2. 在每个转换后的标签上逐一加锁,使得它们所对应的资源记录在资源申请的处理期间保持不变。
+
+3. 根据每个标签:
+
+ 1. 通过Persistence模块从数据库中查询对应的资源记录,如果该记录包含剩余可用资源,则直接用来比较。
+
+ 2. 如果没有直接的剩余可用资源记录,则通过[剩余可用资源=最大可用资源-已用资源-已锁定资源-保护资源]公式进行计算得出。
+
+ 3. 如果没有最大可用资源记录,则请求Configuration模块,看是否有配置的资源信息,如果有则使用到公式中进行计算,如果没有则跳过针对这个标签的资源判断。
+
+ 4. 如果没有任何资源记录,则跳过针对这个标签的资源判断。
+
+4. 只要有一个标签被判断为资源不充足,则资源申请失败,对每个标签逐一解锁。
+
+5. 只有所有标签都判断为资源充足的情况下,才成功通过资源申请,进入下一步。
+
+**锁定申请通过的资源**
+
+1. 根据申请通过的资源数量,在资源表中生成一条新的记录,并与每个标签进行关联。
+
+2. 如果对应的标签有剩余可用资源记录,则扣减对应的数量。
+
+3. 生成一个定时任务,在一定时间后检查这批锁定的资源是否被实际使用,如果超时未使用,则强制回收。
+
+4. 对每个标签进行解锁。
+
+**上报实际使用资源**
+
+1. EngineConn启动后,广播资源使用消息。RM收到消息后,检查该EngineConn对应的标签是否有锁定资源记录,如果没有,则报错。
+
+2. 如果有锁定资源,则对该EngineConn有关联的所有标签进行加锁。
+
+3. 对每个标签,将对应的锁定资源记录转换为已使用资源记录。
+
+4. 解锁所有标签。
+
+**释放实际使用资源**
+
+1. EngineConn结束生命周期后,广播资源回收消息。RM收到消息后,检查该EngineConn对应的标签是否有已使用资源记录。
+
+2. 如果有,则对该EngineConn有关联的所有标签进行加锁。
+
+3. 对每个标签,在已使用资源记录中减去对应的数量。
+
+4. 如果对应的标签有剩余可用资源记录,则增加对应的数量。
+
+5. 对每个标签解锁
+
+
+### 外部资源管理
+
+在RM中,为了更加灵活并有拓展性对资源进行分类,支持多集群的资源管控的同时,使得接入新的外部资源更加便利,在设计上进行了以下几点的考虑:
+
+1. 通过标签来对资源进行统一管理。资源注册后,与标签进行关联,使得资源的属性能够无限拓展。同时,资源申请也都带上标签,实现灵活的匹配。
+
+2. 将集群抽象成一个或多个标签,并在外部资源管理模块中维护每个集群标签对应的环境信息,实现动态的对接。
+
+3. 抽象出通用的外部资源管理模块,如需接入新的外部资源类型,只要实现固定的接口,即可将不同类型的资源信息转换为RM中的Resource实体,实现统一管理。
+
+![06](/Images-zh/Architecture/rm-06.png)
+
+RM的其它模块,通过ExternalResourceService提供的接口来进行外部资源信息的获取。
+
+而ExternalResourceService通过资源类型和标签来获取外部资源的信息:
+
+1. 所有外部资源的类型、标签、配置等属性(如集群名称、Yarn的web
+ url、Hadoop版本等信息),都维护在linkis\_external\_resource\_provider表中。
+
+2. 针对每种资源类型,均有一个ExternalResourceProviderParser接口的实现,将外部资源的属性进行解析,将能够匹配到Label的信息转换成对应的Label,将能够作为参数去请求资源接口的都转换成params。最后构建成一个能够作为外部资源信息查询依据的ExternalResourceProvider实例。
+
+3. 根据ExternalResourceService方法的参数中的资源类型和标签信息,找到匹配的ExternalResourceProvider,根据其中的信息生成ExternalResourceRequest,正式调用外部资源提供的API,发起资源信息请求。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/overview.md
new file mode 100644
index 00000000000..503efc0bff1
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/computation-governance-services/overview.md
@@ -0,0 +1,57 @@
+---
+title: 总览
+sidebar_position: 1
+---
+
+
+## **总述**
+
+计算治理服务组,CGS:Computation Governance Services.完成计算任务和请求的提交、准备、执行、返回结果等主要步骤,是Linkis的核心模块
+
+## **架构图**
+![](/Images-zh/Architecture/linkis-computation-gov-01.png)
+
+**作业流程优化:**
+Linkis1.0将优化Job的整体执行流程,从提交 —\> 准备 —\>
+执行三个阶段,来全面升级Linkis的Job执行架构,如下图所示:
+
+![](/Images-zh/Architecture/linkis-computation-gov-02.png)
+
+## **架构说明**
+
+### 1、Entrance
+
+ Entrance作为计算类型任务的提交入口,提供任务的接收、调度和Job信息的转发能力,是从Linkis0.X的Entrance拆分出来的原生能力;
+
+ [进入Entrance架构设计](entrance.md)
+
+### 2、Orchestrator
+
+ Orchestrator 作为准备阶段的入口,从 Linkis0.X 的 Entrance 继承了解析Job、申请Engine和提交执行的能力;同时,Orchestrator将提供强大的编排和计算策略能力,满足多活、主备、事务、重放、限流、异构和混算等多种应用场景的需求。
+
+
+
+### 3、LinkisManager
+
+ LinkisManager作为Linkis的管理大脑,主要由AppManager、ResourceManager、LabelManager和EngineConnPlugin组成。
+
+ 1. ResourceManager 不仅具备 Linkis0.X 对 Yarn 和 Linkis EngineManager的资源管理能力,还将提供基于标签的多级资源分配和回收能力,让ResourceManager具备跨集群、跨计算资源类型的全资源管理能力;
+ 2. AppManager 将统筹管理所有的 EngineConnManager 和 EngineConn,EngineConn 的申请、复用、创建、切换、销毁等生命周期全交予 AppManager 进行管理;而 LabelManager 将基于多级组合标签,提供跨IDC、跨集群的 EngineConn 和 EngineConnManager 路由和管控能力;
+ 3. EngineConnPlugin 主要用于降低新计算存储的接入成本,真正做到让用户只需要实现一个类,就能接入一个全新的计算存储引擎。
+
+ [进入LinkisManager架构设计](linkis-manager/overview.md)
+
+### 4、EngineConnManager
+
+ EngineConnManager (简称ECM)是 Linkis0.X EngineManager 的精简升级版。Linkis1.0下的ECM去除了引擎的申请能力,整个微服务完全无状态,将聚焦于支持各类 EngineConn 的启动和销毁。
+
+ [进入EngineConnManager架构设计](engine-conn-manager.md)
+
+### 5、EngineConn
+
+EngineConn 是 Linkis0.X Engine 的优化升级版本,将提供 EngineConn 和 Executor 两大模块,其中 EngineConn 用于连接底层的计算存储引擎,提供一个打通了底层各计算存储引擎的 Session 会话;Executor 则基于这个 Session 会话,提供交互式计算、流式计算、离线计算、数据存储的全栈计算能力支持。
+
+[进入EngineConn架构设计](engine/engine-conn.md)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/_category_.json
new file mode 100644
index 00000000000..75425a8bf62
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "公共增强服务架构",
+ "position": 3
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/bml/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/bml/_category_.json
new file mode 100644
index 00000000000..98d0a1aaade
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/bml/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "BML 服务架构",
+ "position": 4
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/bml/engine-bml-dissect.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/bml/engine-bml-dissect.md
new file mode 100644
index 00000000000..923c4ca5219
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/bml/engine-bml-dissect.md
@@ -0,0 +1,294 @@
+---
+title: BML 引擎物料管理功能剖析
+sidebar_position: 1
+---
+
+> 导语:本文以引擎相关的物料管理流程为切入点,同时结合底层数据模型和源码,为大家详细剖析引擎物料管理功能的实现细节,期望能够帮助大家更好地理解BML(物料库)服务的架构。
+
+## 1. BML物料库服务
+
+BML物料库是Linkis中PublicEnhancementService(PS)——公共增强服务架构下的功能模块。
+
+![PS-BML](/Images/Architecture/Public_Enhancement_Service/engine_bml/PS-BML.png)
+
+在Linkis的架构体系里,`物料`的概念是指被统一存储托管起来的各种文件数据,包括脚本代码、资源文件、第三方jar、引擎启动时所需的相关类库和配置文件以及用于安全认证的keytab文件等。
+
+总之,任何以文件态存在的数据,都可以被集中托管在物料库之中,然后在各自所需的场景中被下载使用。
+
+物料服务是无状态的,可进行多实例部署,做到服务高可用,每个实例对外提供独立的服务,互不干扰,所有物料元数据及版本信息等在数据库中共享,底层物料数据可被存储到HDFS或本地(共享)文件系统之中,以及支持实现文件存储相关的接口,扩展其他文件存储系统等。
+
+物料服务提供精确的权限控制,对于引擎资源类型的物料,可被所有用户共享访问;对于一些含有敏感信息的物料数据,也可做到仅有限用户可读。
+
+物料文件采用追加的方式,可将多个版本的资源文件合并成一个大文件,避免产生过多的HDFS小文件,HDFS小文件过多会导致HDFS整体性能的下降。
+
+物料服务提供了文件上传、更新、下载等操作任务的生命周期管理。同时,使用物料服务的方式有rest接口和SDK两种形式,用户可以根据自己的需要进行选择。
+
+BML架构图如下:
+
+![BML架构](/Images/Architecture/Public_Enhancement_Service/engine_bml/bml-jiagou.png)
+
+上述关于BML架构的概述,有参考官网文档:https://linkis.apache.org/zh-CN/docs/latest/architecture/public-enhancement-services/bml
+
+## 2. BML物料库服务底层表模型
+
+在深入理解BML物料管理的流程细节之前,有必要先梳理下BML物料管理服务底层依赖的数据库表模型。
+
+![BML-Model](/Images/Architecture/Public_Enhancement_Service/engine_bml/BML-Model.png)
+
+可结合Linkis的`linkis_ddl.sql`文件以及下文内容阐述的引擎物料上传和更新流程来理解bml resources相关表的字段含义以及表与表之间的字段关系。
+
+## 3. BML物料库服务的使用场景
+
+目前在Linkis中,BML物料库服务的使用场景包括:
+
+- 引擎物料文件,包括引擎启动时所需的conf和lib中的文件
+- 存储脚本,比如工作流任务节点链接的Scripts中的脚本是存储在BML物料库中的
+- DSS中工作流内容版本管理
+- 任务运行时所需资源文件管理
+
+## 4. 引擎物料管理流程剖析
+
+`引擎物料`是Linkis物料概念中的一个子集,其作用是为引擎启动时提供最新版本的jar包资源和配置文件等。本小节主要从引擎物料管理功能为切入点,剖析引擎物料数据在BML中的流转细节。
+
+### 4.1 引擎物料说明
+
+对Linkis的安装包正常部署之后,在`LINKIS_INSTALL_HOME/lib/linkis-engineconn-plugins`目录之下可以看到所有的引擎物料目录,以jdbc引擎为例,引擎物料目录的结构如下:
+
+```shell
+jdbc
+├── dist
+│ └── v4
+│ ├── conf
+│ ├── conf.zip
+│ ├── lib
+│ └── lib.zip
+└── plugin
+ └── 4
+ └── linkis-engineplugin-jdbc-1.1.2.jar
+```
+
+物料目录构成:
+
+```shell
+jdbc/dist/版本号/conf.zip
+jdbc/dist/版本号/lib.zip
+
+jdbc/plugin/版本号(去v留数字)/linkis-engineplugin-引擎名称-1.1.x.jar
+```
+
+conf.zip和lib.zip会作为引擎物料被托管在物料管理服务中,本地每次对物料conf或lib进行修改之后,对应物料会产生一个新的版本号,物料文件数据会被重新上传。引擎启动时,会获取最新版本号的物料数据,加载lib和conf并启动引擎的java进程。
+
+### 4.2 引擎物料上传和更新流程
+
+在Linkis完成部署并首次启动时,会触发引擎物料(lib.zip和conf.zip)首次上传至物料库;当引擎lib下jar包或conf中引擎配置文件有修改时,则需要触发引擎物料的刷新机制来保证引擎启动时能够加载到最新的物料文件。
+
+以现在Linkis1.1.x版本为例,触发引擎物料刷新的两种方式有两种:
+
+通过命令`sh sbin/linkis-daemon.sh restart cg-engineplugin`重启engineplugin服务
+
+通过请求引擎物料刷新的接口
+
+```shell
+# 刷新所有引擎物料
+curl --cookie "linkis_user_session_ticket_id_v1=kN4HCk555Aw04udC1Npi4ttKa3duaCOv2HLiVea4FcQ=" http://127.0.0.1:9001/api/rest_j/v1/engineplugin/refreshAll
+# 指定引擎类型和版本刷新物料
+curl --cookie "linkis_user_session_ticket_id_v1=kN4HCk555Aw04udC1Npi4ttKa3duaCOv2HLiVea4FcQ=" http://127.0.0.1:9001/api/rest_j/v1/engineplugin/refresh?ecType=jdbc&version=4
+```
+
+这两种引擎物料的刷新方式,其底层的实现机制是一样的,都是调用了`EngineConnResourceService`类中的refreshAll()或refresh()方法。
+
+在抽象类`EngineConnResourceService`的默认实现类`DefaultEngineConnResourceService`中的init()方法内部,通过参数wds.linkis.engineconn.dist.load.enable(默认为true)来控制是否在每次启动engineplugin服务时都执行refreshAll(false)来检查所有引擎物料是否有更新(其中faslse代表异步获取执行结果)。
+
+> init()方法被注解@PostConstruct修饰,在DefaultEngineConnResourceService加载后,对象使用前执行,且只执行一次。
+
+手动调用engineplugin/refresh的接口,即手动执行了`EngineConnResourceService`类中的refreshAll或refresh方法。
+
+所以引擎物料检测更新的逻辑在`DefaultEngineConnResourceService`中的refreshAll和refresh方法内。
+
+其中refreshAll()的核心逻辑是:
+
+1)通过参数wds.linkis.engineconn.home获取引擎的安装目录,默认是:
+
+```scala
+getEngineConnsHome = Configuration.getLinkisHome() + "/lib/linkis-engineconn-plugins";
+```
+
+2)遍历引擎目录
+
+```scala
+getEngineConnTypeListFromDisk: Array[String] = new File(getEngineConnsHome).listFiles().map(_.getName)
+```
+
+3)`EngineConnBmlResourceGenerator`接口提供对各个引擎(版本)底层文件或目录的合法性检测。对应实现存在于抽象类`AbstractEngineConnBmlResourceGenerator`中。
+
+4)`DefaultEngineConnBmlResourceGenerator`类主要是为了生成`EngineConnLocalizeResource`。EngineConnLocalizeResource是对物料资源文件元数据和InputStream的封装,在后续的逻辑中EngineConnLocalizeResource会被作为物料参数来参与物料的上传过程。
+
+EngineConnBmlResourceGenerator、AbstractEngineConnBmlResourceGenerator、DefaultEngineConnBmlResourceGenerator这三个文件的代码细节暂不细说,可通过以下UML类图,大致了解其继承机制,并结合方法内的具体实现来理解这一部分的功能。
+
+![BML](/Images/Architecture/Public_Enhancement_Service/engine_bml/bml_uml.png)
+
+再重新回到`DefaultEngineConnResourceService`类中的refreshAll方法内,继续看refreshTask线程的核心流程:
+
+```scala
+engineConnBmlResourceGenerator.getEngineConnTypeListFromDisk foreach { engineConnType =>
+ Utils.tryCatch {
+ engineConnBmlResourceGenerator.generate(engineConnType).foreach {
+ case (version, localize) =>
+ logger.info(s" Try to initialize ${engineConnType}EngineConn-$version.")
+ refresh(localize, engineConnType, version)
+ }
+ }
+ ......
+}
+```
+
+扫描引擎的安装目录,可获得每个引擎物料目录的列表,对于每个引擎物料目录结构的合法性校验通过之后,可得到对应的`EngineConnLocalizeResource`,然后通过调用refresh(localize: Array[EngineConnLocalizeResource], engineConnType: String, version: String)来完成后续物料的上传工作。
+
+而在refresh()方法的内部,主要经过的流程有:
+
+从表`linkis_cg_engine_conn_plugin_bml_resources`中获取对应engineConnType和version的物料列表数据,赋值给变量engineConnBmlResources。
+
+```scala
+val engineConnBmlResources = asScalaBuffer(engineConnBmlResourceDao.getAllEngineConnBmlResource(engineConnType, version))
+```
+
+![ec数据](/Images/Architecture/Public_Enhancement_Service/engine_bml/ec-data.png)
+
+
+
+#### 4.2.1 引擎物料上传流程
+
+**引擎物料上传流程时序图**
+
+![引擎物料上传流程时序图](/Images/Architecture/Public_Enhancement_Service/engine_bml/bml-shixu.png)
+
+如果表`linkis_cg_engine_conn_plugin_bml_resources`中没有匹配到数据,则需要拿EngineConnLocalizeResource中的数据来构造EngineConnBmlResource对象,并保存至`linkis_cg_engine_conn_plugin_bml_resources`表中,此数据保存之前,需要先完成物料文件的上传操作,即执行`uploadToBml(localizeResource)`方法。
+
+在uploadToBml(localizeResource)方法内部,通过构造bmlClient来请求物料上传的接口。即:
+
+```scala
+private val bmlClient = BmlClientFactory.createBmlClient()
+bmlClient.uploadResource(Utils.getJvmUser, localizeResource.fileName, localizeResource.getFileInputStream)
+```
+
+在BML Server中,物料上传的接口位置在BmlRestfulApi类中的uploadResource接口方法内。主要经历的过程是:
+
+```scala
+ResourceTask resourceTask = taskService.createUploadTask(files, user, properties);
+```
+
+每一次物料上传,都会构造一个ResourceTask来完成文件上传的流程,并记录此次文件上传Task的执行记录。在createUploadTask方法内部,主要完成的操作如下:
+
+1)为此次上传的资源文件产生`一个全局唯一标识的resource_id`,String resourceId = UUID.randomUUID().toString();
+
+2)构建ResourceTask记录,并存储在表`linkis_ps_bml_resources_task`中,以及后续一系列的Task状态修改。
+
+```scala
+ResourceTask resourceTask = ResourceTask.createUploadTask(resourceId, user, properties);
+taskDao.insert(resourceTask);
+
+taskDao.updateState(resourceTask.getId(), TaskState.RUNNING.getValue(), new Date());
+```
+
+3)物料文件真正写入物料库的操作是由ResourceServiceImpl类中的upload方法完成的,在upload方法内部,会把一组`List files`对应的字节流持久化至物料库文件存储系统中;把物料文件的properties数据,存储到资源记录表(linkis_ps_bml_resources)和资源版本记录表(linkis_ps_bml_resources_version)中。
+
+```scala
+MultipartFile p = files[0]
+String resourceId = (String) properties.get("resourceId");
+String fileName =new String(p.getOriginalFilename().getBytes(Constant.ISO_ENCODE),
+ Constant.UTF8_ENCODE);
+fileName = resourceId;
+String path = resourceHelper.generatePath(user, fileName, properties);
+// generatePath目前支持Local和HDFS路径,路径的构成规则由LocalResourceHelper或HdfsResourceHelper
+// 中的generatePath方法实现
+StringBuilder sb = new StringBuilder();
+long size = resourceHelper.upload(path, user, inputStream, sb, true);
+// 文件size计算以及文件字节流写入文件由LocalResourceHelper或HdfsResourceHelper中的upload方法实现
+Resource resource = Resource.createNewResource(resourceId, user, fileName, properties);
+// 插入一条记录到resource表linkis_ps_bml_resources中
+long id = resourceDao.uploadResource(resource);
+// 新增一条记录到resource version表linkis_ps_bml_resources_version中,此时的版本号是onstant.FIRST_VERSION
+// 除了记录这个版本的元数据信息外,最重要的是记录了该版本的文件的存储位置,包括文件路径,起始位置,结束位置。
+String clientIp = (String) properties.get("clientIp");
+ResourceVersion resourceVersion = ResourceVersion.createNewResourceVersion(
+ resourceId, path, md5String, clientIp, size, Constant.FIRST_VERSION, 1);
+versionDao.insertNewVersion(resourceVersion);
+```
+
+上述流程执行成功之后,物料数据才算是真正完成,然后把UploadResult返回给客户端,并标记此次ResourceTask的状态为完成,如果有遇到上传文件报错,则标记此次ResourceTask的状态为失败,记录异常信息。
+
+![resource-task](/Images/Architecture/Public_Enhancement_Service/engine_bml/resource-task.png)
+
+
+
+#### 4.2.2 引擎物料更新流程
+
+**引擎物料更新流程时序图**
+
+![引擎物料更新流程时序图](/Images/Architecture/Public_Enhancement_Service/engine_bml/engine-bml-update-shixu.png)
+
+如果表`linkis_cg_engine_conn_plugin_bml_resources`中匹配到本地物料数据,则需要拿EngineConnLocalizeResource中的数据来构造EngineConnBmlResource对象,并更新`linkis_cg_engine_conn_plugin_bml_resources`表中原有物料文件的版本号、文件大小、修改时间等元数据信息,此数据更新前,需要先完成物料文件的更新上传操作,即执行`uploadToBml(localizeResource, engineConnBmlResource.getBmlResourceId)`方法。
+
+在uploadToBml(localizeResource, resourceId)方法内部,通过构造bmlClient来请求物料资源更新的接口。即:
+
+```scala
+private val bmlClient = BmlClientFactory.createBmlClient()
+bmlClient.updateResource(Utils.getJvmUser, resourceId, localizeResource.fileName, localizeResource.getFileInputStream)
+```
+
+在BML Server中,实现物料更新的接口位置在BmlRestfulApi类中的updateVersion接口方法内,主要经历的过程是:
+
+完成resourceId的有效性检测,即检测传入的resourceId是否在linkis_ps_bml_resources表中存在,如果此resourceId不存在,给客户端抛出异常,在接口层面此次物料更新操作失败。
+
+所以在表`linkis_cg_engine_conn_plugin_bml_resources`和`linkis_ps_bml_resources`中的资源数据的对应关系需要保证完整,否则会出现物料文件无法更新的报错。
+
+```scala
+resourceService.checkResourceId(resourceId)
+```
+
+resourceId如果存在于linkis_ps_bml_resources表中,会继续执行:
+
+```scala
+StringUtils.isEmpty(versionService.getNewestVersion(resourceId))
+```
+
+getNewestVersion方法是为了在表`linkis_ps_bml_resources_version`中获取该resourceId的最大版本号,如果resourceId对应的最大version为空,那么物料同样会更新失败,所以此处数据的对应关系完整性也需要严格保证。
+
+上述两处检查都通过之后,会创建ResourceUpdateTask来完成最终的文件写入和记录更新保存等工作。
+
+```scala
+ResourceTask resourceTask = null;
+synchronized (resourceId.intern()) {
+ resourceTask = taskService.createUpdateTask(resourceId, user, file, properties);
+}
+```
+
+而在createUpdateTask方法内部,主要实现的功能是:
+
+```scala
+// 为物料Resource生成新的version
+String lastVersion = getResourceLastVersion(resourceId);
+String newVersion = generateNewVersion(lastVersion);
+// 然后是对ResourceTask的构建,和状态维护
+ResourceTask resourceTask = ResourceTask.createUpdateTask(resourceId, newVersion, user, system, properties);
+// 物料更新上传的逻辑由versionService.updateVersion方法完成
+versionService.updateVersion(resourceTask.getResourceId(), user, file, properties);
+```
+
+在versionService.updateVersion方法内部,主要实现的功能是:
+
+```scala
+ResourceHelper resourceHelper = ResourceHelperFactory.getResourceHelper();
+InputStream inputStream = file.getInputStream();
+// 获取资源的path
+String newVersion = params.get("newVersion").toString();
+String path = versionDao.getResourcePath(resourceId) + "_" + newVersion;
+// getResourcePath的获取逻辑是从原有路径中limit一条,然后以_拼接newVersion
+// select resource from linkis_ps_bml_resources_version WHERE resource_id = #{resourceId} limit 1
+// 资源上传到hdfs或local
+StringBuilder stringBuilder = new StringBuilder();
+long size = resourceHelper.upload(path, user, inputStream, stringBuilder, OVER_WRITE);
+// 最后在linkis_ps_bml_resources_version表中插入一条新的资源版本记录
+ResourceVersion resourceVersion = ResourceVersion.createNewResourceVersion(resourceId, path, md5String, clientIp, size, newVersion, 1);
+versionDao.insertNewVersion(resourceVersion);
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/bml/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/bml/overview.md
new file mode 100644
index 00000000000..fe9efb703ad
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/bml/overview.md
@@ -0,0 +1,97 @@
+---
+title: 总览
+sidebar_position: 0
+---
+## 背景
+
+BML(物料库服务)是linkis的物料管理系统,主要用来存储用户的各种文件数据,包括用户脚本、资源文件、第三方Jar包等,也可以存储引擎运行时需要使用到的类库。
+
+具备以下功能点:
+
+1)、支持各种类型的文件。支持文本形式和二进制形式的文件,如果是在大数据领域的用户,可以将他们的脚本文件、物料压缩包都可以存储到本系统中。
+
+2)、服务无状态,多实例部署,做到服务高可用。本系统在部署的时候,可以进行多实例部署,每个实例对外独立提供服务,不会互相干扰,所有的信息都是存储在数据库中进行共享。
+
+3)、使用方式多样。提供Rest接口和SDK两种方式,用户可以根据自己的需要进行选择。
+
+4)、文件采用追加方式,避免过多的HDFS小文件。HDFS小文件多会导致HDFS整体性能的下降,我们采用了文件追加的方式,将多个版本的资源文件合成一个大文件,有效减少了HDFS的文件数量。
+
+5)、精确权限控制,用户资源文件内容安全存储。资源文件往往会有重要的内容,用户只希望自己可读
+
+6)、提供了文件上传、更新、下载等操作任务的生命周期管理。
+
+## 架构图
+
+![BML架构图](/Images-zh/Architecture/bml-02.png)
+
+## 架构说明
+
+1、Service层 包含资源管理、上传资源、下载资源、共享资源还有工程资源管理。
+
+资源管理负责资源的增删改查操作,访问权限控制,文件是否过期等基本操作。
+
+2、文件版本控制
+每个BML资源文件都是具有版本信息的,同一个资源每次更新操作都会产生一个新的版本,当然也支持历史版本的查询和下载操作。BML使用版本信息表记录了每个版本的资源文件HDFS存储的偏离位置和大小,可以在一个HDFS文件上存储多个版本的数据。
+
+3、资源文件存储
+主要使用HDFS文件作为实际的数据存储,HDFS文件可以有效保证物料库文件不被丢失,文件采用追加方式,避免过多的HDFS小文件。
+
+### 核心流程
+
+**上传文件:**
+
+1. 判断用户上传文件的操作类型,属于首次上传还是更新上传,如果是首次上传需要新增一条资源信息记录,系统已经为这个资源生成了一个全局唯一标识的resource_id和一个资源放置的位置resource_location。资源A的第一个版本A1需要在HDFS文件系统中resource_location位置进行存储。存储完之后,就可以得到第一个版本记为V00001,如果是更新上传需要查找上次最新的版本。
+
+2. 上传文件流到指定的HDFS文件,如果是更新则采用文件追加的方式加到上次内容的末尾。
+
+3. 新增一条版本记录,每次上传都会产生一条新的版本记录。除了记录这个版本的元数据信息外,最重要的是记录了该版本的文件的存储位置,包括文件路径,起始位置,结束位置。
+
+**下载文件:**
+
+1. 用户下载资源的时候,需要指定两个参数一个是resource_id,另外一个是版本version,如果不指定version的话,默认下载最新版本。
+
+2. 用户传入resource_id和version两个参数到系统之后,系统查询resource_version表,查到对应的resource_location和start_byte和end\_byte进行下载,通过流处理的skipByte方法,将resource\_location的前(start_byte-1)个字节跳过,然后读取到end_byte
+ 字节数。读取成功之后,将流信息返回给用户。
+
+3. 在resource_download_history中插入一条下载成功的记录
+
+## 数据库设计
+
+1、资源信息表(resource)
+
+| 字段名 | 作用 | 备注 |
+|-------------------|------------------------------|----------------------------------|
+| resource_id | 全局唯一标识一个资源的字符串 | 可以采用UUID进行标识 |
+| resource_location | 存放资源的位置 | 例如 hdfs:///tmp/bdp/\${用户名}/ |
+| owner | 资源的所属者 | 例如 zhangsan |
+| create_time | 记录创建时间 | |
+| is_share | 是否共享 | 0表示不共享,1表示共享 |
+| update\_time | 资源最后的更新时间 | |
+| is\_expire | 记录资源是否过期 | |
+| expire_time | 记录资源过期时间 | |
+
+2、资源版本信息表(resource_version)
+
+| 字段名 | 作用 | 备注 |
+|-------------------|--------------------|----------|
+| resource_id | 唯一标识资源 | 联合主键 |
+| version | 资源文件的版本 | |
+| start_byte | 资源文件开始字节数 | |
+| end\_byte | 资源文件结束字节数 | |
+| size | 资源文件大小 | |
+| resource_location | 资源文件放置位置 | |
+| start_time | 记录上传的开始时间 | |
+| end\_time | 记录上传的结束时间 | |
+| updater | 记录更新用户 | |
+
+3、资源下载历史表(resource_download_history)
+
+| 字段 | 作用 | 备注 |
+|-------------|---------------------------|--------------------------------|
+| resource_id | 记录下载资源的resource_id | |
+| version | 记录下载资源的version | |
+| downloader | 记录下载的用户 | |
+| start\_time | 记录下载时间 | |
+| end\_time | 记录结束时间 | |
+| status | 记录是否成功 | 0表示成功,1表示失败 |
+| err\_msg | 记录失败原因 | null表示成功,否则记录失败原因 |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/_category_.json
new file mode 100644
index 00000000000..ab3f408b8cd
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "上下文务架构",
+ "position": 3
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/content-service-cleanup.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/content-service-cleanup.md
new file mode 100644
index 00000000000..609c85b3ac5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/content-service-cleanup.md
@@ -0,0 +1,338 @@
+---
+title: CS 清理接口特性
+sidebar_position: 8
+tags: [Feature]
+---
+
+## 1. 功能需求
+### 1.1 背景
+1.1.3版本前,ContextService 统一上下文服务缺少清理机制,且缺少创建时间、更新时间字段以及批量清理的接口,
+在长期累积情况下可能出现百万级数据,影响查询效率。
+
+### 1.2 目标
+- 修改1ContextService`底层库表,添加创建时间、修改时间、最后访问时间字段,完成`ContextID`和`ContextMap`相关数据的更新时间入库
+- 添加清理清理的`restful`接口,支持按照时间范围、按照id列表的批零清理接口
+- 添加对应的`cs-client`的`java sdk`接口
+
+## 2. 总体设计
+本次需求涉及`ContextService`下的`cs-client`、`cs-persistence`以及`cs-server`模块。
+在`cs-persistence`模块添加已有表的3个字段;在`cs-server`模块添加3个`restful`接口,在`cs-client`模块添加3个`sdk api`。
+
+### 2.1 技术架构
+
+ContextService 整体架构可参考已有文档: [ContextService架构文档](overview.md)
+
+ContestService各模块访问关系如下图所示
+![linkis-contextservice-clean-01.png](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-clean-01.png)
+
+
+ 表变更均在`cs-persistence`模块。此次变更涉及5张表`context_id、 context_map 、context_id_listener 、context_key_listener 、 context_history`表,均需要添加`create_time,update_time,access_time` 3个字段。其中`context_id 、context_map` 表已启用,其它3张表未启用。`create_time` 在persistence模块执行insert操作前,添加时间。`update_time` 和 `access_time` 由上游接口主动调用,在update接口中,`update_time` 和 `access_time` 互斥更新,即当`access_time` 存在(不为null)则不更新`update_time`,否则更新update_time。
+
+`update_time`字段更新在cs-cache模块中,检测到从db加载新的`context_id`时的ADD消息,此时同步`access_time` 到db。
+表中仅记录`context_id` 表的`create_time、update_time、access_time`。后续搜索清理,也是从context_id 表进行清理。
+
+增加3个清理相关接口:`searchContextIDByTime、clearAllContextByID、clearAllContextByTime`
+- `searchContextIDByTime`按照3个时间起止范围搜索,返回contextID列表
+- `clearAllContextByID`清理输入的contextID列表中ID对应的context_map表和context_id表内容
+- `clearAllContextByTime` 按照3个时间起止范围搜索,并且清理所有搜索到的contextID对应的context_map表和context_id表的内容
+
+### 2.2 业务架构
+此次特性是给ContextService服务增加批量查询和清理的相关接口,以及增加底层数据表的更新时间等字段,便于根据访问情况清理过期数据。功能点涉及模块如下表。
+
+| 一级模块 | 二级模块 | 功能点 |
+| :------------ | :------------ | :------------ |
+| linkis-ps-cs | cs-client | 增加批量清理接口相关java sdk api接口 |
+| Linkis-ps-cs | cs-server | 增加批量清理接口相关restful接口 |
+| linkis-ps-cs | cs-persistence | 增加底层表的3个时间相关字段 |
+
+
+## 3. 模块设计
+### 主要执行流程
+- 创建ContextID。用户创建ContextID时,会记录create_time,后期不更新这个字段
+- 更新ContextID。用户更新ContextID时,会更新update_time字段。注意此时更新如果是从cache中更新,则不会更新access_time字段;如果从db加载到cache,再更新contextID,则会先更新access_time,然后单独更新update_time
+- 根据时间查询ContextID。用户查询对应时间范围的ContextID,仅会返回haid字符串列表。此接口有分页,默认仅限5000条数据
+- 批量清理ContextID。会批量清理传入的idList对应的所有contextMap数据和contextID数据。传入数组最大5000条
+- 查询并清理ContextID,先查询再批量清理
+
+上述对应时序图如下:
+![linkis-contextservice-clean-02.png](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-clean-02.png)
+
+其中有两处需要额外注意:
+①cs-server服务中restful api,会将请求封装成Job提交到队列并阻塞等待结果。新定义了CLEAR 的操作类型,便于匹配到清理相关接口。
+②处理①中Job的Service服务,需要将名称定义为不包含ContextID,来避免HighAvailable模块的动态代理转换,这个转换仅对于请求内只有一个ContextID的接口,对于批量清理和批量查询接口无意义且影响性能。
+
+## 4. 数据结构
+```
+# 主要涉及的context_id表结构如下,增加了create_time、update_time、expire_time字段
+CREATE TABLE `linkis_ps_cs_context_id` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `user` varchar(32) DEFAULT NULL,
+ `application` varchar(32) DEFAULT NULL,
+ `source` varchar(255) DEFAULT NULL,
+ `expire_type` varchar(32) DEFAULT NULL,
+ `expire_time` datetime DEFAULT NULL,
+ `instance` varchar(128) DEFAULT NULL,
+ `backup_instance` varchar(255) DEFAULT NULL,
+ `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'update unix timestamp',
+ `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'create time',
+ `access_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'last access time',
+ PRIMARY KEY (`id`),
+ KEY `instance` (`instance`(128)),
+ KEY `backup_instance` (`backup_instance`(191)),
+ KEY `instance_2` (`instance`(128),`backup_instance`(128))
+) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
+```
+
+## 5. 接口设计
+### 5.1 Restful接口
+
+
+#### 搜索文本Id执行时间
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/searchContextIDByTime`
+
+
+**请求方式**:`GET`
+
+
+**请求数据类型**:`application/x-www-form-urlencoded`
+
+
+**响应数据类型**:`*/*`
+
+
+**接口描述**:搜索文本Id执行时间
+
+
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 请求类型 | 是否必须 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|accessTimeEnd|访问结束时间|query|false|string|
+|accessTimeStart|访问开始时间|query|false|string|
+|createTimeEnd|创建结束时间|query|false|string|
+|createTimeStart|创建时间|query|false|string|
+|pageNow|页码|query|false|string|
+|pageSize|页面大小|query|false|string|
+|updateTimeEnd|更新结束时间|query|false|string|
+|updateTimeStart|更新时间|query|false|string|
+
+
+**响应状态**:
+
+
+| 状态码 | 说明 | schema |
+| -------- | -------- | ----- |
+|200|OK|Message|
+|401|Unauthorized|
+|403|Forbidden|
+|404|Not Found|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/contextservice/searchContextIDByTime",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "contextIDs": [
+ "8-8--cs_1_devcs_2_dev10493",
+ "8-8--cs_1_devcs_2_dev10494",
+ "8-8--cs_1_devcs_2_dev10495",
+ "8-8--cs_1_devcs_2_dev10496",
+ "8-8--cs_1_devcs_2_dev10497",
+ "8-8--cs_2_devcs_2_dev10498"
+ ]
+ }
+}
+```
+
+
+#### 清理指定ID
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/clearAllContextByID`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:通过ID清除所以上下文
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|idList|上下文id集合|false|String|String|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/contextservice/clearAllContextByID",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "num": "1"
+ }
+}
+```
+
+
+## 通过时间清除所以上下文
+
+
+**接口地址**:`/api/rest_j/v1/contextservice/clearAllContextByTime`
+
+**请求方式**:`POST`
+
+**请求数据类型**:`application/json`
+
+**响应数据类型**:`*/*`
+
+**接口描述**:通过时间清除所以上下文
+
+**请求参数**:
+
+
+| 参数名称 | 参数说明 | 是否必须 | 请求类型 | 数据类型 | schema |
+| -------- | -------- | ----- | -------- | -------- | ------ |
+|accessTimeEnd|访问时间结束|false|String|String|
+|accessTimeStart|访问时间开始|false|String|String|
+|createTimeEnd|创建时间结束|false|String|String|
+|createTimeStart|创建时间|false|String|String|
+|updateTimeStart|更新开始时间|false|String|String|
+
+
+**响应参数**:
+
+
+| 参数名称 | 参数说明 | 类型 | schema |
+| -------- | -------- | ----- |----- |
+|data|数据集|object|
+|message|描述|string|
+|method|请求url|string|
+|status|状态|integer(int32)|integer(int32)|
+
+**输入参数示例**
+```javascript
+{
+ "createTimeStart": "2022-06-01 00:00:00",
+ "createTimeEnd": "2022-06-30 00:00:00"
+}
+```
+
+
+**响应示例**:
+```javascript
+{
+ "method": "/api/contextservice/clearAllContextByTime",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "num": "1"
+ }
+}
+```
+
+### 5.2 JAVA SDK API
+```
+# 引入pom
+
+ org.apache.linkis
+ linkis-cs-client
+ 1.1.3
+
+
+# 代码参考如下
+
+ String createTimeStart = "2022-05-26 22:04:00";
+ String createTimeEnd = "2022-06-01 24:00:00";
+
+ ContextClient contextClient = ContextClientFactory.getOrCreateContextClient();
+
+ # 接口1 searchHAIDByTime
+ List idList =
+ contextClient.searchHAIDByTime(
+ createTimeStart, createTimeEnd, null, null, null, null, 0, 0);
+
+ for (String id : idList) {
+ System.out.println(id);
+ }
+
+ System.out.println("Got " + idList.size() + " ids.");
+
+ if (idList.size() > 0) {
+ String id1 = idList.get(0);
+ System.out.println("will clear context of id : " + id1);
+ }
+
+ # 接口2 batchClearContextByHAID
+ List tmpList = new ArrayList<>();
+ tmpList.add(id1);
+ int num = contextClient.batchClearContextByHAID(tmpList);
+ System.out.println("Succeed to clear " + num + " ids.");
+
+ # 接口3 batchClearContextByTime
+ int num1 =
+ contextClient.batchClearContextByTime(
+ createTimeStart, createTimeEnd, null, null, null, null);
+ System.out.println("Succeed to clear " + num1 + " ids by time.");
+
+```
+
+
+## 6. 非功能性设计
+### 6.1 安全
+resultful接口需要登录认证,且需要管理员才能操作,管理员用户配置在properties文件中
+
+### 6.2 性能
+- 查询ID接口searchContextIDByTime有分页,无性能影响
+- 清理指定ID接口clearAllContextByID限制操作数据量,无性能影响
+- 根据时间清理接口clearAllContextByTime,如果查询时间范围过大,可能会有查询超时,但不会任务失败。并且清理操作是单个操作,不会影响其他查询
+
+### 6.3 容量
+本需求提供了时间范围查询和批量清理接口,需要上层使用ContextService的应用主动清理数据。
+
+### 6.4 高可用
+接口复用ContextService微服务本身的高可用能力。
+
+
+
+
+
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-cache.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-cache.md
new file mode 100644
index 00000000000..936f667a882
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-cache.md
@@ -0,0 +1,101 @@
+---
+title: CS Cache 架构
+sidebar_position: 7
+---
+
+
+## **CSCache架构**
+### **需要解决的问题**
+
+### 1.1. 内存结构需要解决的问题:
+
+1. 支持按ContextType进行拆分:加快存储和查询性能
+
+2. 支持按不同的ContextID进行拆分:需要完成ContextID间元数据隔离
+
+3. 支持LRU:按照特定算法进行回收
+
+4. 支持按关键字进行检索:支持通过关键字进行索引
+
+5. 支持索引:支持直接通过ContextKey进行索引
+
+6. 支持遍历:需要支持通过按照ContextID、ContextType进行遍历
+
+### 1.2 加载与解析需要解决的问题:
+
+1. 支持将ContextValue解析成内存数据结构:需要完成对ContextKey和value解析出对应的关键字。
+
+2. 需要与与Persistence模块进行对接完成ContextID内容的加载与解析
+
+### 1.3 Metric和清理机制需要解决的问题:
+
+1. 当JVM内存不够时能够基于内存使用和使用频率的清理
+
+2. 支持统计每个ContextID的内存使用情况
+
+3. 支持统计每个ContextID的使用频率
+
+## **ContextCache架构**
+
+ContextCache的架构如下图展示:
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-cache-01.png)
+
+1. ContextService:完成对外接口的提供,包括增删改查;
+
+2. Cache:完成对上下文信息的存储,通过ContextKey和ContextValue进行映射存储
+
+3. Index:建立的关键字索引,存储的是上下文信息的关键字和ContextKey的映射;
+
+4. Parser:完成对上下文信息的关键字解析;
+
+5. LoadModule当ContextCache没有对应的ContextID信息时从持久层完成信息的加载;
+
+6. AutoClear:当Jvm内存不足时完成对ContextCache进行按需清理;
+
+7. Listener:用于监听ContextCache的Metric信息,如:内存占用、访问次数。
+
+## **ContextCache存储结构设计**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-cache-02.png)
+
+ContextCache的存储结构划分为了三层结构:
+
+**ContextCach:**存储了ContextID和ContextIDValue的映射关系,并能够完成ContextID按照LRU算法进行回收;
+
+**ContextIDValue:**拥有存储了ContextID的所有上下文信息和索引的CSKeyValueContext。并统计ContextID的内存和使用记录。
+
+**CSKeyValueContext:**包含了按照类型存储并支持关键词的CSInvertedIndexSet索引集,还包含了存储ContextKey和ContextValue的存储集CSKeyValueMapSet。
+
+CSInvertedIndexSet:通过CSType进行分类存储关键词索引
+
+CSKeyValueMapSet:通过CSType进行分类存储上下文信息
+
+## **ContextCache UML类图设计**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-cache-03.png)
+
+## **ContextCache 时序图**
+
+下面的图绘制了以ContextID、KeyWord、ContextType去ContextCache中查对应的ContextKeyValue的整体流程。
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-cache-04.png)
+
+说明:其中ContextIDValueGenerator会去持久层拉取ContextID的Array[ContextKeyValue],并通过ContextKeyValueParser解析ContextKeyValue的关键字存储索引和内容。
+
+ContextCacheService提供的其他接口流程类似,这里不再赘述。
+
+## **KeyWord解析逻辑**
+
+ContextValue具体的实体Bean需要在对应可以作为keyword的get方法上面使用注解\@keywordMethod,比如Table的getTableName方法必须加上\@keywordMethod注解。
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-cache-05.png)
+
+ContextKeyValueParser在解析ContextKeyValue的时候,会去扫描传入的具体对象的所有被KeywordMethod修饰的注解并调用该get方法获得返回对象toString并会通过用户可选的规则进行解析,存入keyword集合里面。规则有分隔符,和正则表达式
+
+注意事项:
+
+1. 该注解会定义到cs的core模块
+
+2. 被修饰的Get方法不能带参数
+
+3. Get方法的返回对象的toSting方法必须返回的是关键字
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-client.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-client.md
new file mode 100644
index 00000000000..b8a45b6c819
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-client.md
@@ -0,0 +1,65 @@
+---
+title: CS Client
+sidebar_position: 2
+---
+## **CSClient设计的思路和实现**
+
+
+CSClient是每一个微服务和CSServer组进行交互的客户端,CSClient需要满足下面的功能。
+
+1. 微服务向cs-server申请一个上下文对象的能力
+
+2. 微服务向cs-server注册上下文信息的能力
+
+3. 微服务能够向cs-server更新上下文信息的能力
+
+4. 微服务向cs-server获取上下文信息的能力
+
+5. 某一些特殊的微服务能够嗅探到cs-server中已经修改了上下文信息的操作
+
+6. CSClient在csserver集群都失败的情况下能够给出明确的指示
+
+7. CSClient需要提供复制csid1所有上下文信息为一个新的csid2用来提供给调度执行的
+
+> 总体的做法是通过的linkis自带的linkis-httpclient进行发送http请求,通过实现各种Action和Result的实体类进行发送请求和接收响应。
+
+### 1. 申请上下文对象的能力
+
+申请上下文对象,例如用户在前端新建了一条工作流,dss-server需要向dss-server申请一个上下文对象,申请上下文对象的时候,需要将工作流的标识信息(工程名、工作流名)通过CSClient发送到CSServer中(这个时候gateway应该是随机发送给一个的,因为此时没有携带csid的信息),申请上下文一旦反馈到正确的结果之后,就会返回一个csid和该工作流进行绑定。
+
+### 2. 注册上下文信息的能力
+
+> 注册上下文的能力,例如用户在前端页面上传了资源文件,文件内容上传到dss-server,dss-server将内容存储到bml中,然后需要将从bml中获得的resourceid和version注册到cs-server中,此时需要使用到csclient的注册的能力,注册的能力是通过传入csid,以及cskey
+> 和csvalue(resourceid和version)进行注册。
+
+### 3. 更新注册的上下文的能力
+
+> 更新上下文信息的能力。举一个例子,比如一个用户上传了一个资源文件test.jar,此时csserver已经有注册的信息,如果用户在编辑工作流的时候,将这个资源文件进行了更新,那么cs-server需要将这个内容进行更新。此时需要调用csclient的更新的接口
+
+### 4. 获取上下文的能力
+
+注册到csserver的上下文信息,在变量替换、资源文件下载、下游节点调用上游节点产生信息的时候,都是需要被读取的,例如engine端在执行代码的时候,需要进行下载bml的资源,此时需要通过csclient和csserver进行交互,获取到文件在bml中的resourceid和version然后再进行下载。
+
+### 5. 某一些特殊的微服务能够嗅探到cs-server中已经修改了上下文信息的操作
+
+这个操作是基于以下的例子,比如一个widget节点和上游的sql节点是有很强的联动性,用户在sql节点中写了一个sql,sql的结果集的元数据为a,b,c三个字段,后面的widget节点绑定了这个sql,能够在页面中进行对这三个字段的编辑,然后用户更改了sql的语句,元数据变成了a,b,c,d四个字段,此时用户需要手动刷新一下才行。我们希望做到如果脚本做到了改变,那么widget节点能够自动的进行将元数据进行更新。这个一般采用的是listener模式,为了简便,也可以采用心跳的机制进行轮询。
+
+### 6. CSClient需要提供复制csid1所有上下文信息为一个新的csid2用来提供给调度执行的
+
+用户一旦发布一个工程,就是希望对这个工程的所有信息进行类似于git打上一个tag,这里的资源文件、自定义变量这些都是不会再变的,但是有一些动态信息,如产生的结果集等还是会更新csid的内容。所以csclient需要提供一个csid1复制所有上下文信息的接口以供微服务进行调用
+
+## **ClientListener模块的实现**
+
+对于一个client而言,有时候会希望在尽快的时间内知道某一个csid和cskey在cs-server中发生了改变,例如visualis的csclient需要能够知道上一个sql节点进行了改变,那么需要被通知到,服务端有一个listener模块,而客户端也需要一个listener模块,例如一个client希望能够监听到某一个csid的某一个cskey的变化,那么他需要将该cskey注册到对应的csserver实例中的callbackEngine,后续的比如有另外一个client进行更改了该cskey的内容,第一个client进行了heatbeat的时候,callbackengine就需要将这个信息通知到已经client监听的所有cskey,这样的话,第一个client就知道了该cskey的内容已经发生了变化。当heatbeat返回数据的时候,我们就应该通知到注册到ContextClientListenerBus的所有的listener进行使用on方法
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-client-01.png)
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-client-02.png)
+
+## **GatewayRouter的实现**
+
+
+Gateway插件实现Context进行转发Gateway的插件的转发逻辑是通过的GatewayRouter进行的,需要分成两种方式进行,第一种是申请一个context上下文对象的时候,这个时候,CSClient携带的信息中是没有包含csid的信息的,此时的判断逻辑应该是通过eureka的注册信息,第一次发送的请求将会随机进入到一个微服务实例中。
+第二种情况是携带了ContextID的内容,我们需要将csid进行解析,解析的方式就是通过字符串切割的方法,获取到每一个instance的信息,然后通过instance的信息通过eureka判断是否还存在这个微服务,如果是存在的,就往这个微服务实例进行发送
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-client-03.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-highavailable.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-highavailable.md
new file mode 100644
index 00000000000..0ff23ddf098
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-highavailable.md
@@ -0,0 +1,90 @@
+---
+title: CS HA 架构设计
+sidebar_position: 3
+---
+## **CS HA架构设计**
+
+### 1,CS HA架构概要
+
+#### (1)CS HA架构图
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-ha-01.png)
+
+#### (2)要解决的问题
+
+- Context instance对象的HA
+
+- Client创建工作流时生成CSID请求
+
+- CS Server的别名列表
+
+- CSID统一的生成和解析规则
+
+#### (3)主要设计思路
+
+①负载均衡
+
+当客户端创建新的工作流时,等概率随机请求到某台Server的HA模块生成新的HAID,HAID信息包含该主Server信息(以下称主instance),和备选instance,其中备选instance为剩余Server中负载最低的instance,以及一个对应的ContextID。生成的HAID与该工作流绑定且被持久化到数据库,并且随后该工作流所有变更操作请求都将发送至主instance,实现负载的均匀分配。
+
+②高可用
+
+在后续操作中,当客户端或者gateway判定主instance不可用时,会将操作请求转发至备instance处理,从而实现服务的高可用。备instance的HA模块会根据HAID信息首先验证请求合法性。
+
+③别名机制
+
+对机器采用别名机制,HAID中包含的Instance信息采用自定义别名,后台维护别名映射队列。在客户端交互时采用HAID,而与后台其它组件交互则采用ContextID,在实现具体操作时采用动态代理机制,将HAID转换为ContextID进行处理。
+
+### 2,模块设计
+
+#### (1)模块图
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-ha-02.png)
+
+#### (2)具体模块
+
+①ContextHAManager模块
+
+提供接口供CS Server调用生成CSID及HAID,并提供基于动态代理的别名转换接口;
+
+调用持久化模块接口持久化CSID信息;
+
+②AbstractContextHAManager模块
+
+ContextHAManager的抽象,可支持实现多种ContextHAManager;
+
+③InstanceAliasManager模块
+
+RPC模块提供Instance与别名转换接口,维护别名映射队列,并提供别名与CS
+Server实例的查询;提供验证主机是否有效接口;
+
+④HAContextIDGenerator模块
+
+生成新的HAID,并且封装成客户端约定格式返回给客户端。HAID结构如下:
+
+\${第一个instance长度}\${第二个instance长度}{instance别名1}{instance别名2}{实际ID},实际ID定为ContextID
+Key;
+
+⑤ContextHAChecker模块
+
+提供HAID的校验接口。收到的每个请求会校验ID格式是否有效,以及当前主机是否为主Instance或备Instance:如果是主Instance,则校验通过;如果为备Instance,则验证主Instance是否失效,主Instance失效则验证通过。
+
+⑥BackupInstanceGenerator模块
+
+生成备用实例,附加在CSID信息里;
+
+⑦MultiTenantBackupInstanceGenerator接口
+
+(保留接口,暂不实现)
+
+### 3. UML类图
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-ha-03.png)
+
+### 4. HA模块操作时序图
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-ha-04.png)
+
+第一次生成CSID:
+由客户端发出请求,Gateway转发到任一Server,HA模块生成HAID,包含主Instance和备instance及CSID,完成工作流与HAID的绑定。
+
+当客户端发送变更请求时,Gateway判定主Instance失效,则将请求转发到备Instance进行处理。备Instance上实例验证HAID有效后,加载Instance并处理请求。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-listener.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-listener.md
new file mode 100644
index 00000000000..87ce94f0978
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-listener.md
@@ -0,0 +1,37 @@
+---
+title: CS Listener 架构
+sidebar_position: 4
+---
+## **Listener架构**
+
+在DSS中,当某个节点更改了它的元数据信息后,则整个工作流的上下文信息就发生了改变,我们期望所有的节点都能感知到变化,并自动进行元数据更新。我们采用监听模式来实现,并使用心跳机制进行轮询,保持上下文信息的元数据一致性。
+
+### **客户端 注册自己、注册CSKey及更新CSKey过程**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-listener-01.png)
+
+主要过程如下:
+
+1、注册操作:客户端client1、client2、client3、client4通过HTPP请求分别向csserver注册自己以及想要监听的CSKey,Service服务通过对外接口获取到callback引擎实例,注册客户端及其对应的CSKeys。
+
+2、更新操作:如ClientX节点更新了CSKey内容,Service服务则更新ContextCache缓存的CSKey,ContextCache将更新操作投递给ListenerBus,ListenerBus通知具体的listener进行消费(即ContextKeyCallbackEngine去更新Client对应的CSKeys),超时未消费的事件,会被自动移除。
+
+3、心跳机制:
+
+所有Client通过心跳信息探测ContextKeyCallbackEngine中CSKeys的值是否发生了变化。
+
+ContextKeyCallbackEngine通过心跳机制返回更新的CSKeys值给所有已注册的客户端。如果有客户端心跳超时,则移除该客户端。
+
+### **Listener UM类图**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-02.png)
+
+接口:ListenerManager
+
+对外:提供ListenerBus,用于投递事件。
+
+对内:提供 callback引擎,进行事件的具体注册、访问、更新,及心跳处理等逻辑
+
+## **Listener callbackengine时序图**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-03.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-persistence.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-persistence.md
new file mode 100644
index 00000000000..b19366084c8
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-persistence.md
@@ -0,0 +1,13 @@
+---
+title: CS Persistence 架构
+sidebar_position: 5
+---
+
+## **CSPersistence架构**
+
+### Persistence UML图
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-persistence-01.png)
+
+
+Persistence模块主要定义了ContextService持久化相关操作。实体主要包含CSID、ContextKeyValue相关、CSResource相关、CSTable相关。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-search.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-search.md
new file mode 100644
index 00000000000..18c1f8ed5e9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service-search.md
@@ -0,0 +1,131 @@
+---
+title: CS Search 架构
+sidebar_position: 6
+---
+## **CSSearch架构**
+### **总体架构**
+
+如下图所示:
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-01.png)
+
+1. ContextSearch:查询入口,接受Map形式定义的查询条件,根据条件返回相应的结果。
+
+2. 构建模块:每个条件类型对应一个Parser,负责将Map形式的条件转换成Condition对象,具体通过调用ConditionBuilder的逻辑实现。具有复杂逻辑关系的Condition会通过ConditionOptimizer进行基于代价的算法优化查询方案。
+
+3. 执行模块:从Cache中,筛选出与条件匹配的结果。根据查询目标的不同,分为Ruler、Fetcher和Match而三种执行模式,具体逻辑在后文描述。
+
+4. 评估模块:负责条件执行代价的计算和历史执行状况的统计。
+
+### **查询条件定义(ContextSearchCondition)**
+
+一个查询条件,规定了该如何从一个ContextKeyValue集合中,筛选出符合条件的那一部分。查询条件可以通过逻辑运算构成更加复杂的查询条件。
+
+1. 支持ContextType、ContextScope、KeyWord的匹配
+
+ 1. 分别对应一个Condition类型
+
+ 2. 在Cache中,这些都应该有相应的索引
+
+2. 支持对key的contains/regex匹配模式
+
+ 1. ContainsContextSearchCondition:包含某个字符串
+
+ 2. RegexContextSearchCondition:匹配某个正则表达式
+
+3. 支持or、and和not的逻辑运算
+
+ 1. 一元运算UnaryContextSearchCondition:
+
+> 支持单个参数的逻辑运算,比如NotContextSearchCondition
+
+1. 二元运算BinaryContextSearchCondition:
+
+> 支持两个参数的逻辑运算,分别定义为LeftCondition和RightCondition,比如OrContextSearchCondition和AndContextSearchCondition
+
+1. 每个逻辑运算均对应一个上述子类的实现类
+
+2. 该部分的UML类图如下:
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-02.png)
+
+### **查询条件的构建**
+
+1. 支持通过ContextSearchConditionBuilder构建:构建时,如果同时声明多项ContextType、ContextScope、KeyWord、contains/regex的匹配,自动以And逻辑运算连接
+
+2. 支持Condition之间进行逻辑运算,返回新的Condition:And,Or和Not(考虑condition1.or(condition2)的形式,要求Condition顶层接口定义逻辑运算方法)
+
+3. 支持通过每个底层实现类对应的ContextSearchParser从Map构建
+
+### **查询条件的执行**
+
+1. 查询条件的三种作用方式:
+
+ 1. Ruler:从一个Array中筛选出符合条件的ContextKeyValue子Array
+
+ 2. Matcher:判断单个ContextKeyValue是否符合条件
+
+ 3. Fetcher:从ContextCache里筛选出符合条件的ContextKeyValue的Array
+
+2. 每个底层的Condition都有对应的Execution,负责维护相应的Ruler、Matcher、Fetcher。
+
+### **查询入口ContextSearch**
+
+提供search接口,接收Map作为参数,从Cache中筛选出对应的数据。
+
+1. 通过Parser,将Map形式的条件转换为Condition对象
+
+2. 通过Optimizer,获取代价信息,并根据代价信息确定查询的先后顺序
+
+3. 通过对应的Execution,执行相应的Ruler/Fetcher/Matcher逻辑后,得到搜索结果
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-03.png)
+
+### **查询优化**
+
+1. OptimizedContextSearchCondition维护条件的Cost和Statistics信息:
+
+ 1. Cost信息:由CostCalculator负责判断某个Condition是否能够计算出Cost,如果可以计算,则返回对应的Cost对象
+
+ 2. Statistics信息:开始/结束/执行时间、输入行数、输出行数
+
+2. 实现一个CostContextSearchOptimizer,其optimize方法以Condition的代价为依据,对Condition进行调优,转换为一个OptimizedContextSearchCondition对象。具体逻辑描述如下:
+
+ 1. 将一个复杂的Condition,根据逻辑运算的组合,拆解成一个树形结构,每个叶子节点均为一个最基本的简单Condition;每个非叶子节点均为一个逻辑运算。
+
+> 如下图所示的树A,就是一个由ABCDE这五个简单条件,通过各种逻辑运算组合成的一个复杂条件。
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-04.png)
+(树A)
+
+1. 这些Condition的执行,事实上就是深度优先、从左到右遍历这个树。而且根据逻辑运算的交换规律,Condition树中一个节点的子节点的左右顺序可以互换,因此可以穷举出所有可能的执行顺序下的所有可能的树。
+
+> 如下图所示的树B,就是上述树A的另一个可能的顺序,与树A的执行结果完全一致,只是各部分的执行顺序有所调整。
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-search-05.png)
+(树B)
+
+1. 针对每一个树,从叶子节点开始计算代价,归集到根节点,即为该树的最终代价,最终得出代价最小的那个树,作为最优执行顺序。
+
+> 计算节点代价的规则如下:
+
+1. 针对叶子节点,每个节点有两个属性:代价(Cost)和权重(Weight)。Cost即为CostCalculator计算出的代价,Weight是根据节点执行先后顺序的不同赋予的,当前默认左边为1,右边为0.5,后续看如何调整(赋予权重的原因是,左边的条件在一些情况下已经可以直接决定整个组合逻辑的匹配与否,所以右边的条件并非所有情况下都要执行,实际开销就需要减少一定的比例)
+
+2. 针对非叶子节点,Cost=所有子节点的Cost×Weight的总和;Weight的赋予逻辑与叶子节点一致。
+
+> 以树A和树B为例子,分别计算出这两个树的代价,如下图所示,节点中的数字为Cost\|Weight,假设ABCDE这5个简单条件的Cost为10、100、50、10和100。由此可以得出,树B的代价小于树A,为更优方案。
+
+
+
+
+
+
+1. 用CostCalculator衡量简单条件的Cost的思路:
+
+ 1. 作用在索引上的条件:根据索引值的分布来确定代价。比如当条件A从Cache中get出来的Array长度是100,条件B为200,那么条件A的代价小于B。
+
+ 2. 需要遍历的条件:
+
+ 1. 根据条件本身匹配模式给出一个初始Cost:如Regex为100,Contains为10等(具体数值等实现时根据情况调整)
+
+ 2. 根据历史查询的效率,在初始Cost的基础上进行不断调整后,得到实时的Cost。单位时间吞吐量
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service.md
new file mode 100644
index 00000000000..628b09a2943
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/context-service.md
@@ -0,0 +1,60 @@
+---
+title: CS 架构
+sidebar_position: 1
+---
+
+## **ContextService架构**
+
+### **水平划分**
+
+从水平上划分为三个模块:Restful,Scheduler,Service
+
+#### Restful职责:
+
+ 将请求封装为httpjob提交到Scheduler
+
+#### Scheduler职责:
+
+ 通过httpjob的protocol的ServiceName找到相应的服务执行这个job
+
+#### Service职责:
+
+ 真正执行请求逻辑的模块,封装ResponseProtocol,并唤醒Restful中wait的线程
+
+### **垂直划分**
+从垂直上划分为4个模块:Listener,History,ContextId,Context:
+
+#### Listener职责:
+
+1. 负责Client端的注册和绑定(写入数据库和在CallbackEngine中进行注册)
+
+2. 心跳接口,通过CallbackEngine返回Array[ListenerCallback]
+
+#### History职责:
+创建和移除history,操作Persistence进行DB持久化
+
+#### ContextId职责:
+主要是对接Persistence进行ContextId的创建,更新移除等操作
+
+#### Context职责:
+
+1. 对于移除,reset等方法,先操作Persistence进行DB持久化,并更新ContextCache
+
+2. 封装查询condition去ContextSearch模块获取相应的ContextKeyValue数据
+
+请求访问步骤如下图:
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-service-01.png)
+
+## **UML类图**
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-service-02.png)
+
+## **Scheduler线程模型**
+
+需要保证Restful的线程池不被填满
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-service-03.png)
+
+时序图如下:
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-service-04.png)
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/overview.md
new file mode 100644
index 00000000000..68591cc5386
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/context-service/overview.md
@@ -0,0 +1,129 @@
+---
+title: 总览
+sidebar_position: 0
+---
+
+## **背景**
+
+### **什么是上下文Context?**
+
+保持某种操作继续进行的所有必需信息。如:同时看三本书,每本书已翻看的页码就是继续看这本书的上下文。
+
+### **为什么需要CS(Context Service)?**
+
+CS,用于解决一个数据应用开发流程,跨多个系统间的数据和信息共享问题。
+
+例如,B系统需要使用A系统产生的一份数据,通常的做法如下:
+
+1. B系统调用A系统开发的数据访问接口;
+
+2. B系统读取A系统写入某个共享存储的数据。
+
+有了CS之后,A和B系统只需要与CS交互,将需要共享的数据和信息写入到CS,需要读取的数据和信息从CS中读出即可,无需外部系统两两开发适配,极大降低了系统间信息共享的调用复杂度和耦合度,使各系统的边界更加清晰。
+
+## **产品范围**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-01.png)
+
+
+### 元数据上下文
+
+元数据上下文定义元数据规范。
+
+元数据上下文依托于数据中间件,主要功能如下:
+
+1. 打通与数据中间件的关系,能拿到所有的用户元数据信息(包括Hive表元数据、线上库表元数据、其他NOSQL如HBase、Kafka等元数据)
+
+2. 所有节点需要访问元数据时,包括已有元数据和应用模板内元数据,都必须经过元数据上下文。元数据上下文记录了应用模板所使用的所有元数据信息。
+
+3. 各节点所产生的新元数据,都必须往元数据上下文注册。
+
+4. 抽出应用模板时,元数据上下文为应用模板抽象(主要是将用到的多个库表做成\${db}.表形式,避免数据权限问题)和打包所有依赖的元数据信息。
+
+元数据上下文是交互式工作流的基础,也是应用模板的基础。设想:Widget定义时,如何知道DataWrangler定义的各指标维度?Qualitis如何校验Widget产生的图报表?
+
+### 数据上下文
+
+数据上下文定义数据规范。
+
+数据上下文依赖于数据中间件和Linkis计算中间件。主要功能如下:
+
+1. 打通数据中间件,拿到所有用户数据信息。
+
+2. 打通计算中间件,拿到所有节点的数据存储信息。
+
+3. 所有节点需要写临时结果时,必须通过数据上下文,由数据上下文统一分配。
+
+4. 所有节点需要访问数据时,必须通过数据上下文。
+
+5. 数据上下文会区分依赖数据和生成数据,在抽出应用模板时,为应用模板抽象和打包所有依赖的数据。
+
+### 资源上下文
+
+资源上下文定义资源规范。
+
+资源上下文主要与Linkis计算中间件交互。主要功能如下:
+
+1. 用户资源文件(如Jar、Zip文件、properties文件等)
+
+2. 用户UDF
+
+3. 用户算法包
+
+4. 用户脚本
+
+### 环境上下文
+
+环境上下文定义环境规范。
+
+主要功能如下:
+
+1. 操作系统
+
+2. 软件,如Hadoop、Spark等
+
+3. 软件包依赖,如Mysql-JDBC。
+
+### 对象上下文
+
+运行时上下文为应用模板(工作流)在定义和执行时,所保留的所有上下文信息。
+
+它用于协助定义工作流/应用模板,在工作流/应用模板执行时提示和完善所有必要信息。
+
+运行时工作流主要是Linkis使用。
+
+
+## **CS架构图**
+
+![](/Images-zh/Architecture/Public_Enhancement_Service/ContextService/linkis-contextservice-02.png)
+
+## **架构说明:**
+
+### 1. Client
+外部访问CS的入口,Client模块提供HA功能;
+[进入Client架构设计](context-service-client.md)
+
+### 2. Service模块
+提供Restful接口,封装和处理客户端提交的CS请求;
+[进入Service架构设计](context-service.md)
+
+### 3. ContextSearch
+上下文查询模块,提供丰富和强大的查询能力,供客户端查找上下文的Key-Value键值对;
+[进入ContextSearch架构设计](context-service-search.md)
+
+### 4. Listener
+CS的监听器模块,提供同步和异步的事件消费能力,具备类似Zookeeper的Key-Value一旦更新,实时通知Client的能力;
+[进入Listener架构设计](context-service-listener.md)
+
+### 5. ContextCache
+上下文的内存缓存模块,提供快速检索上下文的能力和对JVM内存使用的监听和清理能力;
+[进入ContextCache架构设计](context-service-cache.md)
+
+### 6. HighAvailable
+提供CS高可用能力;
+[进入HighAvailable架构设计](context-service-highavailable.md)
+
+### 7. Persistence
+CS的持久化功能;
+[进入Persistence架构设计](context-service-persistence.md)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/datasource-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/datasource-manager.md
new file mode 100644
index 00000000000..66fc3b7fc69
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/datasource-manager.md
@@ -0,0 +1,140 @@
+---
+title: 数据源管理服务架构
+sidebar_position: 5
+---
+## 背景
+
+早期版本中的Exchangis0.x和Linkis0.x都有整合数据源模块,为复用数据源的管理能力,Linkis以linkis-datasource为蓝本(可以参阅相关的文档)重构数据源模块,将数据源管理拆封成数据源管理服务与元数据查询服务。
+
+本文主要涉及DataSource Manager Server数据源管理服务,提供如下功能:
+
+1)、Linkis统一管理服务启动与部署,不增加运维成本,复用Linkis服务能力;
+
+2)、通过Linkis Web提供图形界面的管理服务,界面提供了新增数据源,数据源查询、数据源更新,连通性测试等管理服务;
+
+3)、服务无状态,多实例部署,做到服务高可用。本系统在部署的时候,可以进行多实例部署,每个实例对外独立提供服务,不会互相干扰,所有的信息都是存储在数据库中进行共享。
+
+4)、提供数据源全生命周期管理,包括新建、查询、更新、测试、过期管理。
+
+5)、多版本数据源管理,历史数据源会保存在数据库中,并提供数据源过期管理。
+
+6)、Restful接口提供功能,详细列表:数据源类型查询、数据源详细信息查询、基于版本进行数据源信息查询、数据源版本查询、获取数据源参数列表、多维度数据源搜索、获数据源环境查询及更新、新增数据源、数据源参数配置、数据源过期设置、数据源连通性测试。
+
+## 架构图
+
+![datasource结构图](/Images-zh/Architecture/datasource/linkis-datasource-server.png)
+
+## 架构说明
+
+1、服务登记在Linkis-Eureak-Service服务中,与Linkis其他微服务统一管理,客户端可以通过连接Linkis-GateWay-Service服务与服务名 data-source-manager获取数据源管理服务。
+
+2、接口层,通过Restful接口向其他应用,提供了针对数据源、数据源环境的增删查改、数据源链接与双链接测试、数据源版本管理及过期操作;
+
+3、Service层,主要针对数据库与物料库的服务管理,永久保留数据源相关信息;
+
+4、数据源的链接测试都是通过linkis metastore server服务完成的,该服务现在提供mysql\es\kafka\hive服务
+
+### 核心流程
+
+1、 新建数据源,首先会从请求中获取新建数据源的用户,判断用户是否有效,下一步会对数据源相关字段信息进行校验,数据源名称和数据源类型不能为空,再下一步会根据数据源名称进行确认该数据源是否存在,如果不存在则将在数据库中进行插入,同时数据源ID号返回。
+
+2、 更新数据源,首先会从请求中获取新建数据源的用户,判断用户是否有效,下一步会对新的数据源相关字段信息进行校验,数据源名称和数据源类型不能为空,再下一步会根据数据源ID号进行确认该数据源是否存在,如果不存在返回异常,如果存在将进一步判断该用户是否对该数据源有更新权限,用户是管理员或者数据源owner才有权限更新,如果有权限则将更新该数据源,并返回数据源ID。
+
+3、 更新数据源参数,首先会从请求中获取新建数据源的用户,判断用户是否有效,根据所传参数数据源ID获取详细的数据源信息,接着会判断用户是否是改数据源的owner后者是否为管理员,如果有则进一步校验修改的参数,通过后则会更新参数,并返回versionId。
+
+## 实体对象
+
+| 类名 | 作用 |
+| ---------------------------- | -------------------------------------------- |
+| DataSourceType | 表示数据源的类型 |
+| DataSourceParamKeyDefinition | 声明数据源属性配置定义 |
+| DataSource | 数据源对象实体类,包含权限标签和属性配置定义 |
+| DataSourceEnv | 数据源环境对象实体类,也包含属性配置定义 |
+| DataSourceParameter | 数据源具体参数配置 |
+| DatasourceVersion | 数据源版本详细信息 |
+
+## **数据库设计**
+
+##### 数据库关系图:
+
+![](/Images-zh/Architecture/datasource/dn-db.png)
+
+##### 数据表定义:
+
+表名:linkis_ps_dm_datatsource <-->实体:DataSource
+
+| 序号 | 字段 | 字段描述 |
+| ---- | -------------------- | ---------------- |
+| 1 | id | 数据源ID |
+| 2 | datasource_name | 数据源名称 |
+| 3 | datasource_desc | 数据源详细描述 |
+| 4 | datasource_type_id | 数据源类型ID |
+| 5 | create_identify | 标识 |
+| 6 | create_system | 创建数据源的系统 |
+| 7 | parameter | 数据源参数,注意 不做存储,实体类parameter字段通过linkis_ps_dm_datasource_version的parameter获取 |
+| 8 | create_time | 数据源创建时间 |
+| 9 | modify_time | 数据源修改时间 |
+| 10 | create_user | 数据源创建用户 |
+| 11 | modify_user | 数据源修改用户 |
+| 12 | labels | 数据源标签 |
+| 13 | version_id | 数据源版本ID |
+| 14 | expire | 数据源是否过期 |
+| 15 | published_version_id | 数据源发布版本号 |
+
+表名:linkis_ps_dm_datasource_type <-->实体:DataSourceType
+
+| 序号 | 字段 | 字段描述 |
+| ---- | ----------- | ------------------ |
+| 1 | id | 数据源类型ID |
+| 2 | name | 数据源类型名称 |
+| 3 | description | 数据源类型描述 |
+| 4 | option | 数据源所属类型 |
+| 5 | classifier | 数据源类型分类词 |
+| 6 | icon | 数据源图片显示路径 |
+| 7 | layers | 数据源类型层次 |
+
+表名:linkis_ps_dm_datasource_env <-->实体:DataSourceEnv
+
+| 序号 | 字段 | 字段描述 |
+| ---- | ------------------ | ------------------ |
+| 1 | id | 数据源环境ID |
+| 2 | env_name | 数据源环境名称 |
+| 3 | env_desc | 数据源环境描述 |
+| 4 | datasource_type_id | 数据源类型ID |
+| 5 | parameter | 数据源环境参数 |
+| 6 | create_time | 数据源环境创建时间 |
+| 7 | create_user | 数据源环境创建用户 |
+| 8 | modify_time | 数据源修改时间 |
+| 9 | modify_user | 数据源修改用户 |
+
+表名:linkis_ps_dm_datasource_type_key <-->实体:DataSourceParamKeyDefinition
+
+| 序号 | 字段 | 字段描述 |
+| ---- | ------------------- | ------------------ |
+| 1 | id | 键值类型ID |
+| 2 | data_source_type_id | 数据源类型ID |
+| 3 | key | 数据源参数key值 |
+| 4 | name | 数据源参数名称 |
+| 5 | default_value | 数据源参数默认值 |
+| 6 | value_type | 数据源参数类型 |
+| 7 | scope | 数据源参数范围 |
+| 8 | require | 数据源参数是否必须 |
+| 9 | description | 数据源参数描述 |
+| 10 | value_regex | 数据源参数正则 |
+| 11 | ref_id | 数据源参数关联ID |
+| 12 | ref_value | 数据源参数关联值 |
+| 13 | data_source | 数据源 |
+| 14 | update_time | 更新时间 |
+| 15 | create_time | 创建时间 |
+
+表名:linkis_ps_dm_datasource_version <-->实体:DatasourceVersion
+
+| 序号 | 字段 | 字段描述 |
+| ---- | ------------- | ---------------- |
+| 1 | version_id | 数据源版本ID |
+| 2 | datasource_id | 数据源ID |
+| 3 | parameter | 数据源该版本参数 |
+| 4 | comment | 内容 |
+| 5 | create_time | 创建时间 |
+| 6 | create_user | 创建用户 |
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/metadata-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/metadata-manager.md
new file mode 100644
index 00000000000..5d1eed0b683
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/metadata-manager.md
@@ -0,0 +1,39 @@
+---
+title: 元数据管理服务架构
+sidebar_position: 3
+---
+## 背景
+
+早期版本中的Exchangis0.x和Linkis0.x都有整合数据源模块,为复用数据源的管理能力,Linkis以linkis-datasource为蓝本(可以参阅相关的文档)重构数据源模块,将数据源管理拆封成数据源管理服务与元数据查询服务。
+
+本文主要涉及MetaData Manager Server数据源管理服务,提供如下功能:
+
+1)、Linkis统一管理服务启动与部署,不增加运维成本,复用Linkis服务能力;
+
+2)、服务无状态,多实例部署,做到服务高可用。本系统在部署的时候,可以进行多实例部署,每个实例对外独立提供服务,不会互相干扰,所有的信息都是存储在数据库中进行共享。
+
+3)、提供数据源全生命周期管理,包括新建、查询、更新、测试、过期管理。
+
+4)、多版本数据源管理,历史数据源会保存在数据库中,并提供数据源过期管理。
+
+5)、Restful接口提供功能,详细列表:数据库信息查询、数据库表信息查询、数据库表参数信息查询、数据分区信息查询。
+
+## 架构图
+
+![BML架构图](/Images-zh/Architecture/datasource/meta-server.png)
+
+## 架构说明
+
+1、服务登记在Linkis-Eureak-Service服务中,与Linkis其他微服务统一管理,客户端可以通过连接Linkis-GateWay-Service服务与服务名 metamanager获取数据源管理服务。
+
+2、接口层,通过Restful接口向其他应用,提供了数据库\表\分区信息查询;
+
+3、Service层,通过数据源ID号在数据源管理服务中获取到数据源类型,通过类型获取具体支持的服务,支持的服务为mysql\es\kafka\hive;
+
+### 核心流程
+
+1、 客户端输入指定的数据源ID,通过restful接口获取信息,如查询数据源ID为1的数据库列表,,则url为`http:///metadatamanager/dbs/1`,
+
+2、 根据数据源ID,通过RPC访问数据源服务``获取到数据源类型
+
+3、 根据数据源类型,加载对应的Service服务[hive\es\kafka\mysql],执行对应的操作,然后返回;
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/overview.md
new file mode 100644
index 00000000000..c1e2aff2188
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/overview.md
@@ -0,0 +1,96 @@
+---
+title: 总览
+sidebar_position: 1
+---
+
+PublicEnhencementService(PS)架构设计
+======================================
+
+PublicEnhancementService(PS):公共增强服务,为其他微服务模块提供统一配置管理、上下文服务、物料库、数据源管理、微服务管理和历史任务查询等功能的模块。
+
+![](/Images-zh/Architecture/PublicEnhencement架构图.png)
+
+二级模块介绍:
+==============
+
+BML物料库
+---------
+
+是linkis的物料管理系统,主要用来存储用户的各种文件数据,包括用户脚本、资源文件、第三方Jar包等,也可以存储引擎运行时需要使用到的类库。
+
+| 核心类 | 核心功能 |
+|-----------------|------------------------------------|
+| UploadService | 提供资源上传服务 |
+| DownloadService | 提供资源下载服务 |
+| ResourceManager | 提供了上传、下载资源的统一管理入口 |
+| VersionManager | 提供了资源版本标记和版本管理功能 |
+| ProjectManager | 提供了项目级的资源管控能力 |
+
+Configuration统一配置管理
+-------------------------
+
+Configuration提供了“用户—引擎—应用”三级配置管理方案,实现了为用户提供配置各种接入应用下自定义引擎参数的功能。
+
+| 核心类 | 核心功能 |
+|----------------------|--------------------------------|
+| CategoryService | 提供了应用和引擎目录的管理服务 |
+| ConfigurationService | 提供了用户配置统一管理服务 |
+
+ContextService上下文服务
+------------------------
+
+ContextService用于解决一个数据应用开发流程,跨多个系统间的数据和信息共享问题。
+
+| 核心类 | 核心功能 |
+|---------------------|------------------------------------------|
+| ContextCacheService | 提供对上下文信息缓存服务 |
+| ContextClient | 提供其他微服务和CSServer组进行交互的能力 |
+| ContextHAManager | 为ContextService提供高可用能力 |
+| ListenerManager | 提供消息总线的能力 |
+| ContextSearch | 提供了查询入口 |
+| ContextService | 实现了上下文服务总体的执行逻辑 |
+
+Datasource数据源管理
+--------------------
+
+Datasource为其他微服务提供不同数据源连接的能力。
+
+| 核心类 | 核心功能 |
+|-------------------|--------------------------|
+| datasource-server | 提供不同数据源连接的能力 |
+
+InstanceLabel微服务管理
+-----------------------
+
+InstanceLabel为其他接入linkis的微服务提供注册和标签功能。
+
+| 核心类 | 核心功能 |
+|-----------------|--------------------------------|
+| InsLabelService | 提供微服务注册和标签管理的功能 |
+
+Jobhistory历史任务管理
+----------------------
+
+Jobhistory为用户提供了linkis历史任务查询、进度、日志展示的相关功能,为管理员提供统一历史任务视图。
+
+| 核心类 | 核心功能 |
+|------------------------|----------------------|
+| JobHistoryQueryService | 提供历史任务查询服务 |
+
+Variable用户自定义变量管理
+--------------------------
+
+Variable为用户提供自定义变量存储和使用的相关功能。
+
+| 核心类 | 核心功能 |
+|-----------------|------------------------------------|
+| VariableService | 提供自定义变量存储和使用的相关功能 |
+
+UDF用户自定义函数管理
+---------------------
+
+UDF为用户提供自定义函数的功能,用户可以在在编写代码时自行引入。
+
+| 核心类 | 核心功能 |
+|------------|------------------------|
+| UDFService | 提供用户自定义函数服务 |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/public-service.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/public-service.md
new file mode 100644
index 00000000000..2ca0ea2e92e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/feature/public-enhancement-services/public-service.md
@@ -0,0 +1,27 @@
+---
+title: 公共服务架构
+sidebar_position: 2
+---
+## **背景**
+为什么在我们将Linkis作为统一网关或JobServer后,还要为其增加公共增强的能力呢?这个是在我们实际去开发了多个上层应用工具后,发现如在IDE工具里面定义了一个UDF、变量调试通过后,在发布到调度工具的时候,这些UDF和变量又需要重现定义一遍。当依赖的一些jar包、配置文件等发生变化时,也需要修改两个地方。
+针对这些类似跨上层应用工具的公共上下文的问题,在我们实现任务统一入口为Linkis后,我们就在想是不是可以由Linkis去提供这个公共增强的能力,提供一些公共可以被多个应用工具去复用的能力。所以在Linkis层设计了一层公共增强服务PES
+
+
+## **架构图**
+
+![](/Images/Architecture/Public_Enhancement_Service/pes_arc.png)
+
+## **架构说明**
+
+现在已经提供了以下能力:
+- 提供统一的数据源能力:数据源在Linkis层进行统一定义和管理,应用工具只需要通过数据源名字来进行使用,不再需要去维护对应数据源的连接信息。而且在不同的工具间数据源的含义都是一样的。并提供了相应的数据源的元数据的查询能力。
+- 提供公共的UDF能力:统一UDF、小函数的定义规范和语义,做到一处定义多个工具都可使用。
+- 提供统一上下文的能力:支持任务间传递信息,包括变量、结果集、资源文件的多任务间传递,提供任务间传递上下文的能力。
+- 提供统一物料的能力:提供统一的物料,在多个工具间支持共享访问这些物料,并且物料支持存储多种的文件类型,并支持版本控制。
+- 提供统一配置和变量的能力:提供了统一的配置能力支持模板化的配置不同的引擎参数模版,支持自定义变量、内置常用的系统变量和时间格式变量等。
+- 提供公共错误码的能力:提供统一的错误码能力,对常用计算存储引擎的作物进行分类编码以及知识库的能力,并提供了方便的SDK进行调用。
+
+通过Linkis的公共增强服务,可以打破上层应用工具间的孤岛,做到变量、函数、文件、结果集等上下文的共享,就像下图所暂时的一样,并且大大减少应用工具间的重复开发工作。
+![](/Images/Architecture/Public_Enhancement_Service/pes_arc_demo.png)
+
+[详细介绍可以参考](https://mp.weixin.qq.com/s/UfUB8AGZtusbFmmtiZfK1A)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/overview.md
new file mode 100644
index 00000000000..334314da502
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/overview.md
@@ -0,0 +1,26 @@
+---
+title: 总览
+sidebar_position: 1
+---
+
+Linkis 1.0 将所有微服务总体划分为三大类:公共增强服务、计算治理服务、微服务治理服务。如下图所示为Linkis 1.0 的架构图。
+
+![Linkis1.0架构图](/Images-zh/Architecture/Linkis1.0-architecture.png)
+
+
+各大类的具体职责如下:
+
+1. 公共增强服务为 Linkis 0.X 已经提供的物料库服务、上下文服务、数据源服务和公共服务等。
+
+2. 微服务治理服务为 Linkis 0.X 已经提供的 Spring Cloud Gateway、Eureka 和 Open Feign。
+
+3. 计算治理服务是 Linkis 1.0 的核心重点,从 提交 —> 准备 —> 执行三个阶段,来全面升级 Linkis 对 用户任务的执行管控能力。
+
+以下是 Linkis1.0 架构文档的目录列表:
+
+1. Linkis1.0公共增强服务相关文档,请阅读[公共增强服务](feature/public-enhancement-services/overview.md)。
+
+2. Linkis1.0微服务治理相关文档,请阅读[微服务治理](service-architecture/overview.md)。
+
+3. Linkis1.0提出的计算治理服务相关文档,请阅读 [计算治理服务](feature/computation-governance-services/overview.md)。
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/_category_.json
new file mode 100644
index 00000000000..87ec81471d2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "微服务架构",
+ "position": 3
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/gateway.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/gateway.md
new file mode 100644
index 00000000000..ca13c7470e2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/gateway.md
@@ -0,0 +1,34 @@
+---
+title: 网关架构
+sidebar_position: 1
+---
+## Gateway 架构设计
+
+#### 简述
+Gateway网关是Linkis接受客户端以及外部请求的首要入口,例如接收作业执行请求,而后将执行请求转发到具体的符合条件的Entrance服务中去。
+整个架构底层基于SpringCloudGateway做扩展实现,上层叠加了与Http请求解析,会话权限,标签路由和WebSocket多路转发等相关的模组设计,整体架构可见如下。
+
+### 整体架构示意图
+
+![Gateway整体架构示意图](/Images-zh/Architecture/Gateway/gateway_server_global.png)
+
+#### 架构说明
+- gateway-core: Gateway的核心接口定义模块,主要定义了GatewayParser和GatewayRouter接口,分别对应请求的解析和根据请求进行路由选择;同时还提供了SecurityFilter的权限校验工具类。
+- spring-cloud-gateway: 该模块集成了所有与SpringCloudGateway相关的依赖,对HTTP和WebSocket两种协议类型的请求分别进行了处理转发。
+- gateway-server-support: Gateway的服务驱动模块,依赖spring-cloud-gateway模块,对GatewayParser、GatewayRouter分别做了实现,其中DefaultLabelGatewayRouter提供了请求标签路由的功能。
+- gateway-httpclient-support: 提供了Http访问Gateway服务的客户端通用类。
+- instance-label: 外联的实例标签模块,提供InsLabelService服务接口,用于路由标签的创建以及与应用实例关联。
+
+涉及的详细设计如下:
+
+#### 一、请求路由转发(带标签信息)
+请求的链路首先经SpringCloudGateway的Dispatcher分发后,进入网关的过滤器链表,进入GatewayAuthorizationFilter 和 SpringCloudGatewayWebsocketFilter 两大过滤器逻辑,过滤器集成了DefaultGatewayParser和DefaultGatewayRouter。
+从Parser到Router,执行相应的parse和route方法,DefaultGatewayParser和DefaultGatewayRouter内部还包含了自定义的Parser和Router,按照优先级顺序执行。最后由DefaultGatewayRouter输出路由选中的服务实例ServiceInstance,交由上层进行转发。
+现我们以具有标签信息的作业执行请求转发为例子,绘制如下流程图:
+![Gateway请求路由转发](/Images-zh/Architecture/Gateway/gateway_server_dispatcher.png)
+
+
+#### 二、WebSocket连接转发管理
+默认情况下SpringCloudGateway对WebSocket请求只做一次路由转发,无法做动态的切换,而在Linkis Gateway架构下,每次信息的交互都会附带相应的uri地址,引导路由到不同的后端服务。
+除了负责与前端、客户端连接的webSocketService以及负责和后台服务连接的webSocketClient, 中间会缓存一系列GatewayWebSocketSessionConnection列表,一个GatewayWebSocketSessionConnection代表一个session会话与多个后台ServiceInstance的连接。
+![Gateway的WebSocket转发管理](/Images-zh/Architecture/Gateway/gatway_websocket.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/overview.md
new file mode 100644
index 00000000000..ef33e8fea28
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/overview.md
@@ -0,0 +1,27 @@
+---
+title: 总览
+sidebar_position: 0
+---
+## **背景**
+
+微服务治理包含了Gateway、Eureka、Open Feign等三个主要的微服务。用来解决Linkis的服务发现与注册、统一网关、请求转发、服务间通信、负载均衡等问题。整个Linkis是一个完全的微服务架构,每个业务流程都是需要多个微服务协同完成的。
+
+## **架构图**
+
+![](/Images-zh/Architecture/linkis-microservice-gov-01.png)
+
+## **架构描述**
+
+1. Linkis Gateway作为Linkis的网关入口,主要承担了请求转发、用户访问认证、WebSocket通信等职责。Linkis1.0的Gateway还新增了基于Label的路由转发能力。Linkis在Spring
+Cloud Gateway中,实现了WebSocket路由转发器,用于与客户端建立WebSocket连接,建立连接成功后,会自动分析客户端的WebSocket请求,通过规则判断出请求该转发给哪个后端微服务,从而将WebSocket请求转发给对应的后端微服务实例。
+
+ [进入Linkis Gateway](gateway.md)
+
+2. Linkis Eureka
+主要负责服务注册与发现,Eureka由多个instance(服务实例)组成,这些服务实例可以分为两种:Eureka Server和Eureka Client。为了便于理解,我们将Eureka client再分为Service
+Provider和Service Consumer。Eureka Server 提供服务注册和发现,Service Provider服务提供方,将自身服务注册到Eureka,从而使服务消费方能够找到Service
+Consumer服务消费方,从Eureka获取注册服务列表,从而能够消费服务。
+
+3. Linkis基于Feign实现了一套自己的底层RPC通信方案。Linkis RPC作为底层的通信方案,将提供SDK集成到有需要的微服务之中。一个微服务既可以作为请求调用方,也可以作为请求接收方。作为请求调用方时,将通过Sender请求目标接收方微服务的Receiver,作为请求接收方时,将提供Receiver用来处理请求接收方Sender发送过来的请求,以便完成同步响应或异步响应。
+
+ ![](/Images-zh/Architecture/linkis-microservice-gov-03.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/service_isolation.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/service_isolation.md
new file mode 100644
index 00000000000..f0a51748f1f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/service-architecture/service_isolation.md
@@ -0,0 +1,196 @@
+---
+title: 微服务租户隔离架构设计
+sidebar_position: 9
+---
+
+## 1. 总述
+### 1.1 需求背景
+ Linkis在Gateway进行服务转发时是基于ribbon进行负载均衡的,但是有些情况下存在一些重要业务的任务希望做到服务级别的隔离,如果基于ribbon进行服务在均衡就会存在问题。比如租户A希望他的任务都路由到特定的Linkis-CG-Entrance服务,这样当其他的实例出现异常时可以不会影响到A服务的Entrance。另外支持服务的租户及隔离也可以做到快速隔离某个异常服务,支持灰度升级等场景。
+
+### 1.2 目标
+1. 支持通过解析请求的标签按照路由标签对服务进行转发
+2. 支持服务的标签注册和修改
+
+## 2. 总体设计
+ 此次特性新增主要修改点位linkis-mg-gateway和instance-label两个模块,设计到新增Gateway的转发逻辑,以及instance-label支持服务和标签的注册。
+
+### 2.1 技术架构
+ 整体技术架构主要修改点位RestFul请求需要带上路由标签等标签参数信息,然后在Gateway进行转发时会解析对应的标签完成接口的路由转发。整体如下图所示
+![arc](/Images/Architecture/Gateway/service_isolation_arc.png)
+
+几点说明:
+1. 如果存在多个对应的服务打上了同一个roteLabel则随机转发
+2. 如果对应的routeLabel没有对应的服务,则接口直接失败
+3. 如果接口没有routeLabel则基于原有的转发逻辑,不会路由到打上了特定标签的服务
+
+### 2.2 业务架构
+ 此次的特性主要是为了完成Restful租户隔离转发功能。功能点设计的模块如下:
+
+| 组件名| 一级模块 | 二级模块 | 功能点 |
+|---|---|---|---|
+| Linkis | MG | Gateway| 解析restful请求参数中的路由标签,完成接口按照路由标签的转发功能|
+| Linkis | PS | InstanceLabel| InstanceLabel服务,完成服务和标签的关联|
+
+## 3. 模块设计
+### 3.1 核心执行流程
+- [输入端] 输入端为请求Gatway的restful请求,且是参数中待用roure label的请求才会进行处理
+- [处理流程] Gateway会判断请求是否带有对应的RouteLabel,如果存在则基于RouteLabel来进行转发。
+调用时序图如下:
+
+![Time](/Images/Architecture/Gateway/service_isolation_time.png)
+
+
+
+## 4. 数据结构:
+```sql
+DROP TABLE IF EXISTS `linkis_ps_instance_label`;
+CREATE TABLE `linkis_ps_instance_label` (
+ `id` int(20) NOT NULL AUTO_INCREMENT,
+ `label_key` varchar(32) COLLATE utf8_bin NOT NULL COMMENT 'string key',
+ `label_value` varchar(255) COLLATE utf8_bin NOT NULL COMMENT 'string value',
+ `label_feature` varchar(16) COLLATE utf8_bin NOT NULL COMMENT 'store the feature of label, but it may be redundant',
+ `label_value_size` int(20) NOT NULL COMMENT 'size of key -> value map',
+ `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'update unix timestamp',
+ `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'update unix timestamp',
+ PRIMARY KEY (`id`),
+ UNIQUE KEY `label_key_value` (`label_key`,`label_value`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
+
+DROP TABLE IF EXISTS `linkis_ps_instance_info`;
+CREATE TABLE `linkis_ps_instance_info` (
+ `id` int(11) NOT NULL AUTO_INCREMENT,
+ `instance` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'structure like ${host|machine}:${port}',
+ `name` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'equal application name in registry',
+ `update_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'update unix timestamp',
+ `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'create unix timestamp',
+ PRIMARY KEY (`id`),
+ UNIQUE KEY `instance` (`instance`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
+
+DROP TABLE IF EXISTS `linkis_ps_instance_label_relation`;
+CREATE TABLE `linkis_ps_instance_label_relation` (
+ `id` int(20) NOT NULL AUTO_INCREMENT,
+ `label_id` int(20) DEFAULT NULL COMMENT 'id reference linkis_ps_instance_label -> id',
+ `service_instance` varchar(128) NOT NULL COLLATE utf8_bin COMMENT 'structure like ${host|machine}:${port}',
+ `update_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'update unix timestamp',
+ `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'create unix timestamp',
+ PRIMARY KEY (`id`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
+
+```
+## 5. 如何使用:
+
+### 5.1 add route label for entrance
+```
+echo "spring.eureka.instance.metadata-map.route=et1" >> $LINKIS_CONF_DIR/linkis-cg-entrance.properties
+sh $LINKIS_HOME/sbin/linkis-damemon.sh restart cg-entrance
+```
+![Time](/Images/Architecture/Gateway/service_isolation_time.png)
+
+### 5.2 Use route label
+submit task:
+```
+url:/api/v1/entrance/submit
+{
+ "executionContent": {"code": "echo 1", "runType": "shell"},
+ "params": {"variable": {}, "configuration": {}},
+ "source": {"scriptPath": "ip"},
+ "labels": {
+ "engineType": "shell-1",
+ "userCreator": "peacewong-IDE",
+ "route": "et1"
+ }
+}
+```
+will be routed to a fixed service:
+```
+{
+ "method": "/api/entrance/submit",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "taskID": 45158,
+ "execID": "exec_id018030linkis-cg-entrancelocalhost:9205IDE_peacewong_shell_0"
+ }
+}
+```
+
+or linkis-cli:
+
+```
+sh bin/linkis-cli -submitUser hadoop -engineType shell-1 -codeType shell -code "whoami" -labelMap route=et1 --gatewayUrl http://127.0.0.1:9101
+```
+
+### 5.3 Use non-existing label
+submit task:
+```
+url:/api/v1/entrance/submit
+{
+ "executionContent": {"code": "echo 1", "runType": "shell"},
+ "params": {"variable": {}, "configuration": {}},
+ "source": {"scriptPath": "ip"},
+ "labels": {
+ "engineType": "shell-1",
+ "userCreator": "peacewong-IDE",
+ "route": "et1"
+ }
+}
+```
+will get the error
+```
+{
+ "method": "/api/rest_j/v1/entrance/submit",
+ "status": 1,
+ "message": "GatewayErrorException: errCode: 11011 ,desc: Cannot route to the corresponding service, URL: /api/rest_j/v1/entrance/submit RouteLabel: [{\"stringValue\":\"et2\",\"labelKey\":\"route\",\"feature\":null,\"modifiable\":true,\"featureKey\":\"feature\",\"empty\":false}] ,ip: localhost ,port: 9101 ,serviceKind: linkis-mg-gateway",
+ "data": {
+ "data": "{\r\n \"executionContent\": {\"code\": \"echo 1\", \"runType\": \"shell\"},\r\n \"params\": {\"variable\": {}, \"configuration\": {}},\r\n \"source\": {\"scriptPath\": \"ip\"},\r\n \"labels\": {\r\n \"engineType\": \"shell-1\",\r\n \"userCreator\": \"peacewong-IDE\",\r\n \"route\": \"et2\"\r\n }\r\n}"
+ }
+}
+```
+
+### 5.4 without label
+submit task:
+```
+url:/api/v1/entrance/submit
+{
+ "executionContent": {"code": "echo 1", "runType": "shell"},
+ "params": {"variable": {}, "configuration": {}},
+ "source": {"scriptPath": "ip"},
+ "labels": {
+ "engineType": "shell-1",
+ "userCreator": "peacewong-IDE"
+ }
+}
+```
+
+```
+
+will route to untagged entranceservices
+{
+ "method": "/api/entrance/submit",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "taskID": 45159,
+ "execID": "exec_id018018linkis-cg-entrancelocalhost2:9205IDE_peacewong_shell_0"
+ }
+}
+
+```
+
+## 6. 非功能性设计:
+
+### 6.1 安全
+不涉及安全问题,restful需要登录认证
+
+### 6.2 性能
+对Gateway转发性能影响较小,有缓存相应的label和instance的数据
+
+### 6.3 容量
+不涉及
+
+### 6.4 高可用
+不涉及
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/task-flow.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/task-flow.md
new file mode 100644
index 00000000000..0dd9d2a3ede
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/architecture/task-flow.md
@@ -0,0 +1,187 @@
+---
+title: 任务流转流程介绍
+sidebar_position: 2
+---
+
+> Linkis任务执行是Linkis的核心功能,调用到Linkis的计算治理服务、公共增强服务,微服务治理的三层服务,现在已经支持了OLAP、OLTP、Streaming等引擎类型的任务执行,本文将对OLAP类型引擎的任务提交、准备、执行、结果返回等流程进行介绍。
+
+## 关键名词:
+LinkisMaster:Linkis的计算治理服务层架中的管理服务,主要包含了AppManager、ResourceManager、LabelManager等几个管控服务。原名LinkisManager服务。
+
+Entrance:计算治理服务层架中的入口服务,完成任务的调度、状态管控、任务信息推送等功能。
+
+Orchestrator:Linkis的编排服务,提供强大的编排和计算策略能力,满足多活、主备、事务、重放、限流、异构和混算等多种应用场景的需求。现阶段Orchestrator被Entrance服务所依赖。
+
+EngineConn(EC):引擎连接器,负责接受任务并提交给底层引擎如Spark、hive、Flink、Presto、trino等进行执行。
+
+EngineConnManager(ECM):Linkis 的EC进程管理服务,负责管控EngineConn的生命周期(启动、停止)。
+
+LinkisEnginePluginServer:该服务负责管理各个引擎的启动物料和配置,另外提供每个EngineConn的启动命令获取,以及每个EngineConn所需要的资源。
+
+PublicEnhencementService(PES): 公共增强服务,为其他微服务模块提供统一配置管理、上下文服务、物料库、数据源管理、微服务管理和历史任务查询等功能的模块。
+
+## 一、Linkis交互式任务执行架构
+### 1.1、任务执行思考
+ 在现有Linkis1.0任务执行架构之前,也经历了多次演变,从最开始用户一多起来就各种FullGC导致服务崩溃,到用户开发的脚本如何支持多平台、多租户、强管控、高并发运行,我们遇见了如下几个问题:
+1. 如何支持租户户的上万并发并互相隔离?
+2. 如何支持上下文统一 ,用户定义的UDF、自定义变量等支持多个系统使用?
+3. 如何支持高可用,做到用户提交的任务能够正常运行完?
+4. 如何支持任务的底层引擎日志、进度、状态能够实时推送给前端?
+5. 如何支持多种类型的任务提交sql、python、shell、scala、java等
+
+### 1.2、Linkis任务执行设计
+ 基于以上5个问题出发,Linkis将OLTP任务分成了四个阶段,分别是:
+1. 提交阶段:APP提交到Linkis的CG-Entrance服务到完成任务的持久化(PS-JobHistory)以及任务的各种拦截器处理(危险语法、变量替换、参数检查)等步骤,并做生产者消费者的并发控制;
+2. 准备阶段:任务在Entrance被Scheduler消费调度给Orchestrator模块进行任务的编排、并向LinkisMaster完成EngineConn的申请,在这过程中会对租户的资源进行管控;
+3. 执行阶段:任务从Orchestrator提交给EngineConn执行,EngineConn具体提交底层引擎进行执行,并实时将任务的信息推送给调用方;
+4. 结果返回阶段:向调用方返回结果,支持json和io流返回结果集
+ Linkis的整体任务执行架构如下图所示:
+ ![arc](/Images/Architecture/Job_submission_preparation_and_execution_process/linkis_job_arc.png)
+
+## 二、任务执行流程介绍
+ 首先我们先对OLAP型任务的处理流程进行一个简要介绍,任务整体的一个执行流程如下图所示:
+![flow](/Images/Architecture/Job_submission_preparation_and_execution_process/linkis_job_flow.png)
+
+ 整个任务涉及到了所有的计算治理的所有服务,任务通过Gateway转发到Linkis的人口服务Entrance后,会通过对任务的标签进行多级调度(生产者消费者模式)通过FIFO的模式完成任务的调度执行,Entrance接着将任务提交给Orchestrator进行任务编排和提交,Orchestrator会向LinkisMaster完成EC的申请,在这过程中会通过任务的Label进行资源管控和引擎版本选择申请不同的EC。接着Orchestrator将编排后的任务提交给EC进行执行,EC会将job的日志、进度、资源使用等信息推动给Entrance服务,并推送给调用方。下面我们基于上图和结合任务的四个阶段(提交、准备、执行、返回)对任务的执行流程进行一个简要介绍。
+
+
+### 2.1 Job提交阶段
+ Job提交阶段Linkis支持多种类型的任务:SQL, Python, Shell, Scala, Java等,支持不同的提交接口,支持Restful/JDBC/Python/Shell等提交接口。提交任务主要包含任务代码、标签、参数等信息即可,下面是一个RestFul的示例:
+通过Restfu接口发起一个Spark Sql任务
+```JSON
+ "method": "/api/rest_j/v1/entrance/submit",
+ "data": {
+ "executionContent": {
+ "code": "select * from table01",
+ "runType": "sql"
+ },
+ "params": {
+ "variable": {// task variable
+ "testvar": "hello"
+ },
+ "configuration": {
+ "runtime": {// task runtime params
+ "jdbc.url": "XX"
+ },
+ "startup": { // ec start up params
+ "spark.executor.cores": "4"
+ }
+ }
+ },
+ "source": { //task source information
+ "scriptPath": "file:///tmp/hadoop/test.sql"
+ },
+ "labels": {
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+1. 任务首先会提交给Linkis的网关linkis-mg-gateway服务,Gateway会通过任务中是否带有routeLabel来转发给对应的Entrance服务,如果没有RouteLabel则随机转发给一个Entrance服务
+2. Entrance接受到对应的Job后,会调用PES中JobHistory模块的RPC对Job的信息进行持久化,并对参数和代码进性解析对自定义变量进行替换,并提交给调度器(默认FIFO调度)调度器会通过任务的标签进行分组,标签不同的任务互相不影响调度。
+3. Entrance在通过FIFO调度器消费后会提交给Orchestrator进行编排执行,就完成了任务的提交阶段
+ 主要涉及的类简单说明:
+```
+EntranceRestfulApi: 入口服务的Controller类,任务提交、状态、日志、结果、job信息、任务kill等操作
+EntranceServer:任务的提交入口,完成任务的持久化、任务拦截解析(EntranceInterceptors)、提交给调度器
+EntranceContext:Entrance的上下文持有类,包含获取调度器、任务解析拦截器、logManager、持久化、listenBus等方法
+FIFOScheduler: FIFO调度器,用于调度任务
+EntranceExecutor:调度的执行器,任务调度后会提交给EntranceExecutor进行执行
+EntranceJob:调度器调度的job任务,通过EntranceParser解析用户提交的JobRequest进行生成和JobRequest一一对应
+```
+此时任务状态为排队状态
+
+### 2.2 Job准备阶段
+ Entrance的调度器,会按照Job中的Label生成不同的消费器去消费任务,任务被消费修改状态为Running时开始进入准备状态,到对应的任务后就是任务的准备阶段开始了。主要涉及以下几个服务:Entrance、LinkisMaster、EnginepluginServer、EngineConnManager、EngineConn,下面将对以下服务进行分开介绍。
+### 2.2.1 Entrance步骤:
+1. 消费器(FIFOUserConsumer)通过对应标签配置的支持并发数进行消费将任务消费调度给编排器(Orchestrator)进行执行
+2. 首先是Orchestrator对提交的任务进行编排,对于普通的hive和Spark单引擎的任务主要是任务的解析、label检查和校验,对于多数据源混算的场景会拆分不同的任务提交给不同的数据源进行执行等
+3. 在准备阶段,编排器Orchestrator另外一个重要的事情是通过请求LinkisMaster获取用于执行任务的EngineConn。如果LinkisMaster有对应的EngineConn可以复用则直接返回,如果没有则创建EngineConn。
+4. Orchestrator拿到任务后提交给EngineConn进行执行,准备阶段结束,进入Job执行阶段
+ 主要涉及的类简单说明:
+
+```
+## Entrance
+FIFOUserConsumer: 调度器的消费器,会根据标签生成不同的消费器,如IDE-hadoop、spark-2.4.3生成不同的消费器。消费提交的任务。并控制同时运行的任务个数,通过对应标签配置的并发数:wds.linkis.rm.instance
+DefaultEntranceExecutor:任务执行的入口,发起编排器的调用:callExecute
+JobReq: 编排器接受的任务对象,通过EntranceJob转换而来,主要包括代码、标签信息、参数等
+OrchestratorSession:类似于SparkSession,是编排器的入口。正常单例。
+Orchestration:JobReq被OrchestratorSession编排后的返回对象,支持执行和打印执行计划等
+OrchestrationFuture: Orchestration选择异步执行的返回,包括cancel、waitForCompleted、getResponse等常用方法
+Operation:用于扩展操作任务的接口,现在已经实现了用于获取日志的LogOperation、获取进度的ProgressOperation等
+
+## Orchestrator
+CodeLogicalUnitExecTask: 代码类型任务的执行入口,任务最终编排运行后会调用该类的execute方法,首先会向LinkisMaster请求EngineConn再提交执行
+DefaultCodeExecTaskExecutorManager:负责管控代码类型的EngineConn,包括请求和释放EngineConn
+ComputationEngineConnManager:负责LinkisMaster进行对接,请求和释放ENgineConn
+```
+
+### 2.2.2 LinkisMaster步骤:
+
+1.LinkisMaster接受到Entrance服务发出的请求EngineConn请求进行处理
+2.判断是否有对应Label可以复用的EngineConn,有则直接返回
+3.如果没有则进入创建EngineConn流程:
+- 首先通过Label选择合适的EngineConnManager服务。
+- 接着通过调用EnginePluginServer获取本次请求EngineConn的资源类型和资源使用,
+- 通过资源类型和资源,判断对应的Label是否还有资源,如果有则进入创建,否则抛出重试异常
+- 请求第一步的EngineConnManager启动EngineConn
+- 等待EngineConn空闲,返回创建的EngineConn,否则判断异常是否可以重试
+
+4.锁定创建的EngineConn返回给Entrance,注意这里为异步请求Entrance发出EC请求后会接受到对应的请求ID,LinkisMaster请求完毕后主动通过给对应的Entrance服务
+
+主要涉及的类简单说明:
+```
+## LinkisMaster
+EngineAskEngineService: LinkisMaster负责处理引擎请求的处理类,主要逻辑通过调用EngineReuseService判断是否有EngineConn可以复用,否则调用EngineCreateService创建EngineConn
+EngineCreateService:负责创建EngineConn,主要几个步骤:
+
+
+## LinkisEnginePluginServer
+EngineConnLaunchService:提供ECM获取对应引擎类型EngineConn的启动信息
+EngineConnResourceFactoryService:提供给LinkisMaster获取对应本次任务所需要启动EngineConn需要的资源
+EngineConnResourceService: 负责管理引擎物料,包括刷新和刷新所有
+
+## EngineConnManager
+AbstractEngineConnLaunchService:负责启动接受LinkisMaster请求启动EngineConn的请求,并完成EngineConn引擎的启动
+ECMHook: 用于处理EngineConn启动前后的前置后置操作,如hive UDF Jar加入到EngineConn启动的classPath中
+```
+
+
+这里需要说明的是如果用户存在一个可用空闲的引擎,则会跳过1,2,3,4 四个步骤;
+
+### 2.3 Job执行阶段
+ 当Entrance服务中的编排器拿到EngineConn后就进入了执行阶段,CodeLogicalUnitExecTask会将任务提交给EngineConn进行执行,EngineConn会通过对应的CodeLanguageLabel创建不同的执行器进行执行。主要步骤如下:
+1. CodeLogicalUnitExecTask通过RPC提交任务给到EngineConn
+2. EngineConn判断是否有对应的CodeLanguageLabel的执行器,如果没有则创建
+3. 提交给Executor进行执行,通过链接到具体底层的引擎执行进行执行,如Spark通过sparkSession提交sql、pyspark、scala任务
+4. 任务状态流转实时推送给Entrance服务
+5. 通过实现log4jAppender,SendAppender通过RPC将日志推送给Entrance服务
+6. 通过定时任务实时推送任务进度和资源信息给到Entrance
+
+主要涉及的类简单说明:
+```
+ComputationTaskExecutionReceiver:Entrance服务端编排器用于接收EngineConn所有RPC请求的服务类,负责接收进度、日志、状态、结果集在通过ListenerBus的模式推送给上次调用方
+TaskExecutionServiceImpl:EngineConn接收Entrance所有RPC请求的服务类,包括任务执行、状态查询、任务Kill等
+ComputationExecutor:具体的任务执行父类,比如Spark分为SQL/Python/Scala Executor
+ComputationExecutorHook: 用于Executor创建前后的Hook,比如初始化UDF、执行默认的UseDB等
+EngineConnSyncListener: ResultSetListener/TaskProgressListener/TaskStatusListener 用于监听Executor执行任务过程中的进度、结果集、和进度等信息
+SendAppender: 负责推送EngineConn端的日志给到Entrance
+```
+### 2.4 Job结果推送阶段
+ 该阶段比较简单,主要用于将任务在EngineConn产生的结果集返回给Client,主要步骤如下:
+1. 首先在EngineConn执行任务过程中会进行结果集写入,写入到文件系统中获取到对应路径。当然也支持内存缓存,默认写文件
+2. EngineConn将对应的结果集路径和结果集个数返回给Entrance
+3. Entrance调用JobHistory将结果集路径信息更新到任务表中
+4. Client通过任务信息获取到结果集路径并读取结果集
+ 主要涉及的类简单说明:
+```
+EngineExecutionContext:负责创建结果集和推送结果集给到Entrance服务
+ResultSetWriter:负责写结果集到文件系统中支持linkis-storage支持的文件系统,现在以及支持本地和HDFS。支持的结果集类型,表格、文本、HTML、图片等
+JobHistory:存储有任务的所有信息包括状态、结果路径、指标信息等对应DB中的实体类
+ResultSetReader:读取结果集的关键类
+```
+
+## 三、总结
+ 上面我们主要介绍了Linkis计算治理服务组CGS的OLAP任务的整个执行流程,按照任务请求的处理过程对任务拆分成了提交、准备、执行、返回结果四个阶段。CGS主要就是遵循这4个阶段来设计实现的,服务于这4个阶段,且为每个阶段提供了强大和灵活的能力。在提交阶段,主要提供通用的接口,接收上层应用工具提交过来的任务,并能提供基础的解析和拦截能力;在准备阶段,主要通过编排器Orchestrator和LinkisMaster完成对任务的解析编排,并且做资源控制和完成EngineConn的创建;执行阶段,通过引擎连接器EngineConn来去实际完成和底层引擎的对接,通常每个用户要连接不同的底层引擎,就得先启动一个对应的底层引擎连接器EC。计算任务通过EC来提交给底层引擎做实际的执行和状态、日志、结果等信息的获取,及在结果返回阶段,返回任务执行的结果信息,支持按照多种返回模式,如:文件流、JSON、JDBC等。整体的时序图如下:
+
+![time](/Images/Architecture/Job_submission_preparation_and_execution_process/linkis_job_time.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/_category_.json
new file mode 100644
index 00000000000..0ab705787e5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "安全认证",
+ "position": 6
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/kerberos.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/kerberos.md
new file mode 100644
index 00000000000..49ee593d7cf
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/kerberos.md
@@ -0,0 +1,99 @@
+---
+title: Kerberos
+sidebar_position: 5
+---
+
+## Kerberos 认证
+
+## 场景1 HDFS 存储
+
+如果使用到的hadoop集群,如用来存储的结果集的文件
+```shell script
+# 结果集日志等文件路径,用于存储Job的结果集文件 wds.linkis.filesystem.hdfs.root.path(linkis.properties)
+HDFS_USER_ROOT_PATH=hdfs:///tmp/linkis
+```
+并且 开启了kerberos认证,需要进行对应的kerberos配置
+
+修改`linkis.properties` 对应的配置如下
+```properties
+#是否开启了kerberos认证模式
+wds.linkis.keytab.enable=true
+#keytab放置目录,该目录存储的是多个用户的username.keytab的文件
+wds.linkis.keytab.file=/appcom/keytab/
+#是否带上principle客户端认证 默认值false
+wds.linkis.keytab.host.enabled=false
+#principle认证需要带上的客户端IP
+wds.linkis.keytab.host=127.0.0.1
+```
+修改后重启服务
+
+## 场景2 HDFS 存储 kerberos 代理认证
+
+Hadoop2.0版本开始支持ProxyUser的机制。含义是使用User A的用户认证信息,以User B的名义去访问hadoop集群。
+对于服务端来说就认为此时是User B在访问集群,相应对访问请求的鉴权(包括HDFS文件系统的权限,YARN提交任务队列的权限)都以用户User B来进行。
+User A被认为是superuser。
+
+和场景1主要区别是,可以解决每个用户都需要生成一个keytab文件的问题,如果设置了 kerberos 代理认证,可以使用代理用户的keytab文件进行认证。
+修改`linkis.properties` 对应的配置如下
+
+```properties
+#是否开启了kerberos认证模式
+wds.linkis.keytab.enable=true
+#keytab放置目录,该目录存储的是多个用户的username.keytab的文件
+wds.linkis.keytab.file=/appcom/keytab/
+#是否带上principle客户端认证 默认值false
+wds.linkis.keytab.host.enabled=false
+#principle认证需要带上的客户端IP
+wds.linkis.keytab.host=127.0.0.1
+
+#开启kerberos的代理认证
+wds.linkis.keytab.proxyuser.enable=true
+
+#使用superuser 来验证用户认证信息的
+wds.linkis.keytab.proxyuser.superuser=hadoop
+
+
+
+```
+修改后重启服务
+
+## 场景3 队列管理器查看yarn资源信息
+![yarn-normal](/Images-zh/auth/yarn-normal.png)
+会访问访问Yarn提供了ResourceManager的REST API 接口
+如果yarn的ResourceManager 开启了kerberos认证,需要配置kerberos相关的认证信息
+
+数据库表 `linkis_cg_rm_external_resource_provider`
+插入yarn数据信息
+```sql
+INSERT INTO `linkis_cg_rm_external_resource_provider`
+(`resource_type`, `name`, `labels`, `config`) VALUES
+('Yarn', 'default', NULL,
+'
+ {
+ "rmWebAddress": "http://xx.xx.xx.xx:8088",
+ "hadoopVersion": "2.7.2",
+ "authorEnable":false,
+ "user":"hadoop","pwd":"123456",
+ "kerberosEnable":@YARN_KERBEROS_ENABLE,
+ "principalName":"@YARN_PRINCIPAL_NAME",
+ "keytabPath":"@YARN_KEYTAB_PATH"
+ "krb5Path":"@YARN_KRB5_PATH"
+ }
+'
+);
+
+```
+更新后,因为程序中有使用到缓存,想要立即生效,需要重启`linkis-cg-linkismanager`服务
+
+```shell script
+sh sbin/linkis-daemon.sh restart cg-linkismanager
+```
+
+
+
+## 场景4 数据源功能中 HIVE 数据源
+
+如果需要连接的hive数据源,对应的 hive 集群环境,有开启kerberos认证,需要在配置集群环境时,将kerberos以及keytab认证文件信息上传。
+![](/Images-zh/auth/dsm-kerberos.png)
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/ldap.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/ldap.md
new file mode 100644
index 00000000000..2fcfb991175
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/ldap.md
@@ -0,0 +1,51 @@
+---
+title: LDAP
+sidebar_position: 1
+---
+> LDAP(Lightweight Directory Access Protocol)配置,默认安装部署后,只支持配置的静态用户和密码登录(只能配置一个),如果需要支持多用户登录可以使用LDAP
+
+## 1. 实现逻辑介绍
+
+默认方式的配置`linkis-mg-gateway.properties`
+
+```properties
+#默认用户名
+wds.linkis.admin.user=hadoop
+#默认密码
+wds.linkis.admin.password=123456
+```
+
+登陆请求处理时`org.apache.linkis.gateway.security.UserPwdAbstractUserRestful#tryLogin`,
+如果登陆用户名/用户密码和配置的默认值不一致,会走LDAP模式。
+LDAP核心处理 `org.apache.linkis.gateway.security.LDAPUserRestful#login` 通过调用jdk通用的ldap工具类进行认证。
+`javax.naming.ldap.InitialLdapContext#InitialLdapContext(java.util.Hashtable,?>, javax.naming.ldap.Control[])`
+
+
+## 2. 使用方式
+
+> 前提是有可用的LADP服务
+
+### 2.1 Step1 开启ladp登陆验密方式
+
+修改`linkis-mg-gateway.properties`配置
+
+将LDAP相关参数填入
+```properties
+##LDAP
+#ldap服务地址
+wds.linkis.ldap.proxy.url=ldap://localhost:1389/
+#Directory Name(DN) ldap的目录构成
+wds.linkis.ldap.proxy.baseDN==dc=linkis,dc=org
+#用户名格式化 一般无需要配置
+wds.linkis.ldap.proxy.userNameFormat=
+```
+### 2.2 Step2 重启linkis-mg-gateway 的服务
+
+修改配置后,需要重启`linkis-mg-gateway`服务 `sh sbin/linkis-daemon.sh start mg-mgtaeway`,才能生效
+
+## 3 注意事项
+
+- 认证类型使用的是`java.naming.security.authentication`(安全类型,三个值:none,simple或strong。)中的simple模式
+
+- 关于ldap的介绍可以参考[LDAP目录服务器介绍](https://juejin.cn/post/6844903857311449102)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/proxy.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/proxy.md
new file mode 100644
index 00000000000..2d32ae8bd14
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/proxy.md
@@ -0,0 +1,59 @@
+---
+title: 代理认证
+sidebar_position: 4
+---
+
+
+> 这种方式允许登录用户和实际使用的用户不同,主要作用:控制用户登录时必须为实名用户,但是实际使用大数据平台时,是非实名用户,方便进行权限的校验和管控。
+> 比如:linkis在执行用户提交的任务时,linkis主要进程服务会通过sudo -u ${submit user} 切换到对应用户下,然后执行对应的引擎启动命令,
+> 这就需要为每个${submit user} 提前创建对应的系统用户,并且配置好相关的环境变量。 对于新用户,需要一系列的环境的初始化准备工作,
+> 如果频繁的用户变化,会增大运维成本,而且用户过多,没法针对单个用户配置资源,资源之间无法很好的管控。如果能够实现A代理给指定的代理用户执行,可以将执行入口统一收敛,解决需要初始化环境的问题。
+
+## 1. 实现逻辑介绍
+
+
+- 登陆用户:通过用户名密码直接登陆系统的用户
+- 代理用户:作为登陆用户实际执行操作的用户称之为代理用户,代理登陆用户的执行相关操作
+
+对于登陆cookie处理,解析出登录用户和代理用户
+
+```html
+代理用户的cookie的key为:linkis_user_session_proxy_ticket_id_v1
+登录用户的cookie: linkis_user_session_ticket_id_v1
+
+```
+linkis的相关接口能在基于UserName信息,识别出代理用户信息,使用代理用户进行各项操作。并记录审计日志,包含用户的任务执行操作,下载操作
+任务提交执行的时候,entrance入口服务修改执行的用户为代理用户
+
+## 2. 使用方式
+
+### 2.1 Step1 开启代理模式
+在 `linkis.properties` 指定如下参数:
+```shell script
+# 打开代理模式
+ wds.linkis.gateway.conf.enable.proxy.user=true
+ # 指定代理配置文件
+ wds.linkis.gateway.conf.proxy.user.config=proxy.properties
+```
+
+
+在 conf 目录下,创建`proxy.properties` 文件,内容如下:
+```shell script
+# 格式如下:
+ ${LOGIN_USER}=${PROXY_USER}
+ # 例如:
+ enjoyyin=hadoop
+```
+如果现有的代理模式不能满足您的需求,也可以对:`org.apache.linkis.gateway.security.ProxyUserUtils`进一步改造。
+
+### 2.2 Step2 重启linkis-mg-gateway 的服务
+
+修改配置后,需要重启`linkis-mg-gateway`服务 `sh sbin/linkis-daemon.sh start mg-mgtaeway`,才能生效
+
+## 3 注意事项
+
+- 用户分为代理用户和非代理用户,代理类型的用户不能进行再次代理到其他用户执行
+- 需要控制登陆用户与可代理的系统用户列表,禁止出现任意代理的情况,避免权限不可控。最好支持数据库表来配置,并可以直接修改生效,不需要重启服务
+- 单独记录日志文件包含代理用户的操作,如代理执行、函数更新等PublicService的代理用户操作全部记录到日志中,方便审计
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/test.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/test.md
new file mode 100644
index 00000000000..68375772e85
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/test.md
@@ -0,0 +1,76 @@
+---
+title: 免密认证
+sidebar_position: 3
+---
+> 在有些场景下,为了方便开发调试,能够方便的访问页面和接口,可以开启测试模式配置,进行免密认证
+
+## 1. 实现逻辑介绍
+
+通过统一的认证处理filter:`org.apache.linkis.server.security.SecurityFilter` 来控制
+
+配置项
+```properties
+#是否开启测试模式
+wds.linkis.test.mode=true
+#测试模式的模拟用户名
+wds.linkis.test.user=hadoop
+```
+实现的伪代码
+```scala
+val BDP_TEST_USER = CommonVars("wds.linkis.test.user", "")
+val IS_TEST_MODE = CommonVars("wds.linkis.test.mode", false)
+
+if (IS_TEST_MODE.getValue) {
+ logger.info("test mode! login for uri: " + request.getRequestURI)
+ // 设置登陆用户信息为配置指定的用户
+ SecurityFilter.setLoginUser(response, BDP_TEST_USER)
+ true
+}
+```
+
+## 2. 使用方式
+
+### 2.1 Step1 开启测试模式
+直接修改配置文件 `linkis.properties`(对linkis所有服务生效), 修改对应的配置如下
+```shell script
+#是否开启测试模式
+wds.linkis.test.mode=true
+#测试模式的模拟用户名
+wds.linkis.test.user=hadoop
+```
+
+如果只需要开启某个服务的测试模式,可以修改对应的服务配置项。
+如 只开启 `entrance` 服务的测试模式
+直接修改配置文件 `linkis-cg-entrance.properties`(对linkis的entrance服务生效), 修改对应的配置如下
+```shell script
+#是否开启测试模式
+wds.linkis.test.mode=true
+#测试模式的模拟用户名
+wds.linkis.test.user=hadoop
+```
+
+### 2.2 Step2 重启对应的服务
+
+修改配置后,需要重启对应的服务(如果是所有服务都开启,重启所有服务),才能生效
+
+
+### 2.3 Step3 请求验证
+
+重启服务成功后,可以直接请求原来需要认证的http接口,无需额外的认证,便能正常请求.
+管理台也无需登陆认证,就可以访问内容页面
+
+
+## 3 注意事项
+
+### 3.1 wds.linkis.test.user的值设置
+因为部分接口会进行用户角色的权限校验,如: 【搜索历史EC信息】的接口:`/api/rest_j/v1/linkisManager/ecinfo/ecrHistoryList`
+角色有:
+
+|角色名 | 权限说明| 配置项 | 默认值 |
+| -------- | -------- | ----- |----- |
+|管理员角色|最高权限,拥有所有权限操作|`wds.linkis.governance.station.admin`|`hadoop`|
+|历史任务角色|相对普通用户,还可以查看其他用户的所有任务列表信息|`wds.linkis.jobhistory.admin`|`hadoop`|
+|普通角色|默认的角色|||
+
+对于不同场景的测试,设置的`wds.linkis.test.user`的值,会有不同,需要按实际场景进行设置。
+如果需要访问所有接口,需要配置为和`wds.linkis.governance.station.admin`一样的值,一般是`hadoop`
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/token.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/token.md
new file mode 100644
index 00000000000..9cce5e2e4a5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/auth/token.md
@@ -0,0 +1,111 @@
+---
+title: Token
+sidebar_position: 2
+---
+
+> 通常第三方系统调用linkis服务时,一般是通过token的方式进行认证
+
+## 1. 实现逻辑介绍
+
+通过统一的认证处理filter:`org.apache.linkis.server.security.SecurityFilter` 来控制
+
+实现的伪代码
+```scala
+
+val TOKEN_KEY = "Token-Code"
+val TOKEN_USER_KEY = "Token-User"
+
+/* TokenAuthentication.isTokenRequest 通过判断请求request中:
+ 1.请求头是否包含TOKEN_KEY和TOKEN_USER_KEY :getHeaders.containsKey(TOKEN_KEY) && getHeaders.containsKey(TOKEN_USER_KEY)
+ 2.或则请求cookies中是否包含TOKEN_KEY和TOKEN_USER_KEY:getCookies.containsKey(TOKEN_KEY) &&getCookies.containsKey(TOKEN_USER_KEY)
+*/
+
+if (TokenAuthentication.isTokenRequest(gatewayContext)) {
+ /* 进行token认证
+ 1. 确认是否开启token认证 配置项 `wds.linkis.gateway.conf.enable.token.auth`
+ 2. 提取token tokenUser host信息进行认证,校验合法性
+ */
+ TokenAuthentication.tokenAuth(gatewayContext)
+ } else {
+ //普通的用户名密码认证
+}
+```
+可用的token以及对应可使用的ip相关信息数据存储在表`linkis_mg_gateway_auth_token`中,
+详细见[表解析说明](../development/table/all#16-linkis_mg_gateway_auth_token),非实时更新,
+会定期`wds.linkis.token.cache.expire.hour`(默认间隔12小时)刷新到服务内存中
+
+
+## 2. 使用方式
+
+### 2.1 新增 Token
+
+管理台 `基础数据管理> 令牌管理`进行新增
+
+```text
+名称:token名称 对应 Token-Code,如:TEST-AUTH
+用户:该token对应的用户名,即感知到的请求用户,日志审计会使用到。如果不做限制可以配置为 *
+主机:可访问的主机,会进行请求方的ip校验过滤。如果不做限制可以配置为 *
+有效天数:如果永久有效,配置为-1
+```
+
+### 2.2 原生的方式
+构建的http请求方式,需要在请求头中添加`Token-Code`,`Token-User`参数,
+
+#### 示例
+
+请求地址:
+`http://127.0.0.1:9001/api/rest_j/v1/entrance/submit`
+
+body参数:
+```json
+{
+ "executionContent": {"code": "sleep 5s;echo pwd", "runType": "shell"},
+ "params": {"variable": {}, "configuration": {}},
+ "source": {"scriptPath": "file:///mnt/bdp/hadoop/1.hql"},
+ "labels": {
+ "engineType": "shell-1",
+ "userCreator": "hadoop-IDE",
+ "executeOnce":"false "
+ }
+}
+```
+
+请求头header:
+```text
+Content-Type:application/json
+Token-Code:BML-AUTH
+Token-User:hadoop
+```
+
+### 2.3 客户端使用token认证
+
+linkis 提供的客户端认证方式都支持Token策略模式`new TokenAuthenticationStrategy()`
+
+详细可以参考[SDK 方式](../user-guide/sdk-manual)
+
+#### 示例
+```java
+// 1. build config: linkis gateway url
+ DWSClientConfig clientConfig = ((DWSClientConfigBuilder) (DWSClientConfigBuilder.newBuilder()
+ .addServerUrl("http://127.0.0.1:9001/") //set linkis-mg-gateway url: http://{ip}:{port}
+ .connectionTimeout(30000) //connectionTimeOut
+ .discoveryEnabled(false) //disable discovery
+ .discoveryFrequency(1, TimeUnit.MINUTES) // discovery frequency
+ .loadbalancerEnabled(true) // enable loadbalance
+ .maxConnectionSize(5) // set max Connection
+ .retryEnabled(false) // set retry
+ .readTimeout(30000) //set read timeout
+ .setAuthenticationStrategy(new TokenAuthenticationStrategy()) // AuthenticationStrategy Linkis auth Token
+ .setAuthTokenKey("Token-Code") // set token key
+ .setAuthTokenValue("DSM-AUTH") // set token value
+ .setDWSVersion("v1") //linkis rest version v1
+ .build();
+```
+
+## 3 注意事项
+
+### 3.1 token的配置
+支持的token,对应的可用的用户/可使用请求方ip 是通过表`linkis_mg_gateway_auth_token`来控制,加载是非实时更新,使用了缓存机制
+
+### 3.2 管理员权限token
+对于高危操作的限制,需要管理员角色的token才能操作,管理员token,格式为 `admin-xxx`
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/_category_.json
new file mode 100644
index 00000000000..2d42788825d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "部署指南",
+ "position": 3.0
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/deploy-cluster.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/deploy-cluster.md
new file mode 100644
index 00000000000..ba837895e9c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/deploy-cluster.md
@@ -0,0 +1,176 @@
+---
+title: 分布式部署
+sidebar_position: 2
+---
+
+Linkis的单机部署方式简单,过多的进程在同一个服务器上会让服务器压力过大,生产环境为了保证服务的高可用,推荐使用分部署部署。
+部署方案的选择,和公司的用户规模、用户使用习惯、集群同时使用人数都有关,一般来说,我们会以使用Linkis的同时使用人数和用户对执行引擎的偏好来做依据进行部署方式的选择。
+
+## 1 多节点部署方式计算模型参考
+
+Linkis的每个微服务都支持多活的部署方案,当然不同的微服务在系统中承担的角色不一样,有的微服务调用频率很高,资源会处于高负荷的情况,
+**在安装EngineConnManager的机器上,由于会启动用户的引擎进程,机器的内存负载会比较高,其他类型的微服务对机器的负载则相对不会很高,
+**对于这类微服务我们建议启动多个进行分布式部署,Linkis动态使用的总资源可以按照如下方式计算。
+
+**EngineConnManager**使用总资源
+= 总内存 + 总核数
+= **同时在线人数 \* (所有类型的引擎占用内存) \*单用户最高并发数+ 同时在线人数 \*
+(所有类型的引擎占用核数) \*单用户最高并发数**
+
+例如:
+```html
+
+只使用spark、hive、python引擎且单用户最高并发数为1的情况下,同时使用人数50人,
+spark的Driver内存1G,hive client内存1G,python client 1G,每个引擎都使用1个核
+
+EngineConnManager(ECM)使用总资源
+= 50 *(1+1+1)G *1 + 50 *(1+1+1)核*1
+= 150G 内存 + 150 CPU核
+```
+
+
+分布式部署时微服务本身占用的内存可以按照每个2G计算,对于使用人数较多的情况下建议调大ps-publicservice的内存至6G,同时建议预留10G内存作为buffer。
+
+以下配置假设**每个用户同时启动两个引擎为例**,**对于64G内存的机器**,参考配置如下:
+
+### 1.1 同时在线人数10-50
+**EngineConnManager**使用总资源 = 总内存 + 总核数 =
+**同时在线人数 \* (所有类型的引擎占用内存) \*单用户最高并发数+ 同时在线人数 \*
+(所有类型的引擎占用核数) \*单用户最高并发数**
+
+总内存:同时在线人数 50 * 单个引擎 1G内存 * 每个用户同时启动两个引擎 2 = 100G内存
+
+> **服务器配置推荐**4台服务器,分别命名为S1,S2,S3,S4
+
+| Service | Host name | Remark |
+|----------------------|-----------|------------------|
+| cg-engineconnmanager | S1、S2(共128G)| 每台机器单独部署 |
+| Other services | S3、S4 | Eureka高可用部署 |
+
+### 1.2 同时在线人数50-100
+
+总内存:同时在线人数 100 * 单个引擎 1G内存 * 每个用户同时启动两个引擎 2 = 200G内存
+
+> **服务器配置推荐**:6台服务器,分别命名为S1,S2,S3,S4,S5,S6
+
+| Service | Host name | Remark |
+|----------------------|-----------|------------------|
+| cg-engineconnmanager | S1-S4(共256G)| 每台机器单独部署 |
+| Other services | S5、S6 | Eureka高可用部署 |
+
+### 1.3 同时使用人数 100-300
+
+
+总内存:同时在线人数 300 * 单个引擎 1G内存 * 每个用户同时启动两个引擎 2 = 600G内存
+
+**服务器配置推荐**:12台服务器,分别命名为S1,S2..S12
+
+| Service | Host name | Remark |
+|----------------------|-----------|------------------|
+| cg-engineconnmanager | S1-S10(共640G)| 每台机器单独部署 |
+| Other services | S11、S12 | Eureka高可用部署 |
+
+### 1.4 同时使用人数300-500
+
+> **服务器配置推荐**:20台服务器,分别命名为S1,S2..S20
+
+| Service | Host name | Remark |
+|----------------------|-----------|----------------------------------------------------------------------------------------------|
+| cg-engineconnmanager | S1-S18 | 每台机器单独部署 |
+| Other services | S19、S20 | Eureka高可用部署,部分微服务如果请求量上万可以考虑扩容,目前双活部署可以支持行内上千用户使用 |
+
+### 1.5 同时使用人数500以上
+> 按照同时在线800人估算
+> **服务器配置推荐**:34台服务器,分别命名为S1,S2..S34
+
+| Service | Host name | Remark |
+|----------------------|-----------|----------------------------------------------------------------------------------------------|
+| cg-engineconnmanager | S1-S32 | 每台机器单独部署 |
+| Other services | S33、S34 | Eureka高可用部署,部分微服务如果请求量上万可以考虑扩容,目前双活部署可以支持行内上千用户使用 |
+
+
+## 2 分布式部署的流程
+
+>Linkis的所有服务都支持分布式、多集群部署,建议在分布式部署前,先在一台机器上完成单机部署,并保证 Linkis 各功能正常使用。
+
+目前一键安装脚本对分布式部署还没有很好的支持,需要手动进行调整部署。具体分布式部署,可以参考以下步骤,假设用户已经在 A 机器上完成了单机部署。
+
+
+### 2.1 分布式部署的环境准备
+和服务器A一样,服务器B需要进行基础的环境准备,请参考[Linkis环境准备](deploy-quick#3-linkis%E7%8E%AF%E5%A2%83%E5%87%86%E5%A4%87)
+
+**网络检查**
+
+检查需要分布式部署的各服务机器是否网络互通,可用 ping 命令进行检查
+```
+ping IP
+```
+
+**权限检查**
+
+检查各机器上是否有 hadoop 用户以及hadoop用户是否有 sudo 权限。
+
+**必要的环境检查**
+
+Linkis各服务启动前或任务执行时会依赖一些基础环境,请根据下表检查各机器基础环境,具体检查方法参考[Linkis环境准备](deploy-quick#3-linkis%E7%8E%AF%E5%A2%83%E5%87%86%E5%A4%87)
+
+|服务名称|依赖环境|
+|-|-|
+|mg-eureka|Java|
+|mg-gateway|Java|
+|ps-publicservice|Java、Hadoop|
+|cg-linkismanager|Java|
+|cg-entrance|Java|
+|cg-engineconnmanager|Java、Hive、Spark、Python、Shell|
+
+
+注意:如需使用其它非默认引擎,还需要检查cg-engineconnmanager服务所在机器上对应引擎的环境是否OK,引擎环境可参考各[引擎使用中](https://linkis.apache.org/zh-CN/docs/latest/engine-usage/overview)中的前置工作进行检查。
+
+### 2.2 Eureka多活配置调整
+
+修改 A 机器上 Eureka 配置文件,把所有机器的 Eureka 的配置地址都加上,让 Eureka 服务之间相互注册。
+在服务器A上,进行如下配置修改,以两台 Eureka 集群为例。
+
+```
+修改 $LINKIS_HOME/conf/application-eureka.yml和$LINKIS_HOME/conf/application-linkis.yml配置
+
+eureka:
+ client:
+ serviceUrl:
+ defaultZone: http:/eurekaIp1:port1/eureka/,http:/eurekaIp2:port2/eureka/
+
+
+修改 $LINKIS_HOME/conf/linkis.properties 配置
+
+wds.linkis.eureka.defaultZone=http:/eurekaIp1:port1/eureka/,http:/eurekaIp2:port2/eureka/
+```
+
+### 2.3 安装物料的同步
+在其它所有机器上创建同机器 A 上相同的目录 `$LINKIS_HOME` 。在服务器A上,将linkis的成功安装的目录`$LINKIS_HOME` 打包,然后拷贝并解压到其它机器相同目录下。
+此时,如果在服务器A上以及其它机器上,执行`sbin/linkis-start-all.sh`脚本启动所有服务,那么所有服务都有n个实例,n为机器数量。 可以访问eureka服务展示页面 `http:/eurekaIp1:port1,或http:/eurekaIp2:port2` 查看
+
+### 2.4 调整启动脚本
+根据实际情况,确定各机器上需要部署的Linkis服务,
+比如 微服务`linkis-cg-engineconnmanager` 不会部署在服务器A上,
+则修改服务器A的一键启停脚本,`sbin/linkis-start-all.sh`,`sbin/linkis-stop-all.sh`,将`cg-engineconnmanager`服务相关的启停命令,注释掉
+```html
+sbin/linkis-start-all.sh
+#linkis-cg-linkismanage
+#SERVER_NAME="cg-linkismanager"
+#SERVER_IP=$MANAGER_INSTALL_IP
+#startApp
+
+sbin/linkis-stop-all.sh
+#linkis-cg-engineconnmanager(ecm)
+#SERVER_NAME="cg-engineconnmanager"
+#SERVER_IP=$ENGINECONNMANAGER_INSTALL_IP
+#stopApp
+
+```
+
+
+## 3 注意事项
+- 分部署部署时,linkis的安装目录建议保持一致,方便统一管控,相关的配置文件最好也保持一致
+- 如果某些服务器,端口已被其他应用占用,无法使用时,需要调整该服务端口
+- mg-gateway的多活部署,目前因为登陆session不支持分布式,用一个用户的请求,需要请求到同一个gateway实例上,可以通过nginx的ip hash负载均衡方式来支持
+- 一键启停脚本,根据实际情况,进行调整,对于不再本服务器上部署的微服务,需要在一键启动脚本中,将对应的启停命令注释掉。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/deploy-console.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/deploy-console.md
new file mode 100644
index 00000000000..a276d8022fd
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/deploy-console.md
@@ -0,0 +1,205 @@
+---
+title: 管理台部署
+sidebar_position: 3
+---
+> web端是使用nginx作为静态资源服务器的,访问请求流程是:`Linkis管理台请求->nginx ip:port->linkis-gateway ip:port-> 其他服务`
+
+
+Linkis 提供了单独的前端管理台功能,提供了展示历史任务的全局历史、修改用户参数、管理ECM和微服务等功能,部署前端管理台前需要先将Linkis后端进行部署,Linkis的部署手册见:[Linkis部署手册](deploy-quick.md)
+
+
+## 1 准备工作
+
+1. 从linkis的release页面([点击这里进入下载页面](https://linkis.apache.org/zh-CN/download/main))下载web安装包`apache-linkis-x.x.x-web-bin.tar.gz`
+手动解压:`tar -xvf apache-linkis-x.x.x-web-bin.tar.gz`,
+
+解压后目录为:
+```
+├── config.sh
+├── dist
+├── install.sh
+├── LICENSE
+├── licenses
+└── NOTICE
+```
+
+## 2 部署
+
+> 分为两种部署方式,自动化部署和手动部署
+
+### 2.1 自动化部署(推荐)
+
+#### 2.1.1 修改配置config.sh
+```shell script
+#linkis-mg-gateway服务地址
+linkis_url="http://127.0.0.1:9001"
+
+#可以配置为安装机器的ip 也可以使用默认值
+linkis_ipaddr=127.0.0.1
+# 访问管理台的端口
+linkis_port=8088
+
+```
+
+#### 2.1.2 执行部署脚本
+
+```shell script
+# nginx 需要sudo权限进行安装
+sudo sh install.sh
+```
+安装后,linkis的nginx配置文件默认是 在`/etc/nginx/conf.d/linkis.conf`
+nginx的日志文件在 `/var/log/nginx/access.log` 和`/var/log/nginx/error.log`
+生成的linkis管理台的nginx配置文件示例如下:
+```nginx
+
+ server {
+ listen 8188;# 访问端口 如果端口被占用,则需要修改
+ server_name localhost;
+ #charset koi8-r;
+ #access_log /var/log/nginx/host.access.log main;
+ location / {
+ root /appcom/Install/linkis-web/dist; # 静态文件目录
+ index index.html index.html;
+ }
+ location /ws {
+ proxy_pass http://localhost:9020;#后端Linkis的地址
+ proxy_http_version 1.1;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+
+ location /api {
+ proxy_pass http://localhost:9020; #后端Linkis的地址
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header x_real_ipP $remote_addr;
+ proxy_set_header remote_addr $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_http_version 1.1;
+ proxy_connect_timeout 4s;
+ proxy_read_timeout 600s;
+ proxy_send_timeout 12s;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+
+ #error_page 404 /404.html;
+ # redirect server error pages to the static page /50x.html
+ #
+ error_page 500 502 503 504 /50x.html;
+ location = /50x.html {
+ root /usr/share/nginx/html;
+ }
+ }
+```
+
+
+### 2.2 手动部署
+
+#### 2.2.1 安装Nginx
+>如果已经安装过nginx 可以跳过
+
+```shell script
+sudo yum install nginx -y
+```
+
+#### 2.2.2 修改配置文件
+```shell script
+sudo vi /etc/nginx/conf.d/linkis.conf
+```
+
+添加如下内容:
+```
+server {
+ listen 8080;# 访问端口
+ server_name localhost;
+ #charset koi8-r;
+ #access_log /var/log/nginx/host.access.log main;
+ location / {
+ root /appcom/Install/linkis/dist; # 前端包解压的目录
+ index index.html index.html;
+ }
+
+ location /api {
+ proxy_pass http://192.168.xxx.xxx:9001; # linkis-gateway服务的ip端口
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header x_real_ipP $remote_addr;
+ proxy_set_header remote_addr $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_http_version 1.1;
+ proxy_connect_timeout 4s;
+ proxy_read_timeout 600s;
+ proxy_send_timeout 12s;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+ #error_page 404 /404.html;
+ # redirect server error pages to the static page /50x.html
+ #
+ error_page 500 502 503 504 /50x.html;
+ location = /50x.html {
+ root /usr/share/nginx/html;
+ }
+ }
+
+```
+
+#### 2.2.3 资源部署
+
+将前端包拷贝到对应的目录:`/appcom/Install/linkis/dist`
+
+#### 2.2.4 启动服务
+
+```
+sudo systemctl restart nginx
+```
+
+
+## 3 登录管理台
+
+浏览器访问`http://linkis_ipaddr:linkis_port` 其中linkis_port为config.sh里面配置的端口,linkis_ipaddr为安装机器的IP
+
+用户名/密码在`${LINKIS_HOME}/conf/linkis-mg-gateway.properties`中查看
+```shell script
+wds.linkis.admin.user= #用户
+wds.linkis.admin.password= #密码
+
+```
+
+## 4 注意事项
+
+如果需要修改端口或则静态资源目录等,请修改`/etc/nginx/conf.d/linkis.conf` 文件后执行 `sudo nginx -s reload` 命令
+:::caution 注意
+- 目前暂未集成visualis功能,安装过程中如果提示安装linkis/visualis失败,可以忽略
+- 查看nginx是否正常启动:检查nginx进程是否存在 `ps -ef |grep nginx`
+- 检查nginx的配置是否正确 `sudo nginx -T `
+- 如果端口被占用,可以修改nginx启动的服务端口`/etc/nginx/conf.d/linkis.conf`listen端口值,保存后重新启动
+- 如果访问管理台出现接口502,或则`Unexpected token < in JSON at position 0`异常,请确认linkis-mg-gateway是否正常启动,如果正常启动,查看nginx配置文件中配置的linkis-mg-gateway服务地址是否正确
+:::
+
+
+## 5 常见问题
+
+### 5.1 上传文件大小限制
+
+```
+sudo vi /etc/nginx/nginx.conf
+```
+
+更改上传大小
+
+```
+client_max_body_size 200m
+```
+
+### 5.2 接口超时
+
+```
+sudo vi /etc/nginx/conf.d/linkis.conf
+```
+更改接口超时时间
+
+```
+proxy_read_timeout 600s
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/deploy-quick.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/deploy-quick.md
new file mode 100644
index 00000000000..608f7db07af
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/deploy-quick.md
@@ -0,0 +1,824 @@
+---
+title: 单机部署
+sidebar_position: 1
+---
+
+## 1. 首次安装准备事项
+
+### 1.1 Linux服务器
+
+**硬件要求**
+安装linkis 微服务近6个,至少3G内存。每个微服务默认配置启动的jvm -Xmx 内存大小为 512M(内存不够的情况下,可以尝试调小至256/128M,内存足够情况下也可以调大)。
+
+
+### 1.2 添加部署用户
+
+> 部署用户: linkis核心进程的启动用户,同时此用户会默认作为管理员权限,部署过程中会生成对应的管理员登录密码,位于`conf/linkis-mg-gateway.properties`文件中
+> Linkis支持指定提交、执行的用户。linkis主要进程服务会通过`sudo -u ${linkis-user}` 切换到对应用户下,然后执行对应的引擎启动命令,所以引擎`linkis-engine`进程归属的用户是任务的执行者(因此部署用户需要有sudo权限,而且是免密的)。
+
+以hadoop用户为例(linkis中很多配置用户默认都使用hadoop用户,建议初次安装者使用hadoop用户,否则在安装过程中可能会遇到很多意想不到的错误 ):
+
+先查看系统中是否已经有 hadoop 用户,若已经存在,则直接授权即可,若不存在,先创建用户,再授权。
+
+查看是否已存在 hadoop 用户
+```shell script
+$ id hadoop
+uid=2001(hadoop) gid=2001(hadoop) groups=2001(hadoop)
+```
+
+若不存在,则需要创建 hadoop 用户,并加入 hadoop 用户组
+```shell script
+$ sudo useradd hadoop -g hadoop
+$ vi /etc/sudoers
+#免密配置
+hadoop ALL=(ALL) NOPASSWD: NOPASSWD: ALL
+```
+
+以下操作都是在hadoop用户下进行
+
+### 1.3 依赖环境
+
+Linkis需要的环境引擎如下列表所示,这些必需的引擎在安装检查脚本`${LINKIS_HOME}/bin/checkENv.sh`中检查。
+
+| 引擎类型 | 是否必装 | 安装直通车 |
+|----------------|------|-------------------------------------------------------------------------------------------------------------|
+| JDK(1.8.0 141) | 必需 | [安装JDK和设置JAVA_HOME](https://docs.oracle.com/cd/E19509-01/820-5483/6ngsiu065/index.html) |
+| mysql(5.5+) | 必需 | [安装MySQL](https://docs.oracle.com/cd/E69403_01/html/E56873/mysql.html) |
+| Python(3.6.8) | 必需 | [Python安装和使用](https://docs.python.org/zh-cn/3/using/index.html) |
+| Nginx(1.14.1) | 必需 | [Nginx安装指南](http://nginx.org/en/linux_packages.html#instructions) |
+| Hadoop((2.7.2) | 必需 | [Hadoop快速入门](https://hadoop.apache.org/docs/r1.0.4/cn/quickstart.html#%E5%AE%89%E8%A3%85%E8%BD%AF%E4%BB%B6) |
+| Spark(2.4.3) | 必需 | [Spark安装入门](https://spark.apache.org/downloads.html) |
+| Hive(3.1.3) | 必需 | [Hive安装指南](https://cwiki.apache.org/confluence/display/hive/adminmanual+installation) |
+
+## 2. 配置修改
+
+### 2.1 安装包准备
+
+- 方式1:从官网[下载地址](https://linkis.apache.org/zh-CN/download/main):https://linkis.apache.org/zh-CN/download/main
+,下载对应的安装包(项目安装包和管理台安装包)。
+- 方式2:根据[Linkis 编译打包](../development/build)和[前端管理台编译](../development/build-console) 自行编译出项目安装包和管理台安装包。
+
+上传安装包`apache-linkis-x.x.x-bin.tar.gz`后,进行解压安装包
+
+```shell script
+$ tar -xvf apache-linkis-x.x.x-bin.tar.gz
+```
+
+解压后的目录结构如下
+```shell script
+-rw-r--r-- 1 hadoop hadoop 518192043 Jun 20 09:50 apache-linkis-x.x.x-bin.tar.gz
+drwxrwxr-x 2 hadoop hadoop 4096 Jun 20 09:56 bin //执行环境检查和安装的脚本
+drwxrwxr-x 2 hadoop hadoop 4096 Jun 20 09:56 deploy-config // 部署时依赖的DB等环境配置信息
+drwxrwxr-x 4 hadoop hadoop 4096 Jun 20 09:56 docker
+drwxrwxr-x 4 hadoop hadoop 4096 Jun 20 09:56 helm
+-rwxrwxr-x 1 hadoop hadoop 84732 Jan 22 2020 LICENSE
+drwxr-xr-x 2 hadoop hadoop 20480 Jun 20 09:56 licenses
+drwxrwxr-x 7 hadoop hadoop 4096 Jun 20 09:56 linkis-package // 实际的软件包,包括lib/服务启动脚本工具/db的初始化脚本/微服务的配置文件等
+-rwxrwxr-x 1 hadoop hadoop 119503 Jan 22 2020 NOTICE
+-rw-r--r-- 1 hadoop hadoop 11959 Jan 22 2020 README_CN.md
+-rw-r--r-- 1 hadoop hadoop 12587 Jan 22 2020 README.md
+
+```
+
+### 2.2 配置数据库信息
+
+`vim deploy-config/linkis-env.sh`
+
+```shell script
+# 选择linkis业务数据库类型,默认mysql
+# 如果使用postgresql,请改为postgresql
+# 注意: 当前配置只适用于linkis>=1.4.0
+dbType=mysql
+```
+
+`vim deploy-config/db.sh`
+
+```shell script
+# Linkis自身业务的数据库信息 - mysql
+MYSQL_HOST=xx.xx.xx.xx
+MYSQL_PORT=3306
+MYSQL_DB=linkis_test
+MYSQL_USER=test
+MYSQL_PASSWORD=xxxxx
+
+# Linkis自身业务的数据库信息 - postgresql
+# 注意: 以下配置只适用于linkis>=1.4.0
+PG_HOST=xx.xx.xx.xx
+PG_PORT=5432
+PG_DB=linkis_test
+PG_SCHEMA=linkis_test
+PG_USER=test
+PG_PASSWORD=123456
+
+# 提供 Hive 元数据数据库的 DB 信息,如果不涉及hive引擎(或则只是简单试用),可以不配置
+#主要是配合scriptis一起使用,如果不配置,会默认尝试通过$HIVE_CONF_DIR 中的配置文件获取
+HIVE_META_URL="jdbc:mysql://10.10.10.10:3306/hive_meta_demo?useUnicode=true&characterEncoding=UTF-8"
+HIVE_META_USER=demo # HiveMeta元数据库的用户
+HIVE_META_PASSWORD=demo123 # HiveMeta元数据库的密码
+```
+
+
+### 2.3 配置基础变量
+
+文件位于`deploy-config/linkis-env.sh`。
+
+#### 部署用户
+```shell script
+deployUser=hadoop #执行部署的用户,为 1.2 步骤给中创建的用户
+```
+
+#### 基础目录配置(可选)
+:::caution 注意
+根据实际情况确定是否需要调整,可以选择使用默认值
+:::
+
+
+```shell script
+
+# 指定用户使用的目录路径,一般用于存储用户的脚本文件和日志文件等,是用户的工作空间。 对应的配置文件配置项为 wds.linkis.filesystem.root.path(linkis.properties)
+WORKSPACE_USER_ROOT_PATH=file:///tmp/linkis
+
+# 结果集日志等文件路径,用于存储Job的结果集文件 wds.linkis.resultSet.store.path(linkis-cg-entrance.properties) //如果未配置 使用HDFS_USER_ROOT_PATH的配置
+RESULT_SET_ROOT_PATH=file:///tmp/linkis
+
+# 结果集日志等文件路径,用于存储Job的结果集文件 wds.linkis.filesystem.hdfs.root.path(linkis.properties)
+HDFS_USER_ROOT_PATH=hdfs:///tmp/linkis
+
+# 存放执行引擎的工作路径,需要部署用户有写权限的本地目录 wds.linkis.engineconn.root.dir(linkis-cg-engineconnmanager.properties)
+ENGINECONN_ROOT_PATH=/appcom/tmp
+```
+
+#### Yarn的ResourceManager的地址
+
+:::caution 注意
+如果需要使用Spark引擎 则需要配置
+:::
+
+```shell script
+
+#可以通过访问http://xx.xx.xx.xx:8088/ws/v1/cluster/scheduler 接口确认是否可以正常访问
+YARN_RESTFUL_URL=http://xx.xx.xx.xx:8088
+```
+执行spark任务时,需要使用到yarn的ResourceManager,linkis默认它是未开启权限验证的,如果ResourceManager开启了密码权限验证,请安装部署后,
+修改数据库表 `linkis_cg_rm_external_resource_provider` 插入yarn数据信息,详细可以参考[查看yarn地址是否配置正确](#811-查看yarn地址是否配置正确)
+
+#### 基础组件环境信息
+
+:::caution 注意
+可以通过用户的系统环境变量配置, 如果通过系统环境变量配置的,deploy-config/linkis-env.sh配置文件中可以不进行配置 直接注释掉。
+:::
+
+```shell script
+##如果不使用Hive、Spark等引擎且不依赖Hadoop,则不需要配置以下环境变量
+
+#HADOOP
+HADOOP_HOME=/appcom/Install/hadoop
+HADOOP_CONF_DIR=/appcom/config/hadoop-config
+
+#Hive
+HIVE_HOME=/appcom/Install/hive
+HIVE_CONF_DIR=/appcom/config/hive-config
+
+#Spark
+SPARK_HOME=/appcom/Install/spark
+SPARK_CONF_DIR=/appcom/config/spark-config
+```
+
+
+#### LDAP 登录配置(可选)
+
+:::caution 注意
+默认是使用静态用户和密码,静态用户即部署用户,静态密码会在执行部署是随机生成一个密码串,存储于`${LINKIS_HOME}/conf/linkis-mg-gateway.properties`(>=1.0.3版本)。
+:::
+
+
+```shell script
+#LDAP配置,默认Linkis只支持部署用户登录,如果需要支持多用户登录可以使用LDAP,需要配置以下参数:
+#LDAP_URL=ldap://localhost:1389/
+#LDAP_BASEDN=dc=webank,dc=com
+```
+
+
+#### JVM内存配置(可选)
+>微服务启动jvm内存配置,可以根据机器实际情况进行调整,如果机器内存资源较少,可以尝试调小至256/128M
+```shell script
+## java application default jvm memory
+export SERVER_HEAP_SIZE="512M"
+```
+
+#### 安装目录配置(可选)
+> Linkis最终会被安装到此目录下,不配置默认是与当前安装包同一级目录下
+
+```shell script
+##The decompression directory and the installation directory need to be inconsistent
+LINKIS_HOME=/appcom/Install/LinkisInstall
+```
+
+#### 无HDFS模式部署(可选 >1.1.2版本支持)
+
+> 在没有HDFS 的环境中部署 Linkis 服务,以方便更轻量化的学习使用和调试。去HDFS模式部署不支持hive/spark/flink引擎等任务
+
+修改 `linkis-env.sh` 文件,修改以下内容
+```bash
+#使用[file://]路径模式代替[hdfs://]模式
+WORKSPACE_USER_ROOT_PATH=file:///tmp/linkis/
+HDFS_USER_ROOT_PATH=file:///tmp/linkis
+RESULT_SET_ROOT_PATH=file:///tmp/linkis
+
+export ENABLE_HDFS=false
+export ENABLE_HIVE=false
+export ENABLE_SPARK=false
+```
+
+#### kerberos 认证(可选)
+
+> 默认 Linkis 未开启 kerberos 认证,如果使用的hive集群开启了 kerberos 模式认证,需要配置如下参数。
+
+修改 `linkis-env.sh` 文件,修改内容如下
+```bash
+#HADOOP
+HADOOP_KERBEROS_ENABLE=true
+HADOOP_KEYTAB_PATH=/appcom/keytab/
+```
+
+### 2.4 配置 Token
+文件位于 `bin/install.sh`
+
+Linkis 1.3.2 版本为保证系统安全性已将 Token 值改为32位随机生成,具体可查看[Token变更说明](https://linkis.apache.org/zh-CN/docs/1.3.2/feature/update-token/)。
+
+使用随机生成Token,初次与[WDS其它组件](https://github.com/WeDataSphere/DataSphereStudio/blob/master/README-ZH.md)对接时会遇到很多 Token 验证失败的问题,建议初次安装时不使用随机生成Token,修改如下配置为 true 即可。
+
+```
+DEBUG_MODE=true
+```
+
+### 2.5 注意事项
+
+**全量安装**
+
+对于全量安装新版本 Linkis 时, install.sh 脚本中会自动处理配置文件和数据库 Token 保持一致。因此 Linkis 服务自身 Token 无需修改。各应用可通过管理台查询并使用新 Token。
+
+**版本升级**
+
+版本升级时,数据库 Token 并未修改,因此无需修改配置文件和应用 Token。
+
+**Token 过期问题**
+
+当遇到 Token 令牌无效或已过期问题时可以检查 Token 是否配置正确,可通过管理台 ==> 基础数据管理 ==> 令牌管理,查询 Token。
+
+**Python 版本问题**
+Linkis 升级为 1.4.0 后默认 Spark 版本升级为 3.x,无法兼容 python2。因此如果需要使用 pyspark 功能需要做如下修改。
+1. 映射 python2 命令为 python3
+```
+sudo ln -snf /usr/bin/python3 /usr/bin/python2
+```
+2. spark 引擎连接器配置 $LINKIS_HOME/lib/linkis-engineconn-plugins/spark/dist/3.2.1/conf/linkis-engineconn.properties 中添加如下配置,指定python安装路径
+```
+pyspark.python3.path=/usr/bin/python3
+```
+
+## 3. 安装和启动
+
+### 3.1 执行安装脚本:
+
+```bash
+ sh bin/install.sh
+```
+
+install.sh脚本会询问您是否需要初始化数据库并导入元数据。如果选择初始化,会把数据库中的表数据清空重新初始化。
+
+**第一次安装必须选清空数据库 **
+
+:::tip 注意
+- 如果出现报错,又不清楚具体是执行什么命令报错,可以加 -x 参数`sh -x bin/install.sh`,将shell脚本执行过程日志打印出来,方便定位问题。
+- 权限问题:`mkdir: cannot create directory ‘xxxx’: Permission denied`,请确认部署用户是否拥有该路径的读写权限。
+:::
+
+执行成功提示如下:
+```shell script
+`Congratulations! You have installed Linkis x.x.x successfully, please use sh /data/Install/linkis/sbin/linkis-start-all.sh to start it!
+Your default account password is [hadoop/5e8e312b4]`
+```
+
+### 3.2 添加mysql驱动包
+
+:::caution 注意
+因为mysql-connector-java驱动是GPL2.0协议,不满足Apache开源协议关于license的政策,因此从1.0.3版本开始,提供的Apache版本官方部署包,默认是没有mysql-connector-java-x.x.x.jar的依赖包(**若是通过集成的全家桶物料包安装,则无需手动添加**),安装部署时需要自行添加依赖到对应的lib包中。 可以在对应的目录下查看是否存在,如果不存在则需要添加。
+
+:::
+
+下载mysql驱动 以 8.0.28 版本为例:[下载链接](https://repo1.maven.org/maven2/mysql/mysql-connector-java/8.0.28/mysql-connector-java-8.0.28.jar)
+
+拷贝mysql 驱动包至lib包下
+```
+cp mysql-connector-java-8.0.28.jar ${LINKIS_HOME}/lib/linkis-spring-cloud-services/linkis-mg-gateway/
+cp mysql-connector-java-8.0.28.jar ${LINKIS_HOME}/lib/linkis-commons/public-module/
+```
+### 3.3 添加postgresql驱动包 (可选)
+如果选择使用postgresql作为业务数据库,需要手动添加postgresql驱动
+下载postgresql驱动 以42.5.4版本为例:[下载链接](https://repo1.maven.org/maven2/org/postgresql/postgresql/42.5.4/postgresql-42.5.4.jar)
+拷贝postgresql驱动包至lib包下
+```
+cp postgresql-42.5.4.jar ${LINKIS_HOME}/lib/linkis-spring-cloud-services/linkis-mg-gateway/
+cp postgresql-42.5.4.jar ${LINKIS_HOME}/lib/linkis-commons/public-module/
+```
+### 3.4 配置调整(可选)
+> 以下操作,跟依赖的环境有关,根据实际情况,确定是否需要操作
+
+#### 3.4.1 Yarn的认证
+
+执行spark任务时,需要使用到yarn的ResourceManager,通过配置项`YARN_RESTFUL_URL=http://xx.xx.xx.xx:8088 `控制。
+执行安装部署时,会将`YARN_RESTFUL_URL=http://xx.xx.xx.xx:8088` 信息更新到数据库表中 `linkis_cg_rm_external_resource_provider`中时候,默认访问yarn资源是不需权限验证的,
+如果yarn的ResourceManager开启了密码权限验证,请安装部署后,修改数据库表 `linkis_cg_rm_external_resource_provider` 中生成的yarn数据信息,
+详细可以参考[查看yarn地址是否配置正确](#811-查看yarn地址是否配置正确)。
+
+#### 3.4.2 session
+如果您是对Linkis的升级。同时部署DSS或者其他项目,但其它软件中引入的依赖linkis版本<1.1.1(主要看lib包中,所依赖的Linkis的linkis-module-x.x.x.jar包 <1.1.1),则需要修改位于`${LINKIS_HOME}/conf/linkis.properties`文件。
+```shell
+echo "wds.linkis.session.ticket.key=bdp-user-ticket-id" >> linkis.properties
+```
+
+#### 3.4.3 S3 模式
+> 目前支持将引擎执行日志和结果存储到 S3 文件系统
+>
+> 注意: linkis没有对 S3 做权限适配,所以无法对其做赋权操作
+
+`vim $LINKIS_HOME/conf/linkis.properties`
+```shell script
+# s3 file system
+linkis.storage.s3.access.key=xxx
+linkis.storage.s3.secret.key=xxx
+linkis.storage.s3.endpoint=http://xxx.xxx.xxx.xxx:xxx
+linkis.storage.s3.region=xxx
+linkis.storage.s3.bucket=xxx
+```
+
+`vim $LINKIS_HOME/conf/linkis-cg-entrance.properties`
+```shell script
+wds.linkis.entrance.config.log.path=s3:///linkis/logs
+wds.linkis.resultSet.store.path=s3:///linkis/results
+```
+
+### 3.5 启动服务
+```shell script
+sh sbin/linkis-start-all.sh
+```
+
+### 3.6 安装后配置的修改
+安装完成后,如果需要修改配置(因端口冲突或则某些配置有问题需要调整配置),可以重新执行安装,或则修改对应服务的配置`${LINKIS_HOME}/conf/*properties`文件后,重启对应的服务,如:`sh sbin/linkis-daemon.sh start ps-publicservice`。
+
+
+### 3.7 检查服务是否正常启动
+访问eureka服务页面(http://eurekaip:20303),
+默认会启动6个 Linkis 微服务,其中下图linkis-cg-engineconn服务为运行任务才会启动。
+![Linkis1.0_Eureka](./images/eureka.png)
+
+```shell script
+LINKIS-CG-ENGINECONNMANAGER 引擎管理服务
+LINKIS-CG-ENTRANCE 计算治理入口服务
+LINKIS-CG-LINKISMANAGER 计算治理管理服务
+LINKIS-MG-EUREKA 微服务注册中心服务
+LINKIS-MG-GATEWAY 网关服务
+LINKIS-PS-PUBLICSERVICE 公共服务
+```
+
+注意:在 Linkis 1.3.1 中已将 LINKIS-PS-CS、LINKIS-PS-DATA-SOURCE-MANAGER、LINKIS-PS-METADATAMANAGER服务合并到LINKIS-PS-PUBLICSERVICE,将LINKIS-CG-ENGINEPLUGIN服务合并到LINKIS-CG-LINKISMANAGER。
+
+如果有服务未启动,可以在对应的log/${服务名}.log文件中查看详细异常日志。
+
+### 3.8 配置 Token
+
+Linkis 原有默认 Token 固定且长度太短存在安全隐患。因此 Linkis 1.3.2 将原有固定 Token 改为随机生成,并增加 Token 长度。
+
+新 Token 格式:应用简称-32 位随机数,如BML-928a721518014ba4a28735ec2a0da799。
+
+Token 可能在 Linkis 服务自身使用,如通过 Shell 方式执行任务、BML 上传等,也可能在其它应用中使用,如 DSS、Qualitis 等应用访问 Linkis。
+
+#### 查看 Token
+**通过 SQL 语句查看**
+```sql
+select * from linkis_mg_gateway_auth_token;
+```
+**通过管理台查看**
+
+登录管理台 -> 基础数据管理 -> 令牌管理
+![](/Images-zh/deployment/token-list.png)
+
+#### 检查 Token 配置
+
+Linkis 服务本身使用 Token 时,配置文件中 Token 需与数据库中 Token 一致。通过应用简称前缀匹配。
+
+$LINKIS_HOME/conf/linkis.properties文件 Token 配置
+
+```
+linkis.configuration.linkisclient.auth.token.value=BML-928a721518014ba4a28735ec2a0da799
+wds.linkis.client.common.tokenValue=BML-928a721518014ba4a28735ec2a0da799
+wds.linkis.bml.auth.token.value=BML-928a721518014ba4a28735ec2a0da799
+wds.linkis.context.client.auth.value=BML-928a721518014ba4a28735ec2a0da799
+wds.linkis.errorcode.auth.token=BML-928a721518014ba4a28735ec2a0da799
+
+wds.linkis.client.test.common.tokenValue=LINKIS_CLI-215af9e265ae437ca1f070b17d6a540d
+
+wds.linkis.filesystem.token.value=WS-52bce72ed51741c7a2a9544812b45725
+wds.linkis.gateway.access.token=WS-52bce72ed51741c7a2a9544812b45725
+
+wds.linkis.server.dsm.auth.token.value=DSM-65169e8e1b564c0d8a04ee861ca7df6e
+```
+
+$LINKIS_HOME/conf/linkis-cli/linkis-cli.properties文件 Token 配置
+```
+wds.linkis.client.common.tokenValue=BML-928a721518014ba4a28735ec2a0da799
+```
+
+其它应用使用 Token 时,需要修改其 Token 配置与数据库中 Token 一致。
+
+## 4. 安装web前端
+web端是使用nginx作为静态资源服务器的,访问请求流程是:
+`Linkis管理台请求->nginx ip:port->linkis-gateway ip:port-> 其他服务`
+
+### 4.1 下载前端安装包并解压
+```shell script
+tar -xvf apache-linkis-x.x.x-web-bin.tar.gz
+```
+
+### 4.2 修改配置config.sh
+```shell script
+#访问管理台的端口
+linkis_port="8188"
+
+#linkis-mg-gateway服务地址
+linkis_url="http://localhost:9020"
+```
+
+### 4.3 执行部署脚本
+
+```shell script
+# nginx 需要sudo权限进行安装
+sudo sh install.sh
+```
+安装后,linkis的nginx配置文件默认是 在`/etc/nginx/conf.d/linkis.conf`
+nginx的日志文件在 `/var/log/nginx/access.log` 和`/var/log/nginx/error.log`
+生成的linkis管理台的nginx配置文件示例如下:
+```nginx
+
+ server {
+ listen 8188;# 访问端口 如果端口被占用,则需要修改
+ server_name localhost;
+ #charset koi8-r;
+ #access_log /var/log/nginx/host.access.log main;
+ location / {
+ root /appcom/Install/linkis-web/dist; # 静态文件目录
+ index index.html index.html;
+ }
+ location /ws {
+ proxy_pass http://localhost:9020;#后端Linkis的地址
+ proxy_http_version 1.1;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+
+ location /api {
+ proxy_pass http://localhost:9020; #后端Linkis的地址
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header x_real_ipP $remote_addr;
+ proxy_set_header remote_addr $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_http_version 1.1;
+ proxy_connect_timeout 4s;
+ proxy_read_timeout 600s;
+ proxy_send_timeout 12s;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+
+ #error_page 404 /404.html;
+ # redirect server error pages to the static page /50x.html
+ #
+ error_page 500 502 503 504 /50x.html;
+ location = /50x.html {
+ root /usr/share/nginx/html;
+ }
+ }
+```
+
+如果需要修改端口或则静态资源目录等,请修改`/etc/nginx/conf.d/linkis.conf` 文件后执行 `sudo nginx -s reload` 命令
+:::caution 注意
+- 目前暂未集成visualis功能,安装过程中如果提示安装linkis/visualis失败,可以忽略 。
+- 查看nginx是否正常启动:检查nginx进程是否存在 `ps -ef |grep nginx` 。
+- 检查nginx的配置是否正确 `sudo nginx -T ` 。
+- 如果端口被占用,可以修改nginx启动的服务端口`/etc/nginx/conf.d/linkis.conf`listen端口值,保存后重新启动。
+- 如果访问管理台出现接口502,或则`Unexpected token < in JSON at position 0`异常,请确认linkis-mg-gateway是否正常启动,如果正常启动,查看nginx配置文件中配置的linkis-mg-gateway服务地址是否正确。
+:::
+
+### 4.4 登录管理台
+
+浏览器登陆 `http://xx.xx.xx.xx:8188/#/login`
+用户名/密码在`{LINKIS_HOME}/conf/linkis-mg-gateway.properties`中查看。
+```shell script
+wds.linkis.admin.user= #用户
+wds.linkis.admin.password= #密码
+
+```
+
+## 5. 验证基础功能
+>根据实际需求,验证对应的引擎任务
+
+```
+#引擎的engineType 拼接的版本号,一定要与实际的相匹配,以下示例是默认的版本号
+#shell 引擎任务
+sh bin/linkis-cli -submitUser hadoop -engineType shell-1 -codeType shell -code "whoami"
+
+#hive引擎任务
+sh bin/linkis-cli -submitUser hadoop -engineType hive-3.1.3 -codeType hql -code "show tables"
+
+#spark引擎任务
+sh bin/linkis-cli -submitUser hadoop -engineType spark-3.2.1 -codeType sql -code "show tables"
+
+#python引擎任务
+sh bin/linkis-cli -submitUser hadoop -engineType python-python2 -codeType python -code 'print("hello, world!")'
+```
+如果验证失败,请参考【步骤8】进行排查。
+
+## 6. 开发工具IDE(Scriptis)的安装(可选)
+安装Scripti工具后,可以支持在web页面在线写SQL、Pyspark、HiveQL等脚本,详细指引见[工具Scriptis的安装部署](integrated/install-scriptis)。
+
+## 7. 支持的引擎
+
+### 7.1 引擎适配列表
+
+请注意:Linkis的单独安装包默认只包含Python、Shell、Hive、Spark四个引擎,如果有其他的引擎(如jdbc/flink/sqoop等引擎)使用场景,可以手动安装,具体请参考 [EngineConnPlugin引擎插件安装文档](install-engineconn)。
+
+本版本已适配的支持引擎列表如下:
+
+| 引擎类型 | 适配情况 | 官方安装包是否包含 |
+|---------------|-------------------|------|
+| Python | >=1.0.0 已适配 | 包含 |
+| Shell | >=1.0.0 已适配 | 包含 |
+| Hive | >=1.0.0 已适配 | 包含 |
+| Spark | >=1.0.0 已适配 | 包含 |
+| Pipeline | >=1.0.0 已适配 | **不包含** |
+| JDBC | >=1.0.0 已适配 | **不包含** |
+| Flink | >=1.0.0 已适配 | **不包含** |
+| openLooKeng | >=1.1.1 已适配 | **不包含** |
+| Sqoop | >=1.1.2 已适配 | **不包含** |
+| Trino | >=1.3.2 已适配 | **不包含** |
+| Presto | >=1.3.2 已适配 | **不包含** |
+| Elasticsearch | >=1.3.2 已适配 | **不包含** |
+| Seatunnel | >=1.3.2 已适配 | **不包含** |
+| Impala | >=1.4.0 已适配 | **不包含** |
+
+
+
+### 7.2 查看部署的引擎
+
+#### 方式1: 查看引擎lib包目录
+
+```
+$ tree linkis-package/lib/linkis-engineconn-plugins/ -L 3
+linkis-package/lib/linkis-engineconn-plugins/
+├── hive
+│ ├── dist
+│ │ └── 3.1.3 #版本为 3.1.3 engineType 为hive-3.1.3
+│ └── plugin
+│ └── 3.1.3
+├── python
+│ ├── dist
+│ │ └── python2
+│ └── plugin
+│ └── python2 #版本为python2 engineType 为python-python2
+├── shell
+│ ├── dist
+│ │ └── 1
+│ └── plugin
+│ └── 1
+└── spark
+ ├── dist
+ │ └── 3.2.1
+ └── plugin
+ └── 3.2.1
+```
+
+#### 方式2: 查看linkis的数据库表
+```shell script
+select * from linkis_cg_engine_conn_plugin_bml_resources
+```
+### 7.3 非默认引擎检查
+非默认引擎的检查通过手工执行脚本`sh $LINKIS_HOME/bin/checkAdd.sh ${engineType}`来检查,具体脚本参见目录(`$LINKIS_HOME/bin/checkAdd.sh`) 。具体的检查方法如下:
+
+```shell script
+function print_usage(){
+ echo "Usage: checkAdd [EngineName]"
+ echo " EngineName : The Engine name that you want to check"
+ echo " Engine list as bellow: JDBC Flink openLooKeng Presto Sqoop Elasticsearch "
+}
+```
+
+非默认引擎检查过程中使用到的参数分为两类:一类是数据引擎连接信息,在`$LINKIS_HOME/deploy-config/db.sh`中定义;另一类是引用参数,包括检查开关、版本定义、java路径等,在`$LINKIS_HOME/deploy-config/db.sh`定义。相关的引擎及参数描述如下:
+
+| 引擎类型 | 使用到的参数 | 参数描述 |
+|---------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------|
+| JDBC | ${MYSQL_HOST}, ${MYSQL_PORT}, ${MYSQL_DB}, ${MYSQL_USER}, ${MYSQL_PASSWORD} | MySQL引擎连接信息,包括主机IP、端口、数据库名、用户、密码 |
+| JDBC | ${MYSQL_CONNECT_JAVA_PATH} | MySQL驱动连接所在目录 |
+| Flink | ${FLINK_HOME} | 定义 FLink 安装所在目录,包含Flink执行脚本和样例 |
+| openLooKeng | ${OLK_HOST}, ${OLK_PORT}, ${OLK_CATALOG}, ${OLK_SCHEMA}, {OLK_USER}, ${OLK_PASSWORD} | openLooKeng引擎连接信息,包括主机IP、端口、编目、模式、用户名、密码 |
+| openLooKeng | ${OLK_JDBC_PATH} | openLooKeng连接器目录 |
+| Presto | ${PRESTO_HOST}, ${PRESTO_PORT}, ${PRESTO_CATALOG}, ${PRESTO_SCHEMA} | Presto引擎连接信息,包括主机IP、端口、编目、模式 |
+| Sqoop | ${HIVE_META_URL}, ${HIVE_META_USER}, ${HIVE_META_PASSWORD} | sqoop连接hive的连接信息,包括服务地址、用户名、密码 |
+| Elasticsearch | ${ES_RESTFUL_URL} | Elasticsearch服务地址 |
+| Impala | ${IMPALA_HOST}, ${IMPALA_PORT} | impala连接信息,包括主机 IP 、端口 |
+| Trino | ${TRINO_COORDINATOR_HOST}, ${TRINO_COORDINATOR_PORT}, ${TRINO_COORDINATOR_CATALOG}, ${TRINO_COORDINATOR_SCHEMA} | trino连接信息,包括主机IP、端口、类别、编目、模式 |
+| Seatunnel | ${SEATUNNEL_HOST}, ${SEATUNNEL_PORT} | Seatunnel连接信息,包括主机IP、端口 |
+
+## 8. 常见异常问题排查指引
+### 8.1. Yarn队列检查
+
+>如果需要使用到spark/hive/flink引擎
+
+登录后查看能否正常显示yarn队列资源(点击页面右下角按钮)(需要先安装前端)。
+
+正常如下图所示:
+![yarn-normal](images/yarn-normal.png)
+
+若如果无法显示:可以按以下指引调整
+
+#### 8.1.1 查看yarn地址是否配置正确
+数据库表 `linkis_cg_rm_external_resource_provider` `
+插入yarn数据信息
+```sql
+INSERT INTO `linkis_cg_rm_external_resource_provider`
+(`resource_type`, `name`, `labels`, `config`) VALUES
+('Yarn', 'default', NULL,
+'{\r\n"rmWebAddress": "http://xx.xx.xx.xx:8088",\r\n"hadoopVersion": "3.3.4",\r\n"authorEnable":false,\r\n"user":"hadoop",\r\n"pwd":"123456"\r\n}'
+);
+
+config字段属性
+
+"rmWebAddress": "http://xx.xx.xx.xx:8088", #需要带上http以及端口
+"hadoopVersion": "3.3.4",
+"authorEnable":true, //是否需要认证 可以在浏览器中通过访问http://xx.xx.xx.xx:8088验证用户名和密码
+"user":"user",//用户名
+"pwd":"pwd"//密码
+
+```
+更新后,因为程序中有使用到缓存,想要立即生效,需要重启linkis-cg-linkismanager服务。
+```shell script
+sh sbin/linkis-daemon.sh restart cg-linkismanager
+```
+
+#### 8.1.2 查看yarn队列是否存在
+异常信息:`desc: queue ide is not exists in YARN.`表明配置的yarn队列不存在,需要进行调整。
+
+修改方式:`linkis管理台/参数配置>全局设置>yarn队列名[wds.linkis.rm.yarnqueue]`,修改一个可以使用的yarn队列,以使用的yarn 队列可以在 `rmWebAddress:http://xx.xx.xx.xx:8088/cluster/scheduler` 上查看到。
+
+查看可用的yarn队列
+- 查看yarn队列地址:http://ip:8888/cluster/scheduler
+
+### 8.2 检查引擎物料资源是否上传成功
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources
+```
+
+正常如下:
+![bml](images/bml.png)
+
+查看引擎的物料记录是否存在(如果有更新,查看更新时间是否正确)
+
+- 如果不存在或则未更新,先尝试手动刷新物料资源(详细见[引擎物料资源刷新](install-engineconn#23-引擎刷新))。
+- 通过`log/linkis-cg-linkismanager.log`日志,查看物料失败的具体原因,很多时候可能是hdfs目录没有权限导致。
+- 检查gateway地址配置是否正确`conf/linkis.properties`的配置项`wds.linkis.gateway.url`。
+
+引擎的物料资源默认上传到hdfs目录为 `/apps-data/${deployUser}/bml`。
+
+```shell script
+hdfs dfs -ls /apps-data/hadoop/bml
+#如果没有该目录 请手动创建目录并授予${deployUser}读写权限
+hdfs dfs -mkdir /apps-data
+hdfs dfs -chown hadoop:hadoop /apps-data
+```
+
+### 8.3 登陆密码问题
+
+linkis默认是使用静态用户和密码,静态用户即部署用户,静态密码会在执行部署是随机生成一个密码串,存储于
+
+`${LINKIS_HOME}/conf/linkis-mg-gateway.properties`(>=1.0.3版本)。
+
+### 8.4 版本兼容性问题
+
+linkis默认支持的引擎,与dss兼容关系可以查看[此文档](https://github.com/apache/linkis/blob/master/README.md) 。
+
+
+### 8.5 如何定位服务端异常日志
+
+linkis的微服务比较多,若对系统不熟悉,有时候无法定位到具体哪个模块出现了异常,可以通过全局日志搜索方式。
+```shell script
+tail -f log/* |grep -5n exception(或则tail -f log/* |grep -5n ERROR)
+less log/* |grep -5n exception(或则less log/* |grep -5n ERROR)
+```
+
+
+### 8.6 执行引擎任务的异常排查
+
+** step1:找到引擎的启动部署目录 **
+
+- 方式1:如果执行日志中有显示,可以在管理台上查看到 如下图:
+![engine-log](images/engine-log.png)
+- 方式2:如果方式1中没有找到,可以通过找到`conf/linkis-cg-engineconnmanager.properties`配置的`wds.linkis.engineconn.root.dir`的参数,该值就是引擎启动部署的目录,子目录按执行引擎的用户进行了隔离
+
+```shell script
+# 如果不清楚taskid,可以按时间排序后进行选择 ll -rt /appcom/tmp/${执行的用户}/${日期}/${引擎}/
+cd /appcom/tmp/${执行的用户}/${日期}/${引擎}/${taskId}
+```
+目录大体如下
+```shell script
+conf -> /appcom/tmp/engineConnPublickDir/6a09d5fb-81dd-41af-a58b-9cb5d5d81b5a/v000002/conf #引擎的配置文件
+engineConnExec.sh #生成的引擎的启动脚本
+lib -> /appcom/tmp/engineConnPublickDir/45bf0e6b-0fa5-47da-9532-c2a9f3ec764d/v000003/lib #引擎依赖的包
+logs #引擎启动执行的相关日志
+```
+
+**step2:查看引擎的日志**
+```shell script
+less logs/stdout
+```
+
+**step3:尝试手动执行脚本(如果需要)**
+可以通过尝试手动执行脚本,进行调试
+```
+sh -x engineConnExec.sh
+```
+
+### 8.7 如何修改注册中心eureka的端口
+有时候当eureka的端口被其他服务占用,无法使用默认的eureka端口的时候,需要对eureka端口进行修改,这里把对eureka端口的修改分为执行安装之前和执行安装之后两种情况。
+
+1.执行安装之前修改注册中心eureka端口
+```
+1. 进入apache-linkis-x.x.x-bin.tar.gz的解压目录
+2. 执行 vi deploy-config/linkis-env.sh
+3. 修改EUREKA_PORT=20303为EUREKA_PORT=端口号
+```
+2.执行安装之后修改注册中心eureka端口
+```
+1. 进入${LINKIS_HOME}/conf目录
+
+2. 执行grep -r 20303 ./* ,查询结果如下所示:
+ ./application-eureka.yml: port: 20303
+ ./application-eureka.yml: defaultZone: http://ip:20303/eureka/
+ ./application-linkis.yml: defaultZone: http://ip:20303/eureka/
+ ./linkis-env.sh:EUREKA_PORT=20303
+ ./linkis.properties:wds.linkis.eureka.defaultZone=http://ip:20303/eureka/
+
+3. 将对应位置的端口修改为新的端口,并且重启所有服务sh restart sbin/linkis-start-all.sh
+```
+
+
+### 8.8 CDH适配版本的注意事项
+
+CDH本身不是使用的官方标准的hive/spark包,进行适配时,最好修改linkis的源码中的hive/spark版本的依赖,进行重新编译部署。
+具体可以参考CDH适配博文
+[【Linkis1.0——CDH5环境中的安装与踩坑】](https://mp.weixin.qq.com/s/__QxC1NoLQFwme1yljy-Nw)
+[【DSS1.0.0+Linkis1.0.2——CDH5环境中的试用记录】](https://mp.weixin.qq.com/s/9Pl9P0hizDWbbTBf1yzGJA)
+[【DSS1.0.0与Linkis1.0.2——JDBC引擎相关问题汇总】](https://mp.weixin.qq.com/s/vcFge4BNiEuW-7OC3P-yaw)
+[【DSS1.0.0与Linkis1.0.2——Flink引擎相关问题汇总】](https://mp.weixin.qq.com/s/VxZ16IPMd1CvcrvHFuU4RQ)
+
+### 8.9 Http接口的调试
+
+- 方式1 可以开启[免登陆模式指引](/docs/latest/api/login-api/#2免登录配置)
+- 方式2 postman中的,请求头带上登陆成功的cookie值
+ cookie值可以在浏览器端登陆成功后,获取
+ ![bml](images/bml-cookie.png)
+
+```shell script
+Cookie: bdp-user-ticket-id=xxxxxxxxxxxxxxxxxxxxxxxxxxx
+```
+- 方式3 http请求头添加静态的Token令牌
+ Token在conf/linkis.properties进行配置
+ 如:TEST-AUTH=hadoop,root,user01
+```shell script
+Token-Code:TEST-AUTH
+Token-User:hadoop
+```
+
+### 8.10 异常问题的排查流程
+
+首先要按上述步骤检查服务/环境等是否都正常启动,然后按上述罗列的一些场景的方式进行基础问题的排查 。
+
+[QA文档](https://docs.qq.com/doc/DSGZhdnpMV3lTUUxq)中查找是否有解决方案,链接:https://docs.qq.com/doc/DSGZhdnpMV3lTUUxq
+通过搜索issue中的内容,看是否能找到解决方案。
+![issues](images/issues.png)
+通过官网文档搜索,对于某些问题,可以通过官网搜索关键字进行查询,比如搜索"部署"相关。(如果出现404,请浏览器中刷新一下)
+![search](images/search.png)
+
+
+## 9. 相关的资料如何获取
+linkis官网文档正在不断的完善,可以在本官网查看相关文档。
+
+相关博文链接如下。
+- Linkis的技术博文集 https://github.com/apache/linkis/issues/1233
+- 公众号技术博文https://mp.weixin.qq.com/mp/homepage?__biz=MzI4MDkxNzUxMg==&hid=1&sn=088cbf2bbed1c80d003c5865bc92ace8&scene=18
+- 官网文档 https://linkis.apache.org/zh-CN/docs/latest/about/introduction
+- bili技术分享视频 https://space.bilibili.com/598542776?spm_id_from=333.788.b_765f7570696e666f.2
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/directory-linkis.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/directory-linkis.md
new file mode 100644
index 00000000000..8811c13cb62
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/directory-linkis.md
@@ -0,0 +1,295 @@
+---
+title: 目录结构
+sidebar_position: 7
+---
+
+> Linkis代码层级目录结构,以及安装包目录结构和部署后的目录结构说明,如果想详细了解各个模块,请查看[Linkis的相关架构设计](architecture/overview.md)
+## 1. 源码目录结构
+
+```html
+├── docs
+│ ├── configuration //linkis所有模块的配置项文档
+│ ├── errorcode //linkis所有模块的错误码文档
+│ ├── configuration-change-records.md
+│ ├── index.md
+│ ├── info-1.1.3.md
+│ ├── info-1.2.1.md
+│ ├── info-1.3.1.md
+│ └── trino-usage.md
+├── linkis-commons //核心抽象,里面放有所有的公用模块
+│ ├── linkis-common //通用模块,内置很多通用工具类
+│ ├── linkis-hadoop-common
+│ ├── linkis-httpclient //Java SDK顶层接口 对httpclient的进一步封装
+│ ├── linkis-module // linkis的服务顶层公用模块 涉及到服务启动时的参数和服务初始化 统一的Restful处理 登录态校验等
+│ ├── linkis-mybatis //SpringCloud的Mybatis模块
+│ ├── linkis-protocol //服务请求/响应的一些接口和实体类
+│ ├── linkis-rpc //RPC模块,基于Feign实现的复杂双向通信
+│ ├── linkis-scheduler //通用调度模块
+│ ├── linkis-storage //文件操作工具集
+├── linkis-computation-governance //计算治理服务
+│ ├── linkis-client //Java SDK,用户通过Client可直接访问Linkis
+│ ├── linkis-computation-governance-common
+│ ├── linkis-engineconn
+│ ├── linkis-engineconn-manager
+│ ├── linkis-entrance //通用底层entrance模块
+│ ├── linkis-jdbc-driver //可以类似jdbc sdk方式连接使用linkis
+│ ├── linkis-manager
+├── linkis-dist //编译打包最后阶段步骤 整合所有lib包和安装部署脚本配置等
+│ ├── bin
+│ │ ├── checkEnv.sh
+│ │ ├── common.sh
+│ │ └── install.sh //安装脚本
+│ ├── deploy-config
+│ │ ├── db.sh //数据库配置
+│ │ └── linkis-env.sh //linkis 启动相关配置
+│ ├── docker
+│ │ └── scripts
+│ ├── helm
+│ │ ├── charts
+│ │ ├── scripts
+│ │ ├── README_CN.md
+│ │ └── README.md
+│ ├── package
+│ │ ├── bin
+│ │ ├── conf
+│ │ ├── db
+│ │ └── sbin
+│ ├── release-docs
+│ │ ├── licenses
+│ │ ├── LICENSE
+│ │ └── NOTICE
+│ ├── src
+│ └── pom.xml
+├── linkis-engineconn-plugins // 引擎
+│ ├── elasticsearch
+│ ├── flink
+│ ├── hive
+│ ├── io_file
+│ ├── jdbc
+│ ├── openlookeng
+│ ├── pipeline
+│ ├── presto
+│ ├── python
+│ ├── seatunnel
+│ ├── shell
+│ ├── spark
+│ ├── sqoop
+├── linkis-extensions // 扩展功能增强插件模块
+│ ├── linkis-io-file-client // 对linkis-storage的功能扩展
+├── linkis-orchestrator //服务的编排
+│ ├── linkis-code-orchestrator
+│ ├── linkis-computation-orchestrator
+│ ├── linkis-orchestrator-core
+├── linkis-public-enhancements //公共增强服务
+│ ├── linkis-basedata-manager
+│ ├── linkis-bml // 物料库
+│ ├── linkis-configuration
+│ ├── linkis-context-service //统一上下文
+│ ├── linkis-datasource //数据源服务
+│ ├── linkis-error-code
+│ ├── linkis-instance-label
+│ ├── linkis-jobhistory
+│ ├── linkis-ps-common-lock
+│ ├── linkis-script-dev
+│ ├── linkis-udf
+│ ├── linkis-variable
+├── linkis-spring-cloud-services //微服务治理
+│ ├── linkis-service-discovery
+│ ├── linkis-service-gateway //网关Gateway
+├── linkis-web //linkis的管理台代码
+│ ├── release-docs
+│ │ ├── licenses
+│ │ └── LICENSE
+│ ├── src
+│ ├── config.sh
+│ ├── install.sh
+│ ├── package.json
+│ ├── pom.xml
+│ └── vue.config.js
+├── tool
+│ ├── dependencies
+│ │ ├── known-dependencies.txt
+│ │ └── regenerate_konwn_dependencies_txt.sh
+│ ├── code-style-idea.xml
+│ ├── license-header
+│ └── modify_license.sh
+├── CONTRIBUTING_CN.md
+├── CONTRIBUTING.md
+├── linkis-tree.txt
+├── mvnw
+├── mvnw.cmd
+├── pom.xml
+├── README_CN.md
+├── README.md
+└── scalastyle-config.xml
+
+```
+
+## 2. 安装包目录结构
+```html
+
+├── bin
+│ ├── checkEnv.sh ── 环境变量检测
+│ ├── common.sh ── 部分公共shell函数
+│ └── install.sh ── Linkis安装的主脚本
+├── deploy-config
+│ ├── db.sh //数据库连接配置
+│ └── linkis-env.sh //相关环境配置信息
+├── docker
+├── helm
+├── licenses
+├── linkis-package //微服务相关的启动配置文件,依赖,脚本,linkis-cli等
+│ ├── bin
+│ ├── conf
+│ ├── db
+│ ├── lib
+│ └── sbin
+├── NOTICE
+├── LICENSE
+├── README_CN.md
+└── README.md
+
+```
+
+
+## 3. 部署后的目录结构
+
+
+```html
+├── bin ── linkis-cli 用于向Linkis提交任务的Shell命令行程序
+│ ├── linkis-cli
+│ ├── linkis-cli-hive
+│ ├── linkis-cli-pre
+│ ├── linkis-cli-spark-sql
+│ ├── linkis-cli-spark-submit
+│ └── linkis-cli-sqoop
+├── conf 配置目录
+│ ├── application-eureka.yml
+│ ├── application-linkis.yml ── 微服务通用yml
+│ ├── linkis-cg-engineconnmanager.properties
+│ ├── linkis-cg-engineplugin.properties
+│ ├── linkis-cg-linkismanager.properties
+│ │── linkis-cli
+│ │ ├── linkis-cli.properties
+│ │ └── log4j2.xml
+│ ├── linkis-env.sh ── linkis 环境变量配置
+│ ├── linkis-mg-gateway.properties
+│ ├── linkis.properties ── linkis 服务的全局配合,所有微服务启动都会加载使用
+│ ├── linkis-ps-publicservice.properties
+│ ├── log4j2.xml
+├── db 数据库DML和DDL文件目录
+│ ├── linkis_ddl.sql ── 数据库表定义SQL
+│ ├── linkis_dml.sql ── 数据库表初始化SQL
+│ └── module ── 包含各个微服务的DML和DDL文件
+│ └── upgrade ── 针对每个版本 增量DML/DDL
+├── lib lib目录
+│ ├── linkis-commons ── 公共依赖包 大多服务启动时(linkis-mg-gateway除外) -cp 路径参数 都会加载这个目录
+│ ├── linkis-computation-governance ──计算治理模块的lib目录
+│ ├── linkis-engineconn-plugins ──所有引擎插件的lib目录
+│ ├── linkis-public-enhancements ──公共增强服务的lib目录
+│ └── linkis-spring-cloud-services ──SpringCloud的lib目录
+├── logs 日志目录
+│ ├── linkis-cg-engineconnmanager-gc.log
+│ ├── linkis-cg-engineconnmanager.log
+│ ├── linkis-cg-engineconnmanager.out
+│ ├── linkis-cg-engineplugin-gc.log
+│ ├── linkis-cg-engineplugin.log
+│ ├── linkis-cg-engineplugin.out
+│ ├── linkis-cg-entrance-gc.log
+│ ├── linkis-cg-entrance.log
+│ ├── linkis-cg-entrance.out
+│ ├── linkis-cg-linkismanager-gc.log
+│ ├── linkis-cg-linkismanager.log
+│ ├── linkis-cg-linkismanager.out
+│ ├── linkis-cli
+│ │ ├── linkis-client.hadoop.log.20220409162400037523664
+│ │ ├── linkis-client.hadoop.log.20220409162524417944443
+│ ├── linkis-mg-eureka-gc.log
+│ ├── linkis-mg-eureka.log
+│ ├── linkis-mg-eureka.out
+│ ├── linkis-mg-gateway-gc.log
+│ ├── linkis-mg-gateway.log
+│ ├── linkis-mg-gateway.out
+│ ├── linkis-ps-publicservice-gc.log
+│ ├── linkis-ps-publicservice.log
+│ └── linkis-ps-publicservice.out
+├── pid 所有微服务的进程ID
+│ ├── linkis_cg-engineconnmanager.pid ──引擎管理器微服务
+│ ├── linkis_cg-engineconnplugin.pid ──引擎插件微服务
+│ ├── linkis_cg-entrance.pid ──引擎入口微服务
+│ ├── linkis_cg-linkismanager.pid ──linkis管理器微服务
+│ ├── linkis_mg-eureka.pid ──eureka微服务
+│ ├── linkis_mg-gateway.pid ──gateway微服务
+│ └── linkis_ps-publicservice.pid ──公共微服务
+└── sbin 微服务启停脚本目录
+ ├── ext ──各个微服务的启停脚本目录
+ ├── linkis-daemon.sh ── 快捷启停、重启单个微服务脚本
+ ├── linkis-start-all.sh ── 一键启动全部微服务脚本
+ └── linkis-stop-all.sh ── 一键停止全部微服务脚本
+
+```
+
+### 3.1 配置项修改
+
+在执行完Linkis安装后,所有配置项位于conf目录下,
+如果需要进行配置项修改,修改配置`${LINKIS_HOME}/conf/*properties`文件后,重启对应的服务,
+如:`sh sbin/linkis-daemon.sh start ps-publicservice`。
+如果修改的是公共配置文件`application-eureka.yml/application-linkis.yml/linkis.properties`,需要重启所有服务`sh sbin/linkis-start-all.sh`
+
+
+
+
+### 3.2 微服务启停
+
+所有微服务名称如下:
+ ```
+├── linkis-cg-engineconnmanager 引擎管理服务
+├── linkis-cg-engineplugin 引擎插件管理服务
+├── linkis-cg-entrance 计算治理入口服务
+├── linkis-cg-linkismanager 计算治理管理服务
+├── linkis-mg-eureka 微服务注册中心服务
+├── linkis-mg-gateway Linkis网关服务
+├── linkis-ps-publicservice 公共服务
+ ```
+
+**微服务简称**:
+
+| 简称 | 英文全称 | 中文全称 |
+ |------|-------------------------|------------|
+| cg | Computation Governance | 计算治理 |
+| mg | Microservice Covernance | 微服务治理 |
+| ps | Public Enhancement Service | 公共增强服务 |
+
+
+
+```
+# 一次性启动所有微服务:
+
+ sh linkis-start-all.sh
+
+# 一次性关停所有微服务
+
+ sh linkis-stop-all.sh
+
+# 启动单个微服务(服务名需要去掉linkis前缀如:mg-eureka)
+
+ sh linkis-daemon.sh start service-name
+
+ 例如: sh linkis-daemon.sh start mg-eureka
+
+# 关闭单个微服务
+
+ sh linkis-daemon.sh stop service-name
+
+ 例如: sh linkis-daemon.sh stop mg-eureka
+
+# 重启单个微服务
+
+ sh linkis-daemon.sh restart service-name
+
+ 例如: sh linkis-daemon.sh restart mg-eureka
+# 查看单个微服务的状态
+
+ sh linkis-daemon.sh status service-name
+
+ 例如: sh linkis-daemon.sh status mg-eureka
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/bml-cookie.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/bml-cookie.png
new file mode 100644
index 00000000000..67dc0be98f8
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/bml-cookie.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/bml.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/bml.png
new file mode 100644
index 00000000000..ca9290f945d
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/bml.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/engine-log.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/engine-log.png
new file mode 100644
index 00000000000..3a4c5ee0fb3
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/engine-log.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/eureka.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/eureka.png
new file mode 100644
index 00000000000..3b3f24a4b0e
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/eureka.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/hive-lineage-log.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/hive-lineage-log.png
new file mode 100644
index 00000000000..57caf1f9769
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/hive-lineage-log.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/issues.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/issues.png
new file mode 100644
index 00000000000..b84a711452c
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/issues.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/search.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/search.png
new file mode 100644
index 00000000000..632763a293b
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/search.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/spark-lineage-kafka.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/spark-lineage-kafka.png
new file mode 100644
index 00000000000..3f387f6e62e
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/spark-lineage-kafka.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/spark-lineage-log.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/spark-lineage-log.png
new file mode 100644
index 00000000000..5e9b7cb092c
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/spark-lineage-log.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/yarn-normal.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/yarn-normal.png
new file mode 100644
index 00000000000..fefc3110524
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/images/yarn-normal.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/install-engineconn.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/install-engineconn.md
new file mode 100644
index 00000000000..e09ef0efc5c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/install-engineconn.md
@@ -0,0 +1,182 @@
+---
+title: 引擎的安装
+sidebar_position: 4
+---
+
+> 本文主要介绍对于官方安装包中,未包含的引擎物料(jdbc/sqoop/flink等)/或则自定义实现的新引擎,如何进行安装部署,以支持对应的任务
+
+## 1. 引擎插件目录结构
+
+Linkis的引擎物料包安装目录为`${LINKIS_HOME}/lib/linkis-engineconn-plugins`,目录结构如下:
+
+```html
+hive #引擎主目录,必须为引擎的名字
+│ ├── dist # 引擎启动需要的jar包依赖和配置,不同的版本需要在该目录放置对应的版本目录
+│ │ └── 2.3.3 # 版本号 版本为2.3.3 任务请求参数的engineType 为hive-2.3.3
+│ │ └── conf # 引擎需要的配置文件目录
+│ │ └── lib # 引擎插件需要的依赖包
+│ ├── plugin #引擎插件目录,该目录用于引擎管理服务封装引擎的启动命令和资源申请
+│ └── 2.3.3 # 引擎版本
+│ └── linkis-engineplugin-hive-1.0.0.jar #引擎模块包(只需要放置单独的引擎包)
+├── python
+│ ├── dist
+│ │ └── python2
+│ └── plugin
+│ └── python2 #版本为python2 任务请求参数的engineTypee 为python-python2
+
+```
+
+这里的物料包文件会在Linkis服务启动时候,会根据目录,解析出引擎和版本号,进行引擎物料的持久化存储(HDFS/本地文件系统中),并将持久化存储信息(引擎类型和版本资源索引)
+记录到数据库表`linkis_cg_engine_conn_plugin_bml_resources`中。
+
+示例数据如下:
+
+| engine_conn_type | version | file_name | file_size | last_modified | bml_resource_id | bml_resource_version | create_time | last_update_time |
+| --- | --- | --- | ---: | ---: | --- | --- | --- | --- |
+| hive | v2.3.4 | conf.zip | 2046 | 1651925378000 | 4f0353ac-5703-4b4d-942d-dbaead38b506 | v000001 | 2022-05-07 20:17:45 | 2022-05-07 20:17:45 |
+| hive | v2.3.4 | lib.zip | 137715715 | 1651925379000 | 762595b5-a6d3-4311-8133-4f8d4e0c3aa0 | v000001 | 2022-05-07 20:17:52 | 2022-05-07 20:17:52 |
+
+提交任务执行时,会通过请求的参数`engineType`,从`linkis_cg_engine_conn_plugin_bml_resources`中查询到对应的资源索引,
+通过索引下载对应的引擎物料,并部署启动对应的引擎进程,再进行任务的处理。
+
+如 linkis-cli 提交hive查询示例
+```shell
+sh ./bin/linkis-cli -engineType hive-2.3.3 -codeType hql -code "show tables" -submitUser hadoop -proxyUser hadoop
+```
+
+:::caution 注意
+因为引擎执行时传递的参数`engineType:hive-2.3.3` 是通过-来进行拆分出引擎和版本的,所以版本号里面不能出现`-`,
+如果出现可以通过用其他符号代替,比如`engineType:hive-cdh-2.3.3`,会拆分错,可以直接使用这个:2.3.3 或则cdh_2.3.3 来命名引擎目录
+:::
+
+
+Linkis项目中包含的引擎模块`linkis-engineconn-plugins/engineconn-plugins`都是按这个目录进行打包配置的,
+如果是自己实现的新增引擎,需要按照上述的目录结构进行打包,可以参考hive的assembly配置方式来配置打包流程和配置,
+源码目录:`linkis-engineconn-plugins/hive/src/main/assembly/distribution.xml`
+
+## 2. 引擎的安装
+
+### 2.1 引擎包的准备
+
+#### 方式1
+如果 [非默认引擎物料包](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)中有满足条件的,可以直接下载使用
+
+#### 方式2 手动编译获取
+
+全量编译(首次编译时需要)
+```shell script
+cd ${linkis_code_dir}
+mvn -N install
+mvn clean install
+```
+
+编译引擎
+```shell script
+cd linkis-enginepconn-pugins/engineconn-plugins/pipeline/
+mvn clean install
+```
+
+编译出来的引擎包,位于
+```bash
+${linkis_code_dir}/linkis-engineconn-plugins/{插件模块名}/target/out/{插件模块名}
+```
+
+### 2.2 部署和加载
+
+将 2.1 步编译出来的引擎包,上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+
+### 2.4 并配置默认的引擎版本(可选)
+
+> 主要是配置默认版本,当请求未带版本时 会使用默认版本
+
+修改`$LINKIS_HOME/conf/linkis.properties` 配置文件
+```html
+wds.linkis.hive.engine.version=2.3.3
+```
+
+### 2.5 管理台Configuration配置修改(可选)
+管理台的配置是按照引擎标签来进行管理的,如果新增的引擎,有配置参数需要配置的话,需要修改对应的表的元数据
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:hive-2.3.3
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+以openLooKeng引擎 1.5.0版本 为例
+```html
+
+SET @OPENLOOKENG_LABEL="openlookeng-1.5.0";
+SET @OPENLOOKENG_ALL=CONCAT('*-*,',@OPENLOOKENG_LABEL);
+SET @OPENLOOKENG_IDE=CONCAT('*-IDE,',@OPENLOOKENG_LABEL);
+
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@OPENLOOKENG_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@OPENLOOKENG_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @OPENLOOKENG_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.url', '例如:http://127.0.0.1:8080', '连接地址', 'http://127.0.0.1:8080', 'Regex', '^\\s*http://([^:]+)(:\\d+)(/[^\\?]+)?(\\?\\S*)?$', 'openlookeng', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.catalog', 'catalog', 'catalog', 'system', 'None', '', 'openlookeng', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.source', 'source', 'source', 'global', 'None', '', 'openlookeng', 0, 0, 1, '数据源配置');
+
+
+-- openlookeng-*
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'openlookeng' and label_value = @OPENLOOKENG_ALL);
+
+-- openlookeng default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @OPENLOOKENG_ALL);
+
+```
+
+### 2.6 引擎刷新
+
+#### 2.6.1 方式1 接口刷新
+引擎支持实时刷新,引擎放置到对应目录后,通过http接口向`linkis-cg-engineconnplugin` 服务发送刷新请求即可。
+
+- 接口 `http://${engineconn-plugin-server-IP}:${port}/api/rest_j/v1/rpc/receiveAndReply`
+
+- 请求方式 `POST`
+
+```json
+{
+ "method": "/enginePlugin/engineConn/refreshAll"
+}
+```
+
+#### 2.6.2 方式2 重启刷新
+
+通过重启`linkis-cg-engineconnplugin` 服务,也可以强制刷新引擎目录
+
+```bash
+### cd到sbin目录下,重启linkis-cg-engineconnplugin服务
+
+cd ${LINKIS_HOME}/sbin
+
+## 执行linkis-daemon脚本
+
+sh linkis-daemon.sh restart linkis-cg-linkismanager
+
+```
+
+#### 2.6.3 检查引擎是否刷新成功
+
+如果在刷新过程中遇到问题,需要确认是否刷新成功,则可以查看数据库中的`linkis_engine_conn_plugin_bml_resources`这张表的last_update_time是否为触发刷新的时间。
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources
+```
+
+正常如下:
+![bml](images/bml.png)
+
+查看引擎的物料记录是否存在(如果有更新,查看更新时间是否正确)。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/_category_.json
new file mode 100644
index 00000000000..7cd78cc67d9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "集成",
+ "position": 9
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/hive-lineage.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/hive-lineage.md
new file mode 100644
index 00000000000..c2c17eaf3f5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/hive-lineage.md
@@ -0,0 +1,140 @@
+---
+title: 集成 Hive血缘
+sidebar_position: 1
+---
+
+本文主要介绍在 `Linkis` 中, `Hive` 引擎血缘采集方案。
+
+
+## 1. 介绍
+
+Hive 提供了一个内置的Hook LineageLogger,它用于记录查询执行期间生成的血缘信息。通过使用 LineageLogger Hook,你可以捕获和记录查询的输入和输出表以及列级别的血缘关系
+
+## 2. 将hive血缘采集至日志
+
+### 2.1 修改`hive-site.xml`
+
+```shell
+vim $HIVE_HOME/conf/hive-site.xml
+
+增加如下配置
+
+ hive.exec.post.hooks
+ org.apache.hadoop.hive.ql.hooks.LineageLogger
+
+```
+
+### 2.2 修改`hive-log4j2.properties`
+
+```shell
+vim $HIVE_HOME/conf/hive-log4j2.properties
+
+增加如下配置
+log4j.logger.org.apache.hadoop.hive.ql.hooks.LineageLogger=INFO
+```
+
+### 2.3 提交任务
+```shell
+sh ./bin/linkis-cli -engineType hive-3.1.3 \
+-codeType hql -code \
+"CREATE TABLE input_table (
+ column1 INT,
+ column2 STRING
+);
+CREATE TABLE output_table (
+ column3 INT,
+ column4 STRING
+);
+INSERT INTO TABLE output_table
+SELECT column1, column2
+FROM input_table;" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+### 2.4 查看日志
+```shell
+cat /appcom/tmp/hadoop/20230922/hive/946375fe-f189-487c-b3a7-f9fa821edace/logs/stdout
+```
+
+输出结果如下:
+![hive-lineage-log](../images/hive-lineage-log.png)
+
+详细信息如下:
+```json
+{
+ "version":"1.0",
+ "user":"hadoop",
+ "timestamp":1695354104,
+ "duration":15318,
+ "jobIds":[
+ "job_1691375506204_0488"
+ ],
+ "engine":"mr",
+ "database":"default",
+ "hash":"dbb11fce57f10dccb6ef724f66af611c",
+ "queryText":"INSERT INTO TABLE output_table\nSELECT column1, column2\nFROM input_table",
+ "edges":[
+ {
+ "sources":[
+ 2
+ ],
+ "targets":[
+ 0
+ ],
+ "edgeType":"PROJECTION"
+ },
+ {
+ "sources":[
+ 3
+ ],
+ "targets":[
+ 1
+ ],
+ "edgeType":"PROJECTION"
+ },
+ {
+ "sources":[
+ 2
+ ],
+ "targets":[
+ 0
+ ],
+ "expression":"compute_stats(default.input_table.column1, 'hll')",
+ "edgeType":"PROJECTION"
+ },
+ {
+ "sources":[
+ 3
+ ],
+ "targets":[
+ 1
+ ],
+ "expression":"compute_stats(default.input_table.column2, 'hll')",
+ "edgeType":"PROJECTION"
+ }
+ ],
+ "vertices":[
+ {
+ "id":0,
+ "vertexType":"COLUMN",
+ "vertexId":"default.output_table.column3"
+ },
+ {
+ "id":1,
+ "vertexType":"COLUMN",
+ "vertexId":"default.output_table.column4"
+ },
+ {
+ "id":2,
+ "vertexType":"COLUMN",
+ "vertexId":"default.input_table.column1"
+ },
+ {
+ "id":3,
+ "vertexType":"COLUMN",
+ "vertexId":"default.input_table.column2"
+ }
+ ]
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/install-scriptis.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/install-scriptis.md
new file mode 100644
index 00000000000..ff08cb83b59
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/install-scriptis.md
@@ -0,0 +1,205 @@
+---
+title: 集成 Scriptis
+sidebar_position: 4.1
+---
+
+## 1. 介绍
+
+> 在 Apache Linkis >= 1.1.1 和 DSS >= 1.1.0 之后,支持将 scriptis 单独部署和 Linkis 进行搭配使用,使用 scriptis 的交互式分析的功能,可以在 web 页面在线写 SQL、Pyspark、HiveQL 等脚本,提交给 Linkis 执行且支持 UDF、函数、资源管控和自定义变量等特性,本文将介绍如何单独部署 Web 组件-scriptis,并通过 scriptis 这种 Web 页面来使用 Apache Linkis 。
+
+
+前提:已经成功安装并可以正常使用了 Linkis 服务(后端和管理台服务),Linkis 的部署流程可以见[Apache Linkis 的快速部署 ](../deploy-quick.md)
+
+示例说明:
+
+- linkis-gateway 服务的地址为 10.10.10.10 端口为 9001
+- Linkis 的管理台 nginx 部署在 10.10.10.10 端口为 8080
+
+
+## 2 物料准备 方式1-直接下载
+
+| **DSS版本** | **DSS源码** | **Linkis版本要求** |**下载连接** |
+|:---- |:---- |:---- |:---- |
+|1.1.0 |[dss branch-1.1.0](https://github.com/WeBankFinTech/DataSphereStudio/tree/branch-1.1.0) |>=1.1.1|[scriptis-web 1.1.0](https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeDatasphere/Linkis/scriptis-web/scriptis-1.1.0.tar) |
+
+
+## 3 物料准备 方式2-自行编译
+> 如果不自行编译,可以直接下载编译好的静态资源包,跳过此步
+
+### 3.1 环境准备
+
+> 首次编译时需要安装
+
+#### 3.1.1 安装 node.js
+```shell script
+将 node.js 下载,安装即可。下载地址:http://nodejs.cn/download/ ( 建议使用node v16版本) 该步骤仅第一次使用时需要执行
+```
+#### 3.1.2 安装 learn
+```shell script
+#等待安装完即可,安装 liarn 仅第一次使用时需要执行
+npm install lerna -g
+```
+
+### 3.2 获取 Scriptis 代码
+> scriptis 是一个纯前端的项目,作为一个组件集成在 DSS 的 web 代码组件中,我们只需要将 DSS web 项目进行单独的 scriptis 模块编译
+
+```shell script
+#通过git下载 >=dss 1.1.0 版本来编译scriptis组件
+git clone -b branch-1.1.0 https://github.com/WeBankFinTech/DataSphereStudio
+# 或则直接下载 zip 包 后解压
+https://github.com/WeBankFinTech/DataSphereStudio/archive/refs/heads/branch-1.1.0.zip
+
+#进入 web 目录
+cd DataSphereStudio/web
+
+#该步骤仅第一次使用时需要执行
+lerna init
+
+#添加依赖 注意:这里不是通过 npm install 而是 lerna bootstrap 需先安装 learn 该步骤仅第一次使用时需要执行
+lerna bootstrap
+```
+
+### 3.3 本地运行项目(可选)
+
+> 如果不需要本地运行调试查看,可以跳过此步
+
+#### 3.3.1 配置 linkis-gateway 服务地址配置
+
+如果是在本地启动服务,需要在代码中配置后端 linkis-gateway 服务地址,在`web/packages/dss/`目录下的`.env`文件,
+打包部署时不需要进行配置
+```shell script
+// 后端 linkis-gatway 服务地址
+VUE_APP_HOST=http://10.10.10.10:9001
+VUE_APP_MN_CONFIG_PREFIX=http://10.10.10.10:9001/api/rest_j/v1
+```
+#### 3.3.2 运行 Scriptis 模块
+
+```shell script
+cd DataSphereStudio/web
+# 运行 scriptis 组件
+npm run serve --module=scriptis --micro_module=scriptis
+```
+
+打开浏览器,通过链接`http://localhost:8080`(本地请求默认端口是 8080) 访问应用 scriptis ,因为会请求到远端的 linkis-gatway 服务接口,这会存在跨域问题,chrome 浏览器解决跨域问题可参考[解决 Chrome 跨域问题 ](https://www.jianshu.com/p/56b1e01e6b6a)
+
+
+### 3.4 打包
+```shell script
+#指定 scriptis 模块
+cd DataSphereStudio/web
+
+#该指令成功执行后,web 目录下会出现一个名叫 `dist` 的文件夹,该文件夹即为打包好 scriptis 的组件资源代码。我们需要将该前端资源部署到 linkis-web 所在的 nginx 服务器上
+npm run build --module=scriptis --micro_module=scriptis
+```
+
+## 4 部署 Scriptis
+
+将直接下载(或编译)的静态资源 上传至 Linkis 管理台所在的服务器上,存放于`/data/Install/scriptis-web/dist/`,
+在安装 Linkis 管理台的 nginx 服务器配置中,添加 scriptis 的静态资源访问规则,Linkis 管理台部署的 nginx 配置一般位于 `/etc/nginx/conf.d/linkis.conf`
+
+```shell script
+ location /scriptis {
+ alias /data/Install/scriptis-web/dist/ ;
+ index index.html ;
+}
+```
+
+sudo vim `/etc/nginx/conf.d/linkis.conf`
+
+```shell script
+server {
+ listen 8080;# 访问端口
+ server_name localhost;
+ #charset koi8-r;
+ #access_log /var/log/nginx/host.access.log main;
+
+ location / {
+ root /appcom/Install/linkis-web/dist/; # 静态文件目录
+ index index.html;
+ }
+
+ location /scriptis { #scriptis 的资源带有 scriptis 前缀与 linkis 管理台区分开
+ alias /data/Install/scriptis-web/dist/ ; #nginx scriptis 静态文件存放路径 (可自定义)
+ index index.html ;
+ }
+
+ .......
+
+location /api {
+ proxy_pass http://10.10.10.10:9001; #gatway 的地址
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header x_real_ipP $remote_addr;
+ proxy_set_header remote_addr $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_http_version 1.1;
+ proxy_connect_timeout 4s;
+ proxy_read_timeout 600s;
+ proxy_send_timeout 12s;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+
+ #error_page 404 /404.html;
+ # redirect server error pages to the static page /50x.html
+ #
+ error_page 500 502 503 504 /50x.html;
+ location = /50x.html {
+ root /usr/share/nginx/html;
+ }
+ }
+
+```
+修改配置后,重新加载 nginx 配置
+
+```shell script
+sudo nginx -s reload
+```
+
+注意 nginx 中,location 配置块中使用 root 和 alias 区别
+- root 的处理结果是:root 路径+location 路径.
+- alias 的处理结果是:使用 alias 路径替换 location 路径.
+- alias 是一个目录别名的定义,root 则是最上层目录的定义
+
+## 5 Scriptis 使用步骤
+必须先通过 Linkis 管理台登陆页面登陆成功后,再访问scriptis 页面
+
+### 5.1 正常登录 Linkis 管理台
+
+```shell script
+#http://10.10.10.10:8080/#/
+http://nginxIp:port/#/
+```
+因访问 scriptis 需要进行登录验证,所以需要先进行登录,获取并缓存 cookie。
+
+### 5.2 登录成功后 访问 Scriptis 页面
+
+```shell script
+#http://10.10.10.10:8080/scriptis/#/home
+http://nginxIp:port/scriptis/#/home
+```
+`nginxIp`:Linkis 管理台所部署的 nginx 服务器 ip,`port`:nginx 配置启动的端口号,`scriptis`为请求 scriptis 项目静态文件 nginx 配置的 location 地址(可自定义设置)
+
+### 5.3 使用 Scriptis
+
+以新建一个 sql 查询任务为例。
+
+
+step1 新建脚本 选择脚本类型为 sql 类型
+
+![效果图 ](/Images-zh/deployment/scriptis/new_script.png)
+
+step2 输入要查询的语句
+
+![效果图 ](/Images-zh/deployment/scriptis/test_statement.png)
+
+step3 运行
+
+![效果图 ](/Images-zh/deployment/scriptis/running_results.png)
+
+
+shep4 查看结果
+
+![效果图 ](/Images-zh/deployment/scriptis/design_sketch.png)
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/involve-knife4j.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/involve-knife4j.md
new file mode 100644
index 00000000000..f0e75a1e03f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/involve-knife4j.md
@@ -0,0 +1,63 @@
+---
+title: 集成 Knife4j
+sidebar_position: 5.2
+---
+
+## 1.knife4j介绍
+knife4j是为Java MVC框架集成Swagger生成Api文档的增强解决方案,前身是swagger-bootstrap-ui,取名knife4j是希望它能像一把匕首一样小巧,轻量,并且功能强悍!其底层是对Springfox的封装,使用方式也和Springfox一致,只是对接口文档UI进行了优化
+**核心功能:**
+
+- 文档说明:根据Swagger的规范说明,详细列出接口文档的说明,包括接口地址、类型、请求示例、请求参数、响应示例、响应参数、响应码等信息,对该接口的使用情况一目了然。
+- 在线调试:提供在线接口联调的强大功能,自动解析当前接口参数,同时包含表单验证,调用参数可返回接口响应内容、headers、响应时间、响应状态码等信息,帮助开发者在线调试。
+## 2.Linkis集成knif4j
+### 2.1 测试模式下启动knif4j
+修改application-linkis.yml文件设置knife4j.production=false
+```shell
+knife4j:
+ enable: true
+ production: false
+```
+修改 linkis.properties文件打开测试模式
+```shell
+wds.linkis.test.mode=true
+wds.linkis.test.user=hadoop
+```
+重启所有服务后,可以通过http://ip:port/api/rest_j/v1/doc.html 访问knife4j页面
+```shell
+http://ip:port/api/rest_j/v1/doc.html
+```
+### 2.2 非测试模式下启动knif4j
+修改application-linkis.yml文件设置knife4j.production=false
+```shell
+knife4j:
+ enable: true
+ production: false
+```
+修改 linkis.properties文件添加wds.linkis.server.user.restful.uri.pass.auth
+```shell
+wds.linkis.server.user.restful.uri.pass.auth=/api/rest_j/v1/doc.html,/api/rest_j/v1/swagger-resources,/api/rest_j/v1/webjars,/api/rest_j/v1/v2/api-docs
+```
+重启所有服务后,可以通过http://ip:port/api/rest_j/v1/doc.html 访问knife4j页面
+```shell
+http://ip:port/api/rest_j/v1/doc.html
+```
+由于knife4j调试各接口时,需要进行身份认证,需手工在浏览器添加如下cookie信息
+```shell
+#用户登录ticket-id
+bdp-user-ticket-id=
+#工作空间ID
+workspaceId=
+#内部请求开关
+dataworkcloud_inner_request=true
+```
+以Chrome浏览器为例
+![](/Images-zh/deployment/knife4j/Knife4j_addcookie.png)
+## 3.进入Knife4j页面
+通过http://ip:port/api/rest_j/v1/doc.html 访问knife4j页面
+![](/Images-zh/deployment/knife4j/Knife4j_home.png)
+点击接口名称可展示详细的接口文档
+![](/Images-zh/deployment/knife4j/Knife4j_interface.png)
+点击“调试”并录入参数可对接口进行调试
+![](/Images-zh/deployment/knife4j/Knife4j_debug.png)
+
+详细使用指南可浏览knife4j官网查看:[https://doc.xiaominfo.com/knife4j/](https://doc.xiaominfo.com/knife4j/)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/involve-prometheus.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/involve-prometheus.md
new file mode 100644
index 00000000000..45093aa6e06
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/involve-prometheus.md
@@ -0,0 +1,346 @@
+---
+title: 集成 Prometheus
+sidebar_position: 5.1
+---
+这篇文章描述了如何让Prometheus监控所有正在运行的Linkis服务。
+
+## 1. Prometheus介绍
+
+### 1.1 Prometheus是什么
+
+
+Prometheus 是一个云原生计算基金会项目,是一个系统和服务监控系统。它以给定的时间间隔从配置的目标收集指标,评估规则表达式,显示结果,并在观察到指定条件时触发警报。
+
+在微服务上下文中,它提供了服务发现功能,可以从服务注册中心动态查找目标,如 Eureka、Consul 等,并通过 http 协议从 API 端点拉取指标。
+
+### 1.2 Prometheus架构
+
+下图说明了 Prometheus 的架构及其一些生态系统组件:
+
+![](https://prometheus.io/assets/architecture.png)
+
+Prometheus可以直接抓取指标,或通过push gateway间接地接收短作业的指标。它将所有抓取的样本存储在本地,并在这些数据上运行规则,以从现有数据聚合和记录新的时间序列,或生成警报。可以使用Grafana或其他API消费者对收集的数据进行可视化。
+
+![](/Images/deployment/monitoring/prometheus_architecture.jpg)
+
+在 Linkis中,我们将使用 Prometheus 中的 Eureka (Service Discover)SD 来使用 Eureka REST API 来查询抓取目标。 Prometheus 将定期检查 REST 端点并为每个应用程序实例创建一个抓取目标。
+
+## 2. 如何启用 Prometheus
+
+### 2.1 安装 Linkis时 启用 Prometheus
+
+>安装脚本中,可以通过开关进行开启
+
+修改安装脚本linkis-env.sh中的`PROMETHEUS_ENABLE`。
+
+```bash
+export PROMETHEUS_ENABLE=true
+```
+
+运行 `install.sh`安装linkis后, `prometheus`的相关配置会出现在下列文件中:
+
+```yaml
+## application-linkis.yml ##
+
+eureka:
+ instance:
+ metadata-map:
+ prometheus.path: ${prometheus.path:${prometheus.endpoint}}
+...
+management:
+ endpoints:
+ web:
+ exposure:
+ include: refresh,info,health,metrics,prometheus
+````
+
+```yaml
+## application-eureka.yml ##
+
+eureka:
+ instance:
+ metadata-map:
+ prometheus.path: ${prometheus.path:/actuator/prometheus}
+...
+management:
+ endpoints:
+ web:
+ exposure:
+ include: refresh,info,health,metrics,prometheus
+````
+
+```yaml
+## linkis.properties ##
+...
+wds.linkis.prometheus.enable=true
+wds.linkis.server.user.restful.uri.pass.auth=/api/rest_j/v1/actuator/prometheus,
+...
+```
+
+如果在引擎内部,如 spark、flink 或 hive,都需要手动添加相同的配置。
+```yaml
+## linkis-engineconn.properties ##
+...
+wds.linkis.prometheus.enable=true
+wds.linkis.server.user.restful.uri.pass.auth=/api/rest_j/v1/actuator/prometheus,
+...
+```
+### 2.2 已经安装后 启用 Prometheus
+
+修改`${LINKIS_HOME}/conf/application-linkis.yml`
+endpoints配置修改 增加`prometheus`
+```yaml
+## application-linkis.yml ##
+management:
+ endpoints:
+ web:
+ exposure:
+ #增加 prometheus
+ include: refresh,info,health,metrics,prometheus
+```
+
+修改`${LINKIS_HOME}/conf/application-eureka.yml`,endpoints配置修改增加`prometheus`
+
+```yaml
+## application-eureka.yml ##
+management:
+ endpoints:
+ web:
+ exposure:
+ #增加 prometheus
+ include: refresh,info,health,metrics,prometheus
+````
+
+修改`${LINKIS_HOME}/conf/linkis.properties`,去掉`prometheus.enable`前的注释
+
+```yaml
+## linkis.properties ##
+...
+wds.linkis.prometheus.enable=true
+...
+```
+
+### 2.3 启动Linkis
+
+```bash
+$ bash linkis-start-all.sh
+````
+
+Linkis启动后,各个微服务的prometheus端点是可以直接被访问的,例如http://linkishost:9103/api/rest_j/v1/actuator/prometheus
+:::caution 注意
+gateway/eureka 服务prometheus端点是没有`api/rest_j/v1`前缀的 http://linkishost:9001/actuator/prometheus
+:::
+
+
+## 3. 部署 Prometheus,Alertmanager和 Grafana 示例
+
+:::caution 注意
+gateway/eureka 服务prometheus端点是没有`api/rest_j/v1`前缀的 http://linkishost:9001/actuator/prometheus
+:::
+
+通常来说,云原生应用程序的监控设置将部署在具有服务发现和高可用性的 Kubernetes 上(例如,使用像 Prometheus Operator 这样的 Kubernetes Operator)。
+为了快速展示监控仪表盘,和试验不同类型的图表(histogram/ gauge),你需要一个本地简易的构建。
+这个部分将会解释如何在本地通过 Docker Compose搭建Prometheus/Alert Manager和Grafana这一监控套件。
+
+首先,让我们定义该技术栈的通用组件,如下所示:
+
+- Alert Manager容器对外通过端口9093暴露UI,并从alertmanager.conf读取配置;
+- Prometheus容器对外通过端口9090暴露UI,从prometheus.yml读取配置文件,从alert_rules.yml中读取报警规则;
+- Grafana容器对外通过端口3000暴露UI, 指标数据源定义在grafana_datasources.yml中,配置文件通过grafana_config.ini定义;
+- 以下的docker-compose.yml文件总结了上述组件的配置:
+
+````yaml
+## docker-compose.yml ##
+version: "3"
+networks:
+ default:
+ external: true
+ name: my-network
+services:
+ prometheus:
+ image: prom/prometheus:latest
+ container_name: prometheus
+ volumes:
+ - ./config/prometheus.yml:/etc/prometheus/prometheus.yml
+ - ./config/alertrule.yml:/etc/prometheus/alertrule.yml
+ - ./prometheus/prometheus_data:/prometheus
+ command:
+ - '--config.file=/etc/prometheus/prometheus.yml'
+ ports:
+ - "9090:9090"
+
+ alertmanager:
+ image: prom/alertmanager:latest
+ container_name: alertmanager
+ volumes:
+ - ./config/alertmanager.yml:/etc/alertmanager/alertmanager.yml
+ ports:
+ - "9093:9093"
+
+ grafana:
+ image: grafana/grafana:latest
+ container_name: grafana
+ environment:
+ - GF_SECURITY_ADMIN_PASSWORD=123456
+ - GF_USERS_ALLOW_SIGN_UP=false
+ volumes:
+ - ./grafana/provisioning/dashboards:/etc/grafana/provisioning/dashboards
+ - ./grafana/provisioning/datasources:/etc/grafana/provisioning/datasources
+ - ./grafana/grafana_data:/var/lib/grafana
+ ports:
+ - "3000:3000"
+````
+
+然后,为了根据 Prometheus 中的指标定义一些警报,您可以将它们分组到一个 alert_rules.yml 中,这样您就可以在生产实例中配置它们之前验证这些警报是否在本地设置中正确触发。例如,以下配置转换了用于监控 Linkis 服务的常用指标。
+
+- a. Down instance
+- b. High Cpu for each JVM instance (>80%)
+- c. High Heap memory for each JVM instance (>80%)
+- d. High NonHeap memory for each JVM instance (>80%)
+- e. High Waiting thread for each JVM instance (100)
+
+```yaml
+## alertrule.yml ##
+groups:
+- name: LinkisAlert
+ rules:
+ - alert: LinkisNodeDown
+ expr: last_over_time(up{job="linkis", application=~"LINKISI.*", application!="LINKIS-CG-ENGINECONN"}[1m])== 0
+ for: 15s
+ labels:
+ severity: critical
+ service: Linkis
+ instance: "{{ $labels.instance }}"
+ annotations:
+ summary: "instance: {{ $labels.instance }} down"
+ description: "Linkis instance(s) is/are down in last 1m"
+ value: "{{ $value }}"
+
+ - alert: LinkisNodeCpuHigh
+ expr: system_cpu_usage{job="linkis", application=~"LINKIS.*"} >= 0.8
+ for: 1m
+ labels:
+ severity: warning
+ service: Linkis
+ instance: "{{ $labels.instance }}"
+ annotations:
+ summary: "instance: {{ $labels.instance }} cpu overload"
+ description: "CPU usage is over 80% for over 1min"
+ value: "{{ $value }}"
+
+ - alert: LinkisNodeHeapMemoryHigh
+ expr: sum(jvm_memory_used_bytes{job="linkis", application=~"LINKIS.*", area="heap"}) by(instance) *100/sum(jvm_memory_max_bytes{job="linkis", application=~"LINKIS.*", area="heap"}) by(instance) >= 50
+ for: 1m
+ labels:
+ severity: warning
+ service: Linkis
+ instance: "{{ $labels.instance }}"
+ annotations:
+ summary: "instance: {{ $labels.instance }} memory(heap) overload"
+ description: "Memory usage(heap) is over 80% for over 1min"
+ value: "{{ $value }}"
+
+ - alert: LinkisNodeNonHeapMemoryHigh
+ expr: sum(jvm_memory_used_bytes{job="linkis", application=~"LINKIS.*", area="nonheap"}) by(instance) *100/sum(jvm_memory_max_bytes{job="linkis", application=~"LINKIS.*", area="nonheap"}) by(instance) >= 60
+ for: 1m
+ labels:
+ severity: warning
+ service: Linkis
+ instance: "{{ $labels.instance }}"
+ annotations:
+ summary: "instance: {{ $labels.instance }} memory(nonheap) overload"
+ description: "Memory usage(nonheap) is over 80% for over 1min"
+ value: "{{ $value }}"
+
+ - alert: LinkisWaitingThreadHigh
+ expr: jvm_threads_states_threads{job="linkis", application=~"LINKIS.*", state="waiting"} >= 100
+ for: 1m
+ labels:
+ severity: warning
+ service: Linkis
+ instance: "{{ $labels.instance }}"
+ annotations:
+ summary: "instance: {{ $labels.instance }} waiting threads is high"
+ description: "waiting threads is over 100 for over 1min"
+ value: "{{ $value }}"
+```
+
+**请注意**: 由于服务实例一旦关闭,它就不会成为 Prometheus Eureka SD 的目标之一,并且 up 指标在短时间内不会返回任何数据。因此,我们将收集最后一分钟是否 up=0 以确定服务是否处于活动状态。
+
+第三点, 最重要的是在 prometheus.yml 文件中定义 Prometheus 配置。这将定义:
+
+- 全局设定,例如指标抓取时间间隔,和规则扫描间隔;
+- AlertManager的连接信息,告警规则定义路径;
+- 应用指标端口的连接信息。
+
+这是 Linkis 的示例配置文件:
+````yaml
+## prometheus.yml ##
+# my global config
+global:
+ scrape_interval: 30s # By default, scrape targets every 15 seconds.
+ evaluation_interval: 30s # By default, scrape targets every 15 seconds.
+alerting:
+ alertmanagers:
+ - static_configs:
+ - targets: ['alertmanager:9093']
+# Load and evaluate rules in this file every 'evaluation_interval' seconds.
+rule_files:
+ - "alertrule.yml"
+
+# A scrape configuration containing exactly one endpoint to scrape:
+# Here it's Prometheus itself.
+scrape_configs:
+ - job_name: 'prometheus'
+ static_configs:
+ - targets: ['localhost:9090']
+ - job_name: linkis
+ eureka_sd_configs:
+ # the endpoint of your eureka instance
+ - server: {{linkis-host}}:20303/eureka
+ relabel_configs:
+ - source_labels: [__meta_eureka_app_name]
+ target_label: application
+ - source_labels: [__meta_eureka_app_instance_metadata_prometheus_path]
+ action: replace
+ target_label: __metrics_path__
+ regex: (.+)
+````
+第四点,下面的配置定义了警报将如何发送到外部webhook。
+```yaml
+## alertmanager.yml ##
+global:
+ resolve_timeout: 5m
+
+route:
+ receiver: 'webhook'
+ group_by: ['alertname']
+
+ # How long to wait to buffer alerts of the same group before sending a notification initially.
+ group_wait: 1m
+ # How long to wait before sending an alert that has been added to a group for which there has already been a notification.
+ group_interval: 5m
+ # How long to wait before re-sending a given alert that has already been sent in a notification.
+ repeat_interval: 12h
+
+receivers:
+- name: 'webhook'
+ webhook_configs:
+ - send_resolved: true
+ url: {{your-webhook-url}}
+
+````
+
+最后,在定义完所有配置文件以及 docker compose 文件后,我们可以使用 docker-compose up启动监控套件
+
+## 4. 结果展示
+在 Prometheus 页面上,预计会看到所有 Linkis 服务实例,如下所示:
+![](/Images/deployment/monitoring/prometheus_screenshot.jpg)
+
+当 Grafana 可访问的时候,您需要在 Grafana 中导入 prometheus 作为数据源,并导入 id 为 11378 的仪表板模板,该模板通常用于 springboot 服务(2.1+)。然后您可以在那里查看 Linkis 的一个实时仪表板。
+
+然后您可以在那里查看 Linkis 的实时仪表板。
+
+![](/Images/deployment/monitoring/grafana_screenshot.jpg)
+
+您还可以尝试将 Prometheus alter manager 与您自己的 webhook 集成,您可以在其中查看是否触发了告警消息。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/involve-skywalking.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/involve-skywalking.md
new file mode 100644
index 00000000000..50000b0fa79
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/involve-skywalking.md
@@ -0,0 +1,152 @@
+---
+title: 集成 SkyWalking
+sidebar_position: 5.0
+---
+这篇文章介绍一下如何在启动 Linkis 服务的时候开启 SkyWalking,以方便后续做分布式 trace 和 troubleshooting。
+
+## 1. SkyWalking 介绍
+
+### 1.1 SkyWalking 是什么
+
+SkyWalking 是开源的可视化平台,可以从多种数据源采集数据,并提供分析、聚合以及可视化等功能。通过 SkyWalking,我们可以对分布式系统的拓扑结构,数据交互有一个更加清晰的视图。
+
+
+
+### 1.2 SkyWalking 架构
+
+下图是 SkyWalking 的整体架构图。
+
+![](/Images-zh/deployment/skywalking/SkyWalking_Architecture.png)
+
+从逻辑上可以划分成 4 个部分:
+* **Probe**:可以理解为数据采集 agent,主要负责数据采集和格式化。
+* **Platform Backend**:SkyWalking 的后端服务,支持数据聚合、分析以及流式处理等。
+* **Storage**:负责数据存储,以 plugin 的方式支持多种存储引擎,比如 ElasticSearch, H2, MySQL, TiDB, InfluxDB 等。
+* **UI**: 数据可视化。
+
+在 Linkis 中使用 SkyWalking,需要用户已经存在 Backend 服务以及对应的 Storage。Linkis 服务启动的时候集成 Probe 即可。Probe 集成主要有三种方式:
+* **Language based native agent**:这些 agent 和目标服务进程运行在相同的用户空间,从外部来看,agent 和目标服务的代码是一样的。一个典型的例子是 Java agent,在运行 Java 应用的时候我们可以通过 `-javaagent` 来指定 agent。
+* **Service Mesh probes**:这种 Probe 通过 sidecar 或者 proxy 收集数据。
+* **3rd-party intrument library**:简单来说就是第三方的数据,比如 zipkin。
+
+我们在 Linkis 集成 SkyWalking 的时候采用第一种方式,也就是 java agent 的方式。下面我们为大家演示一下如何在 Linkis 服务中开启 SkyWalking。
+
+## 2. 部署 SkyWalking 后端
+
+SkyWalking 后端是开启 SkyWalk 的前置条件,下面先简单演示下如何安装 SkyWalking 的后端。
+
+首先从 SkyWalking 的 [Downloads](https://skywalking.apache.org/downloads/) 页面下载 SkyWalking APM。
+
+![](/Images-zh/deployment/skywalking/SkyWalking_APM_Download.png)
+
+下载完,直接解压得到如下的目录结构。
+
+```bash
+$ ls
+bin config config-examples LICENSE licenses logs NOTICE oap-libs README.txt tools webapp
+```
+
+后端默认使用 H2 内存数据库作为后端存储,不需要修改配置。按如下方式启动。
+
+启动 Backend
+```bash
+$ sh bin/startup.sh
+```
+
+启动 WebApp
+```bash
+$ sh bin/webappService.sh
+```
+
+UI 默认启动在 8080 端口,也可以通过修改 webapp 目录下的 webapp.yml 文件修改监听端口。
+
+```yaml
+server:
+ port: 8080
+
+spring:
+ cloud:
+ gateway:
+ routes:
+ - id: oap-route
+ uri: lb://oap-service
+ predicates:
+ - Path=/graphql/**
+ discovery:
+ client:
+ simple:
+ instances:
+ oap-service:
+ - uri: http://127.0.0.1:12800
+ # - uri: http://:
+ # - uri: http://:
+
+ mvc:
+ throw-exception-if-no-handler-found: true
+
+ web:
+ resources:
+ add-mappings: true
+
+management:
+ server:
+ base-path: /manage
+```
+
+## 3. Linkis 服务启动开启 SkyWalking
+
+这里假定大家对 Linkis 的服务部署已经比较清晰,如果还不清晰,可以异步:
+
+在 Linkis 中开启 SkyWalking 首先需要下载 SkyWalking 的 Java agent,我们可以在 [Downloads](https://skywalking.apache.org/downloads/) 页面进行下载。
+
+![](/Images-zh/deployment/skywalking/SkyWalking_Agent_Download.png)
+
+下载之后解压,内部的文件结构如下:
+```bash
+tree skywalking-agent
+$ skywalking-agent
+├── LICENSE
+├── NOTICE
+├── activations
+│ ├── apm-toolkit-kafka-activation-8.8.0.jar
+│ ├── ...
+├── bootstrap-plugins
+│ ├── apm-jdk-http-plugin-8.8.0.jar
+│ └── apm-jdk-threading-plugin-8.8.0.jar
+├── config
+│ └── agent.config
+├── licenses
+│ └── LICENSE-asm.txt
+├── logs
+├── optional-plugins
+│ ├── apm-customize-enhance-plugin-8.8.0.jar
+│ ├── ...
+├── optional-reporter-plugins
+│ ├── kafka-reporter-plugin-8.8.0.jar
+│ ├── ...
+├── plugins
+│ ├── apm-activemq-5.x-plugin-8.8.0.jar
+│ ├── ...
+└── skywalking-agent.jar
+```
+
+修改 Linkis 的 deploy-config/linkis-env.sh 中的配置项 `SKYWALKING_AGENT_PATH`。将其设置为 `skywalking-agent.jar` 的路径。
+```bash
+SKYWALKING_AGENT_PATH=/path/to/skywalking-agent.jar
+```
+
+然后启动 Linkis 即可。
+```bash
+$ sh linkis-start-all.sh
+```
+
+## 4. 结果展示
+Linkis 的 UI 端口默认启动在 8080 端口,Linkis 开启 SkyWalking 之后打开 UI 如果能看到如下的图就表示成功了。
+如果看不到展示效果,可能是浏览器兼容性问题,尝试切换浏览器试试。
+
+![](/Images-zh/deployment/skywalking/SkyWalking_UI_Dashboard.png)
+
+![](/Images-zh/deployment/skywalking/SkyWalking_UI_Dashboard2.png)
+
+![](/Images-zh/deployment/skywalking/SkyWalking_Topology.png)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/spark-lineage.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/spark-lineage.md
new file mode 100644
index 00000000000..6e95fb0d6cf
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/spark-lineage.md
@@ -0,0 +1,372 @@
+---
+title: 集成 Spark血缘
+sidebar_position: 1
+---
+
+本文主要介绍在 `Linkis` 中, `Spark` 引擎血缘采集方案。
+
+
+## 1. 介绍
+
+`spline-spark-agent`是一个用于在Spark应用程序中启用血缘跟踪(Lineage Tracking)的组件。它是Spline项目的一部分,旨在对Spark作业进行实时的血缘数据收集
+
+github地址
+```
+https://github.com/AbsaOSS/spline-spark-agent
+```
+
+## 2. 下载`spline-spark-agent`所需jar包
+
+```shell
+cd $SPARK_HOME/jars
+
+wget https://repo1.maven.org/maven2/za/co/absa/spline/agent/spark/spark-3.2-spline-agent-bundle_2.12/2.0.0/spark-3.2-spline-agent-bundle_2.12-2.0.0.jar
+```
+下载完成后 `$SPARK_HOME/jars` 会出现 `spark-3.2-spline-agent-bundle_2.12-2.0.0.jar`
+
+## 3. 将spark血缘采集至日志
+
+### 3.1 修改`spark-defaults.conf`
+
+```shell
+vim $SPARK_HOME/conf/spark-defaults.conf
+
+增加如下配置
+spark.sql.queryExecutionListeners=za.co.absa.spline.harvester.listener.SplineQueryExecutionListener
+spark.spline.lineageDispatcher=log
+spark.spline.lineageDispatcher.log.level=INFO
+spark.spline.lineageDispatcher.log.className=za.co.absa.spline.harvester.dispatcher.LoggingLineageDispatcher
+```
+
+### 3.2 数据准备
+
+```shell
+创建输入文件并上传至hdfs
+
+vim read.json
+
+{"name":"linkis","age":"5"}
+
+hadoop fs -put read.json /tmp
+````
+
+```shell
+创建输出目录
+hadoop fs -mkdir /tmp/jsonWrite
+````
+
+### 3.3 提交任务
+```shell
+sh ./bin/linkis-cli -engineType spark-3.2.1 -codeType sql -code \
+"CREATE TEMPORARY VIEW jsonReadTable
+USING org.apache.spark.sql.json
+OPTIONS (
+ path '/tmp/read.json'
+);
+INSERT OVERWRITE DIRECTORY '/tmp/jsonWrite' SELECT * FROM jsonReadTable;" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+### 3.4 查看日志
+```shell
+cat /appcom/tmp/hadoop/20230829/spark/117ca887-f9d6-4923-8ca1-cef7155ee0e7/logs/stdout
+```
+
+输出结果如下:
+![spark-lineage-log](../images/spark-lineage-log.png)
+
+详细信息如下:
+```json
+{
+ "id":"a5b273b3-a87f-5a30-8ced-c8eeff2d1458",
+ "name":"Linkis-EngineConn-Spark_LINKISCLI",
+ "operations":{
+ "write":{
+ "outputSource":"/tmp/jsonWrite",
+ "append":false,
+ "id":"op-0",
+ "name":"InsertIntoHiveDirCommand",
+ "childIds":[
+ "op-1"
+ ],
+ "extra":{
+ "destinationType":"hive"
+ }
+ },
+ "reads":[
+ {
+ "inputSources":[
+ "hdfs://linkishdfs/tmp/read.json"
+ ],
+ "id":"op-4",
+ "name":"LogicalRelation",
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "path":"/tmp/read.json"
+ },
+ "extra":{
+ "sourceType":"json"
+ }
+ }
+ ],
+ "other":[
+ {
+ "id":"op-3",
+ "name":"View",
+ "childIds":[
+ "op-4"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "desc":"CatalogTable(\nTable: jsonReadTable\nCreated Time: Tue Aug 29 11:52:10 CST 2023\nLast Access: UNKNOWN\nCreated By: Spark \nType: VIEW\nTable Properties: []\nSchema: root\n |-- age: string (nullable = true)\n |-- name: string (nullable = true)\n)",
+ "isTempView":true
+ }
+ },
+ {
+ "id":"op-2",
+ "name":"SubqueryAlias",
+ "childIds":[
+ "op-3"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "identifier":"jsonreadtable"
+ }
+ },
+ {
+ "id":"op-1",
+ "name":"Project",
+ "childIds":[
+ "op-2"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "projectList":[
+ {
+ "__attrId":"attr-0"
+ },
+ {
+ "__attrId":"attr-1"
+ }
+ ]
+ }
+ }
+ ]
+ },
+ "attributes":[
+ {
+ "id":"attr-0",
+ "dataType":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"age"
+ },
+ {
+ "id":"attr-1",
+ "dataType":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"name"
+ }
+ ],
+ "expressions":{
+
+ },
+ "systemInfo":{
+ "name":"spark",
+ "version":"3.2.1"
+ },
+ "agentInfo":{
+ "name":"spline",
+ "version":"2.0.0"
+ },
+ "extraInfo":{
+ "appName":"Linkis-EngineConn-Spark_LINKISCLI",
+ "dataTypes":[
+ {
+ "id":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"string",
+ "nullable":true,
+ "_typeHint":"dt.Simple"
+ }
+ ]
+ }
+}
+```
+
+## 4. 将spark血缘采集至kafka
+
+### 4.1 修改`spark-defaults.conf`
+
+```shell
+vim $SPARK_HOME/conf/spark-defaults.conf
+
+增加如下配置
+spark.sql.queryExecutionListeners=za.co.absa.spline.harvester.listener.SplineQueryExecutionListener
+spark.spline.lineageDispatcher=kafka
+spark.spline.lineageDispatcher.kafka.topic=linkis_spark_lineage_test
+spark.spline.lineageDispatcher.kafka.producer.bootstrap.servers=localhost:9092
+```
+
+### 4.2 提交任务
+```shell
+sh ./bin/linkis-cli -engineType spark-3.2.1 -codeType sql -code \
+"CREATE TEMPORARY VIEW jsonReadTable
+USING org.apache.spark.sql.json
+OPTIONS (
+ path '/tmp/read.json'
+);
+INSERT OVERWRITE DIRECTORY '/tmp/jsonWrite' SELECT * FROM jsonReadTable;" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+### 4.3 查看topic
+```shell
+kafka/bin/kafka-console-consumer.sh --topic linkis_spark_lineage_test --from-beginning --bootstrap-server localhost:9092
+```
+
+输出结果如下:
+![spark-lineage-kafka](../images/spark-lineage-kafka.png)
+
+
+详细信息如下:
+```json
+{
+ "id":"3a0e2b8e-11dc-5bd1-9bbc-cfba2fa469e9",
+ "name":"Linkis-EngineConn-Spark_LINKISCLI",
+ "operations":{
+ "write":{
+ "outputSource":"/tmp/jsonWrite",
+ "append":false,
+ "id":"op-0",
+ "name":"InsertIntoHiveDirCommand",
+ "childIds":[
+ "op-1"
+ ],
+ "extra":{
+ "destinationType":"hive"
+ }
+ },
+ "reads":[
+ {
+ "inputSources":[
+ "hdfs://linkishdfs/tmp/read.json"
+ ],
+ "id":"op-4",
+ "name":"LogicalRelation",
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "path":"/tmp/read.json"
+ },
+ "extra":{
+ "sourceType":"json"
+ }
+ }
+ ],
+ "other":[
+ {
+ "id":"op-3",
+ "name":"View",
+ "childIds":[
+ "op-4"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "desc":"CatalogTable(\nTable: jsonReadTable\nCreated Time: Tue Aug 29 14:48:06 CST 2023\nLast Access: UNKNOWN\nCreated By: Spark \nType: VIEW\nTable Properties: []\nSchema: root\n |-- age: string (nullable = true)\n |-- name: string (nullable = true)\n)",
+ "isTempView":true
+ }
+ },
+ {
+ "id":"op-2",
+ "name":"SubqueryAlias",
+ "childIds":[
+ "op-3"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "identifier":"jsonreadtable"
+ }
+ },
+ {
+ "id":"op-1",
+ "name":"Project",
+ "childIds":[
+ "op-2"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "projectList":[
+ {
+ "__attrId":"attr-0"
+ },
+ {
+ "__attrId":"attr-1"
+ }
+ ]
+ }
+ }
+ ]
+ },
+ "attributes":[
+ {
+ "id":"attr-0",
+ "dataType":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"age"
+ },
+ {
+ "id":"attr-1",
+ "dataType":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"name"
+ }
+ ],
+ "expressions":{
+
+ },
+ "systemInfo":{
+ "name":"spark",
+ "version":"3.2.1"
+ },
+ "agentInfo":{
+ "name":"spline",
+ "version":"2.0.0"
+ },
+ "extraInfo":{
+ "appName":"Linkis-EngineConn-Spark_LINKISCLI",
+ "dataTypes":[
+ {
+ "id":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"string",
+ "nullable":true,
+ "_typeHint":"dt.Simple"
+ }
+ ]
+ }
+}
+```
+
+## 5. 更多方式
+
+```text
+`spline-spark-agent`还支持更多的采集方式,比如:Http、Console,请参考官方文档
+https://github.com/AbsaOSS/spline-spark-agent/#configuration
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/sso-with-redis.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/sso-with-redis.md
new file mode 100644
index 00000000000..aaf9548eb2b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/integrated/sso-with-redis.md
@@ -0,0 +1,47 @@
+---
+title: 网关服务支持多活
+sidebar_position: 8
+---
+## 1.背景
+因为原有的登陆 session 未支持分布式存储,对于同一个用户的所有请求,需要 nginx 转发请求到同一个 gateway 实例上,才能正常处理请求。
+常用的解决方式是通过在入口 nginx 上通过配置 ip hash 负载均衡的方式来支持。
+但是ip hash 方式 如果存在服务器的扩容与缩容时,所有客户端ip的 hash 值都需要重新计算,会导致会话丢失,
+其次容易因为节点分部不均匀⽽造成数据倾斜问题。为了优化 ip hash 方式存在的问题,对登陆态的 session 实现共享存储
+
+
+## 2.实现方案
+因为会话信息主要是通过 ticketId 来标识,所有对外入口为 gateway,所以只需要对 gateway 模块进行改造。
+对于底层的共享存储,选择主流的内存数据库 redis。对于是否启动 redis 会话存储,支持通过配置文件控制。
+关键代码改动为 `org.apache.linkis.server.security.SSOUtils` 的 `userTicketIdToLastAccessTime`。
+
+请求流程:
+
+`用户请求 -> nginx -> linkis-gateway -> linkis 后端服务`
+
+
+## 3.使用方式
+
+需要可用的 reids 环境,支持单机版redis和redis 哨兵模式。
+
+安装部署Linkis 后,修改配置文件 `${LINKIS_HOME}/conf/linkis.properties`
+```shell script
+#开启redis cache配置
+linkis.session.redis.cache.enabled=true
+
+
+#单机版
+linkis.session.redis.host=127.0.0.1
+linkis.session.redis.port=6379
+linkis.session.redis.password=test123
+
+# 哨兵模式
+linkis.session.redis.sentinel.master=sentinel-master-name
+linkis.session.redis.sentinel.nodes=127.0.1.1:6381,127.0.2.1:6381,127.0.3.1:6381
+linkis.session.redis.password=test123
+
+```
+
+正常启用 gateway 即可,启动 redis 后,对于多个 gateway 示例,在 nginx 侧配置时,可以使用 nginx 默认负载均衡模式。
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/version-adaptation.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/version-adaptation.md
new file mode 100644
index 00000000000..a496e5c5119
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/deployment/version-adaptation.md
@@ -0,0 +1,510 @@
+---
+title: 版本适配
+sidebar_position: 8
+---
+
+# 版本适配
+
+## 1. 功能说明
+
+针对Apache,CDH,HDP等版本适配需要手动修改的地方进行说明
+
+## 2. 编译指令
+
+进入到项目的根目录下,依次执行如下指令
+
+```text
+mvn -N install
+mvn clean install -Dmaven.test.skip=true
+```
+
+## 3. SQL脚本切换
+
+linkis-dist -> package -> db 下的 linkis-dml.sql 脚本
+
+将对应的引擎版本切换为自己需要的版本,如果你使用的版本和官方一致的话,则无需修改此步
+
+比如:
+
+1. spark是3.0.0的话,则此处是 SET @SPARK_LABEL="spark-3.0.0";
+2. hive是2.1.1-cdh6.3.2的话,需先调整2.1.1_cdh6.3.2(构建时),则此处是 SET @HIVE_LABEL="hive-2.1.1_cdh6.3.2";
+
+```sql
+-- 变量:
+SET @SPARK_LABEL="spark-2.4.3";
+SET @HIVE_LABEL="hive-2.3.3";
+SET @PYTHON_LABEL="python-python2";
+SET @PIPELINE_LABEL="pipeline-1";
+SET @JDBC_LABEL="jdbc-4";
+SET @PRESTO_LABEL="presto-0.234";
+SET @IO_FILE_LABEL="io_file-1.0";
+SET @OPENLOOKENG_LABEL="openlookeng-1.5.0";
+```
+
+## 4. Linkis官方版本
+
+| 引擎 | 版本 |
+| ------ | ------ |
+| hadoop | 2.7.2 |
+| hive | 2.3.3 |
+| spark | 2.4.3 |
+| flink | 1.12.2 |
+
+## 5. Apache版本适配
+
+### 5.1 Apache3.1.x版本
+
+| 引擎 | 版本 |
+| ------ | ------ |
+| hadoop | 3.1.1 |
+| hive | 3.1.2 |
+| spark | 3.0.1 |
+| flink | 1.13.2 |
+
+#### 5.1.1 linkis的pom文件
+
+Linkis版本小于`1.3.2`时
+```java
+3.1.1
+2.12.10
+2.12
+
+
+
+ org.apache.hadoop
+ hadoop-hdfs-client
+ ${hadoop.version}
+
+```
+
+当Linkis版本大于等于`1.3.2`时, 只需要设置 `scala.version` and `scala.binary.version`
+```java
+2.12.10
+2.12
+```
+因为我们可以直接使用`hadoop-3.3` or `hadoop-2.7` profile来编译
+Profile `hadoop-3.3` 可以用于任意hadoop3.x, 默认hadoop3.x版本是3.3.1,
+Profile `hadoop-2.7` 可以用于任意hadoop2.x, 默认hadoop2.x版本是2.7.2,
+想要用其他版本可以编译时指定 -Dhadoop.version=xxx
+```text
+mvn -N install
+mvn clean install -Phadoop-3.3 -Dmaven.test.skip=true
+mvn clean install -Phadoop-3.3 -Dhadoop.version=3.1.1 -Dmaven.test.skip=true
+```
+
+#### 5.1.2 linkis-hadoop-common的pom文件
+
+Linkis版本小于`1.3.2`时
+```java
+
+
+ org.apache.hadoop
+ hadoop-hdfs-client
+ ${hadoop.version}
+
+```
+
+当Linkis版本大于等于`1.3.2`时,`linkis-hadoop-common`模块不需要变更
+
+#### 5.1.3 linkis-engineplugin-hive的pom文件
+
+```java
+3.1.2
+```
+
+#### 5.1.4 linkis-engineplugin-spark的pom文件
+
+Linkis版本小于`1.3.2`时
+```java
+3.0.1
+```
+
+当Linkis版本大于等于`1.3.2`时
+```text
+我们可以直接编译spark-3.2 profile, 如果我们同时使用hadoop3, 那么我们还需要指定hadoop-3.3 profile.
+默认 spark3.x 版本时3.2.1. 如果我们使用spark-3.2 profile编译, scala版本默认是2.12.15,因此我们不需要在项目根目录设置scala版本了(5.1.1提到当)
+如果Linkis使用hadoop3编译,同时spark仍旧是2.x版本的话,由于spark兼容性问题需要激活profile `spark-2.4-hadoop-3.3`
+```
+```text
+mvn -N install
+mvn clean install -Pspark-3.2 -Phadoop-3.3 -Dmaven.test.skip=true
+mvn clean install -Pspark-2.4-hadoop-3.3 -Phadoop-3.3 -Dmaven.test.skip=true
+```
+
+#### 5.1.5 flink-engineconn-flink的pom文件
+
+```java
+1.13.2
+```
+
+:::caution 临时方案
+
+注意以下复制类操作均在flink中
+
+由于flink1.12.2到1.13.2版本,有部分类进行调整,所以需要进行flink的编译和调整,编译flink选择scala的版本为2.12版本(scala版本根据自己的实际使用版本来)
+
+flink编译参考指令: mvn clean install -DskipTests -P scala-2.12 -Dfast -T 4 -Dmaven.compile.fock=true
+
+:::
+
+```text
+-- 注意,下列的类是从flink的1.12.2版本给copy到flink的1.13.2版本来
+org.apache.flink.table.client.config.entries.DeploymentEntry
+org.apache.flink.table.client.config.entries.ExecutionEntry
+org.apache.flink.table.client.gateway.local.CollectBatchTableSink
+org.apache.flink.table.client.gateway.local.CollectStreamTableSink
+```
+
+#### 5.1.6 linkis-label-common调整
+
+org.apache.linkis.manager.label.conf.LabelCommonConfig 文件调整
+
+```java
+ public static final CommonVars SPARK_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.spark.engine.version", "3.0.1");
+
+ public static final CommonVars HIVE_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.hive.engine.version", "3.1.2");
+```
+
+#### 5.1.7 linkis-computation-governance-common调整
+
+org.apache.linkis.governance.common.conf.GovernanceCommonConf 文件调整
+
+```java
+ val SPARK_ENGINE_VERSION = CommonVars("wds.linkis.spark.engine.version", "3.0.1")
+
+ val HIVE_ENGINE_VERSION = CommonVars("wds.linkis.hive.engine.version", "3.1.2")
+```
+
+## 6. HDP版本适配
+
+### 6.1 HDP3.0.1版本
+
+| 引擎 | 版本 |
+| -------------- | ------ |
+| hadoop | 3.1.1 |
+| hive | 3.1.0 |
+| spark | 2.3.2 |
+| json4s.version | 3.2.11 |
+
+#### 6.1.1 linkis的pom文件
+
+Linkis版本小于`1.3.2`时
+```java
+3.1.1
+3.2.11
+
+
+
+ org.apache.hadoop
+ hadoop-hdfs-client
+ ${hadoop.version}
+
+```
+
+当Linkis版本大于等于`1.3.2`时, 只需要设置 `json4s.version`
+```java
+3.2.11
+```
+因为我们可以直接使用`hadoop-3.3` or `hadoop-2.7` profile来编译
+Profile `hadoop-3.3` 可以用于任意hadoop3.x, 默认hadoop3.x版本是3.3.1,
+Profile `hadoop-2.7` 可以用于任意hadoop2.x, 默认hadoop2.x版本是2.7.2,
+想要用其他版本可以编译时指定 -Dhadoop.version=xxx
+```text
+mvn -N install
+mvn clean install -Phadoop-3.3 -Dmaven.test.skip=true
+mvn clean install -Phadoop-3.3 -Dhadoop.version=3.1.1 -Dmaven.test.skip=true
+```
+
+#### 6.1.2 linkis-engineplugin-hive的pom文件
+
+```java
+3.1.0
+```
+
+#### 6.1.3 linkis-engineplugin-spark的pom文件
+
+Linkis版本小于`1.3.2`时
+```java
+2.3.2
+```
+
+当Linkis版本大于等于`1.3.2`时
+```text
+我们可以直接编译spark-3.2 profile, 如果我们同时使用hadoop3, 那么我们还需要指定hadoop-3.3 profile.
+默认 spark3.x 版本时3.2.1. 如果我们使用spark-3.2 profile编译, scala版本默认是2.12.15,因此我们不需要在项目根目录设置scala版本了(5.1.1提到当)
+如果Linkis使用hadoop3编译,同时spark仍旧是2.x版本的话,由于spark兼容性问题需要激活profile `spark-2.4-hadoop-3.3`
+```
+```text
+mvn -N install
+mvn clean install -Pspark-3.2 -Phadoop-3.3 -Dmaven.test.skip=true
+mvn clean install -Pspark-2.4-hadoop-3.3 -Phadoop-3.3 -Dmaven.test.skip=true
+```
+
+#### 6.1.4 linkis-label-common调整
+
+org.apache.linkis.manager.label.conf.LabelCommonConfig 文件调整
+
+```java
+ public static final CommonVars SPARK_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.spark.engine.version", "2.3.2");
+
+ public static final CommonVars HIVE_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.hive.engine.version", "3.1.0");
+```
+
+#### 6.1.5 linkis-computation-governance-common调整
+
+org.apache.linkis.governance.common.conf.GovernanceCommonConf 文件调整
+
+```java
+ val SPARK_ENGINE_VERSION = CommonVars("wds.linkis.spark.engine.version", "2.3.2")
+
+ val HIVE_ENGINE_VERSION = CommonVars("wds.linkis.hive.engine.version", "3.1.0")
+```
+
+## 7 CDH版本适配
+
+### 7.1 maven配置地址
+
+#### 7.1.1 setting文件
+
+```xml
+
+
+
+ nexus-aliyun
+ *,!cloudera
+ Nexus aliyun
+ http://maven.aliyun.com/nexus/content/groups/public
+
+
+ aliyunmaven
+ *,!cloudera
+ 阿里云公共仓库
+ https://maven.aliyun.com/repository/public
+
+
+ aliyunmaven
+ *,!cloudera
+ spring-plugin
+ https://maven.aliyun.com/repository/spring-plugin
+
+
+ maven-default-http-blocker
+ external:http:*
+ Pseudo repository to mirror external repositories initially using HTTP.
+ http://0.0.0.0/
+ true
+
+
+```
+
+#### 7.1.2 linkis的pom文件
+
+```xml
+
+
+ cloudera
+ https://repository.cloudera.com/artifactory/cloudera-repos/
+
+ true
+
+
+
+
+ aliyun
+ http://maven.aliyun.com/nexus/content/groups/public/
+
+ true
+
+
+
+```
+
+### 7.2 CDH5.12.1版本
+
+| 引擎 | 版本 |
+| --------- | --------------- |
+| hadoop | 2.6.0-cdh5.12.1 |
+| zookeeper | 3.4.5-cdh5.12.1 |
+| hive | 1.1.0-cdh5.12.1 |
+| spark | 2.3.4 |
+| flink | 1.12.4 |
+| python | python3 |
+
+#### 7.2.1 linkis的pom文件
+
+```xml
+2.6.0-cdh5.12.1
+3.4.5-cdh5.12.1
+2.11.8
+```
+
+#### 7.2.2 linkis-engineplugin-hive的pom文件
+
+```xml
+-- 修改
+1.1.0-cdh5.12.1
+-- 添加
+1.1.0_cdh5.12.1
+```
+
+- 修改 assembly 下的 distribution.xml 文件
+
+```xml
+/dist/v${package.hive.version}/lib
+dist/v${package.hive.version}/conf
+plugin/${package.hive.version}
+```
+
+- 修改CustomerDelimitedJSONSerDe文件
+
+ ```
+ /* hive版本过低,需注释
+ case INTERVAL_YEAR_MONTH:
+ {
+ wc = ((HiveIntervalYearMonthObjectInspector) oi).getPrimitiveWritableObject(o);
+ binaryData = Base64.encodeBase64(String.valueOf(wc).getBytes());
+ break;
+ }
+ case INTERVAL_DAY_TIME:
+ {
+ wc = ((HiveIntervalDayTimeObjectInspector) oi).getPrimitiveWritableObject(o);
+ binaryData = Base64.encodeBase64(String.valueOf(wc).getBytes());
+ break;
+ }
+ */
+ ```
+
+#### 7.2.3 linkis-engineplugin-flink的pom文件
+
+```xml
+1.12.4
+```
+
+#### 7.2.4 linkis-engineplugin-spark的pom文件
+
+```xml
+2.3.4
+```
+
+#### 7.2.5 linkis-engineplugin-python的pom文件
+
+```xml
+python3
+```
+
+#### 7.2.6 linkis-label-common调整
+
+org.apache.linkis.manager.label.conf.LabelCommonConfig 文件调整
+
+```java
+ public static final CommonVars SPARK_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.spark.engine.version", "2.3.4");
+
+ public static final CommonVars HIVE_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.hive.engine.version", "1.1.0");
+
+ CommonVars.apply("wds.linkis.python.engine.version", "python3")
+```
+
+#### 7.2.7 linkis-computation-governance-common调整
+
+org.apache.linkis.governance.common.conf.GovernanceCommonConf 文件调整
+
+```java
+ val SPARK_ENGINE_VERSION = CommonVars("wds.linkis.spark.engine.version", "2.3.4")
+
+ val HIVE_ENGINE_VERSION = CommonVars("wds.linkis.hive.engine.version", "1.1.0")
+
+ val PYTHON_ENGINE_VERSION = CommonVars("wds.linkis.python.engine.version", "python3")
+```
+
+### 7.3 CDH6.3.2
+
+| 引擎 | 版本 |
+| ------ | -------------- |
+| hadoop | 3.0.0-cdh6.3.2 |
+| hive | 2.1.1-cdh6.3.2 |
+| spark | 3.0.0 |
+
+#### 7.3.1 linkis的pom文件
+
+```xml
+3.0.0-cdh6.3.2
+2.12.10
+```
+
+#### 7.3.2 linkis-hadoop-common
+
+```xml
+
+
+ org.apache.hadoop
+ hadoop-hdfs-client
+
+```
+
+#### 7.3.3 linkis-engineplugin-hive的pom文件
+
+```xml
+-- 修改
+2.1.1-cdh6.3.2
+-- 添加
+2.1.1_cdh6.3.2
+```
+
+修改 assembly 下的 distribution.xml 文件
+
+```xml
+/dist/v${package.hive.version}/lib
+dist/v${package.hive.version}/conf
+plugin/${package.hive.version}
+```
+
+#### 7.3.4 linkis-engineplugin-spark的pom文件
+
+```xml
+3.0.0
+```
+
+#### 7.3.5 linkis-label-common调整
+
+org.apache.linkis.manager.label.conf.LabelCommonConfig 文件调整
+
+```java
+ public static final CommonVars SPARK_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.spark.engine.version", "3.0.0");
+
+ public static final CommonVars HIVE_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.hive.engine.version", "2.1.1_cdh6.3.2");
+```
+
+#### 7.3.6 linkis-computation-governance-common调整
+
+org.apache.linkis.governance.common.conf.GovernanceCommonConf 文件调整
+
+```java
+ val SPARK_ENGINE_VERSION = CommonVars("wds.linkis.spark.engine.version", "3.0.0")
+
+ val HIVE_ENGINE_VERSION = CommonVars("wds.linkis.hive.engine.version", "2.1.1_cdh6.3.2")
+```
+
+## 8 编译技巧
+
+- 如果遇到类缺少或者类中方法缺少的情况下,找到对应引用这个包依赖,如何尝试切换到有对应包或者类的版本中来
+- 引擎版本如果需要使用到-的话,使用_来进行替换,并且加上来指定替换后的版本,同时在对应的引擎distribution文件中使用${package.引擎名字.version}来替换原有的
+- 如果有时候使用阿里云镜像出现下载guava的jar出现403的问题的话,可以切换到华为,腾讯等镜像仓库
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/_category_.json
new file mode 100644
index 00000000000..a857e622c21
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "开发指南",
+ "position": 8
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/build-console.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/build-console.md
new file mode 100644
index 00000000000..6fa4f38643e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/build-console.md
@@ -0,0 +1,79 @@
+---
+title: 管理台编译
+sidebar_position: 4.0
+---
+
+## 1. 前置准备
+
+## 1.1 安装Node.js
+
+>该步骤仅第一次使用时需要执行,如果已有node环境,可跳过
+
+将Node.js下载到本地,安装即可。下载地址:[http://nodejs.cn/download/](http://nodejs.cn/download/) (建议使用node v16版本)
+
+## 1.2 源码获取
+
+- 方式1:从[github仓库](https://github.com/apache/linkis) https://github.com/apache/linkis 获取项目的源代码。
+- 方式2:从[linkis的官方下载页面](https://linkis.apache.org/download/main) https://linkis.apache.org/download/main 下载所需版本的源码包。
+
+
+## 2. 编译
+
+## 2.1 安装npm依赖
+
+在终端命令行中执行以下指令:
+```
+#进入项目WEB根目录
+$ cd linkis/linkis-web
+#安装项目所需依赖
+$ npm install
+```
+**该步骤仅第一次使用时需要执行。**
+
+
+## 2.2. 打包项目
+
+在终端命令行执行以下指令对项目进行打包,生成压缩后的部署安装包。
+检查`linkis-web/package.json`,`linkis-web/.env`文件,检查前端管理台版本号是否正确。
+```
+$ npm run build
+```
+上述命令执行成功后,会生成前端管理台安装包 `apache-linkis-${version}-web-bin.tar.gz`,可以直接将该文件夹放进您的静态服务器中,或者参考[安装文档](../deployment/deploy-console.md),使用脚本进行部署安装。
+
+## 3 . 注意事项
+### 3.1 Windows下npm install 步骤报错
+```shell
+Error: Can't find Python executable "python", you can set the PYTHON env variable
+安装windows-build-tools (管理员权限)
+$ npm install --global --production windows-build-tools
+安装node-gyp
+$ npm install --global node-gyp
+
+2.如果编译失败 请按如下步骤清理后重新执行
+#进入项目工作目录,删除 node_modules
+$ rm -rf node_modules
+#删除 package-lock.json
+$ rm -rf package-lock.json
+#清除 npm 缓存
+$ npm cache clear --force
+#重新下载依赖
+$ npm install
+
+```
+### 3.2 如果出现兼容问题,建议重新安装node
+[node下载地址](https://nodejs.org/zh-cn/download/)
+```shell
+1.查看node版本(推荐使用node v16版本)
+$ node -v
+2.下载node v16版本并且重新安装node
+```
+
+### 3.3 npm install下载前端依赖无法成功
+如果遇到该情况,可以使用国内的淘宝npm镜像:
+```
+npm install -g cnpm --registry=https://registry.npm.taobao.org
+```
+接着,通过执行以下指令代替npm install指令
+```
+cnpm install
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/build-docker.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/build-docker.md
new file mode 100644
index 00000000000..17c01e84f5b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/build-docker.md
@@ -0,0 +1,136 @@
+---
+title: Docker 编译
+sidebar_position: 5.0
+---
+
+## Linkis 镜像组成
+
+从1.3.0版本起,Linkis引入了一些 Docker 镜像,项目所有镜像的 Dockerfile 文件都在`linkis-dist/docker`目录下。
+
+目前由如下几个镜像组成:
+
+### linkis-base
+
+ - __Dockerfile__:
+ - 文件名: linkis.Dockerfile
+ - 参数, 可以通过 `docker build` 命令的 `--build-arg` 参数来重载:
+ * JDK_VERSION: JDK 版本,默认为 1.8.0-openjdk
+ * JDK_BUILD_REVISION: JDK 发布版本, 默认为 1.8.0.332.b09-1.el7_9
+ - __说明__: Linkis服务基础镜像,主要用于预安装 Linkis 系统需要的外部库,初始化系统环境和目录。本镜像不需要经常更新,利用 docker 的镜像缓存机制,可以加速 Linkis 镜像的制作。
+
+### linkis
+ - __Dockerfile__:
+ - 文件名: linkis.Dockerfile
+ - 参数:
+ * LINKIS_VERSION: Linkis 版本号,默认为 0.0.0
+ * LINKIS_SYSTEM_USER: 系统用户,默认为 hadoop
+ * LINKIS_SYSTEM_UID: 系统用户UID, 默认为 9001
+ * LINKIS_HOME: Linkis 主目录,默认为 /opt/linkis , 系统的二进制包和各类脚本会部署到这里
+ * LINKIS_CONF_DIR: Linkis 配置文件目录,默认为 /etc/linkis-conf
+ * LINKIS_LOG_DIR: Linkis 日志目录,默认为 /var/logs/linkis
+ - __说明__: Linkis服务镜像,镜像中包含了 Apache Linkis 的所有组件的二进制包和各类脚本。
+
+### linkis-web
+ - __Dockerfile__:
+ - 文件名: linkis.Dockerfile
+ - 参数:
+ * LINKIS_VERSION: Linkis 版本号,默认为 0.0.0
+ * LINKIS_HOME: Linkis 主目录,默认为 /opt/linkis , Web 相关的包会被放置在 ${LINKIS_HOME}-web 下
+ - __说明__: Linkis Web 控制台镜像,镜像中包含了 Apache Linkis Web 控制台的的二进制包和各类脚本,本镜像使用 nginx 作为 Web 服务器。
+
+### linkis-ldh
+ - __Dockerfile__:
+ - 文件名: ldh.Dockerfile
+ - 参数:
+ * JDK_VERSION: JDK 版本,默认为 1.8.0-openjdk
+ * JDK_BUILD_REVISION: JDK 发布版本, 默认为 1.8.0.332.b09-1.el7_9
+ * LINKIS_VERSION: Linkis 版本号,默认为 0.0.0
+ * MYSQL_JDBC_VERSION: MySQL JDBC 版本,默认为 8.0.28
+ * HADOOP_VERSION: Apache Hadoop 组件版本,默认为 2.7.2
+ * HIVE_VERSION: Apache Hive 组件版本,默认为 2.3.3
+ * SPARK_VERSION: Apache Spark 组件版本,默认为 2.4.3
+ * SPARK_HADOOP_VERSION: 预编译的 Apache Spark 发布包 Hadoop 版本后缀,默认为 2.7,该值不能任意设置,需要和 Apache Spark 官方发布版本保持一致,否则无法自动下载相关组件
+ * FLINK_VERSION: Apache Flink 组件版本,默认为 1.12.2
+ * ZOOKEEPER_VERSION: Apache Zookeeper 组件版本,默认为 3.5.9
+ - __说明__: LDH 是一个面向测试用途的镜像,LDH 镜像提供了一套完整的、伪分布式模式的 Apache Hadoop 运行环境,包含了 HDFS, YARN, HIVE, Spark, Flink 和 Zookeeper, 可以很方便的在开发环境中拉起一个全真的 Hadoop 环境用来测试 Linkis 的功能。LDH 镜像的 ENTRYPOINT 为 `linkis-dist/docker/scripts/entry-point-ldh.sh`,一些初始化操作,如 HDFS 的 format 操作都是在这个脚本中完成的。
+
+### 集成 MySQL JDBC
+
+由于MySQL的许可协议限制,官方发布的 Linkis 镜像没有集成 MySQL JDBC 驱动,用户在使用 Linkis 容器前需要自行将 MySQL JDBC 驱动放置到容器中。为了简化这个过程,我们提供了一个 Dockerfile:
+
+- 文件名: linkis-with-mysql-jdbc.Dockerfile
+- 参数:
+ * LINKIS_IMAGE: Linkis 镜像名,基于这个镜像来制作包含 MySQL JDBC 驱动的自定义镜像, 默认为 `linkis:dev`
+ * LINKIS_HOME: Linkis 主目录,默认为 /opt/linkis
+ * MYSQL_JDBC_VERSION: MySQL JDBC 版本,默认为 8.0.28
+
+## Linkis 镜像制作
+
+> 因为镜像制作过程中使用了一些 Bash 脚本,目前仅支持在 Linux/MaxOS 下完成 Linkis 镜像打包的工作。
+
+### 使用 Maven 构建镜像
+
+Linkis 镜像制作过程都已经集成到项目的 Maven Profile 中,可以通过 Maven 命令实现 Liniks 镜像的制作。
+
+1. 构建 `linkis` 镜像
+
+ ``` shell
+ # 构建不包含 MySQL JDBC 的 Linkis 镜像
+ $> ./mvnw clean install -Pdocker -Dmaven.javadoc.skip=true -Dmaven.test.skip=true
+ # 构建包含 MySQL JDBC 的 Linkis 镜像
+ $> ./mvnw clean install -Pdocker -Dmaven.javadoc.skip=true -Dmaven.test.skip=true -Dlinkis.build.with.jdbc=true
+ ```
+ 需要注意:
+ * `linkis-base` 镜像会在 `linkis` 镜像第一次构建时被构建,后续如果 Dockerfile 没有被修改,将不会被重复构建;
+ * 受制于 Maven POM 文件的语法,`linkis.build.with.jdbc` 是一个伪布尔参数,实际上`-Dlinkis.build.with.jdbc=false`和`-Dlinkis.build.with.jdbc=true`是一样的,如希望表达`-Dlinkis.build.with.jdbc=false`,请直接将这个参数去掉。其他参数类似。
+
+2. 构建 `linkis-web` 镜像
+
+ ``` shell
+ $> ./mvnw clean install -Pdocker -Dmaven.javadoc.skip=true -Dmaven.test.skip=true -Dlinkis.build.web=true
+ ```
+
+3. 构建 `linkis-ldh` 镜像
+
+ ``` shell
+ $> ./mvnw clean install -Pdocker -Dmaven.javadoc.skip=true -Dmaven.test.skip=true -Dlinkis.build.ldh=true
+ ```
+
+ 需要注意:
+ * 在制作本镜像的过程中,我们从 [Apache Archives](https://archive.apache.org/dist/) 这个官方站点下载每个hadoop组件的预建二进制发行版。但是,受制于国内的网络环境,这种方式可能会非常缓慢。如果你有更快的站点,你可以手动从这些站点下载相应的包,并将其移动到如下这个目录`${HOME}/.linkis-build-cache` 来解决这个问题。
+
+上述参数都可以组合使用,如希望一次性构建所有镜像,可以使用如下命令:
+
+``` shell
+$> ./mvnw clean install -Pdocker -Dmaven.javadoc.skip=true -Dmaven.test.skip=true -Dlinkis.build.web=true -Dlinkis.build.ldh=true
+```
+
+### 使用 docker build 命令构建镜像
+
+使用 Maven 命令构建镜像固然方便,但是构建过程中引入了不少重复的编译过程,整个过程比较漫长。如果仅调整镜像内部结构,如目录结构,初始化命令等,可以在第一次使用 Maven 命令构建镜像后,直接使用`docker build` 命令来快速构建镜像进行测试。
+
+使用 `docker build` 命令构建 linkis-ldh 镜像示例如下:
+
+``` shell
+$> docker build -t linkis-ldh:dev --target linkis-ldh -f linkis-dist/docker/ldh.Dockerfile linkis-dist/target
+
+[+] Building 0.2s (19/19) FINISHED
+ => [internal] load build definition from ldh.Dockerfile 0.0s
+ => => transferring dockerfile: 41B 0.0s
+ => [internal] load .dockerignore 0.0s
+ => => transferring context: 2B 0.0s
+ => [internal] load metadata for docker.io/library/centos:7 0.0s
+ => [ 1/14] FROM docker.io/library/centos:7 0.0s
+ => [internal] load build context 0.0s
+ => => transferring context: 1.93kB 0.0s
+ => CACHED [ 2/14] RUN useradd -r -s ... 0.0s
+ => CACHED [ 3/14] RUN yum install -y ... 0.0s
+ ...
+ => CACHED [14/14] RUN chmod +x /usr/bin/start-all.sh 0.0s
+ => exporting to image 0.0s
+ => => exporting layers 0.0s
+ => => writing image sha256:aa3bde0a31bf704413fb75673fc2894b03a0840473d8fe15e2d7f7dd22f1f854 0.0s
+ => => naming to docker.io/library/linkis-ldh:dev
+```
+
+其他镜像的构建命令请参考 `linkis-dist/pom.xml` 中相关的 profile.
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/build.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/build.md
new file mode 100644
index 00000000000..aba12c6c0e1
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/build.md
@@ -0,0 +1,213 @@
+---
+title: 后端编译
+sidebar_position: 3.0
+---
+
+## 1. 前置准备
+
+## 1.1 环境要求
+
+__编译环境要求:__ 必须 **JDK8** 以上,**Oracle/Sun** 和 **OpenJDK**都支持。
+
+
+### 1.2 源码获取
+
+- 方式1:从[github仓库](https://github.com/apache/linkis) https://github.com/apache/linkis 获取项目的源代码。
+- 方式2:从[linkis的官方下载页面](https://linkis.apache.org/download/main) https://linkis.apache.org/download/main 下载所需版本的源码包。
+
+**请注意**:官方推荐使用 Hadoop-2.7.2、Hive-1.2.1、Spark-2.4.3 和 Scala-2.11.12 对 Linkis 进行编译。
+
+如果您想使用 Hadoop、Hive、Spark 的其他版本对 Linkis 进行编译,请参考:[如何修改Linkis的依赖的Hadoop、Hive、Spark版本](#4-如何修改linkis的依赖的hadoophivespark版本)
+
+### 1.2 修改依赖配置
+:::caution 注意
+因为mysql-connector-java驱动是GPL2.0协议,不满足Apache开源协议关于license的政策,因此从1.0.3版本开始,对mysql-connector-java的依赖项作用域scope默认是test,若自行编译,可以修改顶级pom.xml的mysql-connector-java依赖的scope作用域(注释掉即可)
+:::
+```xml
+
+ mysql
+ mysql-connector-java
+ ${mysql.connector.version}
+
+
+```
+
+## 2. 全量编译 Linkis
+
+### step1 首次编译(非首次可跳过此步)
+
+**如果您是本地第一次编译使用,必须在 Linkis 源码工程的根目录先执行以下命令**:
+```bash
+ cd linkis-x.x.x
+ mvn -N install
+```
+
+### step2 执行编译
+在 Linkis 源码包根目录执行以下命令:
+
+```bash
+ cd linkis-x.x.x
+ mvn clean install
+
+```
+
+### step3 获取安装包
+编译后的完整安装包,在工程的linkis-dist->target目录下:
+
+```bash
+ #详细路径如下
+ linkis-x.x.x/linkis-dist/target/apache-linkis-x.x.x-bin.tar.gz
+```
+
+## 3 常见问题
+
+### 3.1 如何编译单个模块
+> 有些场景可能只需要针对某个模块进行编译,可参考如下流程
+
+:::caution 注意
+如有没有执行过全量编译,先要进行一次全量编译
+:::
+
+#### step1 进入到对应模块进行编译
+进入到对应模块进行编译,比如想重新编译 Entrance,命令如下:
+
+```bash
+ cd linkis-x.x.x/linkis-computation-governance/linkis-entrance
+ mvn clean install
+```
+
+#### step2 获取安装包
+获取安装包,在对应模块的->target目录下会有编译好的包:
+
+```
+ ls linkis-x.x.x/linkis-computation-governance/linkis-entrance/target/linkis-entrance.x.x.x.jar
+```
+
+### 3.2 如何编译某个引擎
+
+>有些场景可能只需要针对某个引擎进行编译,可参考如下流程
+
+:::caution 注意
+如有没有执行过全量编译,先要进行一次全量编译
+:::
+
+这里以编译Spark 引擎为例:
+
+#### step1 进入到对应模块进行编译
+进入到 Spark 引擎所在的目录进行编译打包,命令如下:
+
+```bash
+ cd linkis-x.x.x/linkis-engineconn-plugins/spark
+ mvn clean install
+```
+#### step2 获取引擎的物料包
+在对应模块的target目录下:
+
+```
+ #spark文件下就是编译好的引擎物料
+ linkis-x.x.x/linkis-engineconn-plugins/spark/target/out/spark
+```
+如何单独安装 Spark 引擎?请参考 [Linkis 引擎插件安装文档](../deployment/install-engineconn)
+
+
+### 3.2 如何将非默认引擎打包至安装部署包中
+
+> 默认打包配置中`linkis-dist/src/main/assembly/distribution.xml`,只会将`spark/hive/python/shell`打包到安装包中,如果需要添加其它引擎,可参考此步骤
+
+以jdbc引擎为例
+
+step1 修改`linkis-dist/src/main/assembly/distribution.xml` 添加jdbc引擎
+```shell script
+
+
+
+ ../../linkis-engineconn-plugins/jdbc/target/out/
+
+ lib/linkis-engineconn-plugins/
+
+ **/*
+
+
+```
+step2 如果已经全量编译,可以直接重新编译`linkis-dist`模块,如果没有,这执行全量编译
+
+### 3.3 如何在全量编译时跳过指定引擎
+可使用mvn指令中的`-pl`选项,详情可参考如下
+```
+-pl,--projects Comma-delimited list of specified
+ reactor projects to build instead
+ of all projects. A project can be
+ specified by [groupId]:artifactId
+ or by its relative path.
+```
+通过`!`实现反选,从而排除指定的引擎,缩短全量编译所需时间,以flink、sqoop和hive为例,跳过这些引擎进行编译:
+```
+mvn clean install -Dmaven.test.skip=true \
+-pl '!linkis-engineconn-plugins/flink,!linkis-engineconn-plugins/sqoop,!linkis-engineconn-plugins/hive'
+```
+
+## 4. 如何修改Linkis的依赖的Hadoop、Hive、Spark版本
+
+请注意:Hadoop 作为大数据基础服务,Linkis 必须依赖 Hadoop 进行编译;
+而 Spark、Hive等计算存储引擎则不然,如果您不想使用某个引擎,可以无需设置该引擎的版本,无需编译该引擎插件。
+
+具体而言,修改 Hadoop 的版本与 Spark、Hive 等计算引擎的方式不同,下面详细介绍:
+
+### 4.1 如何修改 Linkis 依赖的 Hadoop 版本
+
+进入 Linkis 源码包根目录,手动修改 pom.xml 文件的 Hadoop 版本信息,具体如下:
+
+```bash
+ cd linkis-x.x.x
+ vim pom.xml
+```
+
+```xml
+
+
+ 2.7.2 在这里修改Hadoop版本号 <-->
+ 2.11.12
+ 1.8
+
+
+```
+:::caution 注意
+**请注意:如果你的hadoop版本是hadoop3,需要修改linkis-hadoop-common的pom文件**
+:::
+
+因为在hadoop2.8以下的时候,hdfs相关的class是在hadoop-hdfs模块中的,但是在hadoop 3.X中将对应的class移动到了模块hadoop-hdfs-client当中,您需要修改下这个文件:
+
+pom:Linkis/linkis-commons/linkis-hadoop-common/pom.xml
+修改依赖hadoop-hdfs为hadoop-hdfs-client:
+```
+
+ org.apache.hadoop
+ hadoop-hdfs
+ ${hadoop.version}
+
+ 将hadoop-hdfs修改为:
+
+ org.apache.hadoop
+ hadoop-hdfs-client
+ ${hadoop.version}
+
+```
+
+### 4.2 如何修改 Linkis 依赖的 Spark、Hive 版本
+
+这里以修改 Spark 的版本为例进行介绍。进入 Spark 引擎所在的目录,手动修改 pom.xml 文件的 Spark 版本信息,具体如下:
+
+```bash
+ cd linkis-x.x.x/linkis-engineconn-plugins/spark
+ vim pom.xml
+```
+
+```xml
+
+ 2.4.3 在这里修改Spark版本号 <-->
+
+```
+
+修改其他引擎的版本与修改 Spark 版本类似,先进入相关引擎所在的目录,手动修改 pom.xml 文件的引擎版本信息即可。
+
+然后请参考 [编译某个引擎](#32-如何编译某个引擎)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/config.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/config.md
new file mode 100644
index 00000000000..a0b86b0d18a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/config.md
@@ -0,0 +1,131 @@
+---
+title: 配置参数介绍
+sidebar_position: 11.0
+---
+
+## 1. 参数分类
+
+Linkis参数主要分为以下三个部分:
+- Linkis 服务端参数,主要包含Linkis本身的参数和Spring的参数
+- Linkis SDK、Restful等客户端端调用提交的参数
+- Linkis 管理台参数
+
+
+## 2. Linkis 服务端参数
+
+1. Linkis本身的参数
+linkis本身的参数支持在配置文件里面进行设置,也支持通过环境变量和系统属性进行设置,推荐使用配置文件进行设置。
+Linkis配置文件格式如下所示:
+```shell
+├── conf 配置目录
+│ ├── application-eureka.yml
+│ ├── application-linkis.yml
+│ ├── linkis-cg-engineconnmanager-io.properties
+│ ├── linkis-cg-engineconnmanager.properties
+│ ├── linkis-cg-engineplugin.properties
+│ ├── linkis-cg-entrance.properties
+│ ├── linkis-cg-linkismanager.properties
+│ ├── linkis.properties ──linkis global properties
+│ ├── linkis-ps-bml.properties
+│ ├── linkis-ps-cs.properties
+│ ├── linkis-ps-datasource.properties
+│ ├── linkis-ps-publicservice.properties
+│ ├── log4j2.xml
+```
+每个服务会加载两个属性配置文件,一个为公用的主配置文件linkis.properties,以及服务配置文件linkis-serviceName.properties。设置的优先级为服务配置文件高于主配置文件
+建议通用的参数放置在主配置文件,个性化配置文件放在服务配置文件
+
+2. Spring 参数
+Linkis服务是基于SpringBoot应用的,Spring相关的参数支持在application-linkis.yml进行设置,也支持在linkis配置文件里面进行配置。在linkis配置文件里面配置需要加上spring.的前缀。如下:
+
+```shell
+# spring port default
+server.port=9102
+# in linkis conf need spring prefix
+spring.server.port=9102
+
+```
+
+## 3. Linkis 客户端参数
+Linkis客户端参数主要是指任务提交时的参数,主要在提交接口里面进行指定的参数。
+1.restful 如何设置参数:
+
+```shell
+{
+ "executionContent": {"code": "show tables", "runType": "sql"},
+ "params": { // 提交参数
+ "variable":{ //代码中需要的自定义变量
+ "k1":"v1"
+ },
+ "configuration":{
+ "special":{ //特殊配置参数 如日志路径,结果集路径等
+ "k2":"v2"
+ },
+ "runtime":{ //运行时参数,执行配置参数,如JDBC引擎的的数据库连接参数,presto引擎的数据源参数
+ "k3":"v3"
+ },
+ "startup":{ //启动参数,如启动EC的内存参数,spark引擎参数、hive引擎参数等
+ "k4":"v4" 如:spark.executor.memory:5G 设置Spark的执行器内存,底层Spark、hive等引擎参数keyName是和原生参数一致的
+ }
+ }
+ },
+ "labels": { //标签参数,支持设置引擎版本、用户和提应用
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+2.SDK如何设置参数:
+
+```java
+JobSubmitAction jobSubmitAction = JobSubmitAction.builder()
+ .addExecuteCode(code)
+ .setStartupParams(startupMap) //启动参数,如启动EC的内存参数,spark引擎参数、hive引擎参数等, 如:spark.executor.memory:5G 设置Spark的执行器内存,底层Spark、hive等引擎参数keyName是和原生参数一致的
+ .setRuntimeParams(runTimeMap) //引擎,执行配置参数,如JDBC引擎的的数据库连接参数,presto引擎的数据源参数
+ .setVariableMap(varMap) //代码中需要的自定义变量
+ .setLabels(labels) //标签参数,支持设置引擎版本、用户和提应用等
+ .setUser(user) //submit user
+ .addExecuteUser(user) // execute user
+ .build();
+```
+3.linkis-cli如何设置参数
+
+```shell
+linkis-cli -runtieMap key1=value -runtieMap key2=value
+ -labelMap key1=value
+ -varMap key1=value
+ -startUpMap key1=value
+
+```
+注意: 客户端参数提交时,只有引擎相关参数和标签参数,以及Yarn队列设置可以生效,其他Linkis服务端参数和资源限制参数,如任务和引擎并发参数wds.linkis.rm.instances不支持任务设置
+
+4.常用标签参数:
+
+```shell
+ Map labels = new HashMap();
+ labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "spark-2.4.3"); // 指定引擎类型和版本
+ labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, user + "-IDE");// 指定运行的用户和您的APPName
+ labels.put(LabelKeyConstant.CODE_TYPE_KEY, "sql"); // 指定运行的脚本类型:spark支持:sql、scala、py;Hive:hql;shell:sh;python:python;presto:psql
+ labels.put(LabelKeyConstant.JOB_RUNNING_TIMEOUT_KEY, "10000");//job运行10s没完成自动发起Kill,单位为s
+ labels.put(LabelKeyConstant.JOB_QUEUING_TIMEOUT_KEY, "10000");//job排队超过10s没完成自动发起Kill,单位为s
+ labels.put(LabelKeyConstant.RETRY_TIMEOUT_KEY, "10000");//job因为资源等原因失败重试的等待时间,单位为ms,如因为队列资源不足的失败,会默认按间隔发起10次重试
+ labels.put(LabelKeyConstant.TENANT_KEY,"hduser02");//租户标签,任务如果指定了租户参数则任务会被路由到单独的ECM机器
+ labels.put(LabelKeyConstant.EXECUTE_ONCE_KEY,"");//执行一次标签,该参数不建议设置,设置后引擎不会复用任务运行完就会结束引擎,只有某个任务参数有特殊化的可以进行设置
+```
+
+## 4. Linkis 管理台参数
+Linkis管理台参数时方便用户指定资源限制参数和默认的任务参数提供的Web界面,如下:
+全局配置参数:
+![](/Images/development/linkis_global_conf.png)
+主要包含了全局队列参数[wds.linkis.rm.yarnqueue],任务默认采用的Yarn队列,支持在客户端StartUPMap里面另外进行指定
+资源限制参数,这些参数不支持任务设置,支持管理台进行调整。
+```shell
+队列CPU使用上限[wds.linkis.rm.yarnqueue.cores.max],现阶段只支持限制Spark类型任务总队列资源的使用
+队列内存使用上限[wds.linkis.rm.yarnqueue.memory.max]
+全局各个引擎内存使用上限[wds.linkis.rm.client.memory.max] 该参数不是指总共只能使用的内存,而是指定某个Creator特定引擎总的内存使用,如限制IDE-SPARK任务只能使用10G内存
+全局各个引擎核心个数上限[wds.linkis.rm.client.core.max]该参数不是指总共只能使用的CPU,而是指定某个Creator特定引擎总的内存使用,如限制IDE-SPARK任务只能使用10Cores
+全局各个引擎最大并发数[wds.linkis.rm.instance],该参数有两层含义,一个是限制某个Creator特定引擎总共能启动多少个,以及限制某个Creator特定引擎任务同时能运行的任务数
+```
+引擎配置参数:
+![](/Images/development/linkis_creator_ec_conf.png)
+主要指定引擎的启动参数和运行时参数,这些参数支持在客户端进行设置,建议使用客户端进行个性化提交设置,页面只设置默认值
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/debug-with-helm-charts.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/debug-with-helm-charts.md
new file mode 100644
index 00000000000..349662b6d53
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/debug-with-helm-charts.md
@@ -0,0 +1,500 @@
+---
+title: 容器化开发调试
+sidebar_position: 7.0
+---
+
+## 前言
+
+本文介绍如何使用 Kubernetes 技术来简化 Linkis 项目的开发调试工作。在没有引入 Kubernetes 工具前,调试 Linkis 是一个非常繁琐和复杂的工作,有时候可能需要搭建 Linkis 依赖的 Hadoop 环境。为了改善这个问题,本文使用了另一种方法,利用 Kubernetes 技术在开发机上创建一个 Hadoop 集群并拉起所有 Linkis 服务,这是个分布式的环境,并且可以随时拉起和销毁,开发者通过 JVM 远程调试功能连接这些服务并进行单步调试. 这里我们用到了如下几个技术:
+
+* Docker: 一种容器化技术,用于支创建和使用 Linux 容器;
+* Kubernetes: 一种可自动部署和管理 Linux 容器的开源平台,Kubernetes 还整合了网络、存储、安全性、遥测和其他服务,提供了全面的基于容器的基础设施;
+* KinD: 一个使用Docker容器作为 "Kubernetes节点" 来运行本地 Kubernetes 集群的工具;
+* Helm: Kubernetes 上一个开源的包管理工具, 通过 Helm 命令行工具和安装包(Chart)来管理 Kubernetes 上的用户资源;
+
+## 依赖工具介绍
+
+### 版本要求
+
+* [Docker](https://docs.docker.com/get-docker/), 最低版本 v20.10.8+
+* [Kubernetes](https://kubernetes.io/docs/setup/), 最低版本 v1.21.0+
+* [Helm](https://helm.sh/docs/intro/install/), 最低版本 v3.0.0+.
+* [KinD](https://kind.sigs.k8s.io/docs/user/quick-start/), 最低版本 v0.11.0+.
+
+### Helm Charts 介绍
+
+Helm 是 Kubernetes 上一个开源的包管理工具,Helm 最初的目标是为用户提供一种更好的方式来管理在 Kubernetes 上创建的所有 Kubernetes YAML 文件。Helm 使用 Charts 这个方式来解决上述问题,Chart 是一组文本文件,使用 Helm 模版语言编写,用来描述一个或者多个 Kubernetes 资源文件,Chart 直接依赖或者引用其他 Chart. 在使用 Charts 时,用户需要提供一个 变量文件,Helm 使用这个变量文件中定义的变量来渲染相应的 Chart, 生产 Kubernetes YAML 文件, 然后调用 Kubernetes api 提交到 Kubernetes 上。每一个发布到 Kubernetes 的 Charts 被称为 Release,一个 Chart 通常可以被多次安装到同一个集群中,而每次安装时,都会创建一个新的 Release。
+
+Helm 的安装方式比较简单,请参考官方文档进行安装: [Installing Helm](https://helm.sh/docs/intro/install/)
+
+### KinD 介绍
+
+在本地创建一个 Kubernetes 测试环境是一个非常普遍的需求,Kubernetes 社区提供了多种解决方案,如 MiniKube 或 MicroK8s 等,KinD 是一个相对较新的工具,KinD 是 Kubernetes IN Docker 的缩写,顾名思义,它使用 Docker 托管节点来创建一个面向测试的 Kubernetes 集群。
+
+KinD 系统架构
+
+![](/Images/development/kind-arc.png)
+
+部署 KinD 也非常简单,请参考官方部署文档: [KinD Installation](https://kind.sigs.k8s.io/docs/user/quick-start/#installation), 部署 KinD 前请先安装 Docker .
+
+> ⚠️注意:
+> KinD 是面向测试的用途的工具,不能用于生产部署。同时,KinD 利用 Docker 带来的便利的同时,也引入了一些限制, 比如,开发机重启后,KinD 集群无法继续使用,需要重新创建(因为 KinD 在创建 Node 容器后会进行一系列的初始化工作,这些工作在机器重启后无法自动回复)。
+
+## Linkis 容器化组件
+
+### Linkis 镜像
+
+Linkis 提供了多个镜像,所有镜像的 Dockerfile 和相关脚本都在 `linkis-dist/docker` 目录下。 可以通过 Maven 命令和 `docker build` 命令来制作相应的镜像。Linkis 镜像主要包括如下几个:
+
+* `linkis`: Linkis 服务镜像,镜像中包含了 Apache Linkis 的所有组件的二进制包和各类脚本。
+* `linkis-web`: Linkis Web 控制台镜像,镜像中包含了 Apache Linkis Web 控制台的的二进制包和各类脚本,本镜像使用 nginx 作为 Web 服务器。
+* `linkis-ldh`: LDH 是一个面向测试用途的镜像,LDH 镜像提供了一套完整的、伪分布式模式的 Apache Hadoop 运行环境,包含了 HDFS, YARN, HIVE, Spark, Flink 和 Zookeeper, 可以很方便的在开发环境中拉起一个全真的 Hadoop 环境用来测试 Linkis 的功能。
+
+具体请参考: [Linkis Docker 镜像打包](https://linkis.apache.org/zh-CN/docs/latest/development/linkis_docker_build_instrument).
+
+### Linkis Helm Chart
+
+Linkis Helm Chart 是遵循 Helm Chart 规范开发的 Helm 安装包,在 `linkis-dist/helm` 目录下. 模块目录结构如下:
+
+``` shell
+linkis-dist/helm
+├── charts # Charts 目录, 目前仅包含 Linkis Helm Chart
+│ └── linkis # Linkis Helm Chart 目录
+│ ├── Chart.yaml # - Chart 元数据
+│ ├── templates # - Chart 模版文件,包含了所有 linkis 组件的 Kubernetes YAML 模版
+│ │ ├── NOTES.txt # - Chart 提示信息
+│ │ ├── _helpers.tpl # - Chart 变量辅助模版
+│ │ ├── configmap-init-sql.yaml # - 数据库初始化 SQL 脚本模版
+│ │ ├── configmap-linkis-config.yaml # - Linkis 服务配置文件模版
+│ │ ├── configmap-linkis-web-config.yaml # - Linkis Web 控制台配置文件模版
+│ │ ├── jobs.yaml # - Kubernetes Job 模版,目前仅包括一个数据库初始化作业, 数据库初始化 SQL 脚本会在这个
+| | | # 作业中被执行
+│ │ ├── linkis-cg-engineconnmanager.yaml # - Linkis EngineConnManager 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-cg-engineplugin.yaml # - Linkis EngineConn 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-cg-entrance.yaml # - Linkis Entrance 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-cg-linkismanager.yaml # - Linkis Manager 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-mg-eureka.yaml # - Linkis Eureka 部署模版,是一个 Kubernetes Statefulset 类型的工作负载
+│ │ ├── linkis-mg-gateway.yaml # - Linkis Gateway 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-ps-publicservice.yaml # - Linkis PublicService 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-web.yaml # - Linkis Web Console 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ └── serviceaccount.yaml # - Linkis 相关的 Kubernetes Service Account 模版
+│ └── values.yaml # - Linkis Helm Chart 变量文件,默认提供了 Linkis Local 模式相关的变量
+├── scripts # 一些用于简化开发调试的工具脚本
+│ ├── common.sh # - 公共脚本,定义了一些公共方法和变量
+│ ├── create-kind-cluster.sh # - 创建 KinD 集群
+│ ├── install-charts-with-ldh.sh # - 在 KinD 集群上部署 Linkis 服务,使用 On-LDH 的部署方式, 调用 install-linkis.sh 实现
+│ ├── install-charts.sh # - 在 KinD 集群上部署 Linkis 服务,使用 Local 的部署方式, 调用 install-linkis.sh 实现
+│ ├── install-ldh.sh # - 在 KinD 集群上部署 LDH 部署
+│ ├── install-linkis.sh # - 在 KinD 集群上部署 Linkis 服务,可以为 Local 或者 On-LDH 的模式
+│ ├── install-mysql.sh # - 在 KinD 集群上部署一个 MySQL 实例
+│ ├── login-pod.sh # - 登入一个 Pod,打开 Bash 进行交互
+│ ├── remote-debug-proxy.sh # - 开启 JVM 远程调试代理,开启后,可以在 IDE 上连接相应的端口进行调试
+│ └── resources # - 一些资源文件
+│ ├── kind-cluster.yaml # - KinD 集群配置,默认为单个 Node
+│ ├── ldh # - LDH 相关资源文件
+│ │ ├── configmaps # - LDH 各个组件的配置文件
+│ │ │ ├── configmap-flink.yaml # - Flink 配置文件
+│ │ │ ├── configmap-hadoop.yaml # - Hdfs & Yarn 配置文件
+│ │ │ ├── configmap-hive.yaml # - Hive 配置文件
+│ │ │ ├── configmap-spark.yaml # - Spark 配置文件
+│ │ │ └── configmap-zookeeper.yaml # - Zookeeper 配置文件
+│ │ └── ldh.yaml # - LDH Kubernetes YAML, 用于在 KinD 上部署 LDH 实例
+│ └── mysql.yaml # - MySQL Kubernetes YAML, 用于在 KinD 上部署 MySQL 实例
+
+```
+
+本项目提供了一组工具脚本,用于快速创建一个用于开发测试的 Linkis 环境。在生产部署中,需要根据集群的实际情况,修改 `values.yaml` 文件,再使用 Helm CLI 进行部署。使用 Helm CLI 进行部署时,通常有如下两种比较常见的做法:
+1. 使用 `helm install` 命令直接部署。适用于非定制化的部署方式;
+2. 使用 `helm template` 命令选生成 Kubernetes YAML 文件,然后手动修改这些文件,添加自定义配置,然后使用`kubectl apply`命令进行部署。适用于需要定制 Linkis Helm Charts 不支持的 Kubernetes 特性的高阶用户, 如需要使用特定的 StorageClass 或者 PV 等;
+
+### LDH
+
+LDH 是一个面向测试用途的 Hadoop 集群镜像,它提供了一个伪分布式的 hadoop 集群,方便快速测试 On Hadoop 的部署模式。
+这个镜像包含以下多个 hadoop 组件,LDH 中引擎的默认模式是 on-yarn 的。
+* Hadoop 2.7.2 , 包括 HDFS 和 YARN
+* Hive 2.3.3
+* Spark 2.4.3
+* Flink 1.12.2
+* ZooKeeper 3.5.9
+
+LDH 启动时会进行一些初始化操作,比如 format hdfs, 在 HDFS 上创建初始化目录等,这些操作定义在`linkis-dist/docker/scripts/entry-point-ldh.sh`这个文件中,添加、修改、删除一些初始化操作需要重新制作 LDH 镜像才能生效。
+
+另外,LDH 中的 Hive 组件依赖外部的 MySQL 实例,需要先部署 MySQL 实例才能使用 LDH 中的 Hive 组件。
+
+```shell
+# 创建 KinD 集群,并部署 Linkis 和 LDH 实例
+$> sh ./scripts/create-kind-cluster.sh \
+ && sh ./scripts/install-mysql.sh \
+ && sh ./scripts/install-ldh.sh
+
+# 快速体验 LDH
+$> kubectl exec -it -n ldh $(kubectl get pod -n ldh -o jsonpath='{.items[0].metadata.name}') -- bash
+
+[root@ldh-96bdc757c-dnkbs /]# hdfs dfs -ls /
+Found 4 items
+drwxrwxrwx - root supergroup 0 2022-07-31 02:48 /completed-jobs
+drwxrwxrwx - root supergroup 0 2022-07-31 02:48 /spark2-history
+drwxrwxrwx - root supergroup 0 2022-07-31 02:49 /tmp
+drwxrwxrwx - root supergroup 0 2022-07-31 02:48 /user
+
+[root@ldh-96bdc757c-dnkbs /]# beeline -u jdbc:hive2://ldh.ldh.svc.cluster.local:10000/ -n hadoop
+Connecting to jdbc:hive2://ldh.ldh.svc.cluster.local:10000/
+Connected to: Apache Hive (version 2.3.3)
+Driver: Hive JDBC (version 2.3.3)
+Transaction isolation: TRANSACTION_REPEATABLE_READ
+Beeline version 2.3.3 by Apache Hive
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> create database demo;
+No rows affected (1.306 seconds)
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> use demo;
+No rows affected (0.046 seconds)
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> create table t1 (id int, data string);
+No rows affected (0.709 seconds)
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> insert into t1 values(1, 'linikis demo');
+WARNING: Hive-on-MR is deprecated in Hive 2 and may not be available in the future versions. Consider using a different execution engine (i.e. spark, tez) or using Hive 1.X releases.
+No rows affected (5.491 seconds)
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> select * from t1;
++--------+---------------+
+| t1.id | t1.data |
++--------+---------------+
+| 1 | linikis demo |
++--------+---------------+
+1 row selected (0.39 seconds)
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> !q
+
+[root@ldh-96bdc757c-dnkbs /]# spark-sql
+22/07/31 02:53:18 INFO hive.metastore: Trying to connect to metastore with URI thrift://ldh.ldh.svc.cluster.local:9083
+22/07/31 02:53:18 INFO hive.metastore: Connected to metastore.
+...
+22/07/31 02:53:19 INFO spark.SparkContext: Running Spark version 2.4.3
+22/07/31 02:53:19 INFO spark.SparkContext: Submitted application: SparkSQL::10.244.0.6
+...
+22/07/31 02:53:27 INFO yarn.Client: Submitting application application_1659235712576_0001 to ResourceManager
+22/07/31 02:53:27 INFO impl.YarnClientImpl: Submitted application application_1659235712576_0001
+22/07/31 02:53:27 INFO cluster.SchedulerExtensionServices: Starting Yarn extension services with app application_1659235712576_0001 and attemptId None
+22/07/31 02:53:28 INFO yarn.Client: Application report for application_1659235712576_0001 (state: ACCEPTED)
+...
+22/07/31 02:53:36 INFO yarn.Client: Application report for application_1659235712576_0001 (state: RUNNING)
+...
+Spark master: yarn, Application Id: application_1659235712576_0001
+22/07/31 02:53:46 INFO thriftserver.SparkSQLCLIDriver: Spark master: yarn, Application Id: application_1659235712576_0001
+spark-sql> use demo;
+Time taken: 0.074 seconds
+22/07/31 02:58:02 INFO thriftserver.SparkSQLCLIDriver: Time taken: 0.074 seconds
+spark-sql> select * from t1;
+...
+1 linikis demo
+2 linkis demo spark sql
+Time taken: 3.352 seconds, Fetched 2 row(s)
+spark-sql> quit;
+
+[root@ldh-96bdc757c-dnkbs /]# zkCli.sh
+Connecting to localhost:2181
+Welcome to ZooKeeper!
+JLine support is enabled
+WATCHER::
+
+WatchedEvent state:SyncConnected type:None path:null
+
+[zk: localhost:2181(CONNECTED) 0] get -s /zookeeper/quota
+
+cZxid = 0x0
+ctime = Thu Jan 01 00:00:00 UTC 1970
+mZxid = 0x0
+mtime = Thu Jan 01 00:00:00 UTC 1970
+pZxid = 0x0
+cversion = 0
+dataVersion = 0
+aclVersion = 0
+ephemeralOwner = 0x0
+dataLength = 0
+numChildren = 0
+[zk: localhost:2181(CONNECTED) 1] quit
+
+# 以 per-job cluster 模式启动 Flink 作业
+[root@ldh-96bdc757c-dnkbs /]# HADOOP_CLASSPATH=`hadoop classpath` flink run -t yarn-per-job /opt/ldh/current/flink/examples/streaming/TopSpeedWindowing.jar
+# 以 session 模式启动 Flink 作业,
+# Flink session 在 LDH Pod 启动时会被启动了一个.
+[root@ldh-96bdc757c-dnkbs /]# flink run /opt/ldh/current/flink/examples/streaming/TopSpeedWindowing.jar
+Executing TopSpeedWindowing example with default input data set.
+Use --input to specify file input.
+Printing result to stdout. Use --output to specify output path.
+...
+```
+
+### KinD 集群
+
+Linkis 项目默认使用的 KinD 集群描述文件是`linkis-dist/helm/scripts/resources/kind-cluster.yaml`, 默认会创建一个包含一个节点的 KinD 集群。打开文件中注释的内容可以添加多个节点。
+
+> ⚠️注意,KinD 集群仅用于测试用途。
+
+``` yaml
+# linkis-dist/helm/scripts/resources/kind-cluster.yaml
+kind: Cluster
+apiVersion: kind.x-k8s.io/v1alpha4
+nodes:
+ - role: control-plane
+ extraMounts:
+ - hostPath: ${KIND_CLUSTER_HOST_PATH} # 指向开发机上的一个目录。这个目录会被映射到 Kind Node 容器中的 `/data` 目录,
+ # Linkis Helm Charts 默认会使用这个目录作为数据目录挂载到各个 Linkis 组件的
+ # Pod 中。当 Linkis 使用 Local 模式进行部署时,所有组件实际上使用了开发机上的
+ # 同一个目录,就和在同一台机器上一样,从而模拟了 Local 模式的行为。当使用
+ # On-Hadoop 模式进行部署时,这个目录不会被使用。
+ containerPath: /data
+# - role: worker # 打开注释可以添加2个 KinD 节点。添加 KinD 节点会增加加载 Docker 镜像到 KinD
+# # 集群的时间,所以默认不打开。
+# extraMounts:
+# - hostPath: ${KIND_CLUSTER_HOST_PATH}
+# containerPath: /data
+# - role: worker
+# extraMounts:
+# - hostPath: ${KIND_CLUSTER_HOST_PATH}
+# containerPath: /data
+
+```
+
+## 使用 Linkis 容器化组件开发调试
+
+下面介绍使用 Linkis 容器化组件开发调试的步骤(目前仅支持 Linux 和 MacOS)。在进行本步骤前请确认如下事项:
+1. 开发机上是否已经安装了 Docker 引擎
+2. 开发机上是否已经安装了 Helm
+3. 开发机上是否已经安装了 KinD
+4. 是否已经按照 [Linkis Docker 镜像打包](https://linkis.apache.org/zh-CN/docs/latest/development/linkis_docker_build_instrument) 所述的方式制作了 Linkis 镜像
+
+### 创建调试环境
+
+本步骤会创建一个 KinD 集群,并在其上部署 MySQL、 Linkis 和 LDH 实例。
+
+``` shell
+$> cd linkis-dist/helm
+$> sh ./scripts/create-kind-cluster.sh \
+> && sh ./scripts/install-mysql.sh \
+> && sh ./scripts/install-ldh.sh \
+> && sh ./scripts/install-charts-with-ldh.sh
+
+# Creating KinD cluster ...
+- kind cluster config: /var/folders/9d/bb6ggdm177j25q40yf5d50dm0000gn/T/kind-XXXXX.Fc2dFJbG/kind-cluster.yaml
+...
+kind: Cluster
+apiVersion: kind.x-k8s.io/v1alpha4
+nodes:
+ - role: control-plane
+ extraMounts:
+ - hostPath: /var/folders/9d/bb6ggdm177j25q40yf5d50dm0000gn/T/kind-XXXXX.Fc2dFJbG/data
+ containerPath: /data
+...
+Creating cluster "test-helm" ...
+ ✓ Ensuring node image (kindest/node:v1.21.1) 🖼
+ ✓ Preparing nodes 📦
+ ✓ Writing configuration 📜
+ ✓ Starting control-plane 🕹️
+ ✓ Installing CNI 🔌
+ ✓ Installing StorageClass 💾
+Set kubectl context to "kind-test-helm"
+You can now use your cluster with:
+
+kubectl cluster-info --context kind-test-helm
+
+Have a nice day! 👋
+# Loading MySQL image ...
+Image: "mysql:5.7" with ID "sha256:3147495b3a5ce957dee2319099a8808c1418e0b0a2c82c9b2396c5fb4b688509" not yet present on node "test-helm-control-plane", loading...
+# Deploying MySQL ...
+namespace/mysql created
+service/mysql created
+deployment.apps/mysql created
+# LDH version: dev
+# Loading LDH image ...
+Image: "linkis-ldh:dev" with ID "sha256:aa3bde0a31bf704413fb75673fc2894b03a0840473d8fe15e2d7f7dd22f1f854" not yet present on node "test-helm-control-plane", loading...
+# Deploying LDH ...
+namespace/ldh created
+configmap/flink-conf created
+configmap/hadoop-conf created
+configmap/hive-conf created
+configmap/spark-conf created
+configmap/zookeeper-conf created
+service/ldh created
+deployment.apps/ldh created
+# Loading Linkis image ...
+Image: "linkis:dev" with ID "sha256:0dfa7882c4216305a80cf57efa8cfb483d006bae5ba931288ffb8025e1db4e58" not yet present on node "test-helm-control-plane", loading...
+Image: "linkis-web:dev" with ID "sha256:1dbe0e9319761dbe0e93197665d38077cb2432b8b755dee834928694875c8a22" not yet present on node "test-helm-control-plane", loading...
+# Installing linkis, image tag=dev,local mode=false ...
+NAME: linkis-demo
+NAMESPACE: linkis
+STATUS: deployed
+REVISION: 1
+TEST SUITE: None
+NOTES:
+...
+
+---
+Welcome to Apache Linkis (v1.3.0)!
+
+.___ .___ .______ .____/\ .___ .________
+| | : __|: \ : / \: __|| ___/
+| | | : || ||. ___/| : ||___ \
+| |/\ | || | || \ | || /
+| / \| ||___| || \| ||__:___/
+|______/|___| |___||___\ /|___| : v1.3.0
+ \/
+
+Linkis builds a layer of computation middleware between upper applications and underlying engines.
+Please visit https://linkis.apache.org/ for details.
+
+Enjoy!
+configmap/flink-conf created
+configmap/hadoop-conf created
+configmap/hive-conf created
+configmap/spark-conf created
+configmap/zookeeper-conf created
+
+$> kubectl get pods -n ldh -o wide
+NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
+ldh-6648554447-ml2bn 1/1 Running 0 6m25s 10.244.0.6 test-helm-control-plane
+
+$> kubectl get pods -n linkis -o wide
+NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
+init-db-bcp85 0/1 Completed 0 4m52s 10.244.0.14 test-helm-control-plane
+linkis-demo-cg-engineconnmanager-659bf85689-ddvhw 1/1 Running 1 4m52s 10.244.0.7 test-helm-control-plane
+linkis-demo-cg-engineplugin-98bd6945-tsgjl 1/1 Running 1 4m52s 10.244.0.10 test-helm-control-plane
+linkis-demo-cg-entrance-858f74c868-xrd82 1/1 Running 0 4m52s 10.244.0.12 test-helm-control-plane
+linkis-demo-cg-linkismanager-6f96f69b8b-ns6st 1/1 Running 0 4m52s 10.244.0.11 test-helm-control-plane
+linkis-demo-mg-eureka-0 1/1 Running 0 4m52s 10.244.0.13 test-helm-control-plane
+linkis-demo-mg-gateway-68ddb8c547-xgvhn 1/1 Running 0 4m52s 10.244.0.15 test-helm-control-plane
+linkis-demo-ps-publicservice-6bbf99fcd7-sc922 1/1 Running 0 4m52s 10.244.0.8 test-helm-control-plane
+linkis-demo-web-554bd7659f-nmdjl 1/1 Running 0 4m52s 10.244.0.9 test-helm-control-plane
+
+```
+
+### 调试组件
+
+#### 打开端口转发
+
+每个组件在容器内的 JVM 远程调试端口均为 5005, 这些端口会被映射到宿主机上的不同端口,具体如下:
+* mg-eureka: 5001
+* mg-gateway: 5002
+* ps-publicservice: 5004
+* cg-linkismanager: 5007
+* cg-entrance: 5008
+* cg-engineconnmanager: 5009
+* cg-engineplugin: 5010
+
+另外,Web Console 会被映射到宿主机上的 8087 端口,可以在浏览器上输入`http://localhost:8087`进行访问.
+
+``` shell
+$> ./scripts/remote-debug-proxy.sh start
+- starting port-forwad for [web] with mapping [local->8087:8087->pod] ...
+- starting port-forwad for [mg-eureka] with mapping [local->5001:5005->pod] ...
+- starting port-forwad for [mg-gateway] with mapping [local->5002:5005->pod] ...
+- starting port-forwad for [ps-publicservice] with mapping [local->5004:5005->pod] ...
+- starting port-forwad for [cg-linkismanager] with mapping [local->5007:5005->pod] ...
+- starting port-forwad for [cg-entrance] with mapping [local->5008:5005->pod] ...
+- starting port-forwad for [cg-engineconnmanager] with mapping [local->5009:5005->pod] ...
+- starting port-forwad for [cg-engineplugin] with mapping [local->5010:5005->pod] ..
+
+$> ./scripts/remote-debug-proxy.sh list
+user 10972 0.0 0.1 5052548 31244 s001 S 12:57AM 0:00.10 kubectl port-forward -n linkis pod/linkis-demo-cg-engineplugin-98bd6945-tsgjl 5010:5005 --address=0.0.0.0
+user 10970 0.0 0.1 5053060 30988 s001 S 12:57AM 0:00.12 kubectl port-forward -n linkis pod/linkis-demo-cg-engineconnmanager-659bf85689-ddvhw 5009:5005 --address=0.0.0.0
+user 10968 0.0 0.1 5054084 30428 s001 S 12:57AM 0:00.10 kubectl port-forward -n linkis pod/linkis-demo-cg-entrance-858f74c868-xrd82 5008:5005 --address=0.0.0.0
+user 10966 0.0 0.1 5053316 30620 s001 S 12:57AM 0:00.11 kubectl port-forward -n linkis pod/linkis-demo-cg-linkismanager-6f96f69b8b-ns6st 5007:5005 --address=0.0.0.0
+user 10964 0.0 0.1 5064092 31152 s001 S 12:57AM 0:00.10 kubectl port-forward -n linkis pod/linkis-demo-ps-publicservice-6bbf99fcd7-sc922 5004:5005 --address=0.0.0.0
+user 10962 0.0 0.1 5051012 31244 s001 S 12:57AM 0:00.12 kubectl port-forward -n linkis pod/linkis-demo-mg-gateway-68ddb8c547-xgvhn 5002:5005 --address=0.0.0.0
+user 10960 0.0 0.1 5053060 31312 s001 S 12:57AM 0:00.13 kubectl port-forward -n linkis pod/linkis-demo-mg-eureka-0 5001:5005 --address=0.0.0.0
+
+...
+
+# 在调试完成后,可以使用如下命令停止端口转发
+$> ./scripts/remote-debug-proxy.sh stop
+- stopping port-forward for [web] with mapping [local->8087:8087->pod] ...
+- stopping port-forward for [mg-eureka] with mapping [local->5001:5005->pod] ...
+- stopping port-forward for [mg-gateway] with mapping [local->5002:5005->pod] ...
+- stopping port-forward for [ps-publicservice] with mapping [local->5004:5005->pod] ...
+- stopping port-forward for [cg-linkismanager] with mapping [local->5007:5005->pod] ...
+- stopping port-forward for [cg-entrance] with mapping [local->5008:5005->pod] ...
+- stopping port-forward for [cg-engineconnmanager] with mapping [local->5009:5005->pod] ...
+- stopping port-forward for [cg-engineplugin] with mapping [local->5010:5005->pod] ...
+```
+
+#### 配置 IDE 进行远程调试
+
+在 IDE 上进行如下配置,开启远程调试:
+
+![](/Images/development/kube-jvm-remote-debug.png)
+
+开启远程调试
+![](/Images/development/kube-jvm-remote-debug-start.png)
+
+设置断点,提交一个作业,进行调试
+
+``` shell
+$> ./scripts/login-pod.sh mg-gateway
+
+- login [mg-gateway]'s bash ...
+bash-4.2$ ./bin/./linkis-cli -engineType shell-1 -codeType shell -code "echo \"hello\" " -submitUser hadoop -proxyUser hadoop
+=====Java Start Command=====
+exec /etc/alternatives/jre/bin/java -server -Xms32m -Xmx2048m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/linkis/logs/linkis-cli -XX:ErrorFile=/opt/linkis/logs/linkis-cli/ps_err_pid%p.log -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFraction=80 -XX:+DisableExplicitGC -classpath /opt/linkis/conf/linkis-cli:/opt/linkis/lib/linkis-computation-governance/linkis-client/linkis-cli/*:/opt/linkis/lib/linkis-commons/public-module/*: -Dconf.root=/etc/linkis-conf -Dconf.file=linkis-cli.properties -Dlog.path=/opt/linkis/logs/linkis-cli -Dlog.file=linkis-client..log.20220925171540947077800 org.apache.linkis.cli.application.LinkisClientApplication '-engineType shell-1 -codeType shell -code echo "hello" -submitUser hadoop -proxyUser hadoop'
+...
+```
+![](/Images/development/kube-jvm-remote-debug-breakpoint.png)
+
+
+### 清理环境
+
+调试完成后,可以使用如下命令清理整个环境:
+
+``` shell
+$> kind delete clusters test-helm
+Deleted clusters: ["test-helm"]
+```
+
+### 其他常用操作
+
+#### 查看组件日志
+
+``` bash
+$> kubectl logs -n linkis linkis-demo-cg-engineconnmanager-659bf85689-ddvhw -f
+
++ RUN_IN_FOREGROUND=true
++ /opt/linkis/sbin/linkis-daemon.sh start cg-engineconnmanager
+Start to check whether the cg-engineconnmanager is running
+Start server, startup script: /opt/linkis/sbin/ext/linkis-cg-engineconnmanager
+=====Java Start Command=====
+java -DserviceName=linkis-cg-engineconnmanager -Xmx512M -XX:+UseG1GC -Xloggc:/var/logs/linkis/linkis-cg-engineconnmanager-gc.log -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -cp /etc/linkis-conf:/opt/linkis/lib/linkis-commons/public-module/*:/opt/linkis/lib/linkis-computation-governance/linkis-cg-engineconnmanager/* org.apache.linkis.ecm.server.LinkisECMApplication --eureka.instance.prefer-ip-address=true --eureka.instance.instance-id=${spring.cloud.client.ip-address}:${spring.application.name}:${server.port} 2>&1
+OpenJDK 64-Bit Server VM warning: If the number of processors is expected to increase from one, then you should configure the number of parallel GC threads appropriately using -XX:ParallelGCThreads=N
+Listening for transport dt_socket at address: 5005
+16:32:41.101 [main] INFO org.apache.linkis.common.conf.BDPConfiguration$ - ******************* Notice: The Linkis configuration file is linkis.properties ! *******************
+16:32:41.130 [main] INFO org.apache.linkis.common.conf.BDPConfiguration$ - *********************** Notice: The Linkis serverConf file is linkis-cg-engineconnmanager.properties ! ******************
+16:32:41.222 [main] INFO org.apache.linkis.LinkisBaseServerApp - Ready to start linkis-cg-engineconnmanager with args: --eureka.instance.prefer-ip-address=true
+--eureka.instance.instance-id=${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}
+...
+```
+
+#### 进入组件 Pod 内
+使用`./scripts/login-pod.sh <组件名>`可以进入组件的 Pod 打开一个 Bash 实例进行交互式操作,其中组件名可以为:
+* cg-engineconnmanager
+* cg-engineplugin
+* cg-entrance
+* cg-linkismanager
+* mg-eureka
+* mg-gateway
+* ps-publicservice
+* web
+
+``` bash
+$> ./scripts/login-pod.sh cg-engineconnmanager
+- login [cg-engineconnmanager]'s bash ...
+bash-4.2$ pwd
+/opt/linkis
+bash-4.2$ env |grep LINKIS
+LINKIS_DEMO_PS_PUBLICSERVICE_SERVICE_HOST=127.0.0.1
+LINKIS_DEMO_CG_LINKISMANAGER_PORT_9101_TCP_PROTO=tcp
+LINKIS_DEMO_WEB_PORT_8087_TCP_PORT=8087
+...
+LINKIS_CLIENT_CONF_DIR=/etc/linkis-conf
+bash-4.2$ ps aux |grep linkis
+hadoop 1 0.0 0.0 11708 2664 ? Ss 16:32 0:00 /bin/bash /opt/linkis/sbin/linkis-daemon.sh start cg-engineconnmanager
+hadoop 10 0.0 0.0 11708 2624 ? S 16:32 0:00 sh /opt/linkis/sbin/ext/linkis-cg-engineconnmanager
+hadoop 11 0.0 0.0 11712 2536 ? S 16:32 0:00 sh /opt/linkis/sbin/ext/linkis-common-start
+hadoop 12 4.0 3.2 4146404 400084 ? Sl 16:32 0:35 java -DserviceName=linkis-cg-engineconnmanager -Xmx512M -XX:+UseG1GC -Xloggc:/var/logs/linkis/linkis-cg-engineconnmanager-gc.log -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -cp /etc/linkis-conf:/opt/linkis/lib/linkis-commons/public-module/*:/opt/linkis/lib/linkis-computation-governance/linkis-cg-engineconnmanager/* org.apache.linkis.ecm.server.LinkisECMApplication --eureka.instance.prefer-ip-address=true --eureka.instance.instance-id=${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}
+bash-4.2$ exit
+exit
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/debug.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/debug.md
new file mode 100644
index 00000000000..63a527a3c6f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/debug.md
@@ -0,0 +1,481 @@
+---
+title: 调试 Debug 指引
+sidebar_position: 6.0
+---
+
+> 导语:本文详细记录了如何在IDEA中配置和启动Linkis的各个微服务,并实现JDBC、Python、Shell等脚本的提交和执行。在Mac OS上,Linkis的各个微服务都支持本地调试。
+> 但在Windows OS上,linkis-cg-engineconnmanager服务暂不支持在本地进行调试,可参考下文第4小节的远程调试文档进行调试。
+
+linkis 1.0.3版本前,还未进入apache孵化,组织还是归属webank,主类的包名为`com.webank.wedatasphere.linkis`,调试时,注意区分。
+
+## 1. 代码调试环境
+
+- jdk1.8
+- maven3.5+
+
+## 2. 准备代码并编译
+
+```shell
+git clone git@github.com:apache/linkis.git
+cd linkis
+git checkout dev-1.2.0
+```
+
+克隆Linkis的源码到本地,并用IDEA打开,首次打开项目会从maven仓库中下载Linkis项目编译所需的依赖jar包。当依赖jar包加载完毕之后,运行如下编译打包命令。
+
+```shell
+##如果对应版本已经发布,则可以跳过该步骤。发布的版本相关依赖已经deploy到maven中央仓库
+mvn -N install
+mvn clean install -DskipTests
+```
+
+编译命令运行成功之后,在目录linkis/linkis-dist/target/下可找到编译好的安装包:apache-linkis-版本号-bin.tar.gz
+
+## 3. 配置并启动服务
+
+### 3.1 add mysql-connector-java到classpath中
+
+服务启动过程中如果遇到mysql驱动类找不到的情况,可以把mysql-connector-java-版本号.jar添加到对应服务模块的classpath下。
+
+目前依赖mysql的服务有和对应的pom.xml路径如下:
+
+- linkis-mg-gateway:linkis-spring-cloud-services/linkis-service-gateway/linkis-gateway-server-support/pom.xml
+- linkis-ps-publicservice:linkis-public-enhancements/pom.xml
+- linkis-cg-linkismanage:linkis-computation-governance/linkis-manager/linkis-application-manager/pom.xml
+- linkis-cg-engineplugin: linkis-computation-governance/linkis-engineconn/linkis-engineconn-plugin-server/pom.xml
+
+增加到依赖的方式如下,修改对应服务的pom.xml文件讲mysql依赖加入进去,
+```xml
+
+ mysql
+ mysql-connector-java
+ ${mysql.connector.version}
+
+```
+同时需要留意 根pom.xml的``中是否将mysql-connector-java依赖的scope设置为test,如是,本地调试时需要注释掉
+
+### 3.2 调整log4j2.xml配置
+
+在Linkis源码文件夹下,子目录linkis-dist/package/conf中,是Linkis的一些默认配置文件,首先对log4j2.xml文件进行编辑,在其中增加日志输出到控制台的配置。
+
+![log4j2.xml](/Images/development/debug/log4j.png)
+
+这里只贴出来需要新增的配置内容。
+
+```xml
+
+
+
+
+
+
+
+
+
+
+
+
+
+```
+__注意:__ linkis.properties需要修改对应的jdbc的参数
+
+### 3.3 启动eureka服务
+
+Linkis的服务依赖Eureka作为注册中心,所以我们需要首先启动Eureka服务,Eureka服务可以在本地启动,也可以使用远程启动的服务。保证各个服务都能访问到Eureka的IP和端口之后,就可以开始着手启动其他微服务了。
+
+在Linkis内部是通过-DserviceName参数设置应用名以及使用配置文件,所以-DserviceName是必须要指定的VM启动参数。
+
+可以通过 “-Xbootclasspath/a:配置文件路径”命令,将配置文件追加到引导程序类的路径末尾,即将依赖的配置文件加到classpath中。
+
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+
+![eureka](/Images/development/debug/eureka.png)
+
+参数解释:
+
+```shell
+[service name]
+linkis-mg-eureka
+
+[Use classpath of module]
+linkis-eureka
+
+[Main Class]
+org.apache.linkis.eureka.SpringCloudEurekaApplication
+
+[VM Opitons]
+-DserviceName=linkis-mg-eureka -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf
+
+[Program arguments]
+--spring.profiles.active=eureka --eureka.instance.preferIpAddress=true
+```
+
+注意调试配置中涉及到的本地路径,需要要修改成自己设置的路径;
+在Windows中路径书写规则是:D:\{YourPathPrefix}\linkis\linkis-dist\package\conf
+(针对以下微服务同样适用)
+
+如果不想默认的20303端口可以修改端口配置:
+
+```shell
+文件路径:conf/application-eureka.yml
+修改端口:
+server:
+ port: 8080 ##启动的端口
+```
+
+上述设置完成之后,直接运行此Application,成功启动后可以通过http://localhost:20303/ 查看eureka服务列表。
+
+![eureka-web](/Images/development/debug/eureka-web.png)
+
+### 3.4 启动linkis-mg-gateway
+
+linkis-mg-gateway是Linkis的服务网关,所有的请求都会经由gateway来转发到对应的服务上。
+启动服务器前,首先需要编辑conf/linkis-mg-gateway.properties配置文件,增加管理员用户名和密码,用户名需要与你当前登录的mac用户名保持一致。
+
+```properties
+wds.linkis.admin.user=leojie
+wds.linkis.admin.password=123456
+```
+
+设置 linkis-mg-gateway的启动Application
+
+![gateway-app](/Images/development/debug/gateway.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-mg-gateway
+
+[Use classpath of module]
+linkis-gateway-server-support
+
+[VM Opitons]
+-DserviceName=linkis-mg-gateway -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf
+
+[main Class]
+org.apache.linkis.gateway.springcloud.LinkisGatewayApplication
+```
+
+上述设置完成之后,可直接运行此Application。
+
+### 3.5 启动linkis-ps-publicservice
+
+publicservice是Linkis的公共增强服务,为其他微服务模块提供统一配置管理、上下文服务、物料库、数据源管理、微服务管理和历史任务查询等功能的模块。
+
+设置linkis-ps-publicservice的启动Application
+
+![publicservice-app](/Images/development/debug/publicservice.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-ps-publicservice
+
+[Module Name]
+linkis-public-enhancements
+
+[VM Opitons]
+-DserviceName=linkis-ps-publicservice -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf
+
+[main Class]
+org.apache.linkis.filesystem.LinkisPublicServiceApp
+
+[Add provided scope to classpath]
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+```
+
+直接启动publicservice时,可能会遇到如下报错:
+
+![publicservice-debug-error](/Images/development/debug/publicservice-debug-error.png)
+
+需要把公共依赖的模块加到linkis-public-enhancements模块的classpath下,修改pes的pom增加以下依赖:
+linkis-public-enhancements/pom.xml
+```xml
+
+ org.apache.linkis
+ linkis-dist
+ ${project.version}
+
+
+
+ mysql
+ mysql-connector-java
+ ${mysql.connector.version}
+
+
+```
+
+做完上述配置后重新启动publicservice的Application
+
+### 3.6 启动linkis-cg-linkismanager
+
+![cg-linkismanager-APP](/Images/development/debug/cg-linkismanager-APP.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-cg-linkismanager
+
+[Use classpath of module]
+linkis-application-manager
+
+[VM Opitons]
+-DserviceName=linkis-cg-linkismanager -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf
+
+[main Class]
+org.apache.linkis.manager.am.LinkisManagerApplication
+
+[Add provided scope to classpath]
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+```
+
+### 3.7 启动linkis-cg-entrance
+
+![cg-entrance-APP](/Images/development/debug/cg-entrance-APP.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-cg-entrance
+
+[Use classpath of module]
+linkis-entrance
+
+[VM Opitons]
+-DserviceName=linkis-cg-entrance -Xbootclasspath/a:D:\yourDir\linkis\linkis-dist\package\conf
+
+[main Class]
+org.apache.linkis.entrance.LinkisEntranceApplication
+
+[Add provided scope to classpath]
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+```
+
+### 3.8 启动linkis-cg-engineconnmanager
+
+![engineconnmanager-app](/Images/development/debug/engineconnmanager-app.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-cg-engineconnmanager
+
+[Use classpath of module]
+linkis-engineconn-manager-server
+
+[VM Opitons]
+-DserviceName=linkis-cg-engineconnmanager -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf -DJAVA_HOME=/Library/Java/JavaVirtualMachines/zulu-8.jdk/Contents/Home/
+
+[main Class]
+org.apache.linkis.ecm.server.LinkisECMApplication
+
+[Add provided scope to classpath]
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+```
+
+-DJAVA_HOME是为了指定ecm启动引擎时所使用的java命令所在的路径,如果你默认JAVA环境变量中的版本满足需要,此配置可以不加
+
+针对linkis-cg-engineconnmanager模块调试暂只支持Mac OS 和 Linux系统
+
+
+
+
+### 3.9 关键配置修改
+
+以上操作只是完成了对Linkis各个微服务启动Application的配置,除此之外,Linkis服务启动时所加载的配置文件中,有些关键配置也需要做针对性地修改,否则启动服务或脚本执行的过程中会遇到一些报错。关键配置的修改归纳如下:
+
+#### 3.9.1 conf/linkis.properties
+
+```properties
+# linkis底层数据库连接参数配置
+wds.linkis.server.mybatis.datasource.url=jdbc:mysql://yourip:3306/linkis?characterEncoding=UTF-8
+wds.linkis.server.mybatis.datasource.username=your username
+wds.linkis.server.mybatis.datasource.password=your password
+
+# 设置bml物料存储路径不为hdfs
+wds.linkis.bml.is.hdfs=false
+wds.linkis.bml.local.prefix=/Users/leojie/software/linkis/data/bml
+
+wds.linkis.home=/Users/leojie/software/linkis
+
+# 设置管理员用户名,你的本机用户名
+wds.linkis.governance.station.admin=leojie
+
+# 设置ip地址优先
+linkis.discovery.prefer-ip-address=true
+
+# 设置ec调试启用
+wds.linkis.engineconn.debug.enable=true
+```
+
+在配置linkis底层数据库连接参数之前,请创建linkis数据库,并运行linkis-dist/package/db/linkis_ddl.sql和linkis-dist/package/db/linkis_dml.sql来初始化所有表和数据。
+
+其中wds.linkis.home={YourPathPrefix}/linkis的目录结构如下,里面只放置了lib目录和conf目录。引擎进程启动时会把wds.linkis.home中的conf和lib路径,加到classpath下,如果wds.linkis.home不指定,可能会遇到目录找不到的异常。
+
+![linkis-home](/Images/development/debug/linkis-home.png)
+
+#### 3.9.2 conf/linkis-cg-entrance.properties
+
+```properties
+# entrance服务执行任务的日志目录
+wds.linkis.entrance.config.log.path=file:///{YourPathPrefix}/linkis/data/entranceConfigLog
+
+# 结果集保存目录,本机用户需要读写权限
+wds.linkis.resultSet.store.path=file:///{YourPathPrefix}/linkis/data/resultSetDir
+```
+
+#### 3.9.3 conf/linkis-cg-engineconnmanager.properties
+
+```properties
+wds.linkis.engineconn.root.dir={YourPathPrefix}/linkis/data/engineconnRootDir
+```
+
+不修改可能会遇到路径不存在异常。
+
+#### 3.9.4 conf/linkis-cg-engineplugin.properties
+
+```properties
+wds.linkis.engineconn.home={YourPathPrefix}/linkis/linkis-engineconn-plugins/shell/target/out
+
+wds.linkis.engineconn.plugin.loader.store.path={YourPathPrefix}/linkis/linkis-engineconn-plugins/shell/target/out
+```
+
+这里两个配置主要为了指定引擎存储的根目录,指定为target/out的主要目的是,引擎相关代码或配置改动后可以直接重启engineplugin服务后生效。
+
+### 3.10 为当前用户设置sudo免密
+
+引擎拉起时需要使用sudo来执行启动引擎进程的shell命令,mac上当前用户使用sudo时一般都需要输入密码,因此,需要为当前用户设置sudo免密,设置方法如下:
+
+```shell
+sudo chmod u-w /etc/sudoers
+sudo visudo
+将#%admin ALL=(ALL) AL替换为 %admin ALL=(ALL) NOPASSWD: ALL
+保存文件退出
+```
+
+### 3.11 服务测试
+
+保证上述服务都是成功启动状态,然后在postman中测试提交运行shell脚本作业。
+
+首先访问登录接口来生成Cookie:
+
+![login](/Images/development/debug/login.png)
+
+然后提交执行shell代码
+
+POST: http://127.0.0.1:9001/api/rest_j/v1/entrance/submit
+
+body参数:
+
+```json
+{
+ "executionContent": {
+ "code": "echo 'hello'",
+ "runType": "shell"
+ },
+ "params": {
+ "variable": {
+ "testvar": "hello"
+ },
+ "configuration": {
+ "runtime": {},
+ "startup": {}
+ }
+ },
+ "source": {
+ "scriptPath": "file:///tmp/hadoop/test.sql"
+ },
+ "labels": {
+ "engineType": "shell-1",
+ "userCreator": "leojie-IDE"
+ }
+}
+```
+
+执行结果:
+
+```json
+{
+ "method": "/api/entrance/submit",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "taskID": 1,
+ "execID": "exec_id018017linkis-cg-entrance127.0.0.1:9104IDE_leojie_shell_0"
+ }
+}
+```
+
+最后检查任务运行状态和获取运行结果集:
+
+GET http://127.0.0.1:9001/api/rest_j/v1/entrance/exec_id018017linkis-cg-entrance127.0.0.1:9104IDE_leojie_shell_0/progress
+
+```json
+{
+ "method": "/api/entrance/exec_id018017linkis-cg-entrance127.0.0.1:9104IDE_leojie_shell_0/progress",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "progress": 1,
+ "progressInfo": [],
+ "execID": "exec_id018017linkis-cg-entrance127.0.0.1:9104IDE_leojie_shell_0"
+ }
+}
+```
+
+GET http://127.0.0.1:9001/api/rest_j/v1/jobhistory/1/get
+
+GET http://127.0.0.1:9001/api/rest_j/v1/filesystem/openFile?path=file:///Users/leojie/software/linkis/data/resultSetDir/leojie/linkis/2022-07-16/214859/IDE/1/1_0.dolphin
+
+```json
+{
+ "method": "/api/filesystem/openFile",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "metadata": "NULL",
+ "totalPage": 0,
+ "totalLine": 1,
+ "page": 1,
+ "type": "1",
+ "fileContent": [
+ [
+ "hello"
+ ]
+ ]
+ }
+}
+```
+
+## 4. 远程调试服务指引
+
+根据需要调试的代码位置,确定其所属的服务,使用启动脚本`linkis-daemon.sh`,启动时针对该服务设置远程调试端口。
+
+### 4.1 确认要调试的包所在的服务
+
+根据需要调试的代码位置,确定其所属的服务(如果不确定服务名称,在 ${LINKIS_HOME}/sbin/linkis-start-all.sh 内查询)
+
+### 4.2 重启需要调试的服务
+
+进入{LINKIS_HOME}/sbin目录,在启动命令中添加debug参数,指定远程调试端口。
+
+```shell
+sh linkis-daemon.sh restart ps-publicservice debug-5005
+```
+观察输出的启动命令,是否包含`-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005`,包含则说明添加远程调试端口成功。
+
+### 4.3 编译器配置远程调试
+
+如下图所示打开窗口并配置远程调试的端口,服务,以及模块
+![c-debug](images/c-debug.png)
+
+### 4.4 开始调试
+
+点击调试按钮,出现如下信息代表可以开始调试
+![debug](images/debug.png)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/_category_.json
new file mode 100644
index 00000000000..b78c0cb3dae
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "开发规范",
+ "position": 12
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/api.md
new file mode 100644
index 00000000000..dcb2ddd9876
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/api.md
@@ -0,0 +1,77 @@
+---
+title: 接口规范
+sidebar_position: 4
+---
+
+> Contributor为Linkis贡献新的Restful接口时,需遵循如下接口规范进行接口开发。
+
+## 1. HTTP or WebSocket ?
+
+Linkis目前提供了两种接口方式:HTTP和WebSocket。
+
+WebSocket相比于HTTP的优势:
+
+- 对服务器产生的压力更小
+- 信息推送更加及时
+- 交互性更加友好
+
+相应的,WebSocket也有如下的劣势:
+
+- WebSocket在使用时可能出现断开连接的情况
+- 对前端的技术要求更高
+- 一般要求前端有降级处理机制
+
+**如非必要,我们通常强烈建议Contributor尽量少用WebSocket的方式提供接口;**
+
+**如您觉得使用WebSocket很有必要,且愿意将开发的功能贡献给Linkis,建议您在开发前与我们取得沟通,多谢!**
+
+## 2. URL规范
+
+```
+/api/rest_j/v1/{applicationName}/.+
+/api/rest_s/v1/{applicationName}/.+
+```
+
+**约定**:
+
+ - rest_j表示接口符合Jersey规范
+ - rest_s表示接口符合springMVC Rest规范
+ - v1为服务的版本号,**版本号会随着Linkis版本进行升级**
+ - {applicationName}为微服务名
+
+## 3. 接口请求格式
+
+```json
+{
+ "method":"/api/rest_j/v1/entrance/execute",
+ "data":{},
+ "websocketTag":"37fcbd8b762d465a0c870684a0261c6e" // WebSocket请求的必需参数,HTTP请求可忽略
+}
+```
+
+**约定**:
+
+ - method:请求的Restful API URL。
+ - data:请求的具体数据。
+ - websocketTag:某一次WebSocket请求的唯一标识,后台也会带回该参数用于给前端进行识别。
+
+## 4. 接口返回格式
+
+```json
+{"method":"/api/rest_j/v1/project/create","status":0, "message":"创建成功!","data":{}}
+```
+
+**约定**:
+
+ - method:返回请求的Restful API URL,主要是websocket模式需要使用。
+ - status:返回状态信息,其中:-1表示没有登录,0表示成功,1表示错误,2表示验证失败,3表示没该接口的访问权限。
+ - data:返回具体的数据。
+ - message:返回请求的提示信息。如果status非0时,message返回的是错误信息,其中data有可能存在stack字段,返回具体的堆栈信息。
+
+另:根据status的不同,HTTP请求的状态码也不一样,一般情况下:
+
+ - 当status为0时,HTTP的状态码为200
+ - 当status为-1时,HTTP的状态码为401
+ - 当status为1时,HTTP的状态码为400
+ - 当status为2时,HTTP的状态码为412
+ - 当status为3时,HTTP的状态码为403
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/commit-message.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/commit-message.md
new file mode 100644
index 00000000000..b03e914fcd6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/commit-message.md
@@ -0,0 +1,95 @@
+---
+title: Commit Message 须知
+sidebar_position: 2
+---
+> 本文引用自 https://dolphinscheduler.apache.org/zh-cn/docs/dev/user_doc/contribute/join/commit-message.html
+
+### 1.前言
+ 一个好的 commit message 是能够帮助其他的开发者(或者未来的开发者)快速理解相关变更的上下文,同时也可以帮助项目管理人员确定该提交是否适合包含在发行版中。但当我们在查看了很多开源项目的 commit log 后,发现一个有趣的问题,一部分开发者,代码质量很不错,但是 commit message 记录却比较混乱,当其他贡献者或者学习者在查看代码的时候,并不能通过 commit log 很直观的了解
+该提交前后变更的目的,正如 Peter Hutterer 所言:Re-establishing the context of a piece of code is wasteful. We can’t avoid it completely, so our efforts should go to reducing it as much as possible. Commit messages can do exactly that and as a result, a commit message shows whether a developer is a good collaborator. 因此,DolphinScheduler 结合其他社区以及 Apache 官方文档制定了该规约。
+
+### 2.Commit Message RIP
+
+#### 2.1 明确修改内容
+
+commit message 应该明确说明该提交解决了哪些问题(bug 修复、功能增强等),以便于用户开发者更好的跟踪问题,明确版本迭代过程中的优化情况。
+
+#### 2.2 关联相应的Pull Request 或者Issue
+
+当我们的改动较大的时候,commit message 最好能够关联 GitHub 上的相关 Issue 或者 Pull Request,这样,我们的开发者在查阅代码的时候能够通过关联信息较为迅速的了解改代码提交的上下文情景,如果当前 commit 针对某个 issue,那么可以在 Footer 部分关闭这个 issue。
+
+#### 2.3 统一的格式
+
+格式化后的 CommitMessage 能够帮助我们提供更多的历史信息,方便快速浏览,同时也可以直接从 commit 生成 Change Log。
+
+Commit message 应该包括三个部分:Header,Body 和 Footer。其中,Header 是必需的,Body 和 Footer 可以省略。
+
+##### header
+Header 部分只有一行,包括三个字段:type(必需)、scope(可选)和 subject(必需)。
+
+[DS-ISSUE编号][type] subject
+
+(1) type 用于说明 commit 的类别,只允许使用下面7个标识。
+
+* feat:新功能(feature)
+* fix:修补bug
+* docs:文档(documentation)
+* style: 格式(不影响代码运行的变动)
+* refactor:重构(即不是新增功能,也不是修改bug的代码变动)
+* test:增加测试
+* chore:构建过程或辅助工具的变动
+
+如果 type 为 feat 和 fix,则该 commit 将肯定出现在 Change log 之中。其他情况(docs、chore、style、refactor、test)建议不放入。
+
+(2)scope
+
+scope 用于说明 commit 影响的范围,比如 server、remote 等,如果没有更合适的范围,你可以用 *。
+
+(3) subject
+
+subject 是 commit 目的的简短描述,不超过50个字符。
+
+##### Body
+
+Body 部分是对本次 commit 的详细描述,可以分成多行,换行符将以72个字符换行,避免自动换行影响美观。
+
+Body 部分需要注意以下几点:
+
+* 使用动宾结构,注意使用现在时,比如使用 change 而非 changed 或 changes
+
+* 首字母不要大写
+
+* 语句最后不需要 ‘.’ (句号) 结尾
+
+
+##### Footer
+
+Footer只适用于两种情况
+
+(1) 不兼容变动
+
+如果当前代码与上一个版本不兼容,则 Footer 部分以 BREAKING CHANGE 开头,后面是对变动的描述、以及变动理由和迁移方法。
+
+(2) 关闭 Issue
+
+如果当前 commit 针对某个issue,那么可以在 Footer 部分关闭这个 issue,也可以一次关闭多个 issue 。
+
+##### 举个例子
+[Linkis-001][docs-zh] add commit message
+
+* commit message RIP
+* build some conventions
+* help the commit messages become clean and tidy
+* help developers and release managers better track issues
+and clarify the optimization in the version iteration
+
+This closes #001
+
+### 3.参考文档
+[Dolphinscheduler Commit Message 须知](https://dolphinscheduler.apache.org/zh-cn/docs/dev/user_doc/contribute/join/commit-message.html)
+
+[提交消息格式](https://cwiki.apache.org/confluence/display/GEODE/Commit+Message+Format)
+
+[关于提交消息](http://who-t.blogspot.com/2009/12/on-commit-messages.html)
+
+[RocketMQ 社区操作约定](https://mp.weixin.qq.com/s/LKM4IXAY-7dKhTzGu5-oug)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/concurrent.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/concurrent.md
new file mode 100644
index 00000000000..09221a88a3f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/concurrent.md
@@ -0,0 +1,13 @@
+---
+title: 并发规范
+sidebar_position: 5
+---
+1. 【**强制**】获取单例对象要线程安全。在单例对象里面做操作也要保证线程安全。
+
+2. 【**强制**】线程资源必须通过线程池提供,不允许在应用中自行显式创建线程。
+
+3. SimpleDateFormat 是线程不安全的类,建议使用使用DateUtils工具类。
+
+4. 【**强制**】高并发时,同步调用应该去考量锁的性能损耗。能用无锁数据结构,就不要用锁;能锁区块,就不要锁整个方法体;能用对象锁,就不要用类锁。
+
+5. 【**强制**】ThreadLocal尽量少用,用的时候如果存入的是一个需要close的对象,记得及时close释放掉。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/exception-catch.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/exception-catch.md
new file mode 100644
index 00000000000..7409280f00f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/exception-catch.md
@@ -0,0 +1,87 @@
+---
+title: 异常规范
+sidebar_position: 3
+---
+
+## 1. 异常层次定义
+1. linkis异常继承层次:
+
+LinkisException:异常继承于Exception,存在三个静态属性,是服务在启动时进行赋值的,这三个属性主要为了在进行异常打印时,标明异常来自于哪个微服务
+```
+ static String applicationName;//Microservice AppName
+ static String hostname;//Microservice hostName
+ static int hostPort;//Microservice port
+```
+可继承异常:
+
+|异常类 | 所在服务| 错误描述|
+|:---- |:--- |:--- |
+|LinkisException| common| 顶级父类,继承自Exception,不允许直接继承|
+|LinkisRuntimeException| common| 顶级父类,继承自RuntimeException,不允许直接继承|
+|WarnException| common| 次级父类,继承自LinkisRuntimeException。提示级的异常,必须直接或间接继承该类|
+|ErrorException| common| 次级父类,继承自LinkisException。错误级的异常,必须直接或间接继承该类|
+|FatalException| common| 次级父类,继承自LinkisException。致命级的异常,必须直接或间接继承该类,出现此类异常服务需要在Catch时进行退出。如:ECM在向LM注册失败时需要退出|
+|LinkisRetryException| common| 次级父类,继承自LinkisException。重试级的异常,必须直接或间接继承该类,一般用于Linkis内部,用于捕获该异常进行请求的重试,如:引擎启动的资源不足异常|
+
+2. 模块使用异常须知:
+- 【**强制**】每个模块需要自定义对应模块的异常,自定义的异常都必须继承自LinkisRetryException、WarnException、ErrorException或FatalException之一
+- 【**强制**】自定义的异常必须包含错误码和错误描述,如有必要,也可将发生异常的ip地址和进程端口封装到异常当中
+- 【**强制**】慎用WarnException!WarnException抛出来的异常,如果在Restful和RPC的Receiver端被捕获,不会给前端或sender端抛出执行失败,而是只返回一条警告信息!
+- 【**强制**】WARNException的异常级别为1,ErrorException的异常级别为2,FatalException的异常级别为3,LinkisRetryException的异常级别为4
+
+3. 错误码需按照规范进行定义,错误码规范如下(PS:现有不规范的错误码,您可以提PR进行修复)
+```
+## 错误码定义:整个调用链路的需要有规则
+linkis-commons:10000-11000
+linkis-computattion-governace:11000-12000
+linkis-engineconn-plugins:12000-13000
+linkis-orchestrator:13000-14000
+linkis-public-enghancements:14000-15000
+linkis-spring-cloud-service:15100-15500
+linkis-extensions:15500-16000
+```
+
+## 2. 异常规范
+1. [强制] 禁止直接catch Throwable,这种代码非常危险,因为会把Error也给catch住,像OOM等异常会被直接catch,原本JVM检测到该异常会自动停止进程,但是因为我们catch住了,会导致进程实际已经无法提供服务,但是不会正常退出。
+```scala
+// 对于Scala代码建议使用Utils工具类里面提供的相关tryCatch方法
+ def tryCatch[T](tryOp: => T)(catchOp: Throwable => T): T = {
+ try tryOp catch {
+ case t: ControlThrowable => throw t
+ case fatal: FatalException =>
+ error("Fatal error, system exit...", fatal)
+ System.exit(fatal.getErrCode)
+ null.asInstanceOf[T]
+ case e: VirtualMachineError =>
+ error("Fatal error, system exit...", e)
+ System.exit(-1)
+ throw e
+ case er: Error =>
+ error("Throw error", er)
+ throw er
+ case t => catchOp(t)
+ }
+ }
+```
+2. [强制] 捕获异常后,如果需要创建新的异常,一定要将cause进行传递对新加的异常进行initCause,防止丢失根因
+```
+// 新生成的异常,需要继承cacuse
+public StorageErrorException(int errCode, String desc, Throwable t){
+ super(errCode, desc);
+ initCause(t);
+}
+```
+
+3. 【**强制**】每个小模块的异常,都应该定义一个专门的exception类,方便后续给用户生成错误码,不允许抛出任何RuntimeException和直接抛Exception。
+
+4. 【推荐】尽量不要对大段代码进行try-catch,这是不负责任的表现。catch时请分清稳定代码和非稳定代码,稳定代码指的是无论如何不会出错的代码。对于非稳定代码的catch尽可能进行区分异常类型,再做对应的异常处理。
+
+5. 【**强制**】捕获异常是为了处理它,不要捕获了却什么都不处理而抛弃之,如果不想处理它,请将该异常抛给它的调用者。注意:什么情况下,都不要用e.printStackTrace()!最外层的业务使用者,必须处理异常,将其转化为用户可以理解的内容。
+
+finally块必须对资源对象、流对象进行关闭,有异常也要做try-catch。
+
+6. 【**强制**】预防NullPointerException。方法的返回值可以为null,不强制返回空集合,或者空对象等,但是必须添加注释充分说明什么情况下会返回 null 值。RPC、SpringCloud Feign调用,一律要求进行非空判断。
+
+7. 【**强制**】不要在finally中使用Return和抛出异常
+
+8. 【**强制**】如果异常已经抛出,禁止打印异常的堆栈日志,会导致日志冗余
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/how-to-write-unit-test-code.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/how-to-write-unit-test-code.md
new file mode 100644
index 00000000000..af8faa8bd56
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/how-to-write-unit-test-code.md
@@ -0,0 +1,365 @@
+---
+title: 如何编写单元测试代码
+sidebar_position: 10
+---
+## 1.框架选型
+Junit5+Mockito+jacoco+h2本地数据库
+Idea增强插件
+- JUnitGenerator V2.0 用于生成测试用例的标准模块
+- GenerateAllSet 用于快速new创建对象,并设置默认值
+- MybatisX dao与mapper的关联映射 方便查看
+
+### 1.1 配置IDEA的Junit的模板
+```properties
+########################################################################################
+##
+## Available variables:
+## $entryList.methodList - List of method composites
+## $entryList.privateMethodList - List of private method composites
+## $entryList.fieldList - ArrayList of class scope field names
+## $entryList.className - class name
+## $entryList.packageName - package name
+## $today - Todays date in MM/dd/yyyy format
+##
+## MethodComposite variables:
+## $method.name - Method Name
+## $method.signature - Full method signature in String form
+## $method.reflectionCode - list of strings representing commented out reflection code to access method (Private Methods)
+## $method.paramNames - List of Strings representing the method's parameters' names
+## $method.paramClasses - List of Strings representing the method's parameters' classes
+##
+## You can configure the output class name using "testClass" variable below.
+## Here are some examples:
+## Test${entry.ClassName} - will produce TestSomeClass
+## ${entry.className}Test - will produce SomeClassTest
+##
+########################################################################################
+##
+## 首字母大写
+#macro (cap $strIn)$strIn.valueOf($strIn.charAt(0)).toUpperCase()$strIn.substring(1)#end
+## 首字母小写 自定义down
+#macro (down $strIn)$strIn.valueOf($strIn.charAt(0)).toLowerCase()$strIn.substring(1)#end
+## Iterate through the list and generate testcase for every entry.
+#foreach ($entry in $entryList)
+#set( $testClass="${entry.className}Test")
+##
+
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package $entry.packageName;
+
+import org.junit.jupiter.api.AfterEach;
+import org.junit.jupiter.api.BeforeEach;
+import org.junit.jupiter.api.DisplayName;
+import org.junit.jupiter.api.Test;
+import org.springframework.beans.factory.annotation.Autowired;
+
+/**
+ * ${entry.className} Tester
+*/
+public class $testClass {
+
+ @Autowired
+ private ${entry.className} #down(${entry.className});
+
+ @BeforeEach
+ @DisplayName("Each unit test method is executed once before execution")
+ public void before() throws Exception {
+ }
+
+ @AfterEach
+ @DisplayName("Each unit test method is executed once before execution")
+ public void after() throws Exception {
+ }
+
+#foreach($method in $entry.methodList)
+
+ @Test
+ @DisplayName("Method description: ...")
+ public void test#cap(${method.name})() throws Exception {
+ //TODO: Test goes here...
+ }
+
+#end
+
+#foreach($method in $entry.privateMethodList)
+
+ @Test
+ @DisplayName("Method description: ...")
+ public void test#cap(${method.name})() throws Exception {
+ //TODO: Test goes here...
+ #foreach($string in $method.reflectionCode)
+ $string
+ #end
+ }
+
+#end
+}
+#end
+
+```
+![test-0](../images/test-0.png)
+
+1.配置配置测试类生成路径
+原配置:${SOURCEPATH}/test/${PACKAGE}/${FILENAME}
+修改后配置:${SOURCEPATH}/../../test/java/${PACKAGE}/${FILENAME}
+如图:
+![test-1](../images/test-1.png)
+2.选择类——>右键——>Generate——>Junit Test,生成测试类
+![test-2](../images/test-2.png)
+
+## 2.单元测试准则
+### 2.1 目录以及命名准则
+
+- 1.单元测试代码目录
+ 必须写在如下工程目录:src/test/java,不允许写在业务代码目录下。
+ 说明:源码编译时会跳过此目录,而单元测试框架默认是扫描此目录,测试的配置文件必须放在:src/test/resources文件下
+
+- 2.测试类所在的包名应该和被测试类所在的包名保持一致
+ 示例:
+ 业务类 src/main/java/org/apache/linkis/jobhistory/dao/JobDetailMapper.java
+ 对应的测试类 src/test/java/org/apache/linkis/jobhistory/dao/JobDetailMapperTest.java
+
+- 3.测试类的命名定义规范:使用Test作为类名的后缀
+ 测试类的命名如下:
+ 被测试的业务+Test、被测试的接口+Test、被测试的类+Test
+
+- 4.测试用例的命名定义规范:使用test作为方法名的前缀
+ 测试用例的命名规则是:test+方法名。避免使用test1、test2没有含义的名称,其次需要有必要的函数方法注释。
+
+
+### 2.2 编写准则
+- 1.单元测试中不准使用 System.out 来进行人肉验证,或则if判断来验证(可以使用log进行关键日志输出),必须使用断言 assert 来验证。
+
+- 2.保持单元测试的独立性。为了保证单元测试稳定可靠且便于维护,单元测试用例之间决不能互相调用,也不能依赖执行的先后次序。
+ 反例:method2 需要依赖 method1 的执行,将执行结果作为 method2 的输入
+
+- 3.单元测试必须可以重复执行的,不能受到外界环境的影响。
+ 说明:单元测试通常会被放到持续集成中,每次有代码 check in 时单元测试都会被执行。如果单测对外部环境(网络、服务、中间件等)有依赖,容易导致持续集成机制的不可用。
+ 正例:为了不受外界环境影响,要求设计代码时就把被测类的相关依赖改成注入,在测试时用 spring 这样的依赖注入框架注入一个本地(内存)实现或者 Mock 实现。
+
+- 4.增量代码确保单元测试通过。
+ 说明:新增代码必须补充单元测试,如果新增代码影响了原有单元测试,请修正
+
+- 5.对于单元测试,要保证测试粒度足够小,有助于精确定位问题。单测粒度一般都是方法级别(工具类或则枚举类等极少场景可以是类级别)。
+ 说明:只有测试粒度小才能在出错时尽快定位到出错位置。单测不负责检查跨类或者跨系统的交互逻辑,那是集成测试的领域。
+
+
+## 3.断言的使用
+所有的测试用例的结果验证都必须使用断言模式
+优先使用Junit5的Assertions断言,极少数场景允许使用AssertJ的断言
+
+### 3.1 Junit5常规断言
+
+| 方法 | 说明 | 备注 |
+|--------|-------------|-------------|
+|assertEquals | 判断两个对象或两个原始类型是否相等| |
+|assertNotEquals| 判断两个对象或两个原始类型是否不相等| |
+|assertTrue| 判断给定的布尔值是否为 true| |
+|assertFalse| 判断给定的布尔值是否为 false | |
+|assertNull| 判断给定的对象引用是否为 null| |
+|assertNotNull| 判断给定的对象引用是否不为 null | |
+|assertAll| 将多个判断逻辑放在一起处理,只要有一个报错就会导致整体测试不通过 | |
+### 3.2 Junit5组合断言和异常断言
+**组合断言**
+assertAll方法可以将多个判断逻辑放在一起处理,只要有一个报错就会导致整体测试不通过:
+```java
+ @Test
+ @DisplayName("assert all")
+ public void all() {
+ //将多个判断放在一起执行,只有全部通过才算通过
+ assertAll("Math",
+ () -> assertEquals(2, 1 + 1),
+ () -> assertTrue(1 > 0)
+ );
+ }
+```
+**异常断言 **
+Assertions.assertThrows方法,用来测试Executable实例执行execute方法时是否抛出指定类型的异常;
+如果execute方法执行时不抛出异常,或者抛出的异常与期望类型不一致,都会导致测试失败;
+示例:
+```java
+ @Test
+ @DisplayName("异常的断言")
+ void exceptionTesting() {
+ // 其execute方法执行时,如果抛出了异常,并且异常的类型是assertThrows的第一个参数(这里是ArithmeticException.class),
+ // 返回值是异常的实例
+ Exception exception = assertThrows(ArithmeticException.class, () -> Math.floorDiv(1,0));
+ log.info("assertThrows通过后,返回的异常实例:{}", exception.getMessage());
+ }
+```
+### 3.3 断言使用准则
+**对象实例是否相等断言**
+1.是否是同一个对象实例
+ ```html
+ 使用Junitd的Assertions.assertEquals
+ Assertions.assertEquals(expectedJobDetail, actualJobDetail)
+ ```
+
+
+ 不是同一个实例,但是比较实例的属性值是否完全相等
+ AssertJ
+ ```html
+ 常用场景 数据库更新操作前/后的对象比较
+ 使用AssertJ的assertThat断言usingRecursiveComparison模式
+ Assertions.assertThat(actualObject).usingRecursiveComparison().isEqualTo(expectedObject);
+ ```
+
+
+2.list等集合结果的断言
+ 结果集集合的大小需要断言
+ 范围或则具体大size
+
+ 结果集集合中的每个对象需要断言,推荐结合stream模式的Predicate进行使用
+ 示例:
+ ```java
+ ArrayList jobRespProtocolArrayList=service.batchChange(jobDetailReqBatchUpdate);
+ //list配和stream的predicate进行断言判断
+ Predicate statusPrecate = e -> e.getStatus()==0;
+ assertEquals(2, jobRespProtocolArrayList.size());
+ assertTrue(jobRespProtocolArrayList.stream().anyMatch(statusPrecate));
+ ```
+
+## 4.Mock模拟返回数据
+
+有时我们单测一些api或者service模块,其中的service或者dao对于一些方法的返回值默认是null,但是逻辑里面有对这个返回null的对象进行判断或者二次取值的话,就是引发一些异常
+
+示例:
+
+```java
+ PageInfo pageInfo =
+ udfService.getManagerPages(udfName, udfTypes, userName, curPage, pageSize);
+ message = Message.ok();
+ // 这里的pageInfo是null,后续的get方法就会出现异常
+ message.data("infoList", pageInfo.getList());
+ message.data("totalPage", pageInfo.getPages());
+ message.data("total", pageInfo.getTotal());
+```
+
+mock模拟数据示例:
+
+```java
+ PageInfo pageInfo = new PageInfo<>();
+ pageInfo.setList(new ArrayList<>());
+ pageInfo.setPages(10);
+ pageInfo.setTotal(100);
+ // 对 udfService.getManagerPages 方法进行任意传递参数,模拟返回pageInfo对象
+ // 有了这个模拟数据,上面示例在执行get方法的时候,就不会有异常
+ Mockito.when(
+ udfService.getManagerPages(
+ Mockito.anyString(),
+ Mockito.anyCollection(),
+ Mockito.anyString(),
+ Mockito.anyInt(),
+ Mockito.anyInt()))
+ .thenReturn(pageInfo);
+```
+
+## 5.单元测试的编写
+
+### 5.1 类的划分
+
+按类的大功能可以大体分类
+- Controller 提供http服务的controller 配合mockmvc做单元测试
+- Service 业务逻辑代码的service层
+- Dao 与数据库操作的Dao层
+- util工具功能类 常用的功能工具
+- exception类 自定义的异常类
+- enum类 枚举类
+- entity类 用于DB交互以及方法处理的参数VO对象等实体类(若除了正常的get set外还有其他自定义函数的需要进行单元测试)
+
+### 5.2 Controller类的单元测试
+使用Mockmvc
+主要验证 接口请求RequestMethod方式,基本参数,以及返回结果预期。
+主要场景:带上非必要参数和不带非必要参数的场景 异常
+
+```java
+ @Test
+ public void testList() throws Exception {
+ //带上非必要参数
+ MultiValueMap paramsMap = new LinkedMultiValueMap<>();
+ paramsMap.add("startDate", String.valueOf(System.currentTimeMillis()));
+ MvcResult mvcResult = mockMvc.perform(get("/jobhistory/list")
+ .params(paramsMap))
+ .andExpect(status().isOk())
+ .andExpect(content().contentType(MediaType.APPLICATION_JSON))
+ .andReturn();
+
+ Message res = JsonUtils.jackson().readValue(mvcResult.getResponse().getContentAsString(), Message.class);
+ assertEquals(res.getStatus(), MessageStatus.SUCCESS());
+ logger.info(mvcResult.getResponse().getContentAsString());
+
+ //不带非必要参数
+ mvcResult = mockMvc.perform(get("/jobhistory/list"))
+ .andExpect(status().isOk())
+ .andExpect(content().contentType(MediaType.APPLICATION_JSON))
+ .andReturn();
+
+ res = JsonUtils.jackson().readValue(mvcResult.getResponse().getContentAsString(), Message.class);
+ assertEquals(res.getStatus(), MessageStatus.SUCCESS());
+
+ logger.info(mvcResult.getResponse().getContentAsString());
+ }
+
+```
+### 5.3 Server 类的单元测试
+ //todo
+### 5.4 Dao 类的单元测试
+使用H2数据库,配置文件中application.properties中需要配置H2数据库的基本信息,以及mybatis的相关路径信息
+
+```properties
+#h2数据库配置
+spring.datasource.driver-class-name=org.h2.Driver
+#连接数据库
+spring.datasource.url=jdbc:h2:mem:test;MODE=MySQL;DB_CLOSE_DELAY=-1;DATABASE_TO_LOWER=true
+#初始化数据库表的脚本
+spring.datasource.schema=classpath:create.sql
+#初始化数据库表中的数据的脚本
+spring.datasource.data=classpath:data.sql
+spring.datasource.username=sa
+spring.datasource.password=
+spring.datasource.hikari.connection-test-query=select 1
+spring.datasource.hikari.minimum-idle=5
+spring.datasource.hikari.auto-commit=true
+spring.datasource.hikari.validation-timeout=3000
+spring.datasource.hikari.pool-name=linkis-test
+spring.datasource.hikari.maximum-pool-size=50
+spring.datasource.hikari.connection-timeout=30000
+spring.datasource.hikari.idle-timeout=600000
+spring.datasource.hikari.leak-detection-threshold=0
+spring.datasource.hikari.initialization-fail-timeout=1
+
+#配置mybatis-plus的mapper信息 因为使用的是mybatis-plus,使用mybatis-plus浅醉
+mybatis-plus.mapper-locations=classpath:org/apache/linkis/jobhistory/dao/impl/JobDetailMapper.xml,classpath:org/apache/linkis/jobhistory/dao/impl/JobHistoryMapper.xml
+mybatis-plus.type-aliases-package=org.apache.linkis.jobhistory.entity
+mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
+```
+
+编写规范
+1. 使用@Transactional以及@Rollback 实现数据回滚,避免数据污染
+2. 每一个DaoTest应该有一个创建初始化数据公共方法(或导入数据的方式csv)来准备数据,相关的查询,更新,删除等操作都应该先调用该公共方法进行数据的准备
+3. 创建测试的数据,如果某属性值是自增id,则不应该进行赋值
+4. 创建的测试数据,应尽可能和实际样例数据保持一致
+5. 更新数据测试时,如果字段允许,请带上`modify-原始值`前缀
+
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/license.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/license.md
new file mode 100644
index 00000000000..8d96d44c674
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/license.md
@@ -0,0 +1,166 @@
+---
+title: License 须知
+sidebar_position: 0.1
+---
+
+>注:本文仅适用于Apache项目。
+>本文参考 Dolphinscheduler项目的License须知文档 https://dolphinscheduler.apache.org/zh-cn/community/development/DS-License.html
+
+ASF(Apache基金会)下的开源项目,对于License有着极其严苛的要求,当您为Linkis贡献代码时,就必须按照Apache的规则来,为了避免贡献者在License上浪费过多的时间,
+本文将为您讲解ASF—License以及参与 Linkis 项目开发时如何规避掉License风险。
+
+## 1.License 文件目录说明
+
+licence相关的可以划分为3部分
+- 源码级别 主要需要关注的场景是: 在项目工程源码中,直接引入第三方资源(如 直接使用了某个其他项目的代码JAVA文件,新增了文本、css、js、图片、图标、音视频等文件,以及在第三方基础上做的修改)
+- 项目的安装物料包 主要需要关注的场景是: 依赖的第三方jar包的运行态依赖,pom 配置中 通过dependency依赖引入 即最后编译打包会被打包到发布的安装包中的
+- 管理台的安装物料包 主要需要关注的场景是:前端web编译依赖的第三方npm依赖包 通过linkis-web/package.json 配置引入
+
+
+[Linkis源码](https://github.com/apache/linkis)涉及到license的目录如下
+
+```shell script
+# 最外层目录开始
+
+├── LICENSE //项目源码的LICENSE 一些没有asf header的文件或则引入外部资源需要在这里标明
+├── NOTICE //项目源码的NOTICE 一般不会变动
+├── licenses //项目源码级别引入第三方组件license 说明
+│ └── LICENSE-py4j-0.10.9.5-src.txt
+├── linkis-dist
+│ └── release-docs
+│ ├── LICENSE //编译的安装包中依赖的第三方jar包的license信息汇总
+│ ├── licenses //编译的安装包中依赖的第三方jar包对应的license信息详细
+│ │ ├── LICENSE-log4j-api.txt
+│ │ ├── LICENSE-log4j-core.txt
+│ │ ├── LICENSE-log4j-jul.txt
+│ │ ├── LICENSE-xxxx.txt
+│ └── NOTICE //编译的安装包中依赖的第三方jar包的NOTICE 汇总
+├── linkis-web
+ └── release-docs
+ ├── LICENSE //前端web编译安装包第三方npm依赖的LICENSE信息汇总
+ ├── licenses //前端web编译安装包第三方npm依赖对应的license信息详细
+ │ ├── LICENSE-vuedraggable.txt
+ │ ├── LICENSE-vue-i18n.txt
+ │ ├── LICENSE-vue.txt
+ │ ├── LICENSE-vuescroll.txt
+ │ └── LICENSE-xxxx.txt
+ └── NOTICE //前端web编译安装包第三方npm依赖的NOTICE 汇总
+
+
+```
+
+
+## 2.如何在 Linkis 合法的使用第三方开源软件
+
+当你提交的代码有如下场景时:
+
+- 场景1. 源码中有新增(或移除)使用第三方代码或则静态资源,如源码中直接使用了某个其他项目的代码文件文件,新增了文本、css、js、图片、图标、音视频等文件,以及在第三方基础上做的修改。
+- 场景2. 项目的运行态依赖有新增(或移除)(运行态依赖:即最后编译打包会被打包到发布的安装包中的)
+
+- 场景1中的引入的文件必须是[ASF第三方许可证策](https://apache.org/legal/resolved.html)的A类License
+- 场景2中的引入的依赖必须是[ASF第三方许可证策](https://apache.org/legal/resolved.html)中的A类/B类License,不能是C类License
+
+我们需要知道被我们项目引入的文件或jar依赖的NOTICE/LICENSE,(绝大多数的开源项目都会有NOTICE文件),这些必须在我们的项目中体现,用Apache的话来讲,就是"Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a
+copyright notice that is included in or attached to the work.
+
+### 2.1 示例 场景1
+比如源码中引入了`linkis-engineconn-plugins/python/src/main/py4j/py4j-0.10.7-src.zip`第三方文件
+
+找到py4j-0.10.7-src.zip 对应的版本源码分支,如果对应版本分支无`LICENSE/NOTICE`文件,则选择主分支
+- 项目源码位于:https://github.com/bartdag/py4j/tree/0.10.7/py4j-python
+- LICENSE文件:https://github.com/bartdag/py4j/blob/0.10.7/py4j-python/LICENSE.txt
+- NOTICE文件:无
+
+需要在`linkis/LICENSE`文件中说明`py4j-0.10.7-src.zip`的license信息。
+`py4j-0.10.7-src.zip`对应的详细的license.txt文件放在同级的目录下`linkis-engineconn-plugins/python/src/main/py4j/LICENSE-py4j-0.10.7-src.txt`
+因为https://github.com/bartdag/py4j/tree/0.10.7/py4j-python 没有NOTICE文件,所以`linkis/NOTICE`文件中无需追加。
+
+### 2.2 示例 场景 2
+
+项目编译依赖了`org.apache.ant:ant:1.9.1`,ant-1.9.1.jar会在最后的编译安装包`target/apache-linkis-x.x.x-bin/linkis-package/lib`中
+可以解压ant-1.9.1.jar,从jar包中提取LICENSE/NOTICE文件,如果没有,则需要找到对应的版本源码
+找到py4j-0.10.7-src.zip 对应的版本源码分支,如果对应版本分支没有,则选择主分支
+- 项目源码位于:https://github.com/apache/ant/tree/rel/1.9.1
+- LICENSE文件:https://github.com/apache/ant/blob/rel/1.9.1/LICENSE
+- NOTICE文件:https://github.com/apache/ant/blob/rel/1.9.1/NOTICE
+
+需要在`linkis/LICENSE-binary`文件中说明`ant-1.9.1.jar`的license信息。
+`ant-1.9.1.jar`对应的详细的license.txt文件放在`licenses-binary/LICENSE-ant.txt`
+`ant-1.9.1.jar`对应的详细的notice.txt,追加到 `NOTICE-binary`文件中
+
+关于具体的各个开源协议使用协议,在此不做过多篇幅一一介绍,有兴趣可以自行查询了解。
+
+## 3.license 检测规则
+我们为自己的项目建立license-check脚本,是为了确保我们在使用过程中能够第一时间避免License的问题。
+
+当我们需要添加新的Jar或其他外部资源的时候,我们需要按照以下步骤:
+
+* 在 tool/dependencies/known-dependencies.txt中添加你所需要的jar名称+版本。
+* 在 linkis-web/release-docs/LICENSE(根据实际情况决定)中添加相关的license信息。
+* 在 linkis-web/release-docs/NOTICE(根据实际情况决定)中追加相关的NOTICE文件,此文件请务必和依赖项的代码版本仓库中的NOTICE文件一致。
+
+:::caution 注意
+如果是移除的场景,则对应的上述步骤的反向操作,需要在对应的文件中移除相应的LICENSE/NOTICE内容,总之需要保证这几个文件与实际源码/编译包的数据保持一致
+- tool/dependencies/known-dependencies.txt
+- LICENSE/LICENSE-binary/LICENSE-binary-ui
+- NOTICE/NOTICE-binary/NOTICE-binary-ui
+:::
+
+** check dependency license fail**
+
+编译后 执行tool/dependencies/diff-dependenies.sh 脚本验证
+```
+--- /dev/fd/63 2020-12-03 03:08:57.191579482 +0000
++++ /dev/fd/62 2020-12-03 03:08:57.191579482 +0000
+@@ -1,0 +2 @@
++HikariCP-java6-2.3.13.jar
+@@ -16,0 +18 @@
++c3p0-0.9.5.2.jar
+@@ -149,0 +152 @@
++mchange-commons-java-0.2.11.jar
+Error: Process completed with exit code 1.
+```
+一般来讲,添加一个jar的工作往往不会如此轻易的结束,因为它往往依赖了其它各种各样的jar,这些jar我们同样需要添加相应的license。
+这种情况下,我们会在check里面得到 check dependency license fail的错误信息,如上,我们缺少了HikariCP-java6-2.3.13、c3p0等的license声明,
+按照添加jar的步骤补充即可。
+
+
+## 4.附件
+附件:新jar的邮件格式
+```
+[VOTE][New/Remove Jar] jetcd-core(registry plugin support etcd3 )
+
+
+(说明目的,以及需要添加/移除的 jar 是什么)
+Hi, the registry SPI will provide the implementation of etcd3. Therefore, we need to introduce a new jar (jetcd-core, jetcd-launcher (test)), which complies with the Apache-2.0 License. I checked his related dependencies to make sure it complies with the license of the Apache project.
+
+new or remove jar :
+
+jetcd-core version -x.x.x license apache2.0
+jetcd-launcher (test) version -x.x.x license apache2.0
+
+dependent jar(它依赖了哪些jar,最好附带版本,以及相关采用的license协议):
+grpc-core version -x.x.x license XXX
+grpc-netty version -x.x.x license XXX
+grpc-protobuf version -x.x.x license XXX
+grpc-stub version -x.x.x license XXX
+grpc-grpclb version -x.x.x license XXX
+netty-all version -x.x.x license XXX
+failsafe version -x.x.x license XXX
+
+如果是新增,邮件需要附上如下内容
+相关地址:主要有github地址、license文件地址、notice 文件地址、maven中央仓库地址
+
+github address:https://github.com/etcd-io/jetcd
+license:https://github.com/etcd-io/jetcd/blob/master/LICENSE
+notice:https://github.com/etcd-io/jetcd/blob/master/NOTICE
+
+Maven repository:
+https://mvnrepository.com/artifact/io.etcd/jetcd-core
+https://mvnrepository.com/artifact/io.etcd/jetcd-launcher
+```
+
+## 5.参考文章
+* [COMMUNITY-LED DEVELOPMENT "THE APACHE WAY"](https://apache.org/dev/licensing-howto.html)
+* [ASF 3RD PARTY LICENSE POLICY](https://apache.org/legal/resolved.html)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/log.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/log.md
new file mode 100644
index 00000000000..ca81c056c35
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/log.md
@@ -0,0 +1,23 @@
+---
+title: 日志规范
+sidebar_position: 2
+---
+1. 【**强制**】日志信息需要使用英文,不能使用中文。可选中英文混打。
+
+1. 【**约定**】Linkis选择slf4j和Log4j2作为日志打印框架,去除了Spring-Cloud包中自带的logback。由于Slf4j会随机选择一个日志框架进行绑定,所以以后在引入新maven包的时候,需要将诸如slf4j-log4j等桥接包exclude掉,不然日志打印会出现问题。但是如果新引入的maven包依赖log4j等包,不要进行exclude,不然代码运行可能会报错
+
+2. 【**配置**】log4j2的配置文件默认为log4j2.xml,需要放置在classpath中。如果需要和springcloud结合,可以在application.yml中加上logging:config:classpath:log4j2-spring.xml(配置文件的位置)
+
+3. 【**强制**】类中不可直接使用日志系统(log4j2、Log4j、Logback)中的API。java采用 LoggerFactory.getLogger(getClass).如果是Scala代码,强制继承Logging trait,Scala打印日志建议加上logger.info 不要直接用info等方法调用,不会打印正确的方法和行数。
+
+4. 【**开发约定**】由于EngineConn是由EngineConnManager通过命令行进行启动的,所以我们在命令行中指定了日志的配置文件的路径,同时也对日志的配置在代码运行中进行了改造,特别是将EngineConn的日志重定向到了系统的standard out中。所以约定EngineConn的日志配置文件在EnginePlugin中定义,名称为log4j2-engineconn.xml(这个是约定名,不能更改)
+
+5. 【**强制**】严格区分日志级别。Fatal级别的日志,在springcloud应用初始化的时候,就应该抛出来,并使用System.out(-1)退出。ERROR级别的异常为开发人员必须关注和处理的异常,不要随便用ERROR级别的。Warn级别是用户操作异常日志和一些方便日后排除BUG的日志。INFO为关键的流程日志。DEBUG为调式日志,尽量少写。
+
+6. 【**强制**】要求:INFO级别的日志,每个小模块都必须有,关键的流程,都至少有INFO级别的日志。守护线程清理资源等必须有WARN级别的日志。
+
+7. 【**强制**】异常信息应该包括两类信息:案发现场信息和异常堆栈信息。如果不处理,那么通过关键字throws往上抛出。 正例:logger.error(各类参数或者对象toString + "_" + e.getMessage(), e);
+
+8. 【**强制**】日志打印时禁止直接用 JSON 工具将对象转换成 String,如果你的类需要在log里面打印,请重写toString方法,不然不知道怎么找问题,只会打印对象名,不会知道具体的对象内容
+
+9. 【**强制**】在日志输出时,字符串变量之间的拼接使用占位符的方式
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/mapper-xml.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/mapper-xml.md
new file mode 100644
index 00000000000..c85afb6fa79
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/mapper-xml.md
@@ -0,0 +1,159 @@
+---
+title: Mapper XML 规范
+sidebar_position: 10
+---
+
+> Contributor为Apache Linkis贡献新的数据表,编写Mapper XML时需遵循如下规范进行开发。
+
+## 1.基本遵循规范
+- 在mapper.xml中namespace等于java接口地址
+- java接口中的方法名和XML中statement的id一致
+- java接口中的方法输入参数类型和XML中statement的parameterType指定的类型一致
+- java接口中的方法返回值类型和XML中statement的resultType指定的类型一致
+- XML中所有mysql关键字统一使用小写
+- 对于过多的查询字段抽象出SQL片段
+- 对于整型返回值类型建议使用Integer,可以区分未赋值和值为0的情况,如确定返回值为数字可使用int。其它数据类型类似。
+- 对于占位符,使用#{name},而不要使用${name}。模糊查询可以使用CONCAT('%',#{sname},'%')
+- 对于sql语句编写,不使用注解方式,统一写在XML文件中
+
+## 2.方法名称规范
+
+|方法名称| 说明| 核心点| 建议|
+|:---- |:--- |:--- |:--- |
+|insert | 新增数据 | 如果是自增主键,应该返回主键ID| |
+|deleteById | 根据主键ID删除数据| sql默认加limit 1,防止多删数据 |此方法不建议有,建议逻辑删除|
+|updateById | 根据主键ID修改数据| sql默认加limit 1,防止多修改数据| |
+|selectById | 根据主键查询数据| 查询一条数据 | |
+|selectByIdForUpdate | 根据主键加锁查询数据| 加锁查询一条数据,事务处理用 | |
+|queryListByParam | 根据输入条件查询数据列表| 多参数查询列表 | |
+|queryCountByParam | 根据输入条件查询总数| 多参数查询数量 | |
+
+## 3.parameterType规范
+java接口中必须包含@Param,XML中可以不包含parameterType
+### 3.1 基本类型
+```java
+// java接口
+User selectUserById(@Param("id") Integer id);
+// XML文件
+
+ select id, name
+ from user
+ where id = #{id}
+
+```
+### 3.2 集合类型
+```java
+// java接口
+List userListByIds(@Param("ids") List ids);
+// XML文件
+
+ select id, name
+ from user
+ where id in
+
+ #{item}
+
+
+```
+### 3.3 Map类型
+```java
+// java接口
+User queryByParams(@Param("map") Map parasms);
+// XML文件
+
+ select id, name
+ from user
+ where id = #{map.id} and name = #{map.name}
+
+```
+### 3.4 实体类型
+```java
+// java接口
+User queryByUser(@Param("user") User user);
+// XML文件
+
+ select id, name
+ from user
+ where id = #{user.id} and name = #{user.name}
+
+```
+### 3.5 多个参数类型
+```java
+// java接口
+User queryByIdAndName(@Param("id") Integer id, @Param("name") String name);
+// XML文件
+
+ select id, name
+ from user
+ where id = #{id} and name = #{name}
+
+```
+## 4.XML文件编写示例
+合理地使用空格和缩进来增强可读性,各类型sql语句示例如下
+```sql
+
+
+ -- 新增语句
+
+ insert into user (id, name)
+ values (1, 'z3');
+
+
+ -- 删除语句
+
+ delete from user
+ where name = #{name}
+ and id = #{id}
+
+
+ -- 修改语句
+
+ update user
+ set name = #{name}
+ where id = #{id}
+
+
+ -- 查询语句
+
+ select id, name
+ from user
+ where name = 'z3'
+
+
+ -- sql片段
+
+ id,
+ name
+
+ -- 引用
+
+
+ -- resultMap
+
+
+
+
+ -- 引用
+
+ do...
+
+
+ -- 条件判断
+
+ name = #{name}
+
+
+ -- 子查询
+
+ select u.id, u.name
+ from user u
+ where u.name in (
+ select t.name
+ from teacher t
+ where t.id = 1
+ and t.name = 'z3'
+ )
+ and u.id = 2
+
+
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/overview.md
new file mode 100644
index 00000000000..ed4cde6e9c7
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/overview.md
@@ -0,0 +1,19 @@
+---
+title: 总览
+sidebar_position: 0
+---
+为了规范 Linkis 的社区开发环境,提高 Linkis 后续版本开发迭代的产出质量,规范 Linkis 的整个开发设计流程,强烈建议各位 Contributor 遵守以下开发规范:
+
+- [License 须知](license.md)
+- [编程规范](programming-specification.md)
+- [日志规范](log.md)
+- [异常规范](exception-catch.md)
+- [接口规范](api.md)
+- [并发规范](concurrent.md)
+- [路径规范](path-usage.md)
+- [测试规范](unit-test.md)
+- [版本和新特性规范](version-feature-specifications.md)
+
+**说明**:Linkis1.0 初始版本的开发规范较为精简,后续会随着 Linkis 的版本迭代不断补充和完善,欢迎各位 Contributor 提出自己的见解和意见。
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/path-usage.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/path-usage.md
new file mode 100644
index 00000000000..b697edcbb84
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/path-usage.md
@@ -0,0 +1,13 @@
+---
+title: 路径规范
+sidebar_position: 6
+---
+
+请注意:Linkis 提供了统一的 Storage模块,所以在使用路径或在配置文件中配置路径时,必须遵守 Linkis 路径规范。
+
+1. 【**强制**】使用文件路径时不管是本地,hdfs,http都必须带有schema信息。其中:
+ - 本地文件 的 Scheme 头为:file:///;
+ - HDFS 的 Scheme 头为:hdfs:///;
+ - http 的 Scheme 头为:http:///。
+
+2. 路径中不应该存在特殊字符,尽量英文,下划线,数字进行组合。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/programming-specification.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/programming-specification.md
new file mode 100644
index 00000000000..04795eff836
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/programming-specification.md
@@ -0,0 +1,102 @@
+---
+title: 编程规约
+sidebar_position: 1
+---
+## 1. 命名规约
+1. 【**强制**】不要用中文拼音和看不懂的缩写
+2. 基本的Java命名规范可以参考[命名规范](https://alibaba.github.io/Alibaba-Java-Coding-Guidelines/#naming-conventions)
+3. 【约束】在linkis中有scalastyle风格配置文件,如果不符合规范的需要按照scalastyle的风格进行命名
+4. 【**强制**】配置文件命令、启动命名、进程命名、配置的key等也需要遵守命名规范,规范如下:
+
+|分类| 风格| 规范| 例子|
+|:---- |:--- |:--- |:--- |
+|配置文件|小写'-'分隔| linkis-分类层级(ps/cg/mg)-服务名.propertis| linkis-cg-linkismanager.properties|
+|启停脚本|小写'-'分隔| linkis-分类层级-服务名| linkis-cg-linkismanager|
+|模块目录|小写'-'分隔| 模块目录必须在对应的分类层级下面,并以模块名为子目录| linkis-public-enhancements/linkis-bml|
+|进程命名|驼峰命名| 以Linkis开头服务名结尾| LinkisBMLApplication|
+|配置Key命名|小写'.'分隔| linkis+模块名+keyName| linkis.bml.hdfs.prefix|
+
+## 2. 注释规约
+1. 【**强制**】类、类属性、接口方法必须加注释,且注释必须使用 Javadoc 规范,使用`/**内容*/`格式。
+
+示例:
+```java
+/** Wrap the communication between Bml service */
+public class BmlAppServiceImpl implements BmlAppService {
+ /** Bml client */
+ private BmlClient client;
+}
+```
+2. 【**强制**】所有的类都不要添加创建者。Linkis项目已捐献给Apache,无须添加作者信息。
+
+3. 【**强制**】所有的抽象方法(包括接口中的方法)必须要用 Javadoc 注释、除了返回值、参数、 异常说明外,还必须指出该方法做什么事情,实现什么功能。
+
+4. 【**强制**】方法内部单行注释,在被注释语句上方另起一行,使用 // 注释。方法内部多行注释使用 /* */ 注释,注意与代码对齐。
+
+示例:
+```java
+ // Store the reflection relation between parameter variable like 'T' and type like
+ Map typeVariableReflect = new HashMap<>();
+```
+5. 【**强制**】所有的枚举类型字段必须要有注释,说明每个数据项的用途。
+
+示例:
+```java
+/**
+ * 节点监控状态信息
+ * to monitor node status info
+ */
+public enum NodeHealthy {
+
+ /**
+ * 状态正常
+ * healthy status
+ */
+ Healthy,
+
+ /**
+ * EM自己标识自己为UnHealthy 或者manager把他标识为UnHealthy 处理引擎状态不正常,
+ * manager主动要求所有的engine强制退出(engine自杀)
+ * EM identifies itself as UnHealthy or
+ * The manager marks it as abnormal in the status of UnHealthy processing engine.
+ * The manager requests all engines to withdraw forcibly (engine suicide).
+ */
+ UnHealthy,
+
+ /**
+ * 引擎处于告警状态,但是可以接受任务
+ * The engine is in the alarm state, but can accept tasks
+ */
+ WARN,
+
+ /**
+ * 存量可用状态,可以接受任务。当EM状态最近n次心跳没有上报,但是已经启动的Engine还是正常的可以接受任务
+ * The stock is available and can accept tasks. When the EM status is not reported for the last n heartbeats,
+ * the Engine that has been started is still normal and can accept tasks
+ */
+ StockAvailable,
+
+ /**
+ * 存量不可用状态,不可以接受任务。(超过n+1没上报心跳)或者(EM自己判断,但是服务正常的情况),
+ * 但是如果往上面提交任务会出现error失败情况 EM处于StockUnavailable时,
+ * manager主动要求所有的engine非强制退出,manager需要将EM标识为UnHealthy。
+ * 如果StockUnavailable状态如果超过n分钟,则发送IMS告警
+ * The stock is not available. Tasks cannot be accepted
+ */
+ StockUnavailable;
+}
+```
+6. 【推荐】代码修改的同时,注释也要进行相应的修改,尤其是参数、返回值、异常、核心逻辑等的修改。
+7. 【推荐】在类中删除未使用的任何字段、方法、内部类;在方法中删除未使用的任何参数声明与内部变量。
+8. 【参考】谨慎注释掉代码。在上方详细说明,而不是简单地注释掉。如果无用,则删除。代码被注释掉有两种可能性:1)后续会恢复此段代码逻辑。2)永久不用。前者如果没有备注信息,难以知晓注释动机。后者建议直接删掉即可,假如需要查阅历史代码,登录代码仓库即可。
+
+示例:
+```java
+ public static final CommonVars TUNING_CLASS =
+ CommonVars.apply(
+ "wds.linkis.cs.ha.class", "org.apache.linkis.cs.highavailable.DefaultContextHAManager");
+ // 应该删除如下注释代码
+ // public static final CommonVars TUNING_CLASS =
+ // CommonVars.apply("wds.linkis.cs.ha.class","org.apache.linkis.cs.persistence.ProxyMethodA");
+```
+9. 【参考】对于注释的要求:第一、能够准确反映设计思想和代码逻辑;第二、能够描述业务含义,使别的程序员能够迅速了解到代码背后的信息。完全没有注释的大段代码对于阅读者形同天书,注释是给自己看的,即使隔很长时间,也能清晰理解当时的思路;注释也是给继任者看的,使其能够快速接替自己的工作。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/release-notes.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/release-notes.md
new file mode 100644
index 00000000000..f79192ef99c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/release-notes.md
@@ -0,0 +1,42 @@
+---
+title: Release-Notes 编写规范
+sidebar_position: 9
+---
+每次版本发布前,需要由发布经理或则开发者,整理好本次版本的release-notes,来简要地描述了新版本更新中包含的特定更改。
+
+为保持统一和方便编写,制定如下规范:
+- 需要有版本的总结,几句话总结性的描述本版本的核心主要变动点
+- 按变化的功能点 以 新特性/增强点/修复功能/其他 四大类进行分类罗列
+- 包含致谢栏:有参与本此版本贡献的同学,除了issue/pr外,以及任何参与到此次版本讨论/社群答疑/意见建议的同学
+- 每条note的规范:`[服务名缩写-L1 maven module名][Linkis-pr/issues序号] 本次变动简要描述信息,能通过描述信息,大体知道这个功能的变化` `[服务名缩写-L1 maven module名]`作为一个标签,示例如下
+- 同一类别(新特性/增强点/修复功能/其他)下, 服务名相同的放在一起,按pr/issues序号升序排列
+- 需要有对应的英文文档
+
+```
+服务名缩写:此pr的变动,在代码层面上,主要归属的服务对应的服务名缩写
+比如某pr是对JDBC引擎做了bug修复,在代码层面上,它是linkis-cg-engineconn 服务下的JDBC模块
+EG:[EC-Jdbc][[Linkis-1851]](https://github.com/apache/linkis/issues/1851) 修复jdbc引擎,一次任务执行中存在多条sql语句时无法正常执行的问题
+若 L1 maven module 不存在,或则是整个服务级别的调整,下级模块可以不写,比如Entrance
+```
+
+## 常见的notes 标签
+```html
+linkis-mg-eureka Eureka
+linkis-mg-gateway Gataway
+linkis-cg-linkismanager LM
+linkis-cg-engineconnplugin ECP
+linkis-cg-engineconnmanager ECM
+linkis-cg-engineconn EC
+linkis-cg-entrance Entrance
+linkis-ps-publicservice PS
+linkis-ps-cs CS
+linkis-ps-metadatamanager MDM
+linkis-ps-data-source-query DSQ
+
+Web管理台 Web
+安装 Install
+安装-脚本 Install-Scripts
+安装-SQL Install-Sql
+安装-Web Install-Web
+公共模块 Common
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/unit-test.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/unit-test.md
new file mode 100644
index 00000000000..7e486ddcd23
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/unit-test.md
@@ -0,0 +1,12 @@
+---
+title: 测试规约
+sidebar_position: 7
+---
+
+1. 【**强制**】工具类和服务内部接口一定要有测试样例。
+2. 【**强制**】单元测试需要能够自动化(通过 mvn编译即可触发)、独立性(单元测试用例间不可相互调用)、可重复执行(可以多次执行,结果一样)。
+3. 【**强制**】一个测试用例应该只测试一个方法。
+4. 【**强制**】测试用例异常不可以catch,需要向上抛出。
+5. 【**强制**】单元测试代码必须写在如下工程目录:src/test/java or scala,不允许写在其他录下。
+6. 【推荐】单元测试需要考虑边界条件,如日期需要考虑月末和2月。
+7. 【推荐】对于数据库相关的单元测试,要考虑数据回滚。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/version-feature-specifications.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/version-feature-specifications.md
new file mode 100644
index 00000000000..f1f441b5874
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/development-specification/version-feature-specifications.md
@@ -0,0 +1,26 @@
+---
+title: 版本和新特性规范
+sidebar_position: 8
+---
+
+## 1. 新增版本规范
+当您有新的版本需要时,需要遵循以下步骤:
+1. 【强制】新版本一定需要组织PMC成员和开发者进行讨论,需要记录会议纪要发送邮件列表
+2. 【强制】新版本的特性列表范围,需要发起邮件投票.需要3+ PMC成员同意且同意票大于反对票
+3. 【强制】版本投票通过后,需要在GitHub建立对应的版本[Project](https://github.com/apache/linkis/projects)
+4. 【强制】每个特性需要单独发送邮件列表,说明设计原因、设计思路
+5. 【强制】涉及到安装、数据库、配置修改的也需要发送邮件列表
+6. 【推荐】一个特性对应一个issue对应一个PR
+7. 【强制】每个版本需要保证CICD通过、测试案例通过才可以发布版本
+8. 【约束】每个版本需要有对应的Leader,leader需要管理相关的Issue和PR,并拉会讨论、积极回复邮件、确认方案、追踪进度等
+
+
+## 2. 新加特性规范
+当您有新特性的新增时,需要遵循以下步骤:
+1. 【强制】新特性需要发送邮件进行投票,并附上设计原因,设计思路
+2. 【强制】需要在GitHub对应的版本中新添加特性[Project](https://github.com/apache/linkis/projects)
+3. 【强制】涉及到安装、数据库、配置修改的也需要发送邮件列表
+4. 【强制】新的特性一定要新增文档
+5. 【强制】新加特性需要新增对应的单元测试,[单元测试规范](https://linkis.apache.org/community/development-specification/unit_test)
+6. 【推荐】一个特性对应一个issue对应一个PR
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/directory-structure.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/directory-structure.md
new file mode 100644
index 00000000000..1d2bc407415
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/directory-structure.md
@@ -0,0 +1,296 @@
+---
+title: 目录结构
+sidebar_position: 2.0
+---
+
+> Linkis代码层级目录结构,以及安装包目录结构和部署后的目录结构说明,如果想详细了解各个模块,请查看[Linkis的相关架构设计](architecture/overview.md)
+
+## 1. 源码目录结构
+
+```html
+├── docs
+│ ├── configuration //linkis所有模块的配置项文档
+│ ├── errorcode //linkis所有模块的错误码文档
+├── linkis-commons //核心抽象,里面放有所有的公用模块
+│ ├── linkis-common //通用模块,内置很多通用工具类
+│ ├── linkis-hadoop-common
+│ ├── linkis-httpclient //Java SDK顶层接口 对httpclient的进一步封装
+│ ├── linkis-module // linkis的服务顶层公用模块 涉及到服务启动时的参数和服务初始化 统一的Restful处理 登录态校验等
+│ ├── linkis-mybatis //SpringCloud的Mybatis模块
+│ ├── linkis-protocol //服务请求/响应的一些接口和实体类
+│ ├── linkis-rpc //RPC模块,基于Feign实现的复杂双向通信
+│ ├── linkis-scheduler //通用调度模块
+│ ├── linkis-storage //文件操作工具集
+├── linkis-computation-governance //计算治理服务
+│ ├── linkis-client //Java SDK,用户通过Client可直接访问Linkis
+│ ├── linkis-computation-governance-common
+│ ├── linkis-engineconn
+│ ├── linkis-engineconn-manager
+│ ├── linkis-entrance //通用底层entrance模块
+│ ├── linkis-jdbc-driver //可以类似jdbc sdk方式连接使用linkis
+│ ├── linkis-manager
+├── linkis-dist //编译打包最后阶段步骤 整合所有lib包和安装部署脚本配置等
+│ ├── bin
+│ │ ├── checkEnv.sh
+│ │ ├── common.sh
+│ │ └── install.sh //安装脚本
+│ ├── deploy-config
+│ │ ├── db.sh //数据库配置
+│ │ └── linkis-env.sh //linkis 启动相关配置
+│ ├── docker
+│ │ └── scripts
+│ ├── helm
+│ │ ├── charts
+│ │ ├── scripts
+│ │ ├── README_CN.md
+│ │ └── README.md
+│ ├── package
+│ │ ├── bin
+│ │ ├── conf
+│ │ ├── db
+│ │ └── sbin
+│ ├── release-docs
+│ │ ├── licenses
+│ │ ├── LICENSE
+│ │ └── NOTICE
+│ ├── src
+│ └── pom.xml
+├── linkis-engineconn-plugins // 引擎
+│ ├── elasticsearch
+│ ├── flink
+│ ├── hive
+│ ├── io_file
+│ ├── jdbc
+│ ├── openlookeng
+│ ├── pipeline
+│ ├── presto
+│ ├── python
+│ ├── seatunnel
+│ ├── shell
+│ ├── spark
+│ ├── sqoop
+├── linkis-extensions // 扩展功能增强插件模块
+│ ├── linkis-io-file-client // 对linkis-storage的功能扩展
+├── linkis-orchestrator //服务的编排
+│ ├── linkis-code-orchestrator
+│ ├── linkis-computation-orchestrator
+│ ├── linkis-orchestrator-core
+├── linkis-public-enhancements //公共增强服务
+│ ├── linkis-basedata-manager
+│ ├── linkis-bml // 物料库
+│ ├── linkis-configuration
+│ ├── linkis-context-service //统一上下文
+│ ├── linkis-datasource //数据源服务
+│ ├── linkis-error-code
+│ ├── linkis-instance-label
+│ ├── linkis-jobhistory
+│ ├── linkis-ps-common-lock
+│ ├── linkis-script-dev
+│ ├── linkis-udf
+│ ├── linkis-variable
+├── linkis-spring-cloud-services //微服务治理
+│ ├── linkis-service-discovery
+│ ├── linkis-service-gateway //网关Gateway
+├── linkis-web //linkis的管理台代码
+│ ├── release-docs
+│ │ ├── licenses
+│ │ └── LICENSE
+│ ├── src
+│ ├── config.sh
+│ ├── install.sh
+│ ├── package.json
+│ ├── pom.xml
+│ └── vue.config.js
+├── tool
+│ ├── dependencies
+│ │ ├── known-dependencies.txt
+│ │ └── regenerate_konwn_dependencies_txt.sh
+│ ├── code-style-idea.xml
+│ ├── license-header
+│ └── modify_license.sh
+├── CONTRIBUTING_CN.md
+├── CONTRIBUTING.md
+├── linkis-tree.txt
+├── mvnw
+├── mvnw.cmd
+├── pom.xml
+├── README_CN.md
+├── README.md
+└── scalastyle-config.xml
+
+```
+
+## 2. 安装包目录结构
+
+> Linkis安装包解压后的目录结构
+
+下载官方发布的[编译完整包](https://linkis.apache.org/zh-CN/download/main),解压后的目录结构如下:
+```html
+
+├── bin
+│ ├── checkEnv.sh ── 环境变量检测
+│ ├── common.sh ── 部分公共shell函数
+│ └── install.sh ── Linkis安装的主脚本
+├── deploy-config
+│ ├── db.sh //数据库连接配置
+│ └── linkis-env.sh //相关环境配置信息
+├── docker
+├── helm
+├── licenses
+├── linkis-package //微服务相关的启动配置文件,依赖,脚本,linkis-cli等
+│ ├── bin
+│ ├── conf
+│ ├── db
+│ ├── lib
+│ └── sbin
+├── NOTICE
+├── LICENSE
+├── README_CN.md
+└── README.md
+
+```
+
+
+## 3. 部署后的目录结构
+
+安装后`${LINKIS_HOME}`目录结构
+
+```html
+├── bin ── linkis-cli 用于向Linkis提交任务的Shell命令行程序
+│ ├── linkis-cli
+│ ├── linkis-cli-hive
+│ ├── linkis-cli-pre
+│ ├── linkis-cli-spark-sql
+│ ├── linkis-cli-spark-submit
+│ └── linkis-cli-sqoop
+├── conf 配置目录
+│ ├── application-eureka.yml
+│ ├── application-linkis.yml ── 微服务通用yml
+│ ├── linkis-cg-engineconnmanager.properties
+│ ├── linkis-cg-engineplugin.properties
+│ ├── linkis-cg-entrance.properties
+│ ├── linkis-cg-linkismanager.properties
+│ │── linkis-cli
+│ │ ├── linkis-cli.properties
+│ │ └── log4j2.xml
+│ ├── linkis-env.sh ── linkis 环境变量配置
+│ ├── linkis-mg-gateway.properties
+│ ├── linkis.properties ── linkis 服务的全局配合,所有微服务启动都会加载使用
+│ ├── linkis-ps-publicservice.properties
+│ ├── log4j2.xml
+├── db 数据库DML和DDL文件目录
+│ ├── linkis_ddl.sql ── 数据库表定义SQL
+│ ├── linkis_dml.sql ── 数据库表初始化SQL
+│ └── module ── 包含各个微服务的DML和DDL文件
+│ └── upgrade ── 针对每个版本 增量DML/DDL
+├── lib lib目录
+│ ├── linkis-commons ── 公共依赖包 大多服务启动时(linkis-mg-gateway除外) -cp 路径参数 都会加载这个目录
+│ ├── linkis-computation-governance ──计算治理模块的lib目录
+│ ├── linkis-engineconn-plugins ──所有引擎插件的lib目录
+│ ├── linkis-public-enhancements ──公共增强服务的lib目录
+│ └── linkis-spring-cloud-services ──SpringCloud的lib目录
+├── logs 日志目录
+│ ├── linkis-cg-engineconnmanager-gc.log
+│ ├── linkis-cg-engineconnmanager.log
+│ ├── linkis-cg-engineconnmanager.out
+│ ├── linkis-cg-engineplugin-gc.log
+│ ├── linkis-cg-engineplugin.log
+│ ├── linkis-cg-engineplugin.out
+│ ├── linkis-cg-entrance-gc.log
+│ ├── linkis-cg-entrance.log
+│ ├── linkis-cg-entrance.out
+│ ├── linkis-cg-linkismanager-gc.log
+│ ├── linkis-cg-linkismanager.log
+│ ├── linkis-cg-linkismanager.out
+│ ├── linkis-cli
+│ │ ├── linkis-client.hadoop.log.20220409162400037523664
+│ ├── linkis-mg-eureka-gc.log
+│ ├── linkis-mg-eureka.log
+│ ├── linkis-mg-eureka.out
+│ ├── linkis-mg-gateway-gc.log
+│ ├── linkis-mg-gateway.log
+│ ├── linkis-mg-gateway.out
+│ ├── linkis-ps-publicservice-gc.log
+│ ├── linkis-ps-publicservice.log
+│ └── linkis-ps-publicservice.out
+├── pid 所有微服务的进程ID
+│ ├── linkis_cg-engineconnmanager.pid ──引擎管理器微服务
+│ ├── linkis_cg-engineconnplugin.pid ──引擎插件微服务
+│ ├── linkis_cg-entrance.pid ──引擎入口微服务
+│ ├── linkis_cg-linkismanager.pid ──linkis管理器微服务
+│ ├── linkis_mg-eureka.pid ──eureka微服务
+│ ├── linkis_mg-gateway.pid ──gateway微服务
+│ └── linkis_ps-publicservice.pid ──公共微服务
+└── sbin 微服务启停脚本目录
+ ├── ext ──各个微服务的启停脚本目录
+ ├── linkis-daemon.sh ── 快捷启停、重启单个微服务脚本
+ ├── linkis-start-all.sh ── 一键启动全部微服务脚本
+ └── linkis-stop-all.sh ── 一键停止全部微服务脚本
+
+```
+
+### 3.1 配置项修改
+
+在执行完Linkis安装后,所有配置项位于conf目录下,
+如果需要进行配置项修改,修改配置`${LINKIS_HOME}/conf/*properties`文件后,重启对应的服务,
+如:`sh sbin/linkis-daemon.sh start ps-publicservice`。
+如果修改的是公共配置文件`application-eureka.yml/application-linkis.yml/linkis.properties`,需要重启所有服务`sh sbin/linkis-start-all.sh`
+
+
+
+
+### 3.2 微服务启停
+
+所有微服务名称如下:
+ ```
+├── linkis-cg-engineconnmanager 引擎管理服务
+├── linkis-cg-engineplugin 引擎插件管理服务
+├── linkis-cg-entrance 计算治理入口服务
+├── linkis-cg-linkismanager 计算治理管理服务
+├── linkis-mg-eureka 微服务注册中心服务
+├── linkis-mg-gateway Linkis网关服务
+├── linkis-ps-publicservice 公共服务
+ ```
+
+**微服务简称**:
+
+ | 简称 | 英文全称 | 中文全称 |
+ |------|-------------------------|------------|
+ | cg | Computation Governance | 计算治理 |
+ | mg | Microservice Covernance | 微服务治理 |
+ | ps | Public Enhancement Service | 公共增强服务 |
+
+
+
+```
+# 一次性启动所有微服务:
+
+ sh linkis-start-all.sh
+
+# 一次性关停所有微服务
+
+ sh linkis-stop-all.sh
+
+# 启动单个微服务(服务名需要去掉linkis前缀如:mg-eureka)
+
+ sh linkis-daemon.sh start service-name
+
+ 例如: sh linkis-daemon.sh start mg-eureka
+
+# 关闭单个微服务
+
+ sh linkis-daemon.sh stop service-name
+
+ 例如: sh linkis-daemon.sh stop mg-eureka
+
+# 重启单个微服务
+
+ sh linkis-daemon.sh restart service-name
+
+ 例如: sh linkis-daemon.sh restart mg-eureka
+# 查看单个微服务的状态
+
+ sh linkis-daemon.sh status service-name
+
+ 例如: sh linkis-daemon.sh status mg-eureka
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/c-debug.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/c-debug.png
new file mode 100644
index 00000000000..d5edce7fe24
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/c-debug.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/c-port.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/c-port.png
new file mode 100644
index 00000000000..2c0a8cb420f
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/c-port.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/debug.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/debug.png
new file mode 100644
index 00000000000..4c0a9e39e4e
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/debug.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/test-0.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/test-0.png
new file mode 100644
index 00000000000..3ebe85fe283
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/test-0.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/test-1.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/test-1.png
new file mode 100644
index 00000000000..3ebe85fe283
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/test-1.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/test-2.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/test-2.png
new file mode 100644
index 00000000000..95ad650c167
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/images/test-2.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/new-engine-conn.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/new-engine-conn.md
new file mode 100644
index 00000000000..0af601bc4a5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/new-engine-conn.md
@@ -0,0 +1,477 @@
+---
+title: 如何实现新引擎
+sidebar_position: 8.0
+---
+
+## 1. Linkis新引擎功能代码实现
+
+实现一个新的引擎其实就是实现一个新的EngineConnPlugin(ECP)引擎插件。具体步骤如下:
+
+### 1.1 新建一个maven模块,并引入ECP的maven依赖
+
+![maven依赖](/Images-zh/EngineConnNew/engine_jdbc_dependency.png)
+
+```xml
+
+ org.apache.linkis
+ linkis-engineconn-plugin-core
+ ${linkis.version}
+
+
+```
+
+### 1.2 实现ECP的主要接口
+
+- **EngineConnPlugin:** 启动EngineConn时,先找到对应的EngineConnPlugin类,以此为入口,获取其它核心接口的实现,是必须实现的主要接口。
+
+- **EngineConnFactory:** 实现如何启动一个引擎连接器,和如何启动一个引擎执行器的逻辑,是必须实现的接口。
+ - 实现createEngineConn方法:返回一个EngineConn对象,其中,getEngine返回一个封装了与底层引擎连接信息的对象,同时包含Engine类型信息。
+ - 对于只支持单一计算场景的引擎,继承SingleExecutorEngineConnFactory,实现createExecutor,返回对应的Executor。
+ - 对于支持多计算场景的引擎,需要继承MultiExecutorEngineConnFactory,并为每种计算类型实现一个ExecutorFactory。EngineConnPlugin会通过反射获取所有的ExecutorFactory,根据实际情况返回对应的Executor。
+- **EngineConnResourceFactory:** 用于限定启动一个引擎所需要的资源,引擎启动前,将以此为依 据 向 Linkis Manager 申 请 资 源。非必须,默认可以使用GenericEngineResourceFactory。
+- **EngineLaunchBuilder:** 用于封装EngineConnManager可以解析成启动命令的必要信息。非必须,可以直接继承JavaProcessEngineConnLaunchBuilder。
+
+### 1.3 实现引擎Executor执行器逻辑
+
+Executor为执行器,作为真正的计算场景执行器,是实际的计算逻辑执行单元,也是对引擎各种具体能力的抽象,提供加锁、访问状态、获取日志等多种不同的服务。并根据实际的使用需要,Linkis默认提供以下的派生Executor基类,其类名和主要作用如下:
+
+- **SensibleExecutor:**
+ - Executor存在多种状态,允许Executor切换状态
+ - Executor切换状态后,允许做通知等操作
+- **YarnExecutor:** 指Yarn类型的引擎,能够获取得到applicationId和applicationURL和队列。
+- **ResourceExecutor:** 指引擎具备资源动态变化的能力,配合提供requestExpectedResource方法,用于每次希望更改资源时,先向RM申请新的资源;而resourceUpdate方法,用于每次引擎实际使用资源发生变化时,向RM汇报资源情况。
+- **AccessibleExecutor:** 是一个非常重要的Executor基类。如果用户的Executor继承了该基类,则表示该Engine是可以被访问的。这里需区分SensibleExecutor的state()和 AccessibleExecutor 的 getEngineStatus()方法:state()用于获取引擎状态,getEngineStatus()会获取引擎的状态、负载、并发等基础指标Metric数据。
+- 同时,如果继承了 AccessibleExecutor,会触发Engine 进程实例化多个EngineReceiver方法。EngineReceiver用于处理Entrance、EM和LinkisMaster的RPC请求,使得该引擎变成了一个可被访问的引擎,用户如果有特殊的RPC需求,可以通过实现RPCService接口,进而实现与AccessibleExecutor通信。
+- **ExecutableExecutor:** 是一个常驻型的Executor基类,常驻型的Executor包含:生产中心的Streaming应用、提交给Schedulis后指定要以独立模式运行的脚步、业务用户的业务应用等。
+- **StreamingExecutor:** Streaming为流式应用,继承自ExecutableExecutor,需具备诊断、do checkpoint、采集作业信息、监控告警的能力。
+- **ComputationExecutor:** 是常用的交互式引擎Executor,处理交互式执行任务,并且具备状态查询、任务kill等交互式能力。
+- **ConcurrentComputationExecutor:** 用户并发引擎Executor,常用于JDBC类型引擎,执行脚本时,由管理员账户拉起引擎实例,所有用户共享引擎实例。
+
+## 2. 以JDBC引擎为例详解新引擎的实现步骤
+
+本章节以JDBC引擎举例,详解新引擎的实现过程,包括引擎代码的编译、安装、数据库配置,管理台引擎标签适配,以及Scripts中新引擎脚本类型扩展和工作流新引擎的任务节点扩展等。
+
+### 2.1 并发引擎设置默认启动用户
+
+JDBC引擎中的核心类`JDBCEngineConnExecutor`继承的抽象类是`ConcurrentComputationExecutor`,计算类引擎中的核心类`XXXEngineConnExecutor`继承的抽象类是`ComputationExecutor`。这导致两者最大的一个区别是:JDBC引擎实例由管理员用户启动,被所有用户共享,以提高机器资源利用率;而计算引擎类型的脚本在提交时,每个用户下会启动一个引擎实例,用户间引擎实例互相隔离。这个在此处暂不细说,因为无论是并发引擎还是计算引擎,下文提到的额外修改流程应是一致的。
+
+相应的,如果你新增的引擎是并发引擎,那么你需要关注下这个类:AMConfiguration.scala,如果你新增的引擎是计算类引擎,则可忽略。
+
+```scala
+object AMConfiguration {
+ // 如果你的引擎是多用户并发引擎,那么这个配置项需要关注下
+ val MULTI_USER_ENGINE_TYPES = CommonVars("wds.linkis.multi.user.engine.types", "jdbc,ck,es,io_file,appconn")
+
+ private def getDefaultMultiEngineUser(): String = {
+ // 此处应该是为了设置并发引擎拉起时的启动用户,默认jvmUser即是引擎服务Java进程的启动用户
+ val jvmUser = Utils.getJvmUser
+ s"""{jdbc:"$jvmUser", presto: "$jvmUser" es: "$jvmUser", ck:"$jvmUser", appconn:"$jvmUser", io_file:"root"}"""
+ }
+}
+```
+
+### 2.2 新引擎类型扩展
+
+实现`ComputationSingleExecutorEngineConnFactory`接口的类`JDBCEngineConnFactory`中,下面两个方法需要实现:
+
+```scala
+override protected def getEngineConnType: EngineType = EngineType.JDBC
+
+override protected def getRunType: RunType = RunType.JDBC
+```
+
+因此需要在EngineType和RunType中增加JDBC对应的变量。
+
+```scala
+// EngineType.scala中类似已存在引擎的变量定义,增加JDBC相关变量或代码
+object EngineType extends Enumeration with Logging {
+ val JDBC = Value("jdbc")
+}
+
+def mapStringToEngineType(str: String): EngineType = str match {
+ case _ if JDBC.toString.equalsIgnoreCase(str) => JDBC
+}
+
+// RunType.scla中
+object RunType extends Enumeration {
+ val JDBC = Value("jdbc")
+}
+```
+
+### 2.3 JDBC引擎标签中的版本号设置
+
+```scala
+// 在LabelCommonConfig中增加JDBC的version配置
+public class LabelCommonConfig {
+ public final static CommonVars JDBC_ENGINE_VERSION = CommonVars.apply("wds.linkis.jdbc.engine.version", "4");
+}
+
+// 在EngineTypeLabelCreator的init方法中补充jdbc的匹配逻辑
+// 如果这一步不做,代码提交到引擎上时,引擎标签信息中会缺少版本号
+public class EngineTypeLabelCreator {
+ private static void init() {
+ defaultVersion.put(EngineType.JDBC().toString(), LabelCommonConfig.JDBC_ENGINE_VERSION.getValue());
+ }
+}
+```
+
+### 2.4 允许脚本编辑器打开的脚本文件类型
+
+关注配置项:wds.linkis.storage.file.type
+
+```scala
+object LinkisStorageConf{
+ val FILE_TYPE = CommonVars("wds.linkis.storage.file.type", "dolphin,sql,scala,py,hql,python,out,log,text,sh,jdbc,ngql,psql,fql").getValue
+}
+```
+
+### 2.5 配置JDBC脚本变量存储和解析
+
+如果这个操作不做,JDBC的脚本中变量不能被正常存储和解析,脚本中直接使用${变量}时代码会执行失败!
+
+![变量解析](/Images-zh/EngineConnNew/variable_resolution.png)
+
+```scala
+// 通过CodeAndRunTypeUtils工具类中的CODE_TYPE_AND_RUN_TYPE_RELATION变量来维护codeType和runType间的对应关系
+val CODE_TYPE_AND_RUN_TYPE_RELATION = CommonVars("wds.linkis.codeType.runType.relation", "sql=>sql|hql|jdbc|hive|psql|fql,python=>python|py|pyspark,java=>java,scala=>scala,shell=>sh|shell")
+```
+
+参考PR:https://github.com/apache/linkis/pull/2047
+
+### 2.6 Linkis管理员台界面引擎管理器中加入JDBC引擎文字提示或图标
+
+linkis-web/src/dss/module/resourceSimple/engine.vue
+
+```js
+methods: {
+ calssifyName(params) {
+ switch (params) {
+ case 'jdbc':
+ return 'JDBC';
+ ......
+ }
+ }
+ // 图标过滤
+ supportIcon(item) {
+ const supportTypes = [
+ ......
+ { rule: 'jdbc', logo: 'fi-jdbc' },
+ ];
+ }
+}
+```
+
+
+
+最终呈现给用户的效果:
+
+![JDBC类型引擎](/Images-zh/EngineConnNew/jdbc_engine_view.png)
+
+### 2.7 JDBC引擎的编译打包和安装部署
+
+JDBC引擎模块编译的示例命令如下:
+
+```shell
+cd /linkis-project/linkis-engineconn-pluginsengineconn-plugins/jdbc
+
+mvn clean install -DskipTests
+```
+
+编译完整项目时,新增引擎默认不会加到最终的tar.gz压缩包中,如果需要,请修改如下文件:
+
+linkis-dist/src/main/assembly/distribution.xml
+
+```xml
+
+
+ ......
+
+
+ ../linkis-engineconn-plugins/jdbc/target/out/
+
+ linkis-package/lib/linkis-engineconn-plugins/
+
+ **/*
+
+
+
+```
+
+然后对在项目根目录运行编译命令:
+
+```shell
+mvn clean install -DskipTests
+```
+
+编译成功后在linkis-dist/target/apache-linkis-1.x.x-bin.tar.gz和linkis-engineconn-plugins/jdbc/target/目录下找到out.zip。
+
+上传out.zip文件到Linkis的部署节点,解压缩到Linkis安装目录/lib/linkis-engineconn-plugins/下面:
+
+![引擎安装](/Images-zh/EngineConnNew/engine_set_up.png)
+
+解压后别忘记删除out.zip,至此引擎编译和安装完成。
+
+### 2.8 JDBC引擎数据库配置
+
+在管理台选择添加引擎
+
+![添加引擎](/Images-zh/EngineConnNew/add_engine_conf.png)
+
+
+
+如果您希望在管理台支持引擎参数配置,可以按照JDBC引擎SQL示例修改数据库。
+
+此处以JDBC引擎为例,引擎安装完之后,要想运行新的引擎代码,还需对引擎进行数据库配置,以JDBC引擎为例,按照你自己实现的新引擎的情况,请按需修改。
+
+SQL参考如下:
+
+```sql
+SET @JDBC_LABEL="jdbc-4";
+
+SET @JDBC_ALL=CONCAT('*-*,',@JDBC_LABEL);
+SET @JDBC_IDE=CONCAT('*-IDE,',@JDBC_LABEL);
+SET @JDBC_NODE=CONCAT('*-nodeexecution,',@JDBC_LABEL);
+
+-- JDBC
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.instance', '范围:1-20,单位:个', 'jdbc引擎最大并发数', '2', 'NumInterval', '[1,20]', '0', '0', '1', '队列资源', 'jdbc');
+
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.driver', '取值范围:对应JDBC驱动名称', 'jdbc驱动名称','', 'None', '', '0', '0', '1', '数据源配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.connect.url', '例如:jdbc:hive2://127.0.0.1:10000', 'jdbc连接地址', 'jdbc:hive2://127.0.0.1:10000', 'None', '', '0', '0', '1', '数据源配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.version', '取值范围:jdbc3,jdbc4', 'jdbc版本','jdbc4', 'OFT', '[\"jdbc3\",\"jdbc4\"]', '0', '0', '1', '数据源配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.connect.max', '范围:1-20,单位:个', 'jdbc引擎最大连接数', '10', 'NumInterval', '[1,20]', '0', '0', '1', '数据源配置', 'jdbc');
+
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.auth.type', '取值范围:SIMPLE,USERNAME,KERBEROS', 'jdbc认证方式', 'USERNAME', 'OFT', '[\"SIMPLE\",\"USERNAME\",\"KERBEROS\"]', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.username', 'username', '数据库连接用户名', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.password', 'password', '数据库连接密码', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.principal', '例如:hadoop/host@KDC.COM', '用户principal', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.keytab.location', '例如:/data/keytab/hadoop.keytab', '用户keytab文件路径', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.proxy.user.property', '例如:hive.server2.proxy.user', '用户代理配置', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.java.driver.cores', '取值范围:1-8,单位:个', 'jdbc引擎初始化核心个数', '1', 'NumInterval', '[1,8]', '0', '0', '1', 'jdbc引擎设置', 'jdbc');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.java.driver.memory', '取值范围:1-8,单位:G', 'jdbc引擎初始化内存大小', '1g', 'Regex', '^([1-8])(G|g)$', '0', '0', '1', 'jdbc引擎设置', 'jdbc');
+
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@JDBC_ALL, 'OPTIONAL', 2, now(), now());
+
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+ (select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'jdbc' and label_value = @JDBC_ALL);
+
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@JDBC_IDE, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@JDBC_NODE, 'OPTIONAL', 2, now(), now());
+
+
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @JDBC_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @JDBC_NODE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+
+-- jdbc default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+ (select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @JDBC_ALL);
+```
+
+如果想重置引擎的数据库配置数据,参考文件如下,请按需进行修改使用:
+
+```sql
+-- 清除jdbc引擎的初始化数据
+SET @JDBC_LABEL="jdbc-4";
+
+SET @JDBC_ALL=CONCAT('*-*,',@JDBC_LABEL);
+SET @JDBC_IDE=CONCAT('*-IDE,',@JDBC_LABEL);
+SET @JDBC_NODE=CONCAT('*-nodeexecution,',@JDBC_LABEL);
+
+delete from `linkis_ps_configuration_config_value` where `config_label_id` in
+ (select `relation`.`engine_type_label_id` AS `config_label_id` FROM `linkis_ps_configuration_key_engine_relation` relation INNER JOIN `linkis_cg_manager_label` label ON relation.engine_type_label_id = label.id AND label.label_value = @JDBC_ALL);
+
+
+delete from `linkis_ps_configuration_key_engine_relation`
+where `engine_type_label_id` in
+ (select label.id FROM `linkis_ps_configuration_config_key` config
+ INNER JOIN `linkis_cg_manager_label` label
+ ON config.engine_conn_type = 'jdbc' and label_value = @JDBC_ALL);
+
+
+delete from `linkis_ps_configuration_category`
+where `label_id` in (select id from `linkis_cg_manager_label` where `label_value` in(@JDBC_IDE, @JDBC_NODE));
+
+
+delete from `linkis_ps_configuration_config_key` where `engine_conn_type` = 'jdbc';
+
+delete from `linkis_cg_manager_label` where `label_value` in (@JDBC_ALL, @JDBC_IDE, @JDBC_NODE);
+
+```
+
+最终的效果:
+
+![JDBC引擎](/Images-zh/EngineConnNew/jdbc_engine_conf_detail.png)
+
+这样配置完之后,linkis-cli以及Scripts提交引擎脚本时,才能正确匹配到引擎的标签信息和数据源的连接信息,然后才能拉起你新加的引擎。
+
+### 2.9 DSS Scripts中新增JDBC脚本类型以及图标等信息
+
+如果你使用到了DSS的Scripts功能,还需要对dss项目中web的前端文件进行一些小小的改动,改动的目的是为了在Scripts中支持新建、打开、执行JDBC引擎脚本类型,以及实现引擎对应的图标、字体等。
+
+#### 2.9.1 scriptis.js
+
+web/src/common/config/scriptis.js
+
+```js
+{
+ rule: /\.jdbc$/i,
+ lang: 'hql',
+ executable: true,
+ application: 'jdbc',
+ runType: 'jdbc',
+ ext: '.jdbc',
+ scriptType: 'jdbc',
+ abbr: 'jdbc',
+ logo: 'fi-jdbc',
+ color: '#444444',
+ isCanBeNew: true,
+ label: 'JDBC',
+ isCanBeOpen: true
+},
+```
+
+#### 2.9.2 脚本复制支持
+
+web/src/apps/scriptis/module/workSidebar/workSidebar.vue
+
+```js
+copyName() {
+ let typeArr = ['......', 'jdbc']
+}
+```
+
+#### 2.9.3 logo与字体配色
+
+web/src/apps/scriptis/module/workbench/title.vue
+
+```js
+ data() {
+ return {
+ isHover: false,
+ iconColor: {
+ 'fi-jdbc': '#444444',
+ },
+ };
+ },
+```
+
+web/src/apps/scriptis/module/workbench/modal.js
+
+```js
+let logoList = [
+ { rule: /\.jdbc$/i, logo: 'fi-jdbc' },
+];
+```
+
+web/src/components/tree/support.js
+
+```js
+export const supportTypes = [
+ // 这里大概没用到
+ { rule: /\.jdbc$/i, logo: 'fi-jdbc' },
+]
+```
+
+引擎图标展示
+
+web/src/dss/module/resourceSimple/engine.vue
+
+```js
+methods: {
+ calssifyName(params) {
+ switch (params) {
+ case 'jdbc':
+ return 'JDBC';
+ ......
+ }
+ }
+ // 图标过滤
+ supportIcon(item) {
+ const supportTypes = [
+ ......
+ { rule: 'jdbc', logo: 'fi-jdbc' },
+ ];
+ }
+}
+```
+
+web/src/dss/assets/projectIconFont/iconfont.css
+
+```css
+.fi-jdbc:before {
+ content: "\e75e";
+}
+```
+
+此处控制的应该是:
+
+![引擎图标](/Images-zh/EngineConnNew/jdbc_engine_logo.png)
+
+
+
+找一个引擎图标的svg文件
+
+web/src/components/svgIcon/svg/fi-jdbc.svg
+
+如果新引擎后续需要贡献社区,那么新引擎对应的svg图标、字体等需要确认其所属的开源协议,或获取其版权许可。
+
+### 2.10 DSS的工作流适配
+
+最终达成的效果:
+
+![工作流适配](/Images-zh/EngineConnNew/jdbc_job_flow.png)
+
+在dss_workflow_node表中保存新加JDBC引擎的定义数据,参考SQL:
+
+```sql
+# 引擎任务节点基本信息定义
+insert into `dss_workflow_node` (`id`, `name`, `appconn_name`, `node_type`, `jump_url`, `support_jump`, `submit_to_scheduler`, `enable_copy`, `should_creation_before_node`, `icon`) values('18','jdbc','-1','linkis.jdbc.jdbc',NULL,'1','1','1','0','svg文件');
+
+# svg文件对应新引擎任务节点图标
+
+# 引擎任务节点分类划分
+insert into `dss_workflow_node_to_group`(`node_id`,`group_id`) values (18, 2);
+
+# 引擎任务节点的基本信息(参数属性)绑定
+INSERT INTO `dss_workflow_node_to_ui`(`workflow_node_id`,`ui_id`) VALUES (18,45);
+
+# 在dss_workflow_node_ui表中定义了引擎任务节点相关的基本信息,然后以表单的形式在上图右侧中展示,你可以为新引擎扩充其他基础信息,然后自动被右侧表单渲染。
+```
+
+web/src/apps/workflows/service/nodeType.js
+
+```js
+import jdbc from '../module/process/images/newIcon/jdbc.svg';
+
+const NODETYPE = {
+ ......
+ JDBC: 'linkis.jdbc.jdbc',
+}
+
+const ext = {
+ ......
+ [NODETYPE.JDBC]: 'jdbc',
+}
+
+const NODEICON = {
+ [NODETYPE.JDBC]: {
+ icon: jdbc,
+ class: {'jdbc': true}
+ },
+}
+```
+
+在web/src/apps/workflows/module/process/images/newIcon/目录下增加新引擎的图标
+
+web/src/apps/workflows/module/process/images/newIcon/jdbc
+
+同样贡献社区时,请考虑svg文件的lincese或版权。
+
+## 3. 本章小结
+
+上述内容记录了新引擎的实现流程,以及额外需要做的一些引擎配置。目前,一个新引擎的扩展流程还是比较繁琐的,希望能在后续版本中,优化新引擎的扩展、以及安装等过程。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/new-microservice.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/new-microservice.md
new file mode 100644
index 00000000000..378b7a3dfd3
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/new-microservice.md
@@ -0,0 +1,381 @@
+---
+title: 如何实现新的微服务
+sidebar_position: 9.0
+---
+
+> 这篇文章介绍如何基于现有的Linkis微服务架构下,在本地开发调试一个新的微服务以及部署,方便有需要新增微服务的二次开发的同学参考。
+
+思维导图:
+
+![思维导图](/Images-zh/deployment/microservice/thinking.png)
+
+
+## 1. 新的微服务开发
+
+> 本文以新增微服务`linkis-new-microservice`为示例,进行介绍。 如何在IDEA中创建和注册一个属于linkis新的微服务
+
+**软件要求**
+- jdk1.8
+- maven3.5+
+
+### 1.1 新建子模块
+
+**注意**:在什么模块下新建子模块,这个并不是固定的因情况而定,一般按服务组来划分确认,这里只是举例子。
+
+- linkis-public-enhancements模块下 右键
+
+![new-module](/Images-zh/deployment/microservice/new-module.png)
+
+- 选择maven点击Nex下一步
+
+![maven-module](/Images-zh/deployment/microservice/maven-module.png)
+
+- 输入模块名点击Finsh
+
+![name-module](/Images-zh/deployment/microservice/name-module.png)
+
+- 创建成功
+
+![created-successfully](/Images-zh/deployment/microservice/created-successfully.png)
+
+#### 1.1.1 修改linkis-new-microservice模块的pom.xml文件
+
+**path**: linkis-public-enhancements/linkis-new-microservice/pom.xml
+
+```
+## 添加linkis的公共依赖模块和 mybatis模块依赖(如果不涉及数据库操作可以不添加mybatis)
+
+ org.apache.linkis
+ linkis-module
+ ${project.version}
+
+
+ org.ow2.asm
+ asm
+
+
+
+
+
+ org.apache.linkis
+ linkis-mybatis
+ ${project.version}
+
+```
+
+
+#### 1.1.2 新增服务对应的配置文件
+
+> 配置文件按 linkis-服务名.properties来命名,统一放在`linkis-dist/package/conf/`目录下,服务启动时候会加载linkis.properties 通用配置文件以及linkis-服务名.properties配置文件
+
+新增`linkis-new-microservice.properties`配置文件
+
+**path**: linkis-dist/package/conf/linkis-new-microservice.properties
+
+``` properties
+#
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+# http://www.apache.org/licenses/LICENSE-2.0
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+
+## 如不需提供接口Api则无需添加此配置
+##restful
+wds.linkis.server.restful.scan.packages=org.apache.linkis.newmicroservice.server.restful
+
+## mybatis 数据操作项目的配置
+wds.linkis.server.mybatis.mapperLocations=classpath*:org/apache/linkis/newmicroservice/server/dao/mapper/*.xml
+wds.linkis.server.mybatis.typeAliasesPackage=org.apache.linkis.newmicroservice.server.domain
+wds.linkis.server.mybatis.BasePackage=org.apache.linkis.newmicroservice.server.dao
+
+
+##切勿与其他服务的端口相同
+spring.server.port=9208
+
+```
+
+
+#### 1.1.4 开启调试模式
+
+> 方便进行接口的调式,无需进行登陆态的验证
+
+**path**: linkis-dist/package/conf/linkis.properties
+
+![test-mode](/Images-zh/deployment/microservice/test-mode.png)
+
+``` properties
+wds.linkis.test.mode=true # 打开测试模式
+wds.linkis.test.user=hadoop # 指定测试模式下,所有请求都代理给哪个用户
+
+```
+
+
+### 1.2 代码开发
+
+> 为方便大家学习,现以创建一个简单的API接口为示例。
+
+#### 1.2.1 新建接口类
+
+![new-microservice](/Images-zh/deployment/microservice/new-microservice.png)
+
+``` java
+package org.apache.linkis.newmicroservice.server.restful;
+
+
+import io.swagger.annotations.ApiOperation;
+import org.apache.linkis.server.Message;
+import org.springframework.web.bind.annotation.*;
+
+import io.swagger.annotations.Api;
+
+import java.util.HashMap;
+import java.util.Map;
+
+@Api(tags = "newmicroservice")
+@RestController
+@RequestMapping(path = "/newmicroservice")
+public class NewMicroservice {
+
+
+ @ApiOperation(value = "establish", httpMethod = "GET")
+ @RequestMapping(path = "establish", method = RequestMethod.GET)
+ public Message list() {
+ Map<String,String> map=new HashMap<>();
+ map.put("NewMicroservice","Hello! This is a new microservice I registered(这是我注册的一个新的微服务)");
+ return Message.ok("").data("map", map);
+ }
+
+}
+```
+
+#### 1.2.2 新建启动类
+
+![maven-module](/Images-zh/deployment/microservice/start-up.png)
+
+``` java
+
+package org.apache.linkis.newmicroservice.server;
+
+import org.apache.linkis.LinkisBaseServerApp;
+
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+
+public class LinkisNewMicroserviceApplication {
+
+ private static final Log logger = LogFactory.getLog(LinkisNewMicroserviceApplication.class);
+
+ public static void main(String[] args) throws ReflectiveOperationException {
+ logger.info("Start to running LinkisNewmicroserviceApplication");
+ LinkisBaseServerApp.main(args);
+ }
+}
+```
+
+### 1.3 启动eureka服务
+
+> 这一步骤的具体指引在 [调试指引](../development/debug) 文档中已有写 可直接访问,这里就不在过多介绍
+
+
+### 1.4 本地启动新微服务
+
+> 设置linkis-new-microservice的启动Application
+
+![commissioning-service](/Images-zh/deployment/microservice/commissioning-service.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-new-microservice
+
+[Module Name]
+linkis-new-microservice
+
+[VM Opitons]
+-DserviceName=linkis-new-microservice -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf
+
+[main Class]
+org.apache.linkis.newmicroservice.server.LinkisNewmicroserviceApplication
+
+[Add provided scope to classpath]
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+```
+
+> 上述设置完成之后,可直接运行此Application。运行成功后打开浏览器输入eureka注册中心的url
+
+``` text
+ http://ip:port/
+```
+
+![new-service](/Images-zh/deployment/microservice/new-service.png)
+
+> 当eureka注册中心出现linkis-new-microservice服务即为本地注册新的微服务成功。
+
+### 1.5 Postman 进行接口调试
+
+**URL**: http://ip:port/api/rest_j/v1/newmicroservice/establish
+
+![postman-test](/Images-zh/deployment/microservice/postman-test.png)
+
+
+
+## 2. 打包部署
+> 打包部署主要有有两个阶段 第一步是模块通过maven打包后 会将模块所需要的依赖 打包到模块对应的target目录下 linkis-new-microservice/target/out/lib。
+> 第二步是 组装完整的最终部署安装包时,需要将` linkis-new-microservice/target/out/lib` 自动拷贝至 `linkis-dist/target/apache-linkis-x.x.x-bin/linkis-package/lib`下
+
+### 2.1 修改新服务下的distribution.xml
+
+**path**: linkis-public-enhancements/linkis-new-microservice/src/main/assembly/distribution.xml
+
+![new-distribution](/Images-zh/deployment/microservice/new-distribution.png)
+
+> 由于需要排除的依赖比较多这里只贴部分代码
+
+``` xml
+
+ antlr:antlr:jar
+ aopalliance:aopalliance:jar
+ com.fasterxml.jackson.core:jackson-annotations:jar
+ com.fasterxml.jackson.core:jackson-core:jar
+
+```
+
+> 这里解释下为什么需要加`excludes`,因为服务启动脚本 linkis-dist/package/sbin/ext/linkis-common-start 中一般会默认加载通用的lib
+
+![common-start](/Images-zh/deployment/microservice/common-start.png)
+
+> 所以在打包服务依赖时候,可以排除已有的lib包.详细可以参考linkis-computation-governance/linkis-entrance/src/main/assembly/distribution.xml
+
+
+### 2.2 修改linkis-dist下的distribution.xml
+
+**path**: linkis-dist/src/main/assembly/distribution.xml
+
+
+> 添加fileSet 配置,改配置主要是控制编译打包时的能输出linkis-new-microservice服务包
+
+![fileset](/Images-zh/deployment/microservice/fileset.png)
+
+> 这里只贴出来需要新增的配置内容。
+
+``` xml
+
+
+ ../linkis-public-enhancements/linkis-new-microservice/target/out/lib
+
+
+ linkis-package/lib/linkis-public-enhancements/linkis-new-microservice
+
+
+ **/*
+
+
+
+```
+
+### 2.3 服务的运行配置脚本
+
+![new-configuration](/Images-zh/deployment/microservice/new-configuration.png)
+
+``` text
+
+#!/usr/bin/env bash
+#
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+# http://www.apache.org/licenses/LICENSE-2.0
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# description: manager start cmd
+#
+# Modified for Linkis 1.0.0
+
+
+export SERVER_SUFFIX="linkis-public-enhancements/linkis-new-microservice"
+
+
+export SERVER_CLASS=org.apache.linkis.newmicroservice.server.LinkisNewMicroserviceApplication
+
+#export DEBUG_PORT=
+
+export COMMON_START_BIN=$LINKIS_HOME/sbin/ext/linkis-common-start
+if [[ ! -f "${COMMON_START_BIN}" ]]; then
+ echo "The $COMMON_START_BIN does not exist!"
+ exit 1
+else
+ sh $COMMON_START_BIN
+fi
+
+```
+
+
+### 2.4 linkis-start-all.sh 配置修改
+
+**path**: linkis-dist/package/sbin/linkis-start-all.sh
+
+![start-script](/Images-zh/deployment/microservice/start-script.png)
+
+> 这里只贴出来需要新增的配置内容。
+
+``` text
+ ## 启动脚本
+ #linkis-new-microservice
+ SERVER_NAME="new-microservice"
+ startApp
+```
+
+![detection-script](/Images-zh/deployment/microservice/detection-script.png)
+
+> 这里只贴出来需要新增的配置内容。
+
+``` text
+ ##检测脚本
+ #linkis-new-microservice
+ SERVER_NAME="new-microservice"
+ checkServer
+```
+
+### 2.5 linkis-stop-all.sh 配置修改
+
+**path**:linkis-dist/package/sbin/linkis-stop-all.sh
+
+![stop-script](/Images-zh/deployment/microservice/stop-script.png)
+
+> 这里只贴出来需要新增的配置内容。
+
+``` text
+ ## 停止脚本
+ #linkis-new-microservice
+ export SERVER_NAME="new-microservice"
+ stopApp
+```
+
+### 2.6 安装包准备
+
+> 这一步骤的具体指引在 [后端编译](../development/build) 文档中已有写 可直接访问,这里就不在过多介绍
+
+### 2.7 服务器部署
+
+> 这里为单机部署做示例,而该步骤的具体指引在 [单机部署](../deployment/deploy-quick) 文档中已有写 可直接访问,这里就不在过多介绍
+当安装部署成功后可直接在浏览器中访问eureka注册中心,看中心是否已经成功注册linkis-new-microservice服务,如注册成功即为创建新的微服务成功。
+
+![new-service](/Images-zh/deployment/microservice/new-service.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/swwager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/swwager.md
new file mode 100644
index 00000000000..9b570a3f7af
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/swwager.md
@@ -0,0 +1,261 @@
+---
+title: Swagger 注解使用
+sidebar_position: 10.0
+---
+
+## 1. Swagger注解的作用域
+| API| 作用范围 | 使用位置 |
+| -------- | -------- | ----- |
+|@Api|协议集描述|用于controller类上|
+|@ApiOperation|协议描述|用在controller的方法上|
+|@ApiImplicitParams|非对象参数集|用在controller的方法上|
+|@ApiImplicitParam|非对象参数描述|用在@ApiImplicitParams的方法里边|
+|@ApiResponses|Response集|用在controller的方法上|
+|@ApiResponse|Response|用在 @ApiResponses里边|
+|@ApiModel|描述返回对象的意义| 用在返回对象类上|
+|@ApiModelProperty|对象属性|用在出入参数对象的字段上|
+|@ApiParam|协议描述|用在方法、参数、类的字段上|
+
+## 2. @Api
+使用位置即用在类上,对请求类进行描述。标识一个Controller类是Swagger文档类。
+
+### 2.1 注解的属性
+
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|描述,无实际意义。|
+|tags|String[]|""|分组|
+|basePath|String|""|基本路径|
+|protocols|String|int|请求协议|
+|authorizations|Authorization[]|@Authorization(value = "")|高级特性认证时的配置|
+|hidden|boolean|false|是否隐藏(不显示,默认为false)|
+
+
+### 2.2 属性value、tags二者的区别
+
+value属性作用在类和作用在方法上都用于描述;
+
+tags属性作用在类和作用在方法上都用于分组,但分组的效果区别很大:
+
+tags作用在类上时,会对全局的方法分组,即根据tags属性值复制多份,此时方法上的tags值无效,方法上tags配或不配效果都一样。
+
+tags作用在方法上时,会根据当前类的所有方法的tags值做分组,粒度更细。
+
+### 2.3 使用方法
+注意:java和scala在@Api注解上使用的区别
+
+```java
+*java
+@Api(tags = "Swagger测试相关接口")
+@RestController
+
+*scala
+@Api(tags = Array("Swagger测试相关接口"))
+@RestController
+```
+
+
+
+## 3. @ApiOperation
+用在方法上,对请求方法进行描述。
+### 3.1 注解的属性
+
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|描述|
+|notes|String|""| 详细描述|
+|tags|String[]|""|分组|
+|response|Class>|Void.class|响应参数类型|
+|responseReference|String[]|""|指定对响应类型的引用,本地/远程引用,并将覆盖任何其它指定的response()类|
+|httpMethod|String|""|http请求方式,如:GET、HEAD、POST、PUT、DELETE、OPTION、SPATCH|
+|hidden|boolean|false|是否隐藏(不显示)默认为false|
+|code|int|200|http的状态码|
+|extensions|Extension[]|@Extension(properties = @ExtensionProperty(name = "", value = "")|扩展属性|
+
+### 3.2 使用方法
+
+```java
+@GetMapping("test1")
+@ApiOperation(value = "test1接口",notes = "test1接口详细描述")
+public ApiResult test1(@RequestParam String aa, @RequestParam String bb, @RequestParam String cc) {
+ return ApiUtil.success("success");
+}
+```
+
+## 4. @ApiImplicitParams
+
+常用在方法上,对请求参数列表进行描述。
+其中的value属性可包含多个@ApiImplicitParam,对每个参加进行具体的描述。
+
+### 4.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|描述|
+
+## 5. @ApiImplicitParams
+
+用在方法上,对请求参数进行描述。当需要对多个参数进行描述时,作为@ApiImplicitParams的属性使用。
+
+### 5.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|描述|
+|name|String|""|参数说明|
+|defaultValue|String|""|默认值|
+|allowableValues|String|""|参数允许值|
+|required|boolean|false|是否必填,默认false|
+|access|String|""|参数过滤|
+|allowMultiple|boolean|false|参数是否可以通过多次出现来接受多个值,默认不允许|
+|dataType|String|""|参数的数据类型,可以使类名或原始数据类型|
+|dataTypeClass|Class>|Void.class|参数的数据类型,如果提供则覆盖 dataType|
+|paramType|String|""|参数类型,有效值为 path, query, body, header, form|
+|example|String|""|非body类型的参数示例|
+|examples|Example|@Example(value = @ExampleProperty(mediaType = “”, value = “”))|body类型的参数示例|
+|type|String|""|添加覆盖检测到的类型的功能|
+|format|String|""|添加提供自定义format格式的功能|
+|readOnly|boolean|false|添加被指定为只读的功能|
+
+### 5.2 使用方法
+
+```java
+@GetMapping("test1")
+@ApiOperation(value = "test1接口",notes = "test1接口详细描述")
+@ApiImplicitParams(value = {
+ @ApiImplicitParam(name = "aa",value = "aa的说明",defaultValue = "1",allowableValues = "1,2,3",required = true),
+ @ApiImplicitParam(name = "bb",value = "bb的说明",defaultValue = "1",allowableValues = "1,2,3",required = true),
+ @ApiImplicitParam(name = "cc",value = "cc的说明",defaultValue = "2",allowableValues = "1,2,3",required = true),
+
+})
+```
+
+## 6. @ApiParam
+
+用在方法、参数、类的字段上,对请求参数进行描述。
+
+### 6.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|描述|
+|name|String|""|参数说明|
+|defaultValue|String|""|默认值|
+|allowableValues|String|""|参数允许值|
+|required|boolean|false|是否必填,默认false|
+|access|String|""|参数过滤|
+|allowMultiple|boolean|false|参数是否可以通过多次出现来接受多个值,默认不允许|
+|dataType|String|""|参数的数据类型,可以使类名或原始数据类型|
+|dataTypeClass|Class>|Void.class|参数的数据类型,如果提供则覆盖 dataType|
+|paramType|String|""|参数类型,有效值为 path, query, body, header, form|
+|example|String|""|非body类型的参数示例|
+|examples|Example|@Example(value = @ExampleProperty(mediaType = “”, value = “”))|body类型的参数示例|
+|type|String|""|添加覆盖检测到的类型的功能|
+|format|String|""|添加提供自定义format格式的功能|
+|readOnly|boolean|false|添加被指定为只读的功能|
+
+### 6.2 使用方法
+
+```java
+@GetMapping("test2")
+@ApiOperation(value = "test2接口",notes = "test2接口详细描述")
+public ApiResult test2(@ApiParam(value = "aa的说明") @RequestParam String aa, @ApiParam(value = "bb的说明") @RequestParam String bb) {
+ return ApiUtil.success(new TestRes());
+}
+```
+## 7. @ApiModel
+
+用在类上,对请求、响应类,实体类进行描述。
+
+### 7.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""| 为提供模型的替代名称,默认情况下,使用类名|
+|description|String|""|类的描述|
+|parent|Class> parent|Void.class|为模型提供父类以允许描述继承关系|
+|discriminatory|String|""|支持模型继承和多态,使用鉴别器的字段的名称,可以断言需要使用哪个子类型|
+|subTypes|boolean|false|是否必填,默认false|
+|access|Class> parent|Void.class| 从此模型继承的子类型数组|
+|reference|boolean|false|指定对应类型定义的引用,覆盖指定的任何其他元数据|
+
+## 8 @ApiModelProperty
+
+用在类上,对请求、响应类,实体类进行描述。
+
+### 8.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|属性说明|
+|name|String|""|覆盖属性的名称|
+|allowableValues|String|""|参数允许值|
+|access|String|""|过滤属性|
+|required|boolean|false|是否必填,默认false|
+|dataType|String|""|参数的数据类型,可以使类名或原始数据类型|
+|hidden|boolean|false| 是否隐藏|
+|readOnly|String|""|添加被指定为只读的功能|
+|reference|String|""|指定对应类型定义的引用,覆盖指定的任何其他元数据|
+|allowEmptyValue|boolean|false|允许传空值|
+|example|String|""|属性的示例值|
+
+### 8.2 使用方法
+
+注意:java和scala在@ApiModelProperty注解上的使用的区别
+
+```java
+*java实体类
+@Data
+@ApiModel(description = "测试请求类")
+public class TestReq {
+
+ @ApiModelProperty(value = "用户ID",required = true)
+ private Long userId;
+ @ApiModelProperty(value = "用户名",example = "张三")
+}
+
+*scala实体类
+@Data
+@ApiModel(description = "测试响应类")
+public class TestRes {
+ @(ApiModelProperty @field)("用户ID")
+ private Long userId;
+ @(ApiModelProperty @field)("用户名")
+}
+```
+
+
+## 9. @ApiResponses
+
+用在方法、类上,对响应状态码列表进行描述。
+
+### 9.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|ApiResponse[]|""|响应状态码列表的描述|
+
+## 10. @ApiResponse
+
+用在方法上,对响应状态码进行描述。一般作为@ApiResponses的属性使用。
+
+### 10.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|code|int|""|响应的HTTP状态码|
+|message|String|""|响应的描述|
+|response|Class>|Void.class|用于描述消息有效负载的可选响应类,对应于响应消息对象的 schema 字段|
+|reference|String|""|指定对响应类型的引用,指定的应用可以使本地引用,也可以是远程引用,将按原样使用,并将覆盖任何指定的response()类|
+|responseHeaders|ResponseHeader[]|@ResponseHeader(name = "", response = Void.class)|可能响应的header列表|
+|responseContainer|String|""|声明响应的容器,有效值为List,Set,Map,任何其他值都将被忽略|
+
+
+### 10.2 使用方法
+
+```java
+@GetMapping("test2")
+@ApiOperation(value = "test2接口",notes = "test2接口详细描述")
+@ApiResponses(value = {
+ @ApiResponse(code = 200, message = "请求成功", responseHeaders = {@ResponseHeader(name = "header1", description = "header1的描述",response = String.class)}),
+ @ApiResponse(code = 401, message = "没有权限"),
+ @ApiResponse(code = 403, message = "禁止访问")
+})
+public ApiResult test2(@ApiParam(value = "aa的说明") @RequestParam String aa, @ApiParam(value = "bb的说明") @RequestParam String bb) {
+ return ApiUtil.success(new TestRes());
+}
+
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/table/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/table/_category_.json
new file mode 100644
index 00000000000..f565b1d581f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/table/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "表结构",
+ "position": 13
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/table/all.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/table/all.md
new file mode 100644
index 00000000000..e3d78b25c0f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/table/all.md
@@ -0,0 +1,1782 @@
+---
+title: 库表结构
+sidebar_position: 1
+---
+
+## 1. linkis_cg_ec_resource_info_record
+
+> 历史引擎信息记录表 ec 为`engine conn` 缩写 ecm为 engineconn manager 服务缩写
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_value` | ec 的label标签 stringValue 如 `userCreator, engineType`->`hadoop-LINKISCLI,shell-1`| varchar(255) | | NO | | |
+| 3 | `create_user` | ec 的创建用户| varchar(128) | | NO | | |
+| 4 | `service_instance` | ec 实例信息 如 bdpdev01dss02:19756| varchar(128) | | YES | | |
+| 5 | `ecm_instance` | ecm 实例信息 如bdpdev01dss02:9102 | varchar(128) | | YES | | |
+| 6 | `ticket_id` | ec 的 ticket id | varchar(100) | MUL | NO | | |
+| 7 | `log_dir_suffix` | ec 日志log所在的路径 | varchar(128) | | YES | | |
+| 8 | `request_times` | 资源请求次数 | int(8) | | YES | | |
+| 9 | `request_resource` | 请求的资源 | varchar(1020) | | YES | | |
+| 10 | `used_times` | 资源使用次数 | int(8) | | YES | | |
+| 11 | `used_resource` | 使用的资源信息 | varchar(1020) | | YES | | |
+| 12 | `release_times` | 释放资源次数 | int(8) | | YES | | |
+| 13 | `released_resource` | 释放的资源 | varchar(1020) | | YES | | |
+| 14 | `release_time` | 释放的时间 | datetime | | YES | | |
+| 15 | `used_time` | 使用时间 | datetime | | YES | | |
+| 16 | `create_time` | 创建时间| datetime | | YES | | CURRENT_TIMESTAMP |
+
+
+**示例数据**
+
+| id | label_value | create_user | service_instance | ecm_instance | ticket_id | status | log_dir_suffix | request_times | request_resource | used_times | used_resource | release_times | released_resource | release_time | used_time | create_time |
+| ---: | --- | --- | --- | --- | --- | --- | --- | ---: | --- | ---: | --- | ---: | --- | --- | --- | --- |
+| 1 | hadoop-LINKISCLI,shell-1 | hadoop | bdpdev01dss02:19756 | bdpdev01dss02:9102 | fc0d442d-7e18-49f6-a01e-a4f4685f0155 | ShuttingDown | hadoop/20221025/shell/fc0d442d-7e18-49f6-a01e-a4f4685f0155/logs | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 2022-10-25 17:55:41 | 2022-10-25 17:53:09 | 2022-10-25 17:52:56 |
+| 2 | hadoop-LINKISCLI,hive-2.3.3 | hadoop | bdpdev01dss02:20903 | bdpdev01dss02:9102 | 63ea31dc-65b1-42c4-8963-5fe4468f0ae0 | ShuttingDown | hadoop/20221025/hive/63ea31dc-65b1-42c4-8963-5fe4468f0ae0/logs | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 2022-10-25 17:55:52 | 2022-10-25 17:54:36 | 2022-10-25 17:54:20 |
+| 3 | hadoop-LINKISCLI,python-python2 | hadoop | bdpdev01dss02:21320 | bdpdev01dss02:9102 | 3f8a4f73-fdbb-407e-ae1b-0b14b9d08bcf | ShuttingDown | hadoop/20221025/python/3f8a4f73-fdbb-407e-ae1b-0b14b9d08bcf/logs | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 2022-10-25 17:57:41 | 2022-10-25 17:55:55 | 2022-10-25 17:55:44 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_tid` | 将`ticket_id` 列设置为普通索引 | INDEX | `ticket_id` |
+| 2 | `uniq_tid_lv` | 将`ticket_id`,`label_value`列设置为唯一索引 | UNIQUE KEY | `ticket_id`,`label_value` |
+
+
+
+## 2. linkis_cg_engine_conn_plugin_bml_resources
+
+> 引擎物料存储信息表 主要用于引擎实例启动时,根据对应的物料资源的进行下载,以及进行引擎物料刷新时会使用到。
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary key | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `engine_conn_type` |引擎名 如 hive | varchar(100) | | NO | | |
+| 3 | `version` | 物料版本 | varchar(100) | | YES | | |
+| 4 | `file_name` | 文件名 conf.zip/lib.zip | varchar(255) | | YES | | |
+| 5 | `file_size` | 大小 byte | bigint(20) | | NO | | 0 |
+| 6 | `last_modified` |最新修改时间| bigint(20) | | YES | | |
+| 7 | `bml_resource_id` | bml物料id | varchar(100) | | NO | | |
+| 8 | `bml_resource_version` | bml物料版本 | varchar(200) | | NO | | |
+| 9 | `create_time` | created time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 10 | `last_update_time` | updated time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | engine_conn_type | version | file_name | file_size | last_modified | bml_resource_id | bml_resource_version | create_time | last_update_time |
+| ---: | --- | --- | --- | ---: | ---: | --- | --- | --- | --- |
+| 3 | hive | 2.3.3 | conf.zip | 2363 | 1666683401000 | 8f9879b4-9950-43c9-8eca-5f570211e784 | v000001 | 2022-10-25 15:42:08 | 2022-10-25 15:42:08 |
+| 4 | hive | 2.3.3 | lib.zip | 106319116 | 1666683401000 | ac77aa15-e873-4f5f-9ed1-17435cad390f | v000001 | 2022-10-25 15:42:13 | 2022-10-25 15:42:13 |
+| 5 | elasticsearch | 7.6.2 | conf.zip | 1981 | 1666683401000 | f17874ca-54fa-4153-8edb-a4d31268847b | v000001 | 2022-10-25 15:42:14 | 2022-10-25 15:42:14 |
+| 6 | elasticsearch | 7.6.2 | lib.zip | 15935016 | 1666683401000 | 2f340471-a495-4b93-a197-b8eb362d04bb | v000001 | 2022-10-25 15:42:15 | 2022-10-25 15:42:15 |
+
+
+
+## 3. linkis_cg_manager_engine_em
+
+>引擎实例engine conn 和归属的ecm(engine conn manager)实例的关系表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `engine_instance` | ec 实例信息 | varchar(128) | | YES | | |
+| 3 | `em_instance` | ecm 实例信息 | varchar(128) | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | engine_instance | em_instance | update_time | create_time |
+| ---: | --- | --- | --- | --- |
+| 223 | localhost110003:10394 | localhost110003:9102 | 2022-11-12 23:30:09 | 2022-11-12 23:30:09 |
+| 224 | localhost110003:33483 | localhost110003:9102 | 2022-11-12 23:30:48 | 2022-11-12 23:30:48 |
+| 226 | localhost110003:19782 | localhost110003:9102 | 2022-11-13 01:48:05 | 2022-11-13 01:48:05 |
+
+
+
+## 4. linkis_cg_manager_label
+
+> 标签记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_key` | 标签 label | varchar(32) | MUL | NO | | |
+| 3 | `label_value` | 标签值 json格式 | varchar(255) | | NO | | |
+| 4 | `label_feature` | | varchar(16) | | NO | | |
+| 5 | `label_value_size` | 标签存储的元素个数 | int(20) | | NO | | |
+| 6 | `update_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 7 | `create_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+
+
+**示例数据**
+
+| id | label_key | label_value | label_feature | label_value_size | update_time | create_time |
+| ---: | --- | --- | --- | ---: | --- | --- |
+| 19 | combined_userCreator_engineType | *-nodeexecution,python-python2 | OPTIONAL | 2 | 2021-06-08 20:25:28 | 2021-06-08 20:25:28 |
+| 21 | serverAlias | {"alias":"linkis-cg-engineconnmanager"} | OPTIONAL | 1 | 2021-06-08 20:27:07 | 2021-06-08 20:27:07 |
+| 24 | combined_userCreator_engineType | {"creator":"IDE","user":"hadoop","engineType":"hive","version":"2.3.3"} | OPTIONAL | 4 | 2021-06-08 20:42:00 | 2021-06-08 20:42:00 |
+| 26 | userCreator | {"creator":"IDE","user":"hadoop"} | OPTIONAL | 2 | 2021-06-08 20:42:07 | 2021-06-08 20:42:07 |
+| 27 | engineType | {"engineType":"hive","version":"2.3.3"} | OPTIONAL | 2 | 2021-06-08 20:42:07 | 2021-06-08 20:42:07 |
+| 28 | serverAlias | {"alias":"EngineConn"} | OPTIONAL | 1 | 2021-06-08 20:42:07 | 2021-06-08 20:42:07 |
+| 29 | codeType | {"codeType":"hql"} | OPTIONAL | 1 | 2021-06-08 20:42:16 | 2021-06-08 20:42:16 |
+| 30 | combined_userCreator_engineType | {"creator":"IDE","user":"root","engineType":"io_file","version":"1.0"} | OPTIONAL | 4 | 2021-06-08 20:50:47 | 2021-06-08 20:50:47 |
+| 32 | userCreator | {"creator":"IDE","user":"root"} | OPTIONAL | 2 | 2021-06-08 20:50:52 | 2021-06-08 20:50:52 |
+| 33 | concurrentEngineConn | {} | OPTIONAL | 0 | 2021-06-08 20:50:52 | 2021-06-08 20:50:52 |
+| 34 | engineType | {"engineType":"io_file","version":"1.0"} | OPTIONAL | 2 | 2021-06-08 20:50:52 | 2021-06-08 20:50:52 |
+| 35 | codeType | {"codeType":"io_file"} | OPTIONAL | 1 | 2021-06-08 20:50:59 | 2021-06-08 20:50:59 |
+| 36 | combined_userCreator_engineType | johnnwang-*,*-* | OPTIONAL | 2 | 2021-06-08 22:07:07 | 2021-06-08 22:07:07 |
+| 37 | combined_userCreator_engineType | {"creator":"IDE","user":"johnnwang","engineType":"flink","version":"1.11.1"} | OPTIONAL | 4 | 2021-06-08 22:07:20 | 2021-06-08 22:07:20 |
+| 39 | userCreator | {"creator":"IDE","user":"johnnwang"} | OPTIONAL | 2 | 2021-06-08 22:07:26 | 2021-06-08 22:07:26 |
+| 40 | engineType | {"engineType":"flink","version":"1.11.1"} | OPTIONAL | 2 | 2021-06-08 22:07:26 | 2021-06-08 22:07:26 |
+| 41 | combined_userCreator_engineType | {"creator":"IDE","user":"johnnwang","engineType":"spark","version":"2.4.3"} | OPTIONAL | 4 | 2021-06-08 22:07:37 | 2021-06-08 22:07:37 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lk_lv` | 将`label_key`,`label_value` 列设置为唯一索引 | UNIQUE KEY | `label_key`,`label_value` |
+
+
+
+
+## 5. linkis_cg_manager_label_resource
+
+> 标签id 和资源id 的关联关系表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_id` | linkis_cg_manager_label的id | int(20) | UNI | YES | | |
+| 3 | `resource_id` | linkis_cg_manager_linkis_resources对应的id | int(20) | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | label_id | resource_id | update_time | create_time |
+| ---: | ---: | ---: | --- | --- |
+| 14217 | 13266 | 14218 | 2022-11-12 23:09:36 | 2022-11-12 23:09:36 |
+| 14218 | 24 | 14219 | 2022-11-12 23:30:09 | 2022-11-12 23:30:09 |
+| 14219 | 13267 | 14220 | 2022-11-12 23:30:09 | 2022-11-12 23:30:09 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_label_id` | 将`label_id` 列设置为唯一索引 | UNIQUE KEY | `label_id` |
+
+
+
+
+## 6. linkis_cg_manager_label_service_instance
+
+>引擎实例engine conn/ecm(engine conn manager)实例 标签记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_id` | linkis_cg_manager_label的id | int(20) | MUL | YES | | |
+| 3 | `service_instance` | 实例信息 | varchar(128) | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+
+**示例数据**
+
+| id | label_id | service_instance | update_time | create_time |
+| ---: | ---: | --- | --- | --- |
+| 200 | 94 | bdpdev01dss02:33755 | 2022-11-14 17:11:26 | 2022-11-14 17:11:26 |
+| 201 | 105 | bdpdev01dss02:9102 | 2022-11-15 14:54:56 | 2022-11-15 14:54:56 |
+| 202 | 23 | bdpdev01dss02:9102 | 2022-11-15 14:54:56 | 2022-11-15 14:54:56 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_lid_instance` | 将`label_id`,`service_instance` 列设置为普通索引 | INDEX | `label_id`,`service_instance` |
+
+
+
+## 7. linkis_cg_manager_label_user
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `username` | | varchar(255) | | YES | | |
+| 3 | `label_id` | | int(20) | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+
+## 8. linkis_cg_manager_label_value_relation
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_value_key` | | varchar(255) | MUL | NO | | |
+| 3 | `label_value_content` | | varchar(255) | | YES | | |
+| 4 | `label_id` | | int(20) | | YES | | |
+| 5 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 6 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lvk_lid` | 将`label_value_key`,`label_id` 列设置为唯一索引 | UNIQUE KEY | `label_value_key`,`label_id` |
+
+
+
+**示例数据**
+
+| label_value_key | label_value_content | label_id | update_time | create_time |
+| --- | --- | ---: | --- | --- |
+| creator | IDE | 7589 | 2022-05-16 19:31:13 | 2022-05-16 19:31:13 |
+| user | owenxu | 7589 | 2022-05-16 19:31:13 | 2022-05-16 19:31:13 |
+| creator | mide | 7511 | 2022-05-12 10:40:27 | 2022-05-12 10:40:27 |
+| user | davidhua | 7511 | 2022-05-12 10:40:27 | 2022-05-12 10:40:27 |
+
+
+## 9. linkis_cg_manager_linkis_resources
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `max_resource` | | varchar(1020) | | YES | | |
+| 3 | `min_resource` | | varchar(1020) | | YES | | |
+| 4 | `used_resource` | | varchar(1020) | | YES | | |
+| 5 | `left_resource` | | varchar(1020) | | YES | | |
+| 6 | `expected_resource` | | varchar(1020) | | YES | | |
+| 7 | `locked_resource` | | varchar(1020) | | YES | | |
+| 8 | `resourceType` | | varchar(255) | | YES | | |
+| 9 | `ticketId` | | varchar(255) | | YES | | |
+| 10 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 11 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 12 | `updator` | | varchar(255) | | YES | | |
+| 13 | `creator` | | varchar(255) | | YES | | |
+
+**示例数据**
+
+| id | max_resource | min_resource | used_resource | left_resource | expected_resource | locked_resource | resourceType | ticketId | update_time | create_time | updator | creator |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
+| 14219 | {"memory":21474836480,"cores":10,"instance":10} | {"memory":0,"cores":0,"instance":0} | {"memory":1073741824,"cores":1,"instance":1} | {"memory":20401094656,"cores":9,"instance":9} | \N | {"memory":0,"cores":0,"instance":0} | LoadInstance | \N | \N | 2022-11-12 23:30:09 | hadoop-IDE,hive-2.3.3 | hadoop-IDE,hive-2.3.3 |
+| 14220 | {"memory":1073741824,"cores":1,"instance":1} | {"memory":1073741824,"cores":1,"instance":1} | {"memory":1073741824,"cores":1,"instance":1} | {"memory":0,"cores":0,"instance":0} | \N | {"memory":0,"cores":0,"instance":0} | LoadInstance | 24f8c8a8-d481-4976-a11a-5765f81d9795 | \N | 2022-11-12 23:30:09 | hadoop-IDE,hive-2.3.3 | hadoop-IDE,hive-2.3.3 |
+| 14221 | {"DriverAndYarnResource":{"loadInstanceResource":{"memory":21474836480,"cores":10,"instances":5},"yarnResource":{"queueMemory":322122547200,"queueCores":150,"queueInstances":30,"queueName":"dws","applicationId":""}}} | {"DriverAndYarnResource":{"loadInstanceResource":{"memory":0,"cores":0,"instances":0},"yarnResource":{"queueMemory":0,"queueCores":0,"queueInstances":0,"queueName":"default","applicationId":""}}} | {"DriverAndYarnResource":{"loadInstanceResource":{"memory":1073741824,"cores":1,"instances":1},"yarnResource":{"queueMemory":6442450944,"queueCores":4,"queueInstances":0,"queueName":"dws","applicationId":""}}} | {"DriverAndYarnResource":{"loadInstanceResource":{"memory":20401094656,"cores":9,"instances":4},"yarnResource":{"queueMemory":315680096256,"queueCores":146,"queueInstances":30,"queueName":"dws","applicationId":""}}} | \N | {"DriverAndYarnResource":{"loadInstanceResource":{"memory":0,"cores":0,"instances":0},"yarnResource":{"queueMemory":0,"queueCores":0,"queueInstances":0,"queueName":"dws","applicationId":""}}} | DriverAndYarn | \N | \N | 2022-11-12 23:30:47 | hadoop-IDE,spark-2.4.3 | hadoop-IDE,spark-2.4.3 |
+
+
+## 10. linkis_cg_manager_lock
+
+> 通用的用于实现分布式锁
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `lock_object` | | varchar(255) | UNI | YES | | |
+| 3 | `time_out` | | longtext | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+
+## 11. linkis_cg_manager_metrics_history
+
+//todo 可以移除?
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `instance_status` | | int(20) | | YES | | |
+| 3 | `overload` | | varchar(255) | | YES | | |
+| 4 | `heartbeat_msg` | | varchar(255) | | YES | | |
+| 5 | `healthy_status` | | int(20) | | YES | | |
+| 6 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 7 | `creator` | | varchar(255) | | YES | | |
+| 8 | `ticketID` | | varchar(255) | | YES | | |
+| 9 | `serviceName` | | varchar(255) | | YES | | |
+| 10 | `instance` | | varchar(255) | | YES | | |
+
+
+## 12. linkis_cg_manager_service_instance
+
+> 引擎服务实例/引擎资源管理服务实例 信息表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `instance` | 实例信息 localhost110004:9102| varchar(128) | UNI | YES | | |
+| 3 | `name` | 服务名 linkis-cg-engineconnmanager/linkis-cg-engineconn | varchar(32) | | YES | | |
+| 4 | `owner` | 服务实例的启动用户| varchar(32) | | YES | | |
+| 5 | `mark` | //todo | varchar(32) | | YES | | |
+| 6 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 7 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 8 | `updator` | | varchar(32) | | YES | | |
+| 9 | `creator` | | varchar(32) | | YES | | |
+
+**示例数据**
+
+| id | instance | name | owner | mark | update_time | create_time | updator | creator |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- |
+| 121637 | localhost110004:9102 | linkis-cg-engineconnmanager | hadoop | process | 2022-11-08 09:52:08 | 2022-11-08 09:52:08 | hadoop | hadoop |
+| 121640 | localhost110002:9102 | linkis-cg-engineconnmanager | hadoop | process | 2022-11-08 09:52:16 | 2022-11-08 09:52:16 | hadoop | hadoop |
+| 121686 | gz.xg.localhost110001.webank:35932 | linkis-cg-engineconn | neiljianliu | process | 2022-11-08 10:40:39 | 2022-11-08 10:40:23 | neiljianliu | neiljianliu |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_instance` | 将`instance` 列设置为唯一索引 | UNIQUE KEY | `instance` |
+
+
+
+## 13. linkis_cg_manager_service_instance_metrics
+
+> 引擎服务实例/引擎资源管理服务的内存等信息 指标表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `instance` | 实例| varchar(128) | PRI | NO | | |
+| 2 | `instance_status` |状态 | int(11) | | YES | | |
+| 3 | `overload` | 资源过载情况 | varchar(255) | | YES | | |
+| 4 | `heartbeat_msg` | 心跳信息| text | | YES | | |
+| 5 | `healthy_status` | 心跳状态| varchar(255) | | YES | | |
+| 6 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 7 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| instance | instance_status | overload | heartbeat_msg | healthy_status | update_time | create_time |
+| --- | ---: | --- | --- | --- | --- | --- |
+| localhost110003:9102 | 5 | {"maxMemory":67385790464,"usedMemory":3662913536,"systemCPUUsed":null,"systemLeftMemory":63722876928} | | {"nodeHealthy":"Healthy","msg":""} | 2022-11-16 14:29:56 | 2022-11-15 15:59:17 |
+| localhost110004:10781 | 1 | {"maxMemory":1073741824,"usedMemory":175014896,"systemCPUUsed":6.29,"systemLeftMemory":2746556416} | \N | {"nodeHealthy":"Healthy","msg":""} | 2022-11-16 14:30:18 | 2022-11-16 11:53:48 |
+| localhost110004:12845 | 1 | {"maxMemory":1073741824,"usedMemory":104839664,"systemCPUUsed":6.29,"systemLeftMemory":2800877568} | \N | {"nodeHealthy":"Healthy","msg":""} | 2022-11-16 14:30:17 | 2022-11-16 12:03:20 |
+
+
+## 14. linkis_cg_rm_external_resource_provider
+
+> 资源扩展信息配置表 目前主要用于yarn资源信息的配置
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(10) | PRI | NO | auto_increment | |
+| 2 | `resource_type` | 资源类型 Yarn| varchar(32) | | NO | | |
+| 3 | `name` | 名称| varchar(32) | | NO | | |
+| 4 | `labels` | 标签| varchar(32) | | YES | | |
+| 5 | `config` | 连接信息 | text | | NO | | |
+
+
+```scala
+//默认使用的为default 通过配置项wds.linkis.rm.default.yarn.cluster.name 控制
+ val DEFAULT_YARN_CLUSTER_NAME = CommonVars("wds.linkis.rm.default.yarn.cluster.name", "default")
+ val DEFAULT_YARN_TYPE = CommonVars("wds.linkis.rm.default.yarn.cluster.type", "Yarn")
+```
+
+**示例数据**
+
+| id | resource_type | name | labels | config |
+| ---: | --- | --- | --- | --- |
+| 1 | Yarn | sit | \N | {"rmWebAddress": "http://127.0.0.1:8088","hadoopVersion": "2.7.2","authorEnable":true,"user":"hadoop","pwd":"123456"} |
+| 2 | Yarn | DEV | \N | {"rmWebAddress": "http://127.0.0.1:8088","hadoopVersion": "2.7.2","authorEnable":true,"user":"hadoop","pwd":"123456"} |
+| 3 | Yarn | PROD | \N | {"rmWebAddress": "http://127.0.0.1:8088","hadoopVersion": "2.7.2","authorEnable":true,"user":"hadoop","pwd":"123456"} |
+
+
+
+
+## 15. linkis_cg_rm_resource_action_record
+
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_value` | | varchar(100) | MUL | NO | | |
+| 3 | `ticket_id` | | varchar(100) | | NO | | |
+| 4 | `request_times` | | int(8) | | YES | | |
+| 5 | `request_resource_all` | | varchar(100) | | YES | | |
+| 6 | `used_times` | | int(8) | | YES | | |
+| 7 | `used_resource_all` | | varchar(100) | | YES | | |
+| 8 | `release_times` | | int(8) | | YES | | |
+| 9 | `release_resource_all` | | varchar(100) | | YES | | |
+| 10 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 11 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | label_value | ticket_id | request_times | request_resource_all | used_times | used_resource_all | release_times | release_resource_all | update_time | create_time |
+| ---: | --- | --- | ---: | --- | ---: | --- | ---: | --- | --- | --- |
+| 6 | leebai-IDE,hive-2.3.3 | 0dff1547-6867-4e5c-8baa-4bb561d586e3 | 1 | {"memory":1073741824,"cores":2,"instance":1} | 0 | {"memory":0,"cores":0,"instance":0} | 0 | {"memory":0,"cores":0,"instance":0} | 2021-12-30 19:29:21 | 2021-12-30 19:29:21 |
+| 7 | hadoop-Schedulis,spark-2.4.3 | e3a1aeeb-c04a-44cb-a94b-d84e54e55185 | 1 | {"memory":2147483648,"cores":1,"instance":1} | 0 | {"memory":0,"cores":0,"instance":0} | 0 | {"memory":0,"cores":0,"instance":0} | 2021-12-30 19:47:37 | 2021-12-30 19:47:37 |
+
+
+
+
+
+## 16. linkis_mg_gateway_auth_token
+
+> gateway 的token方式认证的 token令牌信息记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `token_name` | token 名 | varchar(128) | UNI | NO | | |
+| 3 | `legal_users` | 合法可使用用户 * 为所有| text | | YES | | |
+| 4 | `legal_hosts` | 合法可请求的源ip * 为所有 | text | | YES | | |
+| 5 | `business_owner` | 业务归属方 | varchar(32) | | YES | | |
+| 6 | `create_time` | | date | | YES | | |
+| 7 | `update_time` | | date | | YES | | |
+| 8 | `elapse_day` | 过期天数 -1 为永久有效| bigint(20) | | YES | | |
+| 9 | `update_by` | | varchar(32) | | YES | | |
+
+
+**示例数据**
+
+| id | token_name | legal_users | legal_hosts | business_owner | create_time | update_time | elapse_day | update_by |
+| ---: | --- | --- | --- | --- | --- | --- | ---: | --- |
+| 2 | BML-AUTH | * | * | BDP | 2021-09-15 | 2021-09-15 | -1 | LINKIS |
+| 3 | WS-AUTH | * | * | BDP | 2021-09-15 | 2021-09-15 | -1 | LINKIS |
+| 4 | dss-AUTH | * | * | BDP | 2021-09-15 | 2021-09-15 | -1 | LINKIS |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_token_name` | 将`token_name` 列设置为唯一索引 | UNIQUE KEY | `token_name` |
+
+
+
+## 17. linkis_ps_bml_project
+
+> bml 物料管理工程项目记录 主要提供给dss 工程空间的项目列表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(10) | PRI | NO | auto_increment | |
+| 2 | `name` | 项目名| varchar(128) | UNI | YES | | |
+| 3 | `system` | 使用系统 | varchar(64) | | NO | | dss |
+| 4 | `source` | | varchar(1024) | | YES | | |
+| 5 | `description` | | varchar(1024) | | YES | | |
+| 6 | `creator` | | varchar(128) | | NO | | |
+| 7 | `enabled` | | tinyint(4) | | YES | | 1 |
+| 8 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | name | system | source | description | creator | enabled | create_time |
+| ---: | --- | --- | --- | --- | --- | ---: | --- |
+| 2524 | metabase_test_ywz_1234 | dss | \N | jinyangrao 在bml创建的工程 | jinyangrao | 1 | 2022-11-16 09:36:58 |
+| 2523 | metabase_test_tjg_345 | dss | \N | jinyangrao 在bml创建的工程 | jinyangrao | 1 | 2022-11-16 09:11:08 |
+| 2522 | test_1114_54_copynull | dss | \N | stacyyan 在bml创建的工程 | stacyyan | 1 | 2022-11-15 10:44:27 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_name` | 将`name` 列设置为唯一索引 | UNIQUE KEY | `name` |
+
+
+
+## 18. linkis_ps_bml_project_resource
+
+> bml项目和对应的资源id关系表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(10) | PRI | NO | auto_increment | |
+| 2 | `project_id` | 项目id | int(10) | | NO | | |
+| 3 | `resource_id` | 资源存储的resource id | varchar(128) | | YES | | |
+
+
+**示例数据**
+
+| id | project_id | resource_id |
+| ---: | ---: | --- |
+| 1 | 1 | 103cb0cc-e12b-4c2e-b8de-a8f58ad17d75 |
+| 2 | 1 | 86bcd05d-4ed9-46be-ab26-d8a76433138b |
+| 3 | 1 | 01697abe-7658-4d3f-b49b-bac4c809a7ba |
+
+
+
+## 19. linkis_ps_bml_project_user
+
+> bml项目和用户关系表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(10) | PRI | NO | auto_increment | |
+| 2 | `project_id` | 项目id | int(10) | | NO | | |
+| 3 | `username` | | varchar(64) | MUL | YES | | |
+| 4 | `priv` | rwx 421 权限值为7。8为管理员,可以授权其他用户| int(10) | | NO | | 7 |
+| 5 | `creator` | 创建者 | varchar(128) | | NO | | |
+| 6 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 7 | `expire_time` | | datetime | | YES | | |
+
+
+**示例数据**
+
+| id | project_id | username | priv | creator | create_time | expire_time |
+| ---: | ---: | --- | ---: | --- | --- | --- |
+| 22 | 21 | jianfuzhang | 7 | jianfuzhang | 2021-05-10 15:20:48 | \N |
+| 23 | 22 | neiljianliu | 7 | neiljianliu | 2021-05-10 15:26:23 | \N |
+| 24 | 22 | jianfuzhang | 5 | neiljianliu | 2021-05-10 15:26:23 | \N |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_name_pid` | 将`username`, `project_id` 列设置为唯一索引 | UNIQUE KEY | `username`, `project_id` |
+
+
+
+## 20. linkis_ps_bml_resources
+
+> bml 物料资源存储信息表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary key | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `resource_id` | 资源的 uuid | varchar(50) | | NO | | |
+| 3 | `is_private` | 资源是否私有,0表示私有,1表示公共 | tinyint(1) | | YES | | 0 |
+| 4 | `resource_header` | 分类,0表示未分类,1表示分类 | tinyint(1) | | YES | | 0 |
+| 5 | `downloaded_file_name` | 下载时的文件名 | varchar(200) | | YES | | |
+| 6 | `sys` | 归属系统 | varchar(100) | | NO | | |
+| 7 | `create_time` | 创建时间 | datetime | | NO | | CURRENT_TIMESTAMP |
+| 8 | `owner` | 资源所有则 | varchar(200) | | NO | | |
+| 9 | `is_expire` | 是否过期,0表示未过期,1表示过期| tinyint(1) | | YES | | 0 |
+| 10 | `expire_type` | 到期类型,date指的是在指定的日期到期,TIME指的是时间| varchar(50) | | YES | | |
+| 11 | `expire_time` | 过期时间,默认一天 | varchar(50) | | YES | | |
+| 12 | `max_version` | 默认为10,表示保留最新的10个版本 | int(20) | | YES | | 10 |
+| 13 | `update_time` | Updated time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 14 | `updator` | updator | varchar(50) | | YES | | |
+| 15 | `enable_flag` | 状态,1:正常,0:冻结 | tinyint(1) | | NO | | 1 |
+
+**示例数据**
+
+| id | resource_id | is_private | resource_header | downloaded_file_name | sys | create_time | owner | is_expire | expire_type | expire_time | max_version | update_time | updator | enable_flag |
+| ---: | --- | ---: | ---: | --- | --- | --- | --- | ---: | --- | --- | ---: | --- | --- | ---: |
+| 332800 | 72eac098-0d71-42c9-962c-e9580ac5ac0b | 1 | \N | 72eac098-0d71-42c9-962c-e9580ac5ac0b | WTSS | 2022-07-27 09:47:06 | hadoop | 0 | \N | \N | 10 | 2022-07-27 09:47:06 | \N | 1 |
+| 398336 | 273611e6-e1be-480e-8556-c2534910e855 | 1 | \N | 273611e6-e1be-480e-8556-c2534910e855 | WTSS | 2022-07-29 06:31:44 | hadoop | 0 | \N | \N | 10 | 2022-07-29 06:31:44 | \N | 1 |
+| 463872 | a111ab00-bafd-4341-a17b-ab9101970abd | 1 | \N | a111ab00-bafd-4341-a17b-ab9101970abd | WTSS | 2022-08-03 06:18:32 | hadoop | 0 | \N | \N | 10 | 2022-08-03 06:18:32 | \N | 1 |
+
+
+## 21. linkis_ps_bml_resources_permission
+
+ // todo 未使用?
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary key | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `resource_id` | Resource uuid | varchar(50) | | NO | | |
+| 3 | `permission` | permission | varchar(10) | | NO | | |
+| 4 | `create_time` | created time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 5 | `system` | creator | varchar(50) | | YES | | dss |
+| 6 | `update_time` | updated time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 7 | `updator` | updator | varchar(50) | | NO | | |
+
+
+## 22. linkis_ps_bml_resources_task
+
+> bml 物料资源操作记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `resource_id` | 资源uuid | varchar(50) | | YES | | |
+| 3 | `version` | 当前操作的资源版本号 | varchar(20) | | YES | | |
+| 4 | `operation` |操作类型。 上传 = 0,更新 = 1 | varchar(20) | | NO | | |
+| 5 | `state` | 任务当前状态:Schduled, Running, Succeed, Failed,Cancelled | varchar(20) | | NO | | Schduled |
+| 6 | `submit_user` | 作业提交用户名 | varchar(20) | | NO | | |
+| 7 | `system` | 系统名称 如: wtss | varchar(20) | | YES | | dss |
+| 8 | `instance` | 提供服务的实例| varchar(128) | | NO | | |
+| 9 | `client_ip` | 请求方ip | varchar(50) | | YES | | |
+| 10 | `extra_params` | 附加关键信息。 比如批量删除的资源ID和版本,资源下的所有版本都被删除 | text | | YES | | |
+| 11 | `err_msg` | 任务失败信息。e.getMessage | varchar(2000) | | YES | | |
+| 12 | `start_time` | 开始时间 | datetime | | NO | | CURRENT_TIMESTAMP |
+| 13 | `end_time` | 结束时间 | datetime | | YES | | |
+| 14 | `last_update_time` | 最后更新时间 | datetime | | NO | | |
+
+**示例数据**
+
+| id | resource_id | version | operation | state | submit_user | system | instance | client_ip | extra_params | err_msg | start_time | end_time | last_update_time |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
+| 183039 | 873513f8-9ad0-4473-b7b9-1cc2500abab7 | \N | copyResource | success | stacyyan | \N | localhost11ide01:9107 | 127.0.0.1 | \N | \N | 2022-03-24 20:11:18 | 2022-03-24 20:11:19 | 2022-03-24 20:11:19 |
+| 259846 | 7ae110d2-5649-4c57-9e4c-b48bb62f3382 | \N | deleteResource | success | stacyyan | WTSS | localhost11ide01:9107 | 127.0.0.1 | delete resourceId:7ae110d2-5649-4c57-9e4c-b48bb62f3382, and delete versions is :v000001 | \N | 2022-06-01 14:38:42 | 2022-06-01 14:38:43 | 2022-06-01 14:38:43 |
+| 12551 | 8678bbd5-cfc7-411b-a838-1b145dab8473 | \N | deleteResource | success | neiljianliu | WTSS | localhost11ide01:9107 | 127.0.0.1 | delete resourceId:8678bbd5-cfc7-411b-a838-1b145dab8473, and delete versions is :v000001 | \N | 2021-07-16 14:47:15 | 2021-07-16 14:47:15 | 2021-07-16 14:47:15 |
+| 36360 | eadc8908-e00c-4604-ab30-6671f33e753e | \N | deleteResource | success | neiljianliu | WTSS | localhost11ide01:9107 | 127.0.0.1 | delete resourceId:eadc8908-e00c-4604-ab30-6671f33e753e, and delete versions is :v000001 | \N | 2021-10-26 17:46:15 | 2021-10-26 17:46:15 | 2021-10-26 17:46:15 |
+| 549888 | dfbd7603-d513-413a-b491-d79a62a25407 | v000001 | upload | success | hadoop | dss | localhost11ide01:9107 | 127.0.0.1 | \N | \N | 2022-07-29 00:26:43 | 2022-07-29 00:26:43 | 2022-07-29 00:26:43 |
+| 51775 | ba304c46-ab63-404e-b2aa-69f522ef3baa | v000004 | rollbackVersion | success | johnnwang | \N | localhost11ide01:9107 | 127.0.0.1 | \N | \N | 2021-11-27 17:04:28 | 2021-11-27 17:04:28 | 2021-11-27 17:04:28 |
+| 28 | d07d8636-5415-418f-9aff-dde1b3a69569 | v000005 | update | success | hadoop | WTSS | localhost11ide01:9107 | 127.0.0.1 | \N | \N | 2021-04-29 14:24:36 | 2021-04-29 14:24:36 | 2021-04-29 14:24:36 |
+
+
+## 23. linkis_ps_bml_resources_version
+
+>资源和对应的版本信息关联表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary key | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `resource_id` | 资源uuid | varchar(50) | MUL | NO | | |
+| 3 | `file_md5` | 文件的md5摘要 | varchar(32) | | NO | | |
+| 4 | `version` | 资源版本(v 后面加五位数字) | varchar(20) | | NO | | |
+| 5 | `size` | 文件大小 | int(10) | | NO | | |
+| 6 | `start_byte` | 开始字节 | bigint(20) unsigned | | NO | | 0 |
+| 7 | `end_byte` | 结束字节 | bigint(20) unsigned | | NO | | 0 |
+| 8 | `resource` | 资源内容(文件信息包括路径和文件名) | varchar(2000) | | NO | | |
+| 9 | `description` | 说明 | varchar(2000) | | YES | | |
+| 10 | `start_time` | 开始时间 | datetime | | NO | | CURRENT_TIMESTAMP |
+| 11 | `end_time` | 停止时间 | datetime | | NO | | CURRENT_TIMESTAMP |
+| 12 | `client_ip` | 客户端ip | varchar(200) | | NO | | |
+| 13 | `updator` | updator | varchar(50) | | YES | | |
+| 14 | `enable_flag` | 状态,1:正常,0:冻结| tinyint(1) | | NO | | 1 |
+
+
+**示例数据**
+
+| id | resource_id | file_md5 | version | size | start_byte | end_byte | resource | description | start_time | end_time | client_ip | updator | enable_flag |
+| ---: | --- | --- | --- | ---: | ---: | ---: | --- | --- | --- | --- | --- | --- | ---: |
+| 1 | 863846e2-bd31-49ba-babe-9a2b96616d71 | b8fd956fd8f83d09d203bf9e4b40543f | v000001 | 1668 | 1 | 1668 | hdfs:///apps-data/hadoop/bml/20210429/863846e2-bd31-49ba-babe-9a2b96616d71 | \N | 2021-04-29 12:21:07 | 2021-04-29 12:21:07 | 127.0.0.1 | \N | 1 |
+| 2 | 9d39cb8e-1447-46d5-a11d-b597b2e3200f | 46bf4ff26651c448efb85ffa9c54907f | v000001 | 58965932 | 1 | 58965932 | hdfs:///apps-data/hadoop/bml/20210429/9d39cb8e-1447-46d5-a11d-b597b2e3200f | \N | 2021-04-29 12:21:10 | 2021-04-29 12:21:10 | 127.0.0.1 | \N | 1 |
+| 3 | bc620bfd-d3f4-4fa5-84f7-1c484fac2241 | 8e13ba687fa1ee04e113bff50290a5c6 | v000001 | 1745 | 1 | 1745 | hdfs:///apps-data/hadoop/bml/20210429/bc620bfd-d3f4-4fa5-84f7-1c484fac2241 | \N | 2021-04-29 12:21:14 | 2021-04-29 12:21:14 | 127.0.0.1 | \N | 1 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_rid_version` | 将`resource_id`, `version` 列设置为唯一索引 | UNIQUE KEY | `resource_id`, `version` |
+
+
+
+## 24. linkis_ps_common_lock
+
+> 通用的用于实现分布式锁
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `lock_object` | | varchar(255) | UNI | YES | | |
+| 3 | `time_out` | | longtext | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+
+## 25. linkis_ps_configuration_category
+
+> 参数配置目录树表 对应于管理台的`参数配置页面`
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_id` | linkis_cg_manager_label 标签的id | int(20) | UNI | NO | | |
+| 3 | `level` | 1为应用类型级别 2 为引擎类型级别 | int(20) | | NO | | |
+| 4 | `description` | | varchar(200) | | YES | | |
+| 5 | `tag` | | varchar(200) | | YES | | |
+| 6 | `update_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 7 | `create_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lock_object` | 将`lock_object` 列设置为唯一索引 | UNIQUE KEY | `lock_object` |
+
+
+**示例数据**
+
+| id | label_id | level | description | tag | update_time | create_time |
+| ---: | ---: | ---: | --- | --- | --- | --- |
+| 101 | 46586 | 1 | | \N | 2021-08-19 20:07:09 | 2021-08-19 20:07:09 |
+| 102 | 46587 | 2 | | \N | 2021-08-19 20:07:20 | 2021-08-19 20:07:20 |
+| 103 | 47340 | 1 | | \N | 2021-08-23 10:50:02 | 2021-08-23 10:50:02 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_label_id` | 将`label_id` 列设置为唯一索引 | UNIQUE INDEX | `label_id` |
+
+
+
+## 26. linkis_ps_configuration_config_key
+
+> 引擎相关参数的配置表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `key` | 配置项的key 如 spark.executor.instances | varchar(50) | | YES | | |
+| 3 | `description` | 描述 | varchar(200) | | YES | | |
+| 4 | `name` | 名称 | varchar(50) | | YES | | |
+| 5 | `default_value` | 当用户未进行设置时,使用默认值 | varchar(200) | | YES | | |
+| 6 | `validate_type` | 验证类型,以下之一:None、NumInterval、FloatInterval、Include、Regex、OPF、Custom Rules| varchar(50) | | YES | | |
+| 7 | `validate_range` | 验证范围 | varchar(50) | | YES | | |
+| 8 | `engine_conn_type` | 引擎类型,如 spark、hive 等| varchar(50) | | YES | | |
+| 9 | `is_hidden` | 是否对用户隐藏。 如果设置为 1(true),则用户不能修改,但仍然可以在后端使用 | tinyint(1) | | YES | | |
+| 10 | `is_advanced` | 是否为高级参数。 如果设置为 1(true),参数将仅在用户选择【显示高级参数】时显示 | tinyint(1) | | YES | | |
+| 11 | `level` | 前端显示排序的依据。 级别越高,参数优先显示| tinyint(1) | | YES | | |
+| 12 | `treeName` | 配置项的engineType的子目录分类 | varchar(20) | | YES | | |
+
+
+**示例数据**
+
+| id | key | description | name | default_value | validate_type | validate_range | engine_conn_type | is_hidden | is_advanced | level | treeName |
+| ---: | --- | --- | --- | --- | --- | --- | --- | ---: | ---: | ---: | --- |
+| 1 | wds.linkis.rm.yarnqueue | yarn队列名 | yarn队列名 | default | None | \N | \N | 0 | 0 | 1 | 队列资源 |
+| 2 | wds.linkis.rm.yarnqueue.instance.max | 取值范围:1-128,单位:个 | yarn队列实例最大个数 | 30 | Regex | ^(?:[1-9]\d?|[1234]\d{2}|200)$ | \N | 1 | 0 | 1 | 队列资源 |
+| 3 | wds.linkis.rm.yarnqueue.cores.max | 取值范围:1-1500,单位:个 | 队列CPU使用上限 | 150 | Regex | ^(?:[1-9]\d{0,2}|1[0-4]\d{2}|1500)$ | \N | 0 | 0 | 1 | 队列资源 |
+| 4 | wds.linkis.rm.yarnqueue.memory.max | 取值范围:1-5000,单位:G | 队列内存使用上限 | 300G | Regex | ^([1-9]\d{0,2}|[1-4]\d{3}|5000)(G|g)$ | \N | 0 | 0 | 1 | 队列资源 |
+
+
+## 27. linkis_ps_configuration_config_value
+
+> 参数配置项key对应的配置值表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `config_key_id` | linkis_ps_configuration_config_key的id | bigint(20) | MUL | YES | | |
+| 3 | `config_value` | 设置的值 | varchar(200) | | YES | | |
+| 4 | `config_label_id` | 对应的linkis_cg_manager_label 的id | int(20) | | YES | | |
+| 5 | `update_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 6 | `create_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | config_key_id | config_value | config_label_id | update_time | create_time |
+| ---: | ---: | --- | ---: | --- | --- |
+| 57 | 1 | dws | 25716 | 2022-04-08 16:35:37 | 2021-06-08 16:07:49 |
+| 61 | 30 | python2 | 30819 | 2022-07-04 11:17:25 | 2021-06-08 16:35:23 |
+| 62 | 1 | dws | 519 | 2022-11-07 19:13:29 | 2021-06-08 17:19:44 |
+| 64 | 19 | python2 | 3300 | 2022-08-09 17:38:15 | 2021-06-08 20:15:04 |
+| 65 | 5 | 50G | 1348 | 2022-05-16 15:39:44 | 2021-06-10 17:55:11 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_kid_lid` | 将 `config_key_id`, `config_label_id` 列设置为唯一索引 | UNIQUE INDEX | `config_key_id`, `config_label_id` |
+
+
+
+## 28. linkis_ps_configuration_key_engine_relation
+
+>配置项和引擎的关联关系,设置引擎配置参数模板
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `config_key_id` | config key id | bigint(20) | MUL | NO | | |
+| 3 | `engine_type_label_id` | 对应的linkis_cg_manager_label 的id | bigint(20) | | NO | | |
+
+
+**示例数据**
+
+| id | config_key_id | engine_type_label_id |
+| ---: | ---: | ---: |
+| 1 | 1 | 5 |
+| 73 | 1 | 46586 |
+| 80 | 1 | 47340 |
+| 2 | 2 | 5 |
+| 74 | 2 | 46586 |
+| 81 | 2 | 47340 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_kid_lid` | 将`config_key_id`, `engine_type_label_id` 列设置为唯一索引 | UNIQUE INDEX | `config_key_id`, `engine_type_label_id` |
+
+
+
+## 29. linkis_ps_cs_context_history
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `context_id` | | int(11) | | YES | | |
+| 3 | `source` | | text | | YES | | |
+| 4 | `context_type` | | varchar(32) | | YES | | |
+| 5 | `history_json` | | text | | YES | | |
+| 6 | `keyword` | | varchar(255) | MUL | YES | | |
+| 7 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 8 | `create_time` | create time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 9 | `access_time` | last access time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_keyword` | 将`keyword` 列设置为普通索引 | INDEX | `keyword` |
+
+
+
+
+## 30. linkis_ps_cs_context_id
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `user` | | varchar(32) | | YES | | |
+| 3 | `application` | | varchar(32) | | YES | | |
+| 4 | `source` | | varchar(255) | | YES | | |
+| 5 | `expire_type` | | varchar(32) | | YES | | |
+| 6 | `expire_time` | | datetime | | YES | | |
+| 7 | `instance` | | varchar(128) | MUL | YES | | |
+| 8 | `backup_instance` | | varchar(255) | MUL | YES | | |
+| 9 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 10 | `create_time` | create time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 11 | `access_time` | last access time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | user | application | source | expire_type | expire_time | instance | backup_instance | update_time | create_time | access_time |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
+| 62131 | jinyangrao | \N | {"className":"org.apache.linkis.cs.common.entity.source.LinkisHAWorkFlowContextID","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | \N | \N | cs_1_dev | cs_1_dev | 2022-11-16 14:48:58 | 2022-11-16 14:48:58 | 2022-11-16 14:48:58 |
+| 62126 | alexwu | \N | {"className":"org.apache.linkis.cs.common.entity.source.LinkisHAWorkFlowContextID","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | \N | \N | cs_1_dev | cs_1_dev | 2022-11-16 14:45:49 | 2022-11-16 14:45:49 | 2022-11-16 14:45:49 |
+| 62122 | stacyyan | \N | {"className":"org.apache.linkis.cs.common.entity.source.LinkisHAWorkFlowContextID","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | \N | \N | cs_2_dev | cs_1_dev | 2022-11-16 14:43:54 | 2022-11-16 14:43:54 | 2022-11-16 14:43:54 |
+| 62120 | alexwu | \N | {"className":"org.apache.linkis.cs.common.entity.source.LinkisHAWorkFlowContextID","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | \N | \N | cs_2_dev | cs_1_dev | 2022-11-16 14:32:16 | 2022-11-16 14:32:16 | 2022-11-16 14:32:16 |
+
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_instance` | 将`instance` 列设置为普通索引 | INDEX | `instance` |
+| 2 | `idx_backup_instance` | 将`backup_instance` 列设置为普通索引 | INDEX | `backup_instance` |
+| 3 | `idx_instance_bin` | 将`instance`(128),`backup_instance` 列设置为普通索引 | INDEX | `instance`(128),`backup_instance` |
+
+
+
+## 31. linkis_ps_cs_context_listener
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `listener_source` | | varchar(255) | | YES | | |
+| 3 | `context_id` | | int(11) | | YES | | |
+| 4 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | create time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 6 | `access_time` | last access time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+
+## 32. linkis_ps_cs_context_map
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `key` | | varchar(128) | MUL | YES | | |
+| 3 | `context_scope` | | varchar(32) | | YES | | |
+| 4 | `context_type` | | varchar(32) | | YES | | |
+| 5 | `props` | | text | | YES | | |
+| 6 | `value` | | mediumtext | | YES | | |
+| 7 | `context_id` | | int(11) | | YES | | |
+| 8 | `keywords` | | varchar(255) | MUL | YES | | |
+| 9 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 10 | `create_time` | create time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 11 | `access_time` | last access time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | key | context_scope | context_type | props | value | context_id | keywords | update_time | create_time | access_time |
+| ---: | --- | --- | --- | --- | --- | ---: | --- | --- | --- | --- |
+| 45 | node.sql_1742.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":3735}"} | 1 | ["node.sql_1742.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 51 | node.widget_1508.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":5167}"} | 1 | ["node.widget_1508.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 170 | node.display_3009.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":3738}"} | 1 | ["node.display_3009.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 172 | node.dashboard_7941.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":3740}"} | 1 | ["node.dashboard_7941.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 166 | node.sql_1742.table.cs_tmp_sql_1742_rs1 | PUBLIC | METADATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSTable","value":"{\"name\":\"cs_tmp_sql_1742_rs1\",\"alias\":null,\"creator\":\"jianfuzhang\",\"comment\":\"cs temp table\",\"createTime\":\"2021-05-15T19:18:05+0800\",\"productName\":null,\"projectName\":null,\"usage\":null,\"lifecycle\":null,\"useWay\":null,\"isImport\":false,\"modelLevel\":null,\"isExternalUse\":true,\"isPartitionTable\":false,\"isAvailable\":true,\"isView\":true,\"location\":\"hdfs:///tmp/linkis/jianfuzhang/linkis/20210515_191700/nodeexecution/3735/_0.dolphin\",\"columns\":[{\"name\":\"id\",\"alias\":null,\"type\":\"int\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"name\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"sex\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"age\",\"alias\":null,\"type\":\"int\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"class\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"lesson\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"city\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"teacher\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"score\",\"alias\":null,\"type\":\"double\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"fee\",\"alias\":null,\"type\":\"double\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"birthday\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"exam_date\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null}],\"partitions\":null,\"db\":null}"} | 1 | ["cs_tmp_sql_1742_rs1","hdfs:///tmp/linkis/jianfuzhang/linkis/20210515_191700/nodeexecution/3735/_0.dolphin","node.sql_1742.table.cs_tmp_sql_1742_rs1"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 1744 | node.widget_1508.table.cs_tmp_widget_1508_rs1 | PUBLIC | METADATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSTable","value":"{\"name\":\"cs_tmp_widget_1508_rs1\",\"alias\":null,\"creator\":\"jianfuzhang\",\"comment\":\"cs temp table\",\"createTime\":\"2021-05-18T11:38:47+0800\",\"productName\":null,\"projectName\":null,\"usage\":null,\"lifecycle\":null,\"useWay\":null,\"isImport\":false,\"modelLevel\":null,\"isExternalUse\":true,\"isPartitionTable\":false,\"isAvailable\":true,\"isView\":true,\"location\":\"hdfs:///tmp/linkis/jianfuzhang/linkis/20210518_113844/nodeexecution/5167/_0.dolphin\",\"columns\":[{\"name\":\"birthday\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null}],\"partitions\":null,\"db\":null}"} | 1 | ["hdfs:///tmp/linkis/jianfuzhang/linkis/20210518_113844/nodeexecution/5167/_0.dolphin","cs_tmp_widget_1508_rs1","node.widget_1508.table.cs_tmp_widget_1508_rs1"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 173 | flow.variable.user.to.proxy | PUBLIC | OBJECT | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisVariable","value":"{\"key\":\"user.to.proxy\",\"value\":\"jianfuzhang\"}"} | 1 | ["user.to.proxy","flow.variable.user.to.proxy"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 174 | flow.infos | PUBLIC | OBJECT | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSFlowInfos","value":"{\"infos\":{\"parent\":\"null\",\"id_nodeName\":{\"3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1\":\"sql_1742\",\"a1dfd377-32a1-4b34-b70c-7123a9890bd8\":\"widget_1508\",\"fa7334ed-5811-48a4-9a26-7498e83348dd\":\"display_3009\",\"c5cc7633-a3ef-42dc-8103-550ca4a3d3ce\":\"dashboard_7941\"},\"edges\":[{\"source\":\"3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1\",\"target\":\"a1dfd377-32a1-4b34-b70c-7123a9890bd8\",\"sourceLocation\":\"bottom\",\"targetLocation\":\"top\"},{\"source\":\"a1dfd377-32a1-4b34-b70c-7123a9890bd8\",\"target\":\"fa7334ed-5811-48a4-9a26-7498e83348dd\",\"sourceLocation\":\"bottom\",\"targetLocation\":\"top\"},{\"source\":\"fa7334ed-5811-48a4-9a26-7498e83348dd\",\"target\":\"c5cc7633-a3ef-42dc-8103-550ca4a3d3ce\",\"sourceLocation\":\"bottom\",\"targetLocation\":\"top\"}]}}"} | 1 | ["flow.infos"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 42 | node.sql_1742.resource.3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1.sql | PUBLIC | RESOURCE | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"linkisBMLResource","value":"{\"resourceId\":\"850d6dc7-4489-4b06-90f4-1d2b5b65d0b7\",\"version\":\"v000001\",\"isPrivate\":null,\"resourceHeader\":null,\"downloadedFileName\":\"3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1.sql\",\"sys\":null,\"createTime\":null,\"isExpire\":null,\"expireType\":null,\"expireTime\":null,\"updateTime\":null,\"updator\":null,\"maxVersion\":null,\"user\":null,\"system\":null,\"enableFlag\":null}"} | 1 | ["v000001","3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1.sql","850d6dc7-4489-4b06-90f4-1d2b5b65d0b7","node.sql_1742.resource.3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1.sql"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 79 | flow.infos | PUBLIC | RESOURCE | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSFlowInfos","value":"{\"infos\":{\"parent\":\"flow2\",\"id_nodeName\":{\"90a6ee94-4bd6-47d9-a536-f92660c4c051\":\"sql\",\"90a6ee94-4bd6-47d9-a536-f92660c4c052\":\"hql\"},\"edges\":[{\"sourceLocation\":\"bottom\",\"source\":\"sql \",\"targetLocation\":\"top\",\"target\":\"hql\"}]}}"} | 2 | ["flow.infos"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 199 | node.sql_3999.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":344064}"} | 3 | ["node.sql_3999.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 210 | node.widget_654.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":3808}"} | 3 | ["node.widget_654.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 31327 | node.sql_3999.table.cs_tmp_sql_3999_rs1 | PUBLIC | METADATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSTable","value":"{\"name\":\"cs_tmp_sql_3999_rs1\",\"alias\":null,\"creator\":\"hadoop\",\"comment\":\"cs temp table\",\"createTime\":\"2021-07-28T17:55:56+0800\",\"productName\":null,\"projectName\":null,\"usage\":null,\"lifecycle\":null,\"useWay\":null,\"isImport\":false,\"modelLevel\":null,\"isExternalUse\":true,\"isPartitionTable\":false,\"isAvailable\":true,\"isView\":true,\"location\":\"hdfs:///apps-data/hadoop/linkis/20210728_175555/nodeexecution/344064/_0.dolphin\",\"columns\":[{\"name\":\"database\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"tableName\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"isTemporary\",\"alias\":null,\"type\":\"boolean\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null}],\"partitions\":null,\"db\":null}"} | 3 | ["node.sql_3999.table.cs_tmp_sql_3999_rs1","hdfs:///apps-data/hadoop/linkis/20210728_175555/nodeexecution/344064/_0.dolphin","cs_tmp_sql_3999_rs1"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 31325 | flow.variable.user.to.proxy | PUBLIC | OBJECT | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisVariable","value":"{\"key\":\"user.to.proxy\",\"value\":\"alexyang\"}"} | 3 | ["user.to.proxy","flow.variable.user.to.proxy"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 31326 | flow.infos | PUBLIC | OBJECT | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSFlowInfos","value":"{\"infos\":{\"parent\":\"null\",\"id_nodeName\":{\"b08c3f5e-f5d7-4209-866b-f4f963196b3d\":\"sql_3999\",\"4b9b446b-304d-451f-90b6-67d9ad5d3e49\":\"widget_654\"},\"edges\":[{\"source\":\"b08c3f5e-f5d7-4209-866b-f4f963196b3d\",\"target\":\"4b9b446b-304d-451f-90b6-67d9ad5d3e49\",\"sourceLocation\":\"right\",\"targetLocation\":\"left\"}]}}"} | 3 | ["flow.infos"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_key_cid_ctype` | 将`key`,`context_id`,`context_type`列设置为唯一索引 | UNIQUE INDEX | `key`,`context_id`,`context_type` |
+| 2 | `idx_keywords` | 将`keywords`列设置为普通索引 | INDEX | `keywords` |
+
+
+## 33. linkis_ps_cs_context_map_listener
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `listener_source` | | varchar(255) | | YES | | |
+| 3 | `key_id` | | int(11) | | YES | | |
+| 4 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | create time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 6 | `access_time` | last access time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+
+
+## 34. linkis_ps_datasource_access
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `table_id` | | bigint(20) | | NO | | |
+| 3 | `visitor` | | varchar(16) | | NO | | |
+| 4 | `fields` | | varchar(255) | | YES | | |
+| 5 | `application_id` | | int(4) | | NO | | |
+| 6 | `access_time` | | datetime | | NO | | |
+
+
+## 35. linkis_ps_datasource_field
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `table_id` | | bigint(20) | | NO | | |
+| 3 | `name` | | varchar(64) | | NO | | |
+| 4 | `alias` | | varchar(64) | | YES | | |
+| 5 | `type` | | varchar(64) | | NO | | |
+| 6 | `comment` | | varchar(255) | | YES | | |
+| 7 | `express` | | varchar(255) | | YES | | |
+| 8 | `rule` | | varchar(128) | | YES | | |
+| 9 | `is_partition_field` | | tinyint(1) | | NO | | |
+| 10 | `is_primary` | | tinyint(1) | | NO | | |
+| 11 | `length` | | int(11) | | YES | | |
+
+
+**示例数据**
+
+| id | table_id | name | alias | type | comment | express | rule | is_partition_field | is_primary | length | mode_info |
+| ---: | ---: | --- | --- | --- | --- | --- | --- | ---: | ---: | ---: | --- |
+| 4396 | 216 | ds | | string | | \N | \N | 1 | 0 | 8 | \N |
+| 4395 | 216 | b | | string | | \N | | 0 | 0 | \N | \N |
+| 4394 | 216 | a | | string | | \N | | 0 | 0 | \N | \N |
+| 4393 | 215 | ds | | string | | \N | \N | 1 | 0 | 8 | \N |
+| 4392 | 215 | col_3 | | string | | | | 0 | 0 | \N | \N |
+| 4391 | 215 | col_2 | | string | | | | 0 | 0 | \N | \N |
+| 4390 | 215 | col_1 | | string | | | | 0 | 0 | \N | \N |
+
+
+
+## 36. linkis_ps_datasource_import
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `table_id` | | bigint(20) | | NO | | |
+| 3 | `import_type` | | int(4) | | NO | | |
+| 4 | `args` | | varchar(255) | | NO | | |
+
+
+**示例数据**
+
+| id | table_id | import_type | args |
+| ---: | ---: | ---: | --- |
+| 94 | 215 | 1 | {"exportPath":"/mnt/bdap/stacyyan/aa/aaa125.csv","type":"share","separator":",","chartset":"utf-8","quote":"","isHasHeader":"false"} |
+| 93 | 214 | 0 | {"database":"stacyyan_ind","table":"00153d26da1a11eb8c30813d0f05b1af1"} |
+| 92 | 213 | 2 | {"exportPath":"/mnt/bdap/stacyyan/aa/studentInfo.xlsx","type":"share","isHasHeader":"false"} |
+| 88 | 170 | 1 | {"exportPath":"/mnt/bdap/janicegong/file测试/上传文件/orc.csv","type":"share","separator":",","chartset":"utf-8","quote":"","isHasHeader":"false"} |
+| 87 | 169 | 1 | {"exportPath":"/mnt/bdap/johnnwang/test1_hql__1652150994191.csv","type":"share","separator":",","chartset":"utf-8","quote":"","isHasHeader":"false"} |
+
+
+
+## 37. linkis_ps_datasource_lineage
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `table_id` | | bigint(20) | | YES | | |
+| 3 | `source_table` | | varchar(64) | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | |
+
+**示例数据**
+
+| id | table_id | source_table | update_time |
+| ---: | ---: | --- | --- |
+| 40 | 214 | stacyyan_ind.00153d26da1a11eb8c30813d0f05b1af1 | 2022-11-08 21:14:41 |
+| 39 | 162 | janicegong_ind.aa | 2022-09-04 17:28:46 |
+| 38 | 156 | jin_ind.test_0902j | 2022-09-02 19:47:20 |
+
+
+
+## 38. linkis_ps_datasource_table
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(255) | PRI | NO | auto_increment | |
+| 2 | `database` | | varchar(64) | MUL | NO | | |
+| 3 | `name` | | varchar(64) | | NO | | |
+| 4 | `alias` | | varchar(64) | | YES | | |
+| 5 | `creator` | | varchar(16) | | NO | | |
+| 6 | `comment` | | varchar(255) | | YES | | |
+| 7 | `create_time` | | datetime | | NO | | |
+| 8 | `product_name` | | varchar(64) | | YES | | |
+| 9 | `project_name` | | varchar(255) | | YES | | |
+| 10 | `usage` | | varchar(128) | | YES | | |
+| 11 | `lifecycle` | | int(4) | | NO | | |
+| 12 | `use_way` | | int(4) | | NO | | |
+| 13 | `is_import` | | tinyint(1) | | NO | | |
+| 14 | `model_level` | | int(4) | | NO | | |
+| 15 | `is_external_use` | | tinyint(1) | | NO | | |
+| 16 | `is_partition_table` | | tinyint(1) | | NO | | |
+| 17 | `is_available` | | tinyint(1) | | NO | | |
+
+
+**示例数据**
+
+| id | database | name | alias | creator | comment | create_time | product_name | project_name | usage | lifecycle | use_way | is_import | model_level | is_external_use | is_partition_table | is_available |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- | --- | ---: | ---: | ---: | ---: | ---: | ---: | ---: |
+| 216 | stacyyan_ind | aa_1109 | 表别名_1109 | stacyyan | | 2022-11-09 16:15:03 | | | | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
+| 215 | jin_ind | test_1109aaa | test_1109aaa | stacyyan | | 2022-11-09 09:51:41 | | | | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
+| 214 | stacyyan_ind | test_1108ar | test_1108ar | stacyyan | | 2022-11-08 21:14:41 | | | | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_db_name` | 将`database`,`name` 列设置为唯一索引 | UNIQUE INDEX |`database`,`name` |
+
+
+
+## 39. linkis_ps_datasource_table_info
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `table_id` | | bigint(20) | | NO | | |
+| 3 | `table_last_update_time` | | datetime | | NO | | |
+| 4 | `row_num` | | bigint(20) | | NO | | |
+| 5 | `file_num` | | int(11) | | NO | | |
+| 6 | `table_size` | | varchar(32) | | NO | | |
+| 7 | `partitions_num` | | int(11) | | NO | | |
+| 8 | `update_time` | | datetime | | NO | | |
+| 9 | `field_num` | | int(11) | | NO | | |
+
+
+## 40. linkis_ps_dm_datasource
+
+> 配置的数据源信息表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `datasource_name` | 数据源名称 | varchar(255) | | NO | | |
+| 3 | `datasource_desc` | 数据源描述 | varchar(255) | | YES | | |
+| 4 | `datasource_type_id` |数据源类型ID linkis_ps_dm_datasource_type对应的id | int(11) | | NO | | |
+| 5 | `create_identify` |标识 | varchar(255) | | YES | | |
+| 6 | `create_system` | 创建数据源的系统 | varchar(255) | | YES | | |
+| 7 | `parameter` | 数据源参数,注意 不做存储,实体类parameter字段通过linkis_ps_dm_datasource_version的parameter获取 | varchar(255) | | YES | | |
+| 8 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 9 | `modify_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 10 | `create_user` | | varchar(255) | | YES | | |
+| 11 | `modify_user` | | varchar(255) | | YES | | |
+| 12 | `labels` | 数据源标签 | varchar(255) | | YES | | |
+| 13 | `version_id` | 数据源版本ID | int(11) | | YES | | |
+| 14 | `expire` | 数据源是否过期 | tinyint(1) | | YES | | 0 |
+| 15 | `published_version_id` |数据源发布版本号 | int(11) | | YES | | |
+
+
+**示例数据**
+
+| id | datasource_name | datasource_desc | datasource_type_id | create_identify | create_system | parameter | create_time | modify_time | create_user | modify_user | labels | version_id | expire | published_version_id |
+| ---: | --- | --- | ---: | --- | --- | --- | --- | --- | --- | --- | --- | ---: | ---: | ---: |
+| 243 | mongodb_test_20221020101428 | create | 6 | \N | Linkis | {"dataSourceTypeId":"6","host":"127.0.0.1","port":"20500","params":"{\"connectTimeout\":\"100\"}","database":"dpvcs-dev","username":"dpvcsopr","password":"dpvcsopr"} | 2022-10-20 10:14:36 | 2022-10-20 10:14:36 | janicegong | \N | auto_test20220801 | 2 | 0 | 1 |
+| 244 | elasticsearch_test__20221020101428 | create | 7 | \N | Linkis | {"dataSourceTypeId":"7","username":"test","password":"123456","elasticUrls":"[\"http://127.0.0.1:9101\"]"} | 2022-10-20 10:14:38 | 2022-10-20 10:14:38 | janicegong | \N | auto_test20220801 | 2 | 1 | 1 |
+| 245 | mysql_test_1027 | mysql | 1 | | MYSQL | {"host":"127.0.0.1","port":"15304","params":"{\"tinyInt1isBit\":\"false\"}","username":"test","password":"123456"} | 2022-10-27 20:35:05 | 2022-10-27 20:35:05 | stacyyan | \N | demo,勿删 | 1 | 0 | 1 |
+| 246 | hive_test_sit | demo,勿删 | 4 | | HIVE | {"envId":"2"} | 2022-10-27 20:35:55 | 2022-10-27 20:35:55 | stacyyan | \N | | 1 | 0 | 1 |
+
+
+
+## 41. linkis_ps_dm_datasource_env
+
+> 数据源环境信息 主要用户hive类型数据源的配置 通过hive集群环境进行数据源连接配置的选择
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `env_name` | 环境名| varchar(32) | | NO | | |
+| 3 | `env_desc` | 环境描述 | varchar(255) | | YES | | |
+| 4 | `datasource_type_id` | 数据源类型ID linkis_ps_dm_datasource_type对应的id | int(11) | | NO | | |
+| 5 | `parameter` | 数据源环境参数| varchar(255) | | YES | | |
+| 6 | `create_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 7 | `create_user` | | varchar(255) | | YES | | |
+| 8 | `modify_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 9 | `modify_user` | | varchar(255) | | YES | | |
+
+
+**示例数据**
+
+| id | env_name | env_desc | datasource_type_id | parameter | create_time | create_user | modify_time | modify_user |
+| ---: | --- | --- | ---: | --- | --- | --- | --- | --- |
+| 1 | BDP-UAT | BDP-UAT测试环境 | 4 | {"uris":"thrift://localhost100001:9083", "hadoopConf":{"hive.metastore.execute.setugi":"true"}} | 2022-04-12 22:34:11 | \N | 2022-04-12 22:34:11 | \N |
+| 2 | BDAP-UAT | BDAP-UAT测试环境 | 4 | {"uris":"thrift://localhost110001:9083", "hadoopConf":{"hive.metastore.execute.setugi":"true"}} | 2022-04-12 22:34:11 | \N | 2022-04-12 22:34:11 | \N |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_env_name` | 将`env_name` 列设置为唯一索引 | UNIQUE KEY | `env_name` |
+| 2 | `uniq_name_dtid` | 将`env_name`, `datasource_type_id` 列设置为唯一索引 | UNIQUE INDEX | `env_name`, `datasource_type_id` |
+
+
+
+## 42. linkis_ps_dm_datasource_type
+
+> 数据源类型表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `name` | 数据源类型名称 | varchar(32) | | NO | | |
+| 3 | `description` | 数据源类型描述 | varchar(255) | | YES | | |
+| 4 | `option` | 数据源所属类型| varchar(32) | | YES | | |
+| 5 | `classifier` | 数据源类型分类词 | varchar(32) | | NO | | |
+| 6 | `icon` | 数据源图片显示路径| varchar(255) | | YES | | |
+| 7 | `layers` | 数据源类型层次 | int(3) | | NO | | |
+
+**示例数据**
+
+| id | name | description | option | classifier | icon | layers |
+| ---: | --- | --- | --- | --- | --- | ---: |
+| 1 | mysql | mysql数据库 | mysql数据库 | 关系型数据库(Relational DB) | | 3 |
+| 2 | kafka | kafka | kafka | 消息队列(Message DB) | | 2 |
+| 3 | presto | presto SQL | presto | 大数据存储(BigData) | | 3 |
+| 4 | hive | hive数据库 | hive | 大数据存储(BigData) | | 3 |
+| 6 | mongodb | mongodb 数据源 | mongodb | 半结构化数据库 | \N | 3 |
+| 7 | elasticsearch | ES description | es无结构存储 | 分布式全文索引 | \N | 3 |
+| 8 | oracle | This is oracle datasource | oracle关系型数据库 | 关系型数据库 | \N | 3 |
+
+
+
+
+## 43. linkis_ps_dm_datasource_type_key
+
+> 不同数据源类型所需要进行配置的参数
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `data_source_type_id` | 数据源类型ID linkis_ps_dm_datasource_type对应的id | int(11) | | NO | | |
+| 3 | `key` | 数据源参数key值| varchar(32) | | NO | | |
+| 4 | `name` | 数据源参数名称 用于前端展示 | varchar(32) | | NO | | |
+| 5 | `name_en` | 数据源参数名称 英文 用于前端展示 | varchar(32) | | NO | | |
+| 6 | `default_value` | 数据源参数默认值 | varchar(50) | | YES | | |
+| 7 | `value_type` | 数据源参数类型 | varchar(50) | | NO | | |
+| 8 | `scope` | 数据源参数范围 一般未使用到 | varchar(50) | | YES | | |
+| 9 | `require` | 数据源参数是否必须 | tinyint(1) | | YES | | 0 |
+| 10 | `description` | 数据源参数描述 用于前端展示| varchar(200) | | YES | | |
+| 11 | `description_en` | 数据源参数描述 英文 用于前端展示| varchar(200) | | YES | | |
+| 12 | `value_regex` | 数据源参数正则| varchar(200) | | YES | | |
+| 13 | `ref_id` | | bigint(20) | | YES | | |
+| 14 | `ref_value` | | varchar(50) | | YES | | |
+| 15 | `data_source` |数据来源 可以从是一个接口获取 | varchar(200) | | YES | | |
+| 16 | `update_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 17 | `create_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | data_source_type_id | key | name | default_value | value_type | scope | require | description | value_regex | ref_id | ref_value | data_source | update_time | create_time |
+| ---: | ---: | --- | --- | --- | --- | --- | ---: | --- | --- | ---: | --- | --- | --- | --- |
+| 1 | 1 | host | Host | \N | TEXT | \N | 1 | mysql Host | \N | \N | \N | \N | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+| 2 | 1 | port | 端口 | \N | TEXT | \N | 1 | 端口 | \N | \N | \N | \N | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+| 3 | 1 | params | 连接参数 | \N | TEXT | \N | 0 | 输入JSON格式: {"param":"value"} | \N | \N | \N | \N | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+| 4 | 1 | username | 用户名 | \N | TEXT | \N | 1 | 用户名 | ^[0-9A-Za-z_-]+$ | \N | \N | \N | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+| 5 | 1 | password | 密码 | \N | PASSWORD | \N | 1 | 密码 | | \N | \N | \N | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+| 6 | 4 | envId | 集群环境 | \N | SELECT | \N | 1 | 集群环境 | \N | \N | \N | /data-source-manager/env-list/all/type/4 | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_dstid_key` | 将`data_source_type_id`, `key` 列设置为唯一索引 | UNIQUE KEY | `data_source_type_id`, `key` |
+
+
+
+## 44. linkis_ps_dm_datasource_version
+
+> 数据源版本信息表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `version_id` | 数据源版本ID | int(11) | PRI | NO | auto_increment | |
+| 2 | `datasource_id` | 数据源ID linkis_ps_dm_datasourc 对应的id | int(11) | PRI | NO | | |
+| 3 | `parameter` | 数据源该版本参数 | varchar(2048) | | YES | | |
+| 4 | `comment` | | varchar(255) | | YES | | |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 6 | `create_user` | | varchar(255) | | YES | | |
+
+
+**示例数据**
+
+| version_id | datasource_id | parameter | comment | create_time | create_user |
+| ---: | ---: | --- | --- | --- | --- |
+| 1 | 41 | {"envId":"2"} | 初始化版本 | 2022-05-25 12:26:44 | neiljianliu |
+| 1 | 42 | {"password":"1234123213","subSystem":"","port":"123","appid":null,"host":"123","authType":null,"objectid":null,"username":"123","mkPrivate":null,"timestamp":null} | qualitis | 2022-05-27 19:56:41 | allenzhou |
+| 1 | 43 | {"host":"333","port":"333","username":"333","password":"1234123213"} | 初始化版本 | 2022-05-30 12:31:42 | janicegong |
+
+
+
+## 45. linkis_ps_error_code
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `error_code` | | varchar(50) | | NO | | |
+| 3 | `error_desc` | | varchar(1024) | | NO | | |
+| 4 | `error_regex` | | varchar(1024) | | YES | | |
+| 5 | `error_type` | | int(3) | | YES | | 0 |
+
+
+**示例数据**
+
+| id | error_code | error_desc | error_regex | error_type |
+| ---: | --- | --- | --- | ---: |
+| 1 | 01001 | 您的任务没有路由到后台ECM,请联系管理员 | The em of labels | 0 |
+| 2 | 01002 | Linkis服务负载过高,请联系管理员扩容 | Unexpected end of file from server | 0 |
+| 3 | 01003 | Linkis服务负载过高,请联系管理员扩容 | failed to ask linkis Manager Can be retried SocketTimeoutException | 0 |
+| 4 | 01004 | 引擎在启动时被Kill,请联系管理员 | [0-9]+ Killed | 0 |
+
+## 46. linkis_ps_instance_info
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `instance` | structure like ${host\|machine}:${port} | varchar(128) | UNI | YES | | |
+| 3 | `name` | equal application name in registry | varchar(128) | | YES | | |
+| 4 | `update_time` | update unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | create unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_instance` | 将`instance` 列设置为唯一索引 | UNIQUE KEY | `instance` |
+
+
+
+## 47. linkis_ps_instance_label
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_key` | string key | varchar(32) | MUL | NO | | |
+| 3 | `label_value` | string value | varchar(255) | | NO | | |
+| 4 | `label_feature` | store the feature of label, but it may be redundant | varchar(16) | | NO | | |
+| 5 | `label_value_size` | size of key -> value map | int(20) | | NO | | |
+| 6 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 7 | `create_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+
+
+**示例数据**
+
+| id | label_key | label_value | label_feature | label_value_size | update_time | create_time |
+| ---: | --- | --- | --- | ---: | --- | --- |
+| 68 | route | offline | OPTIONAL | 0 | 2022-11-15 12:51:48 | 2022-11-08 21:58:36 |
+| 64 | route | cs_1_dev | OPTIONAL | 0 | 2022-11-08 09:51:26 | 2022-02-16 17:28:31 |
+| 5 | route | cs_2_dev | OPTIONAL | 0 | 2022-11-08 09:51:23 | 2021-05-26 14:46:00 |
+| 58 | route | auto_test | OPTIONAL | 0 | 2022-11-04 16:51:04 | 2021-09-08 14:19:23 |
+| 67 | route | cs_1_dev1 | OPTIONAL | 0 | 2022-10-31 15:58:07 | 2022-10-31 15:58:07 |
+| 66 | route | et1 | OPTIONAL | 0 | 2022-08-07 21:39:55 | 2022-08-07 21:39:55 |
+| 65 | route | test114 | OPTIONAL | 0 | 2022-07-05 00:18:52 | 2022-07-05 00:18:52 |
+| 39 | route | test | OPTIONAL | 0 | 2022-06-28 13:24:19 | 2021-08-02 15:30:03 |
+| 62 | route | gjy_test | OPTIONAL | 0 | 2022-02-24 19:25:11 | 2022-01-05 17:27:46 |
+| 6 | route | cs_3_dev | OPTIONAL | 0 | 2022-02-17 14:20:33 | 2021-05-26 14:57:12 |
+| 63 | route | test_A | OPTIONAL | 0 | 2022-01-06 15:04:35 | 2022-01-06 15:04:35 |
+| 61 | userCreator | auto-test | OPTIONAL | 2 | 2021-12-22 14:36:33 | 2021-12-22 14:36:33 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lk_lv` | 将`label_key`,`label_value` 列设置为唯一索引 | UNIQUE KEY | `label_key`,`label_value` |
+
+
+
+**示例数据**
+
+| id | instance | name | update_time | create_time |
+| ---: | --- | --- | --- | --- |
+| 1527 | localhost110004:8008 | visualis-prod | 2022-06-28 14:14:36 | 2022-06-28 14:14:36 |
+| 1537 | localhost110004:9008 | visualis-dev | 2022-06-30 15:39:19 | 2022-06-30 15:39:18 |
+| 1702 | localhost110004:9108 | linkis-ps-cs | 2022-11-08 09:51:23 | 2022-11-08 09:51:23 |
+
+
+## 48. linkis_ps_instance_label_relation
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_id` | id reference linkis_ps_instance_label -> id | int(20) | MUL | YES | | |
+| 3 | `service_instance` | structure like ${host\|machine}:${port} | varchar(128) | | NO | | |
+| 4 | `update_time` | update unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | create unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | label_id | service_instance | update_time | create_time |
+| ---: | ---: | --- | --- | --- |
+| 562 | 2 | localhost110002:9108 | 2022-02-14 11:58:57 | 2022-02-14 11:58:57 |
+| 875 | 5 | localhost110004:9108 | 2022-11-08 09:51:23 | 2022-11-08 09:51:23 |
+| 876 | 64 | localhost11ide01:9108 | 2022-11-08 09:51:26 | 2022-11-08 09:51:26 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lid_instance` | 将`label_id`,`service_instance` 列设置为唯一索引 | UNIQUE KEY | `label_id`,`service_instance` |
+
+
+
+## 49. linkis_ps_instance_label_value_relation
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_value_key` | value key | varchar(255) | MUL | NO | | |
+| 3 | `label_value_content` | value content | varchar(255) | | YES | | |
+| 4 | `label_id` | id reference linkis_ps_instance_label -> id | int(20) | | YES | | |
+| 5 | `update_time` | update unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+| 6 | `create_time` | create unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| label_value_key | label_value_content | label_id | update_time | create_time |
+| --- | --- | ---: | --- | --- |
+| creator | test | 61 | 2021-12-22 14:36:33 | 2021-12-22 14:36:33 |
+| user | auto | 61 | 2021-12-22 14:36:33 | 2021-12-22 14:36:33 |
+| creator | a | 50 | 2021-08-03 19:40:48 | 2021-08-03 19:40:48 |
+| user | a | 50 | 2021-08-03 19:40:48 | 2021-08-03 19:40:48 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lvk_lid` | 将`label_value_key`,`label_id` 列设置为唯一索引 | UNIQUE KEY | `label_value_key`,`label_id` |
+
+
+
+## 50. linkis_ps_job_history_detail
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary Key, auto increment | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `job_history_id` | ID of JobHistory | bigint(20) | | NO | | |
+| 3 | `result_location` | File path of the resultsets | varchar(500) | | YES | | |
+| 4 | `execution_content` | The script code or other execution content executed by this Job | text | | YES | | |
+| 5 | `result_array_size` | size of result array | int(4) | | YES | | 0 |
+| 6 | `job_group_info` | Job group info/path | text | | YES | | |
+| 7 | `created_time` | Creation time | datetime(3) | | YES | | CURRENT_TIMESTAMP(3) |
+| 8 | `updated_time` | Update time | datetime(3) | | YES | | CURRENT_TIMESTAMP(3) |
+| 9 | `status` | status | varchar(32) | | YES | | |
+| 10 | `priority` | order of subjob | int(4) | | YES | | 0 |
+
+**示例数据**
+
+| id | job_history_id | result_location | execution_content | result_array_size | job_group_info | created_time | updated_time | status | priority |
+| ---: | ---: | --- | --- | ---: | --- | --- | --- | --- | ---: |
+| 1700001 | 1561337 | hdfs:///apps-data/neiljianliu/linkis/20211225_201252/nodeexecution/1561337 | select * from default.dwc_vsbi_students_demo limit 5000 | 1 | | 2021-12-25 20:12:52 | 2021-12-25 20:12:54 | Succeed | 0 |
+| 1700002 | 1561339 | \N | {"configuration":{},"variable":{"user.to.proxy":"neiljianliu","run_date":"20211224"},"run_date":"20211224","labels":{"labels":"{\"route\":\"prod\"}"}} | \N | | 2021-12-25 20:15:51 | 2021-12-25 20:15:52 | Failed | 0 |
+| 1700003 | 1561338 | hdfs:///apps-data/neiljianliu/linkis/20211225_201551/nodeexecution/1561338 | {"config":"","description":"","id":380.0,"model":"","name":"view_3142","projectId":864.0,"roles":"","source":{"id":318.0,"name":"hiveDataSource"},"sourceId":318.0,"sql":"","variable":""} | 1 | | 2021-12-25 20:15:51 | 2021-12-25 20:15:55 | Succeed | 0 |
+| 1700004 | 1561340 | hdfs:///apps-data/neiljianliu/linkis/20211225_201552/nodeexecution/1561340 | select * from default.dwc_vsbi_students_demo limit 5000 | 1 | | 2021-12-25 20:15:52 | 2021-12-25 20:15:54 | Succeed | 0 |
+| 1700005 | 1561341 | hdfs:///apps-data/neiljianliu/linkis/20211225_201852/nodeexecution/1561341 | {"config":"","description":"","id":380.0,"model":"","name":"view_3142","projectId":864.0,"roles":"","source":{"id":318.0,"name":"hiveDataSource"},"sourceId":318.0,"sql":"","variable":""} | 1 | | 2021-12-25 20:18:52 | 2021-12-25 20:18:56 | Succeed | 0 |
+| 1700006 | 1561342 | \N | {"configuration":{},"variable":{"user.to.proxy":"neiljianliu","run_date":"20211224"},"run_date":"20211224","labels":{"labels":"{\"route\":\"prod\"}"}} | \N | | 2021-12-25 20:18:52 | 2021-12-25 20:18:52 | Failed | 0 |
+
+
+
+
+
+## 51. linkis_ps_job_history_group_history
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary Key, auto increment | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `job_req_id` | job execId | varchar(64) | | YES | | |
+| 3 | `submit_user` | who submitted this Job | varchar(50) | MUL | YES | | |
+| 4 | `execute_user` | who actually executed this Job | varchar(50) | | YES | | |
+| 5 | `source` | job source | text | | YES | | |
+| 6 | `labels` | job labels | text | | YES | | |
+| 7 | `params` | job params | text | | YES | | |
+| 8 | `progress` | Job execution progress | varchar(32) | | YES | | |
+| 9 | `status` | Script execution status, must be one of the following: Inited, WaitForRetry, Scheduled, Running, Succeed, Failed, Cancelled, Timeout | varchar(50) | | YES | | |
+| 10 | `log_path` | File path of the job log | varchar(200) | | YES | | |
+| 11 | `error_code` | Error code. Generated when the execution of the script fails | int(11) | | YES | | |
+| 12 | `error_desc` | Execution description. Generated when the execution of script fails | varchar(1000) | | YES | | |
+| 13 | `created_time` | Creation time | datetime(3) | MUL | YES | | CURRENT_TIMESTAMP(3) |
+| 14 | `updated_time` | Update time | datetime(3) | | YES | | CURRENT_TIMESTAMP(3) |
+| 15 | `instances` | Entrance instances | varchar(250) | | YES | | |
+| 16 | `metrics` | Job Metrics | text | | YES | | |
+| 17 | `engine_type` | Engine type | varchar(32) | | YES | | |
+| 18 | `execution_code` | Job origin code or code path | text | | YES | | |
+| 19 | `result_location` | File path of the resultsets | varchar(500) | | YES | | |
+
+
+**示例数据**
+
+| id | job_req_id | submit_user | execute_user | source | labels | params | progress | status | log_path | error_code | error_desc | created_time | updated_time | instances | metrics | engine_type | execution_code | result_location |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- | --- | ---: | --- | --- | --- | --- | --- | --- | --- | --- |
+| 3400407 | nodeexecution_owenxu_spark_29 | owenxu | owenxu | {"nodeName":"sql_9024","requestIP":"127.0.0.1","projectName":"testpubauthority","flowName":"test01"} | {"codeType":"sql","engineType":"spark-2.4.3","userCreator":"owenxu-nodeexecution"} | {"configuration":{"runtime":{"nodeName":"sql_9024","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"+PHsmq+A1AkWQ3olJILCuFspWs9RflbL2HLiVea4FcQ\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","wds.dss.workflow.submit.user":"owenxu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"owenxu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"testpubauthority\\\",\\\"flow\\\":\\\"test01\\\",\\\"contextId\\\":\\\"8-8--cs_1_devcs_1_dev58211\\\",\\\"version\\\":\\\"v000003\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","nodeType":"sql","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/owenxu/linkis/2022-11-16/155518/nodeexecution/3400407","source":{"nodeName":"sql_9024","projectName":"testpubauthority","flowName":"test01","requestIP":"127.0.0.1"},"jobId":"3400407","job":{"#rt_rs_store_path":"hdfs:///apps-data/owenxu/linkis/2022-11-16/155518/nodeexecution/3400407"}},"startup":{"jobId":"3400407"}},"variable":{"user.to.proxy":"owenxu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"owenxu-schedulis","codeType":"sql","engineType":"spark-2.4.3","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/owenxu/3400407.log | 0 | | 2022-11-16 15:55:18.000 | 2022-11-16 15:55:20.387 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:55:19+0800","timeToOrchestrator":"2022-11-16T15:55:19+0800","engineconnMap":{"gz.xg.localhost110001.webank:27735":{"engineInstance":"gz.xg.localhost110001.webank:27735","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400407_otJobId_astJob_647_codeExec_647","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_647"}},"submitTime":"2022-11-16T15:55:18+0800","yarnResource":{},"completeTime":"2022-11-16T15:55:20+0800"} | spark | select 1| hdfs:///apps-data/owenxu/linkis/2022-11-16/155518/nodeexecution/3400407 |
+| 3400406 | nodeexecution_johnnwang_spark_42 | johnnwang | johnnwang | {"nodeName":"sql_2947","requestIP":"127.0.0.1","projectName":"hmh0901","flowName":"flow001"} | {"codeType":"sql","engineType":"spark-2.4.3","userCreator":"johnnwang-nodeexecution"} | {"configuration":{"startup":{"spark.executor.memory":"3G","spark.driver.memory":"3G","spark.executor.cores":"2","spark.executor.instances":"2","wds.linkis.rm.yarnqueue":"dws","ReuseEngine":"true","jobId":"3400406"},"runtime":{"nodeName":"sql_2947","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"Lg76z9Wq/bjKI3Kp1nTKBNZnRJ6dDz3v5E4e2cL2cD4\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","wds.dss.workflow.submit.user":"johnnwang","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"johnnwang\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"hmh0901\\\",\\\"flow\\\":\\\"flow001\\\",\\\"contextId\\\":\\\"8-8--cs_1_devcs_1_dev61373\\\",\\\"version\\\":\\\"v000005\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","nodeType":"sql","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400406","source":{"nodeName":"sql_2947","projectName":"hmh0901","flowName":"flow001","requestIP":"127.0.0.1"},"jobId":"3400406","job":{"#rt_rs_store_path":"hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400406"}}},"variable":{"user.to.proxy":"johnnwang","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"johnnwang-schedulis","codeType":"sql","engineType":"spark-2.4.3","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/johnnwang/3400406.log | 0 | | 2022-11-16 15:52:17.000 | 2022-11-16 15:52:19.328 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"gz.xg.localhost110001.webank:35637":{"engineInstance":"gz.xg.localhost110001.webank:35637","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400406_otJobId_astJob_646_codeExec_646","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_646"}},"submitTime":"2022-11-16T15:52:17+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:19+0800"} | spark | show tables;| hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400406 |
+| 3400405 | nodeexecution_johnnwang_appconn_42 | johnnwang | johnnwang | {"nodeName":"sqoop_6588","requestIP":"127.0.0.1","projectName":"hmh0901","flowName":"flow001"} | {"codeType":"exchangis.sqoop","engineType":"appconn-1","userCreator":"johnnwang-nodeexecution"} | {"configuration":{"runtime":{"nodeName":"sqoop_6588","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"Lg76z9Wq/bjKI3Kp1nTKBNZnRJ6dDz3vupd1m5IsFA0\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","variables":{"user.to.proxy":"johnnwang","run_today_h":"2022111615","run_date":"20221115"},"wds.dss.workflow.submit.user":"johnnwang","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"johnnwang\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"hmh0901\\\",\\\"flow\\\":\\\"flow001\\\",\\\"contextId\\\":\\\"8-8--cs_1_devcs_1_dev61373\\\",\\\"version\\\":\\\"v000005\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","nodeType":"exchangis.sqoop","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400405","source":{"nodeName":"sqoop_6588","projectName":"hmh0901","flowName":"flow001","requestIP":"127.0.0.1"},"jobId":"3400405","job":{"#rt_rs_store_path":"hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400405"}},"startup":{"jobId":"3400405"}},"variable":{"user.to.proxy":"johnnwang","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"johnnwang-schedulis","codeType":"exchangis.sqoop","engineType":"appconn-1","labels":"{\"route\":\"prod\"}"}} | 1.0 | Failed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/johnnwang/3400405.log | \N | 21304, Task(codeExec_645) status not succeed,is Failed | 2022-11-16 15:52:17.000 | 2022-11-16 15:52:18.475 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:10781":{"engineInstance":"localhost110004:10781","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400405_otJobId_astJob_645_codeExec_645","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_645"}},"submitTime":"2022-11-16T15:52:17+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:18+0800"} | appconn | {"id":5924} | hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400405 |
+| 3400404 | nodeexecution_allenlliu_shell_25 | allenlliu | allenlliu | {"nodeName":"shell_4441","requestIP":"127.0.0.1","projectName":"mytest_xq_0032","flowName":"test_workflow001"} | {"codeType":"shell","engineType":"shell-1","userCreator":"allenlliu-nodeexecution"} | {"configuration":{"runtime":{"nodeName":"shell_4441","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"y4h8zre1zbG7a5OlwX8oULazMLTJJpelCaiwk84RsEk\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","wds.dss.workflow.submit.user":"allenlliu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"allenlliu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"mytest_xq_0032\\\",\\\"flow\\\":\\\"test_workflow001\\\",\\\"contextId\\\":\\\"8-8--cs_2_devcs_2_dev10489\\\",\\\"version\\\":\\\"v000009\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","nodeType":"sh","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400404","source":{"nodeName":"shell_4441","projectName":"mytest_xq_0032","flowName":"test_workflow001","requestIP":"127.0.0.1"},"jobId":"3400404","job":{"#rt_rs_store_path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400404"}},"startup":{"jobId":"3400404"}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"allenlliu-schedulis","codeType":"shell","engineType":"shell-1","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/allenlliu/3400404.log | 0 | | 2022-11-16 15:52:17.000 | 2022-11-16 15:52:18.359 | localhost110002:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:14499":{"engineInstance":"localhost110004:14499","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400404_otJobId_astJob_532_codeExec_532","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_532"}},"submitTime":"2022-11-16T15:52:17+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:18+0800"} | shell | echo 'hello'| hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400404 |
+| 3400403 | nodeexecution_allenlliu_appconn_111 | allenlliu | allenlliu | {"nodeName":"datachecker_90101_copy_copy","requestIP":"127.0.0.1","projectName":"mytest_xq_0032","flowName":"test_workflow001"} | {"codeType":"datachecker","engineType":"appconn-1","userCreator":"allenlliu-nodeexecution"} | {"configuration":{"startup":{"ReuseEngine":"true","jobId":"3400403"},"runtime":{"max.check.hours":"1","nodeName":"datachecker_90101_copy_copy","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"y4h8zre1zbG7a5OlwX8oUNZnRJ6dDz3vcFfovQF97E8\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","variables":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"wds.dss.workflow.submit.user":"allenlliu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"allenlliu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"mytest_xq_0032\\\",\\\"flow\\\":\\\"test_workflow001\\\",\\\"contextId\\\":\\\"8-8--cs_2_devcs_2_dev10489\\\",\\\"version\\\":\\\"v000009\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","check.object":"allenlliu_ind.a","nodeType":"datachecker","source.type":"hivedb","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400403","source":{"nodeName":"datachecker_90101_copy_copy","projectName":"mytest_xq_0032","flowName":"test_workflow001","requestIP":"127.0.0.1"},"jobId":"3400403","job":{"#rt_rs_store_path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400403"}}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"allenlliu-schedulis","codeType":"datachecker","engineType":"appconn-1","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/allenlliu/3400403.log | 0 | | 2022-11-16 15:52:17.000 | 2022-11-16 15:52:18.060 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:10781":{"engineInstance":"localhost110004:10781","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400403_otJobId_astJob_644_codeExec_644","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_644"}},"submitTime":"2022-11-16T15:52:17+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:18+0800"} | appconn | {"configuration":{"startup":{"ReuseEngine":"true"},"runtime":{"max.check.hours":"1","check.object":"allenlliu_ind.a","source.type":"hivedb"}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"labels":"{\"route\":\"prod\"}"}} | hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400403 |
+| 3400402 | nodeexecution_allenlliu_spark_32 | allenlliu | allenlliu | {"nodeName":"sql_3520","requestIP":"127.0.0.1","projectName":"mytest_xq_0032","flowName":"test_workflow001"} | {"codeType":"sql","engineType":"spark-2.4.3","userCreator":"allenlliu-nodeexecution"} | {"configuration":{"runtime":{"nodeName":"sql_3520","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"y4h8zre1zbG7a5OlwX8oULazMLTJJpelslfPQ0jh9bw\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","wds.dss.workflow.submit.user":"allenlliu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"allenlliu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"mytest_xq_0032\\\",\\\"flow\\\":\\\"test_workflow001\\\",\\\"contextId\\\":\\\"8-8--cs_2_devcs_2_dev10489\\\",\\\"version\\\":\\\"v000009\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","nodeType":"sql","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400402","source":{"nodeName":"sql_3520","projectName":"mytest_xq_0032","flowName":"test_workflow001","requestIP":"127.0.0.1"},"jobId":"3400402","job":{"#rt_rs_store_path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400402"}},"startup":{"jobId":"3400402"}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"allenlliu-schedulis","codeType":"sql","engineType":"spark-2.4.3","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/allenlliu/3400402.log | 0 | | 2022-11-16 15:52:16.000 | 2022-11-16 15:52:18.436 | localhost110002:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:25145":{"engineInstance":"localhost110004:25145","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400402_otJobId_astJob_531_codeExec_531","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_531"}},"submitTime":"2022-11-16T15:52:16+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:18+0800"} | spark | show tables| hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400402 |
+| 3400401 | nodeexecution_allenlliu_appconn_85 | allenlliu | allenlliu | {"nodeName":"datachecker_90101","requestIP":"127.0.0.1","projectName":"mytest_xq_0032","flowName":"test_workflow001"} | {"codeType":"datachecker","engineType":"appconn-1","userCreator":"allenlliu-nodeexecution"} | {"configuration":{"startup":{"ReuseEngine":"true","jobId":"3400401"},"runtime":{"max.check.hours":"1","nodeName":"datachecker_90101","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"y4h8zre1zbG7a5OlwX8oULazMLTJJpelHY1ioj7PF6w\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","variables":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"wds.dss.workflow.submit.user":"allenlliu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"allenlliu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"mytest_xq_0032\\\",\\\"flow\\\":\\\"test_workflow001\\\",\\\"contextId\\\":\\\"8-8--cs_2_devcs_2_dev10489\\\",\\\"version\\\":\\\"v000009\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","check.object":"allenlliu_ind.a","nodeType":"datachecker","source.type":"hivedb","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400401","source":{"nodeName":"datachecker_90101","projectName":"mytest_xq_0032","flowName":"test_workflow001","requestIP":"127.0.0.1"},"jobId":"3400401","job":{"#rt_rs_store_path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400401"}}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"allenlliu-schedulis","codeType":"datachecker","engineType":"appconn-1","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/allenlliu/3400401.log | 0 | | 2022-11-16 15:52:16.000 | 2022-11-16 15:52:17.718 | localhost110002:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:10781":{"engineInstance":"localhost110004:10781","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400401_otJobId_astJob_530_codeExec_530","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_530"}},"submitTime":"2022-11-16T15:52:16+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:17+0800"} | appconn | {"configuration":{"startup":{"ReuseEngine":"true"},"runtime":{"max.check.hours":"1","check.object":"allenlliu_ind.a","source.type":"hivedb"}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"labels":"{\"route\":\"prod\"}"}} | hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400401 |
+| 3400400 | nodeexecution_allenlliu_appconn_110 | allenlliu | allenlliu | {"nodeName":"datachecker_90101_copy","requestIP":"127.0.0.1","projectName":"mytest_xq_0032","flowName":"test_workflow001"} | {"codeType":"datachecker","engineType":"appconn-1","userCreator":"allenlliu-nodeexecution"} | {"configuration":{"startup":{"ReuseEngine":"true","jobId":"3400400"},"runtime":{"max.check.hours":"1","nodeName":"datachecker_90101_copy","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"y4h8zre1zbG7a5OlwX8oULazMLTJJpelBtBXO2lr2rM\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","variables":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"wds.dss.workflow.submit.user":"allenlliu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"allenlliu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"mytest_xq_0032\\\",\\\"flow\\\":\\\"test_workflow001\\\",\\\"contextId\\\":\\\"8-8--cs_2_devcs_2_dev10489\\\",\\\"version\\\":\\\"v000009\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","check.object":"allenlliu_ind.a","nodeType":"datachecker","source.type":"hivedb","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400400","source":{"nodeName":"datachecker_90101_copy","projectName":"mytest_xq_0032","flowName":"test_workflow001","requestIP":"127.0.0.1"},"jobId":"3400400","job":{"#rt_rs_store_path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400400"}}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"allenlliu-schedulis","codeType":"datachecker","engineType":"appconn-1","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/allenlliu/3400400.log | 0 | | 2022-11-16 15:52:16.000 | 2022-11-16 15:52:17.736 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:10781":{"engineInstance":"localhost110004:10781","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400400_otJobId_astJob_643_codeExec_643","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_643"}},"submitTime":"2022-11-16T15:52:16+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:17+0800"} | appconn | {"configuration":{"startup":{"ReuseEngine":"true"},"runtime":{"max.check.hours":"1","check.object":"allenlliu_ind.a","source.type":"hivedb"}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"labels":"{\"route\":\"prod\"}"}} | hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400400 |
+| 3400399 | IDE_connorliuyude_spark_1 | connorliuyude | connorliuyude | {"DSS-Scriptis":"import_to_connorliuyude_qml.peter_100w_1000_a_1668585127900.scala","requestIP":"127.0.0.1"} | {"codeType":"scala","engineType":"spark-2.4.3","userCreator":"connorliuyude-IDE"} | {"configuration":{"special":{},"runtime":{"args":"","env":[],"wds.linkis.resultSet.store.path":"hdfs:///apps-data/connorliuyude/linkis/2022-11-16/155208/IDE/3400399","source":{"DSS-Scriptis":"import_to_connorliuyude_qml.peter_100w_1000_a_1668585127900.scala","requestIP":"127.0.0.1"},"jobId":"3400399","job":{"#rt_rs_store_path":"hdfs:///apps-data/connorliuyude/linkis/2022-11-16/155208/IDE/3400399"}},"startup":{"jobId":"3400399"}},"variable":{}} | 0.7191358 | Running | hdfs:///appcom/logs/linkis/log/2022-11-16/IDE/connorliuyude/3400399.log | \N | \N | 2022-11-16 15:52:08.000 | 2022-11-16 15:55:38.556 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:52:09+0800","timeToOrchestrator":"2022-11-16T15:52:09+0800","engineconnMap":{"gz.xg.localhost110001.webank:33228":{"engineInstance":"gz.xg.localhost110001.webank:33228","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400399_otJobId_astJob_642_codeExec_642","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_642"}},"submitTime":"2022-11-16T15:52:08+0800","yarnResource":{"application_1662051718074_332612":{"queueMemory":107374182400,"queueCores":20,"queueInstances":0,"jobStatus":"COMPLETED","queue":"queue_0701_01"}}} | spark | val source = """{"path":"/apps-data/connorliuyude/peter_100w_1000_a.csv","pathType":"hdfs","encoding":"utf-8","fieldDelimiter":",","hasHeader":true,"sheet":"","quote":"","escapeQuotes":false}""" val destination = """hdfs:///tmp/bdp-ide/connorliuyude/executionCode/20221116/_bgservice;454023#74026""" org.apache.linkis.engineplugin.spark.imexport.LoadData.loadDataToTableByFile(spark,destination,source) | hdfs:///apps-data/connorliuyude/linkis/2022-11-16/155208/IDE/3400399 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_created_time` | 将`created_time` 列设置为普通索引 | INDEX | `created_time` |
+| 2 | `idx_submit_user` | 将`submit_user` 列设置为普通索引 | INDEX | `submit_user` |
+
+
+## 52. linkis_ps_resources_download_history
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | primary key | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `start_time` | start time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 3 | `end_time` | stop time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 4 | `client_ip` | client ip | varchar(200) | | NO | | |
+| 5 | `state` | Download status, 0 download successful, 1 download failed | tinyint(1) | | NO | | |
+| 6 | `resource_id` | | varchar(50) | | NO | | |
+| 7 | `version` | | varchar(20) | | NO | | |
+| 8 | `downloader` | Downloader | varchar(50) | | NO | | |
+
+
+**示例数据**
+
+| id | start_time | end_time | client_ip | state | resource_id | version | downloader |
+| ---: | --- | --- | --- | ---: | --- | --- | --- |
+| 1859617 | 2022-11-16 15:56:17 | 2022-11-16 15:56:18 | 127.0.0.1 | 0 | 11b8ca20-3437-4f31-a808-915a6f016a87 | v000001 | owenxu |
+| 1859614 | 2022-11-16 15:55:18 | 2022-11-16 15:55:18 | 127.0.0.1 | 0 | 836ba735-3a46-4303-8e9f-c4276a356386 | v000001 | owenxu |
+| 1859613 | 2022-11-16 15:53:06 | 2022-11-16 15:53:07 | 127.0.0.1 | 0 | cb407155-242b-4303-8365-1da6256a01e3 | v000173 | hadoop |
+| 1859612 | 2022-11-16 15:52:17 | 2022-11-16 15:52:17 | 127.0.0.1 | 0 | 665fe5ce-fdc6-4b9a-ab08-955e48b1f8d4 | v000001 | owenxu |
+
+
+## 53. linkis_ps_udf
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `create_user` | | varchar(50) | | NO | | |
+| 3 | `udf_name` | | varchar(255) | | NO | | |
+| 4 | `udf_type` | | int(11) | | YES | | 0 |
+| 5 | `path` | Path of the referenced function | varchar(255) | | YES | | |
+| 6 | `register_format` | | varchar(255) | | YES | | |
+| 7 | `use_format` | | varchar(255) | | YES | | |
+| 8 | `description` | | varchar(255) | | YES | | |
+| 9 | `is_expire` | | bit(1) | | YES | | |
+| 10 | `is_shared` | | bit(1) | | YES | | |
+| 11 | `tree_id` | | bigint(20) | | NO | | |
+| 12 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 13 | `update_time` | | timestamp | | NO | | CURRENT_TIMESTAMP |
+
+
+**示例数据**
+
+| id | create_user | udf_name | udf_type | path | register_format | use_format | description | is_expire | is_shared | tree_id | create_time | update_time |
+| ---: | --- | --- | ---: | --- | --- | --- | --- | ---: | ---: | ---: | --- | --- |
+| 204 | neiljianliu | jar_udf | 0 | /mnt/bdap/neiljianliu/zy_test/Wbjar_1.0.0.jar | create temporary function jar_udf as "com.webank.bdp.mask.udf.BdpBankCardNoFirstEightMask" | String jar_udf(String) | | 0 | 0 | 145 | 2021-11-09 09:52:31 | 2021-11-09 09:52:31 |
+| 205 | neiljianliu | jar_udf1 | 0 | /mnt/bdap/neiljianliu/zy_test/Wbjar_1.1.jar | create temporary function jar_udf1 as "com.webank.bdp.mask.udf.BdpBankCardNoFirstEightMask" | String jar_udf1(String) | | 0 | 0 | 145 | 2021-11-09 09:43:28 | 2021-11-09 09:43:28 |
+
+
+
+
+## 54. linkis_ps_udf_baseinfo
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `create_user` | | varchar(50) | | NO | | |
+| 3 | `udf_name` | | varchar(255) | | NO | | |
+| 4 | `udf_type` | | int(11) | | YES | | 0 |
+| 5 | `tree_id` | | bigint(20) | | NO | | |
+| 6 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 7 | `update_time` | | timestamp | | NO | | CURRENT_TIMESTAMP |
+| 8 | `sys` | source system | varchar(255) | | NO | | ide |
+| 9 | `cluster_name` | | varchar(255) | | NO | | |
+| 10 | `is_expire` | | bit(1) | | YES | | |
+| 11 | `is_shared` | | bit(1) | | YES | | |
+
+
+**示例数据**
+
+| id | create_user | udf_name | udf_type | tree_id | create_time | update_time | sys | cluster_name | is_expire | is_shared |
+| ---: | --- | --- | ---: | ---: | --- | --- | --- | --- | ---: | ---: |
+| 318 | neiljianliu | h01 | 3 | 1370 | 2022-08-08 19:39:39 | 2021-11-04 20:36:46 | IDE | all | 0 | 1 |
+| 321 | neiljianliu | h14 | 1 | 1331 | 2021-11-01 23:28:25 | 2021-10-29 10:39:08 | IDE | all | 0 | 0 |
+| 324 | stacyyan | udf_jar_834 | 0 | 133 | 2021-10-29 11:28:10 | 2021-10-29 11:28:10 | ide | all | 0 | 0 |
+
+## 55. linkis_ps_udf_manager
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `user_name` | | varchar(20) | | YES | | |
+
+**示例数据**
+
+| id | user_name |
+| ---: | --- |
+| 1 | stacyyan |
+| 2 | johnnwang |
+| 3 | neiljianliu |
+
+
+
+
+## 56. linkis_ps_udf_shared_group
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | bigint(20) | | NO | | |
+| 3 | `shared_group` | | varchar(50) | | NO | | |
+
+**示例数据**
+
+| id | udf_id | user_name |
+| ---: | ---: | --- |
+| 1 | 36 | jianfuzhang |
+| 2 | 36 | stacyyan |
+| 3 | 38 | shanhuang |
+| 4 | 38 | stacyyan |
+
+
+
+
+## 57. linkis_ps_udf_shared_info
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | bigint(20) | | NO | | |
+| 3 | `user_name` | | varchar(50) | | NO | | |
+
+
+## 58. linkis_ps_udf_shared_user
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | bigint(20) | | NO | | |
+| 3 | `user_name` | | varchar(50) | | NO | | |
+
+**示例数据**
+
+| id | udf_id | user_name |
+| ---: | ---: | --- |
+| 63 | 117 | jianfuzhang |
+| 64 | 119 | neiljianliu |
+| 65 | 119 | johnnwang |
+| 66 | 126 | jianfuzhang |
+
+
+
+## 59. linkis_ps_udf_tree
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `parent` | | bigint(20) | | NO | | |
+| 3 | `name` | Category name of the function. It would be displayed in the front-end | varchar(100) | | YES | | |
+| 4 | `user_name` | | varchar(50) | | NO | | |
+| 5 | `description` | | varchar(255) | | YES | | |
+| 6 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 7 | `update_time` | | timestamp | | NO | | CURRENT_TIMESTAMP |
+| 8 | `category` | Used to distinguish between udf and function | varchar(50) | | YES | | |
+
+
+**示例数据**
+
+| id | parent | name | user_name | description | create_time | update_time | category |
+| ---: | ---: | --- | --- | --- | --- | --- | --- |
+| 21 | -1 | 系统函数 | sys | | 2021-04-29 19:22:07 | 2021-04-29 19:22:07 | function |
+| 22 | -1 | BDAP函数 | bdp | | 2021-04-29 19:22:07 | 2021-04-29 19:22:07 | function |
+| 23 | -1 | 共享函数 | share | | 2021-04-29 19:22:07 | 2021-04-29 19:22:07 | function |
+| 24 | -1 | 个人函数 | jianfuzhang | | 2021-04-29 19:22:07 | 2021-04-29 19:22:07 | function |
+| 25 | -1 | 个人函数 | hduser05 | | 2021-04-30 10:15:14 | 2021-04-30 10:15:14 | udf |
+| 26 | -1 | 系统函数 | sys | | 2021-04-30 11:21:13 | 2021-04-30 11:21:13 | udf |
+| 27 | -1 | BDAP函数 | bdp | | 2021-04-30 11:21:13 | 2021-04-30 11:21:13 | udf |
+| 28 | -1 | 共享函数 | share | | 2021-04-30 11:21:13 | 2021-04-30 11:21:13 | udf |
+| 29 | -1 | 个人函数 | alexyang | | 2021-05-06 20:41:48 | 2021-05-06 20:41:48 | function |
+| 30 | -1 | 个人函数 | johnnwang | | 2021-05-06 21:47:52 | 2021-05-06 21:47:52 | udf |
+| 1587 | -1 | 个人函数 | aronlv | | 2022-11-15 10:47:27 | 2022-11-15 10:47:27 | udf |
+| 1586 | -1 | 个人函数 | aronlv | | 2022-11-15 10:47:26 | 2022-11-15 10:47:26 | function |
+| 1585 | -1 | 个人函数 | jackyxxie | | 2022-11-14 14:59:44 | 2022-11-14 14:59:44 | udf |
+| 1584 | 36 | 自定义分类1 | stacyyan | | 2022-11-11 17:10:56 | 2022-11-11 17:10:56 | udf |
+| 1583 | -1 | 个人函数 | alvinzhou | | 2022-11-09 11:23:04 | 2022-11-09 11:23:04 | function |
+| 1582 | 36 | qualitis自定义分类 | stacyyan | | 2022-11-08 16:22:31 | 2022-11-08 16:22:31 | udf |
+| 1581 | 36 | qualitis测试 | stacyyan | | 2022-11-07 12:21:30 | 2022-11-07 12:21:30 | udf |
+| 1580 | 29 | fun自动化测试 | alexyang | | 2022-11-04 19:16:29 | 2022-11-04 19:16:29 | function |
+| 1579 | 20 | udf自动化测试 | alexyang | | 2022-11-04 19:16:25 | 2022-11-04 19:16:25 | udf |
+| 1578 | 20 | 测试 | alexyang | | 2022-11-01 11:05:46 | 2022-11-01 11:05:46 | udf |
+| 1577 | -1 | 个人函数 | jeromepeng | | 2022-10-31 10:54:33 | 2022-10-31 10:54:33 | function |
+| 1576 | -1 | 个人函数 | jeromepeng | | 2022-10-31 10:54:31 | 2022-10-31 10:54:31 | udf |
+
+
+## 60. linkis_ps_udf_user_load
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | bigint(20) | | NO | | |
+| 3 | `user_name` | | varchar(50) | | NO | | |
+
+**示例数据**
+
+| udf_id | user_name |
+| ---: | --- |
+| 34 | johnnwang |
+| 53 | johnnwang |
+| 34 | neiljianliu |
+| 109 | stacyyan |
+| 110 | stacyyan |
+
+
+
+
+
+## 61. linkis_ps_udf_user_load_info
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | int(11) | | NO | | |
+| 3 | `user_name` | | varchar(50) | | NO | | |
+
+
+**示例数据**
+
+| id | udf_id | user_name |
+| ---: | ---: | --- |
+| 1 | 13 | hadoop |
+| 2 | 14 | bob |
+| 3 | 18 | testuser |
+
+
+
+## 62. linkis_ps_udf_version
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | bigint(20) | | NO | | |
+| 3 | `path` | Source path for uploading files | varchar(255) | | NO | | |
+| 4 | `bml_resource_id` | | varchar(50) | | NO | | |
+| 5 | `bml_resource_version` | | varchar(20) | | NO | | |
+| 6 | `is_published` | is published | bit(1) | | YES | | |
+| 7 | `register_format` | | varchar(255) | | YES | | |
+| 8 | `use_format` | | varchar(255) | | YES | | |
+| 9 | `description` | version desc | varchar(255) | | NO | | |
+| 10 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 11 | `md5` | | varchar(100) | | YES | | |
+
+**示例数据**
+
+| id | udf_id | path | bml_resource_id | bml_resource_version | is_published | register_format | use_format | description | create_time | md5 |
+| ---: | ---: | --- | --- | --- | ---: | --- | --- | --- | --- | --- |
+| 80 | 34 | file:///mnt/bdap/johnnwang/wds_functions1_0_0.jar | aee4698a-0aad-4dfe-9e3c-0d2c674c81f9 | v000001 | 0 | create temporary function cf_charcount_s as "com.webank.wedatasphere.willink.bdp.udf.CountTotalCharInStr" | int cf_charcount_s(string,string) | | 2021-10-20 16:50:57 | \N |
+| 93 | 34 | file:///mnt/bdap/johnnwang/wds_functions1_0_0.jar | aee4698a-0aad-4dfe-9e3c-0d2c674c81f9 | v000002 | 1 | create temporary function cf_charcount_s as "com.webank.wedatasphere.willink.bdp.udf.CountTotalCharInStr" | int cf_charcount_s(string,string) | | 2021-10-20 18:53:59 | \N |
+| 205 | 96 | file:///mnt/bdap/stacyyan/tm_client_1.6_cp.jar | 759c6179-060e-4c61-9ff9-8f6e18d0efaf | v000001 | 0 | create temporary function udf_jar_834 as "com.webank.bdp.mask.udf.BdpBankCardNoFirstEightMask" | udf_jar_834() | | 2021-10-23 16:57:00 | \N |
+| 250 | 109 | file:///mnt/bdap/stacyyan/scala系统函数调用.scala | 4519f563-ac8a-48a3-a487-36b0d629bc59 | v000001 | 0 | \N | String aadfdff() | | 2021-10-25 16:56:04 | \N |
+| 251 | 110 | file:///mnt/bdap/stacyyan/scala系统函数调用.scala | e0caa4a5-754e-4517-9d0d-5610c7712d82 | v000001 | 0 | \N | String df78() | | 2021-10-25 16:56:28 | \N |
+| 257 | 116 | file:///mnt/bdap/udf/udf_pyspark_011621477729461.py | 2917d57a-0078-455f-8eda-45d18d90adb3 | v000001 | 1 | udf.register("udf_hello_0518",hello) | String udf_hello_0518(String) | aaaad | 2021-10-25 17:31:43 | \N |
+
+
+## 63. linkis_ps_variable_key
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `key` | Key of the global variable | varchar(50) | | YES | | |
+| 3 | `description` | Reserved word | varchar(200) | | YES | | |
+| 4 | `name` | Reserved word | varchar(50) | | YES | | |
+| 5 | `application_id` | Reserved word | bigint(20) | MUL | YES | | |
+| 6 | `default_value` | Reserved word | varchar(200) | | YES | | |
+| 7 | `value_type` | Reserved word | varchar(50) | | YES | | |
+| 8 | `value_regex` | Reserved word | varchar(100) | | YES | | |
+
+**示例数据**
+
+| id | key | description | name | application_id | default_value | value_type | value_regex |
+| ---: | --- | --- | --- | ---: | --- | --- | --- |
+| 1 | di_marw_warn_flow_dcn_d | \N | \N | -1 | \N | \N | \N |
+| 2 | table_a | \N | \N | -1 | \N | \N | \N |
+| 3 | table_a | \N | \N | -1 | \N | \N | \N |
+| 4 | aaaa | \N | \N | -1 | \N | \N | \N |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_aid` | 将`application_id` 列设置为普通索引 | INDEX | `application_id` |
+
+
+
+## 64. linkis_ps_variable_key_user
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `application_id` | Reserved word | bigint(20) | MUL | YES | | |
+| 3 | `key_id` | | bigint(20) | MUL | YES | | |
+| 4 | `user_name` | | varchar(50) | | YES | | |
+| 5 | `value` | Value of the global variable | varchar(200) | | YES | | |
+
+
+**示例数据**
+
+| id | application_id | key_id | user_name | value |
+| ---: | ---: | ---: | --- | --- |
+| 1 | -1 | 1 | neiljianliu | d |
+| 2 | -1 | 2 | stacyyan | student |
+| 3 | -1 | 3 | jianfuzhang | a_01 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_key_id` | 将`key_id` 列设置为普通索引 | INDEX | `key_id` |
+| 2 | `uniq_aid_kid_uname` | 将`application_id`,`key_id`,`user_name` 列设置为普通索引 | INDEX | `application_id`,`key_id`,`user_name` |
+| 3 | `idx_aid` | 将`application_id` 列设置为普通索引 | INDEX | `application_id` |
+
+## 65.linkis_cg_user_ip_config
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `user` | | varchar(50) | NO | | | |
+| 3 | `creator` | | varchar(50) | NO | | | |
+| 4 | `ip_list` | | text | NO | | | |
+| 5 | `create_time` | | datetime |NO | | | |
+| 6 | `update_time` | | datetime |NO | | | |
+| 7 | `desc` | | varchar(100) |NO | | | |
+| 8 | `bussiness_user` | | varchar(50) |NO | | | |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_user_creator` | 将`user`,`creator` 列设置为唯一索引 | UNIQUE KEY | `user`,`creator` |
+
+
+## 66.linkis_cg_tenant_label_config
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `user` | | varchar(50) | NO | | | |
+| 3 | `creator` | | varchar(50) | NO | | | |
+| 4 | `tenant_value` | | varchar(128) | NO | | | |
+| 5 | `create_time` | | datetime |NO | | | |
+| 6 | `update_time` | | datetime |NO | | | |
+| 7 | `desc` | | varchar(100) |NO | | | |
+| 8 | `bussiness_user` | | varchar(50) |NO | | | |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uin_user_creator` | 将`user`,`creator` 列设置为唯一索引 | UNIQUE KEY | `user`,`creator` |
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/table/udf-table.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/table/udf-table.md
new file mode 100644
index 00000000000..e7f88fbd95e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/development/table/udf-table.md
@@ -0,0 +1,99 @@
+---
+title: UDF 表结构
+sidebar_position: 2
+---
+
+## 1.linkis_ps_udf_baseinfo
+
+udf函数的基本信息表,存储udf名称/类型等基础信息
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | 主键自增id | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `create_user` | 创建用户 | varchar(50) | | NO | | |
+| 3 | `udf_name` | udf名称 | varchar(255) | | NO | | |
+| 4 | `udf_type` | udf类型 | int(11) | | YES | | 0 |
+| 5 | `tree_id` | linkis_ps_udf_tree的id | bigint(20) | | NO | | |
+| 6 | `create_time` | 创建时间 | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 7 | `update_time` | 更新时间 | timestamp | | NO | | CURRENT_TIMESTAMP |
+| 8 | `sys` | source system | varchar(255) | | NO | | ide |
+| 9 | `cluster_name` | 集群名 ,暂时未使用到,默认都是all | varchar(255) | | NO | | |
+| 10 | `is_expire` | 是否过期 | bit(1) | | YES | | |
+| 11 | `is_shared` | 是否被分享 | bit(1) | | YES | | |
+
+
+udf_type
+```
+udf_type 0:udf函数-通用
+udf_type 2: udf函数-spark
+
+udf_type 3:自定义函数-python函数
+udf_type 4:自定义函数-scala 函数
+```
+
+## 2.linkis_ps_udf_manager
+
+udf函数的管理员用户表,具有共享权限,只有udf管理员 前端才有共享的入口
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `user_name` | | varchar(20) | | YES | | |
+
+## 3.linkis_ps_udf_shared_info
+
+udf共享的记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | linkis_ps_udf_baseinfo的id | bigint(20) | | NO | | |
+| 3 | `user_name` | 共享使用的用户名 | varchar(50) | | NO | | |
+
+## 4.linkis_ps_udf_tree
+
+udf分类的树形层级记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `parent` | 父级分类 | bigint(20) | | NO | | |
+| 3 | `name` | 函数的分类名称 | varchar(100) | | YES | | |
+| 4 | `user_name` | 用户名 | varchar(50) | | NO | | |
+| 5 | `description` | 描述信息 | varchar(255) | | YES | | |
+| 6 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 7 | `update_time` | | timestamp | | NO | | CURRENT_TIMESTAMP |
+| 8 | `category` | 类别区分 udf / function | varchar(50) | | YES | | |
+
+## 5.linkis_ps_udf_user_load
+
+udf是否默认加载的配置
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | linkis_ps_udf_baseinfo的id | int(11) | | NO | | |
+| 3 | `user_name` | 归属用户 | varchar(50) | | NO | | |
+
+## 6.linkis_ps_udf_version
+
+udf的版本信息表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | linkis_ps_udf_baseinfo的id | bigint(20) | | NO | | |
+| 3 | `path` | 上传的脚本/jar包的文件本地路径 | varchar(255) | | NO | | |
+| 4 | `bml_resource_id` | bml中的物料资源id | varchar(50) | | NO | | |
+| 5 | `bml_resource_version` | bml物料版本 | varchar(20) | | NO | | |
+| 6 | `is_published` | 是否发布 | bit(1) | | YES | | |
+| 7 | `register_format` | 注册格式 | varchar(255) | | YES | | |
+| 8 | `use_format` | 使用格式 | varchar(255) | | YES | | |
+| 9 | `description` | 版本描述 | varchar(255) | | NO | | |
+| 10 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 11 | `md5` | | varchar(100) | | YES | | |
+
+
+## ER图
+
+![image](/Images-zh/table/udf.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/_category_.json
new file mode 100644
index 00000000000..d8d839fbfd6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "引擎使用",
+ "position": 5
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/elasticsearch.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/elasticsearch.md
new file mode 100644
index 00000000000..1cde1a50605
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/elasticsearch.md
@@ -0,0 +1,243 @@
+---
+title: ElasticSearch
+sidebar_position: 10
+---
+
+本文主要介绍在 `Linkis` 中,`ElasticSearch` 引擎连接器的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 引擎连接器安装
+
+如果您希望在您的 `Linkis` 服务上使用 `ElasticSearch` 引擎连接器,您需要安装 `ElasticSearch` 服务并保证服务可用。
+
+### 1.2 服务验证
+通过如下命令验证 `ElasticSearch` 引擎连接器服务是否可用,如服务已开启用户验证则需要增加 `--user username:password`
+```
+curl [--user username:password] http://ip:port/_cluster/healty?pretty
+```
+输出如下内容代表 `ElasticSearch` 服务可用,注意集群 `status` 为 `green`
+```json
+{
+ "cluster_name" : "docker-cluster",
+ "status" : "green",
+ "timed_out" : false,
+ "number_of_nodes" : 1,
+ "number_of_data_nodes" : 1,
+ "active_primary_shards" : 7,
+ "active_shards" : 7,
+ "relocating_shards" : 0,
+ "initializing_shards" : 0,
+ "unassigned_shards" : 0,
+ "delayed_unassigned_shards" : 0,
+ "number_of_pending_tasks" : 0,
+ "number_of_in_flight_fetch" : 0,
+ "task_max_waiting_in_queue_millis" : 0,
+ "active_shards_percent_as_number" : 100.0
+}
+```
+## 2. 引擎连接器安装
+
+### 2.1 引擎连接器准备(二选一)[非默认引擎连接器](./overview.md)
+
+方式一:直接下载引擎连接器包
+
+[Linkis 引擎连接器下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎连接器(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/elasticsearch/
+mvn clean install
+# 编译出来的引擎连接器包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/elasticsearch/target/out/
+```
+
+[EngineConnPlugin 引擎连接器安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎连接器的上传和加载
+
+将 2.1 中的引擎连接器包上传到服务器的引擎连接器目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── elasticsearch
+│ ├── dist
+│ │ └── 7.6.2
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 7.6.2
+```
+### 2.3 引擎连接器刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎连接器
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎连接器是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3.引擎连接器使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+**`-codeType` 参数说明**
+- `essql`:通过 `SQL` 脚本的方式执行 `ElasticSearch` 引擎连接器任务
+- `esjson`:通过 `JSON` 脚本的方式执行 `ElasticSearch` 引擎连接器任务
+
+**`essql` 方式示例**
+
+**注意:** 使用这种形式, `ElasticSearch` 服务必须安装SQL插件,安装方式参考:https://github.com/NLPchina/elasticsearch-sql#elasticsearch-762
+```shell
+ sh ./bin/linkis-cli -submitUser hadoop \
+ -engineType elasticsearch-7.6.2 -codeType essql \
+ -code '{"sql": "select * from kibana_sample_data_ecommerce limit 10' \
+ -runtimeMap linkis.es.http.method=GET \
+ -runtimeMap linkis.es.http.endpoint=/_sql \
+ -runtimeMap linkis.es.datasource=hadoop \
+ -runtimeMap linkis.es.cluster=127.0.0.1:9200
+```
+
+**`esjson` 方式示例**
+```shell
+sh ./bin/linkis-cli -submitUser hadoop \
+-engineType elasticsearch-7.6.2 -codeType esjson \
+-code '{"query": {"match": {"order_id": "584677"}}}' \
+-runtimeMap linkis.es.http.method=GET \
+-runtimeMap linkis.es.http.endpoint=/kibana_sample_data_ecommerce/_search \
+-runtimeMap linkis.es.datasource=hadoop \
+-runtimeMap linkis.es.cluster=127.0.0.1:9200
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 4. 引擎连接器配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| linkis.es.cluster | 127.0.0.1:9200 |是 | ElasticSearch 集群,多个节点使用逗号分隔 |
+| linkis.es.datasource | hadoop |是 | ElasticSearch datasource |
+| linkis.es.username | 无 |否 | ElasticSearch 集群用户名 |
+| linkis.es.password | 无 |否 | ElasticSearch 集群密码 |
+| linkis.es.auth.cache | false |否 | 客户端是否缓存认证 |
+| linkis.es.sniffer.enable | false |否 | 客户端是否开启 sniffer |
+| linkis.es.http.method | GET |否 | 调用方式 |
+| linkis.es.http.endpoint | /_search |否 | JSON 脚本调用的 Endpoint |
+| linkis.es.sql.endpoint | /_sql |否 | SQL 脚本调用的 Endpoint |
+| linkis.es.sql.format | {"query":"%s"} |否| SQL 脚本调用的模板,%s 替换成 SQL 作为请求体请求Es 集群 |
+| linkis.es.headers.* | 无 |否| 客户端 Headers 配置 |
+| linkis.engineconn.concurrent.limit | 100|否 | 引擎连接器最大并发 |
+
+### 4.2 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 管理台配置
+
+![](./images/es-manage.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE -submitUser hadoop \
+-engineType elasticsearch-7.6.2 -codeType esjson \
+-code '{"query": {"match": {"order_id": "584677"}}}' \
+-runtimeMap linkis.es.http.method=GET \
+-runtimeMap linkis.es.http.endpoint=/kibana_sample_data_ecommerce/_search
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "select * from kibana_sample_data_ecommerce limit 10;", "runType": "essql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "linkis.es.cluster":"http://127.0.0.1:9200",
+ "linkis.es.datasource":"hadoop",
+ "linkis.es.username":"",
+ "linkis.es.password":""
+ }
+ }
+ },
+ "labels": {
+ "engineType": "elasticsearch-7.6.2",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+#### 4.2.3 文件配置
+通过修改目录 `${LINKIS_HOME}/lib/linkis-engineconn-plugins/elasticsearch/dist/7.6.2/conf/` 中的 `linkis-engineconn.properties` 文件进行配置,如下图:
+
+![](./images/es-config.png)
+
+### 4.3 引擎连接器相关数据表
+
+`Linkis` 是通过引擎连接器标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎连接器的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎连接器label如:elasticsearch-7.6.2
+linkis_ps_configuration_category: 插入引擎连接器的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎连接器需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎连接器的关联关系
+```
+
+表中与引擎连接器相关的初始数据如下
+
+```sql
+-- set variable
+SET @ENGINE_LABEL="elasticsearch-7.6.2";
+SET @ENGINE_ALL=CONCAT('*-*,',@ENGINE_LABEL);
+SET @ENGINE_IDE=CONCAT('*-IDE,',@ENGINE_LABEL);
+SET @ENGINE_NAME="elasticsearch";
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @ENGINE_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @ENGINE_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from `linkis_cg_manager_label` where label_value = @ENGINE_IDE;
+insert into `linkis_ps_configuration_category` (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.cluster', '例如:http://127.0.0.1:9200', '连接地址', 'http://127.0.0.1:9200', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.datasource', '连接别名', '连接别名', 'hadoop', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.username', 'username', 'ES集群用户名', '无', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.password', 'password', 'ES集群密码', '无', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.auth.cache', '客户端是否缓存认证', '客户端是否缓存认证', 'false', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.sniffer.enable', '客户端是否开启 sniffer', '客户端是否开启 sniffer', 'false', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.http.method', '调用方式', 'HTTP请求方式', 'GET', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.http.endpoint', '/_search', 'JSON 脚本调用的 Endpoint', '/_search', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.sql.endpoint', '/_sql', 'SQL 脚本调用的 Endpoint', '/_sql', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.sql.format', 'SQL 脚本调用的模板,%s 替换成 SQL 作为请求体请求Es 集群', '请求体', '{"query":"%s"}', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.headers.*', '客户端 Headers 配置', '客户端 Headers 配置', '无', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.engineconn.concurrent.limit', '引擎连接器最大并发', '引擎连接器最大并发', '100', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as config_key_id, label.id AS engine_type_label_id FROM `linkis_ps_configuration_config_key` config
+INNER JOIN `linkis_cg_manager_label` label ON config.engine_conn_type = @ENGINE_NAME and label_value = @ENGINE_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select relation.config_key_id AS config_key_id, '' AS config_value, relation.engine_type_label_id AS config_label_id FROM `linkis_ps_configuration_key_engine_relation` relation
+INNER JOIN `linkis_cg_manager_label` label ON relation.engine_type_label_id = label.id AND label.label_value = @ENGINE_ALL);
+
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/flink.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/flink.md
new file mode 100644
index 00000000000..b506bd3b04b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/flink.md
@@ -0,0 +1,191 @@
+---
+title: Flink
+sidebar_position: 6
+---
+
+# Flink 引擎使用文档
+
+本文主要介绍在 `Linkis` 中,`flink` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 引擎环境配置
+
+如果您希望在您的服务器上使用 `Flink` 引擎,您需要保证以下的环境变量已经设置正确并且引擎的启动用户是有这些环境变量的。
+
+### 1.2 引擎验证
+
+强烈建议您在执行 `Flink` 任务之前,检查下执行用户的这些环境变量。具体方式是
+```
+sudo su - ${username}
+echo ${JAVA_HOME}
+echo ${FLINK_HOME}
+```
+
+| 环境变量名 | 环境变量内容 | 备注 |
+|-----------------|----------------|----------------------------------------|
+| JAVA_HOME | JDK安装路径 | 必须 |
+| HADOOP_HOME | Hadoop安装路径 | 必须 |
+| HADOOP_CONF_DIR | Hadoop配置路径 | Linkis启动Flink引擎采用的Flink on yarn的模式,所以需要yarn的支持。 |
+| FLINK_HOME | Flink安装路径 | 必须 |
+| FLINK_CONF_DIR | Flink配置路径 | 必须,如 ${FLINK_HOME}/conf |
+| FLINK_LIB_DIR | Flink包路径 | 必须,${FLINK_HOME}/lib |
+
+
+## 2. 引擎插件安装
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/flink/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/flink/target/out/
+```
+
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── flink
+│ ├── dist
+│ │ └── 1.12.2
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 1.12.2
+```
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+
+## 3. Flink引擎的使用
+
+`Linkis` 的 `Flink` 引擎是通过 `flink on yarn` 的方式进行启动的,所以需要指定用户使用的队列,如下图所示。
+
+![yarn](./images/yarn-conf.png)
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType flink-1.12.2 \
+-codeType sql -code "show tables" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+更多 `Linkis-Cli` 命令参数参考: [`Linkis-Cli` 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过 `ComputationEngineConn` 提交任务
+
+`FlinkSQL` 可以支持多种数据源,例如 `binlog` , `kafka` , `hive` 等,如果您想要在 `Flink` 代码中使用这些数据源,您需要将这些 `connector` 的插件 `jar` 包放置到 `Flink` 引擎的 `lib` 中,并重启下 `Linkis` 的 `EnginePlugin` 服务。如你想要在您的 `FlinkSQL` 中使用 `binlog` 作为数据源,那么您需要将 `flink-connector-mysql-cdc-1.1.1.jar` 放置到 `Flink` 引擎的 `lib` 中。
+
+为了方便大家进行采样调试,我们在 `Scriptis` 新增了 `fql` 的脚本类型,专门用于执行 `FlinkSQL` 。但是需要保证您的 `DSS` 已经升级到 `DSS1.0.0` 。升级到 `DSS1.0.0` 之后,您可以直接进入 `Scriptis` ,新建 `fql` 脚本进行编辑和执行。
+
+`FlinkSQL` 的编写示例,以 `binlog` 为例
+```sql
+CREATE TABLE mysql_binlog (
+ id INT NOT NULL,
+ name STRING,
+ age INT
+) WITH (
+ 'connector' = 'mysql-cdc',
+ 'hostname' = 'ip',
+ 'port' = 'port',
+ 'username' = 'username',
+ 'password' = 'password',
+ 'database-name' = 'dbname',
+ 'table-name' = 'tablename',
+ 'debezium.snapshot.locking.mode' = 'none' --建议添加,不然会要求锁表
+);
+select * from mysql_binlog where id > 10;
+```
+在 `Scriptis` 中使用 `select` 语法进行调试的时候,`Flink` 引擎会有一个自动 `cancel` 的机制,即到了指定的时间或者采样的行数到了指定的数量,`Flink` 引擎将会主动将任务 `cancel` ,并且将已经获取到的结果集持久化,然后前端会调用打开结果集的接口将结果集在前端进行展示。
+
+### 3.3 通过 `OnceEngineConn` 提交任务
+
+`OnceEngineConn` 的使用方式是用于正式启动 `Flink` 的流式应用,具体的是通过 `LinkisManagerClient` 调用 `LinkisManager` `的createEngineConn` 的接口,并将代码发给创建的 `Flink` 引擎,然后 `Flink` 引擎就开始执行,此方式可以被其他系统进行调用,比如 `Streamis` 。 `Client` 的使用方式也很简单,首先新建一个 `maven` 项目,或者在您的项目中引入以下的依赖。
+```xml
+
+ org.apache.linkis
+ linkis-computation-client
+ ${linkis.version}
+
+```
+然后新建 `scala` 测试文件,点击执行,就完成了从一个 `binlog` 数据进行解析并插入到另一个 `mysql` 数据库的表中。但是需要注意的是,您必须要在 `maven` 项目中新建一个 `resources` 目录,放置一个 `linkis.properties` 文件,并指定 `linkis` 的 `gateway` 地址和 `api` 版本,如
+```properties
+wds.linkis.server.version=v1
+wds.linkis.gateway.url=http://ip:9001/
+```
+```java
+object OnceJobTest {
+ def main(args: Array[String]): Unit = {
+ val sql = """CREATE TABLE mysql_binlog (
+ | id INT NOT NULL,
+ | name STRING,
+ | age INT
+ |) WITH (
+ | 'connector' = 'mysql-cdc',
+ | 'hostname' = 'ip',
+ | 'port' = 'port',
+ | 'username' = '${username}',
+ | 'password' = '${password}',
+ | 'database-name' = '${database}',
+ | 'table-name' = '${tablename}',
+ | 'debezium.snapshot.locking.mode' = 'none'
+ |);
+ |CREATE TABLE sink_table (
+ | id INT NOT NULL,
+ | name STRING,
+ | age INT,
+ | primary key(id) not enforced
+ |) WITH (
+ | 'connector' = 'jdbc',
+ | 'url' = 'jdbc:mysql://${ip}:port/${database}',
+ | 'table-name' = '${tablename}',
+ | 'driver' = 'com.mysql.jdbc.Driver',
+ | 'username' = '${username}',
+ | 'password' = '${password}'
+ |);
+ |INSERT INTO sink_table SELECT id, name, age FROM mysql_binlog;
+ |""".stripMargin
+ val onceJob = SimpleOnceJob.builder().setCreateService("Flink-Test").addLabel(LabelKeyUtils.ENGINE_TYPE_LABEL_KEY, "flink-1.12.2")
+ .addLabel(LabelKeyUtils.USER_CREATOR_LABEL_KEY, "hadoop-Streamis").addLabel(LabelKeyUtils.ENGINE_CONN_MODE_LABEL_KEY, "once")
+ .addStartupParam(Configuration.IS_TEST_MODE.key, true)
+ // .addStartupParam("label." + LabelKeyConstant.CODE_TYPE_KEY, "sql")
+ .setMaxSubmitTime(300000)
+ .addExecuteUser("hadoop").addJobContent("runType", "sql").addJobContent("code", sql).addSource("jobName", "OnceJobTest")
+ .build()
+ onceJob.submit()
+ println(onceJob.getId)
+ onceJob.waitForCompleted()
+ System.exit(0)
+ }
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/hbase.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/hbase.md
new file mode 100644
index 00000000000..fb09c8905f6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/hbase.md
@@ -0,0 +1,101 @@
+---
+title: HBase
+sidebar_position: 15
+---
+
+# HBase 引擎使用文档
+
+本文主要介绍在 `Linkis` 中,`HBase` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+
+### 1.1 引擎验证
+
+强烈建议您在执行 `HBase` 任务之前,检查下执行用户的这些环境变量。具体方式是
+```
+sudo su - ${username}
+echo ${JAVA_HOME}
+```
+
+## 2. 引擎插件安装
+
+### 2.1 引擎插件准备 [非默认引擎](./overview.md)
+
+单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/hbase/
+mvn clean install -DskipTests -Dhbase.profile=1.2|1.4|2.2|2.5
+
+# hbase.profile 支持1.2|1.4|2.2|2.5,对应的HBase版本是1.2.0,1.4.3,2.2.6,2.5.3
+# 默认hbase.profile=2.5,按需编译不同HBase版本的插件
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/hbase/target/out/
+```
+
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineplugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── hbase
+│ ├── dist
+│ │ └── 2.5.3
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 2.5.3
+```
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+
+## 3. HBase引擎的使用
+
+`Linkis` 的 `HBase` 引擎是通过后台运行一个Jruby环境来执行hbase-shell中的指令,完全兼容hbase-shell的指令。
+
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+ sh bin/linkis-cli -engineType hbase-2.5.3 -code "list" \
+ -codeType shell -runtimeMap linkis.hbase.zookeeper.quorum=zk1,zk2,zk3
+```
+
+更多 `Linkis-Cli` 命令参数参考: [`Linkis-Cli` 使用](../user-guide/linkiscli-manual.md)
+
+HBase引擎,支持的连接参数有:
+
+| 配置名称 | 备注及默认值信息 | 是否必须 |
+|-----------------|----------------|----------------------------------------|
+| linkis.hbase.zookeeper.quorum | 连接hbase的zk地址,如:zk1,zk2,zk3, 默认值:localhost | 必须 |
+| linkis.hbase.zookeeper.property.clientPort | 连接hbase的zk端口,默认值:2181 | 非必须,一般就是默认值 |
+| linkis.zookeeper.znode.parent | 连接HBase的zk znode path,默认值:/hbase | 非必须,一般就是默认值 |
+| linkis.hbase.rootdir | HBase集群的hdfs根目录,默认值:/hbase | 非必须,一般就是默认值 |
+| linkis.hbase.security.authentication | HBase集群连接的认证方式:simple|kerberos,默认值:simple | 非必须,视自己集群情况定 |
+| linkis.hbase.kerberos.principal | HBase kerberos认证principal,如:hbase@HADOOP.LINKIS.COM | kerberos认证方式下必须 |
+| linkis.hbase.keytab.file | HBase kerberos认证所需keytab文件地址,如:/tmp/hbase.keytab | kerberos认证方式下必须 |
+| linkis.hbase.kerberos.proxy.user | kerberos代理用户,需保证kerberos认证用户有代理普通用户的权限 | 非必须,可以不用代理用户 |
+| linkis.hbase.regionserver.kerberos.principal | 如:hbase/_HOST@HADOOP.LINKIS.COM,自行从集群配置文件中获取 | kerberos认证方式下必须 |
+| linkis.hbase.master.kerberos.principal | 如:hbase/_HOST@HADOOP.LINKIS.COM,自行从集群配置文件中获取 | kerberos认证方式下必须 |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/hive.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/hive.md
new file mode 100644
index 00000000000..4a5e724bd0d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/hive.md
@@ -0,0 +1,293 @@
+---
+title: Hive
+sidebar_position: 2
+---
+
+本文主要介绍在 `Linkis` 中, `Hive` 引擎连接器的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 擎使用前的环境配置
+
+如果您希望在您的服务器上使用 `Hive` 引擎连接器,您需要保证以下的环境变量已经设置正确并且引擎连接器的启动用户是有这些环境变量的。
+
+强烈建议您在执行 `Hive` 任务之前,检查下执行用户的这些环境变量。
+
+| 环境变量名 | 环境变量内容 | 备注 |
+|-----------------|----------------|------|
+| JAVA_HOME | JDK安装路径 | 必须 |
+| HADOOP_HOME | Hadoop安装路径 | 必须 |
+| HADOOP_CONF_DIR | Hadoop配置路径 | 必须 |
+| HIVE_CONF_DIR | Hive配置路径 | 必须 |
+
+### 1.1 环境验证
+```
+# 链接hive
+bin/hive
+
+# 测试命令
+show databases;
+
+# 能够链接成功,并正常输出数据库信息代表环境配置成功
+hive (default)> show databases;
+OK
+databases_name
+default
+```
+
+## 2. 引擎插件安装 [默认引擎](./overview.md)
+
+`linkis` 发布的二进制安装包中默认包含了 `Hive` 引擎插件,用户无需额外安装。
+
+`Hive` 的版本是支持 `Hive1.x` 和` Hive2.x` ,默认是支持 `Hive on MapReduce` ,如果您想改成 `Hive on Tez`,
+Linkis是可以兼容hive on tez的需要以下步骤:
+- 需要将Tez相关的依赖拷贝到 {LINKIS_HOME}/lib/linkis-engineconn-plugins/hive/dist/3.1.3/lib 是dist not plugin 目录[1]. 你也可以修改hive ec pom增加tez dependency重新编译
+- vim {LINKIS_HOME}/lib/linkis-engineconn-plugins/hive/dist/3.1.3/conf/linkis-engineconn.properties and update linkis.hive.engine.type=tez
+- sh linkis-daemon.sh restart linkis-cg-manager
+
+
+默认支持的 `Hive` 版本是 3.1.3 ,如果您想修改 `Hive` 的版本,您可以找到 `linkis-engineplugin-hive` 模块,修改 `` 标签,然后单独编译此模块即可
+
+[EngineConnPlugin引擎插件安装](../deployment/install-engineconn.md)
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType hive-3.1.3 \
+-codeType hql -code "show databases" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+更多 `Linkis-Cli` 命令参数参考: [`Linkis-Cli` 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过Linkis SDK提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。对于 `Hive` 任务你只需要修改 `Demo` 中的 `EngineConnType` 和 `CodeType` 参数即可:
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "hive-3.1.3"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "hql"); // required codeType
+```
+
+## 4. 引擎连接器配置说明
+
+### 4.1 默认配置说明
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| wds.linkis.rm.instance | 10 |否 | 引擎连接器最大并发数 |
+| wds.linkis.engineconn.java.driver.memory | 1g |否 | 引擎连接器初始化内存大小 |
+| wds.linkis.engineconn.max.free.time | 1h |否 | 引擎连接器空闲退出时间 |
+
+### 4.2 队列资源配置
+`Hive` 的 `MapReduce` 任务是需要用到 `yarn` 的资源,所以需要设置队列。
+
+![yarn](./images/yarn-conf.png)
+
+### 4.3 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.3.1 管理台配置
+
+![hive](./images/hive-config.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE \
+-engineType hive-3.1.3 -codeType hql \
+-code "show databases" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.3.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "show databases;", "runType": "sql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "wds.linkis.rm.instance":"10"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "hive-3.1.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+### 4.4 引擎连接器相关数据表
+
+`Linkis` 是通过引擎连接器标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎连接器的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎连接器标签如:hive-3.1.3
+linkis_ps_configuration_category: 插入引擎连接器的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎连接器需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎连接器的关联关系
+```
+
+表中与引擎连接器相关的初始数据如下
+
+```sql
+-- set variable
+SET @HIVE_LABEL="hive-3.1.3";
+SET @HIVE_ALL=CONCAT('*-*,',@HIVE_LABEL);
+SET @HIVE_IDE=CONCAT('*-IDE,',@HIVE_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @HIVE_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @HIVE_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @HIVE_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.instance', '范围:1-20,单位:个', 'hive引擎连接器最大并发数', '10', 'NumInterval', '[1,20]', '0', '0', '1', '队列资源', 'hive');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.java.driver.memory', '取值范围:1-10,单位:G', 'hive引擎连接器初始化内存大小','1g', 'Regex', '^([1-9]|10)(G|g)$', '0', '0', '1', 'hive引擎连接器设置', 'hive');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('hive.client.java.opts', 'hive客户端进程参数', 'hive引擎连接器启动时jvm参数','', 'None', NULL, '1', '1', '1', 'hive引擎连接器设置', 'hive');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('mapred.reduce.tasks', '范围:-1-10000,单位:个', 'reduce数', '-1', 'NumInterval', '[-1,10000]', '0', '1', '1', 'hive资源设置', 'hive');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.max.free.time', '取值范围:3m,15m,30m,1h,2h', '引擎连接器空闲退出时间','1h', 'OFT', '[\"1h\",\"2h\",\"30m\",\"15m\",\"3m\"]', '0', '0', '1', 'hive引擎连接器设置', 'hive');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'hive' and label_value = @HIVE_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @HIVE_ALL);
+```
+
+## 5. Hive修改日志展示
+默认的日志界面是不显示 `application_id` 以及 `task` 完成数量的,用户可以根据需要输出该日志
+引擎连接器内的 `log4j2-engineconn.xml/log4j2.xml` 配置文件中需要修改的代码块如下
+1. `appenders` 组件下需要添加
+```xml
+
+
+
+```
+2. `root` 组件下需要添加
+```xml
+
+```
+3. `loggers` 组件下需要添加
+```xml
+
+
+
+```
+进行如上相关修改后日志可以增加任务 `task` 进度信息,显示为如下样式
+```
+2022-04-08 11:06:50.228 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Status: Running (Executing on YARN cluster with App id application_1631114297082_432445)
+2022-04-08 11:06:50.248 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Map 1: -/- Reducer 2: 0/1
+2022-04-08 11:06:52.417 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Map 1: 0/1 Reducer 2: 0/1
+2022-04-08 11:06:55.060 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Map 1: 0(+1)/1 Reducer 2: 0/1
+2022-04-08 11:06:57.495 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Map 1: 1/1 Reducer 2: 0(+1)/1
+2022-04-08 11:06:57.899 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Map 1: 1/1 Reducer 2: 1/1
+```
+
+完整 `xml` 配置文件范例如下:
+```xml
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/check-seatunnel.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/check-seatunnel.png
new file mode 100644
index 00000000000..982c227195b
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/check-seatunnel.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/datasourceconntest.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/datasourceconntest.png
new file mode 100644
index 00000000000..9b1308a10ba
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/datasourceconntest.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/datasourcemanage.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/datasourcemanage.png
new file mode 100644
index 00000000000..f59d64c7483
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/datasourcemanage.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/es-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/es-config.png
new file mode 100644
index 00000000000..d06c2b878ba
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/es-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/es-manage.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/es-manage.png
new file mode 100644
index 00000000000..f4a4616a528
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/es-manage.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/historical_information.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/historical_information.png
new file mode 100644
index 00000000000..6c10cd71b7c
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/historical_information.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/hive-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/hive-config.png
new file mode 100644
index 00000000000..9e57ec2ebfc
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/hive-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/hive-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/hive-run.png
new file mode 100644
index 00000000000..287b1abfdef
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/hive-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/jdbc-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/jdbc-config.png
new file mode 100644
index 00000000000..2977040d148
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/jdbc-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/jdbc-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/jdbc-run.png
new file mode 100644
index 00000000000..fe51598b235
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/jdbc-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/job_state.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/job_state.png
new file mode 100644
index 00000000000..cadf1d1cd90
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/job_state.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/k8s-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/k8s-config.png
new file mode 100644
index 00000000000..d9986c972a4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/k8s-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/k8s-ecm-label.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/k8s-ecm-label.png
new file mode 100644
index 00000000000..a6f116b7418
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/k8s-ecm-label.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/muti-data-source-usage.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/muti-data-source-usage.png
new file mode 100644
index 00000000000..cc017a53935
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/muti-data-source-usage.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/new_pipeline_script.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/new_pipeline_script.png
new file mode 100644
index 00000000000..8a1b59ce29e
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/new_pipeline_script.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/openlookeng-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/openlookeng-config.png
new file mode 100644
index 00000000000..00abce5093a
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/openlookeng-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/pipeline-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/pipeline-conf.png
new file mode 100644
index 00000000000..325efe24c84
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/pipeline-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/presto-console.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/presto-console.png
new file mode 100644
index 00000000000..d3a92de1a57
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/presto-console.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/presto-file.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/presto-file.png
new file mode 100644
index 00000000000..49c00b99656
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/presto-file.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/presto-psql.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/presto-psql.png
new file mode 100644
index 00000000000..505f0a7a8c1
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/presto-psql.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/pyspakr-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/pyspakr-run.png
new file mode 100644
index 00000000000..c80c85bae00
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/pyspakr-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/python-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/python-conf.png
new file mode 100644
index 00000000000..3417af1c1e1
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/python-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/python-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/python-config.png
new file mode 100644
index 00000000000..acfb69a6482
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/python-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/python-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/python-run.png
new file mode 100644
index 00000000000..65467afca15
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/python-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/queue-set.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/queue-set.png
new file mode 100644
index 00000000000..78fc0f3e6a4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/queue-set.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/scala-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/scala-run.png
new file mode 100644
index 00000000000..7c01aadcdf8
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/scala-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/shell-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/shell-run.png
new file mode 100644
index 00000000000..734bdb22dce
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/shell-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/spark-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/spark-conf.png
new file mode 100644
index 00000000000..d452a3f4ad8
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/spark-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/sparksql-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/sparksql-run.png
new file mode 100644
index 00000000000..f0b1d1bcaf2
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/sparksql-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/to_write.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/to_write.png
new file mode 100644
index 00000000000..e75ab0638e4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/to_write.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/trino-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/trino-config.png
new file mode 100644
index 00000000000..0f7cc9c94ac
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/trino-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/workflow.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/workflow.png
new file mode 100644
index 00000000000..3a5919f2594
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/workflow.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/yarn-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/yarn-conf.png
new file mode 100644
index 00000000000..15256381f92
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/images/yarn-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/impala.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/impala.md
new file mode 100644
index 00000000000..eb1170a7550
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/impala.md
@@ -0,0 +1,219 @@
+---
+title: Impala
+sidebar_position: 12
+---
+
+本文主要介绍在 `Linkis` 中,`Impala` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+
+### 1.1 环境安装
+
+如果您希望在您的服务器上使用 Impala 引擎,您需要准备 Impala 服务并提供连接信息,如 Impala 集群的连接地址、SASL用户名和密码等
+
+### 1.2 环境验证
+
+执行 impala-shell 命令得到如下输出代表 impala 服务可用。
+```
+[root@8f43473645b1 /]# impala-shell
+Starting Impala Shell without Kerberos authentication
+Connected to 8f43473645b1:21000
+Server version: impalad version 2.12.0-cdh5.15.0 RELEASE (build 23f574543323301846b41fa5433690df32efe085)
+***********************************************************************************
+Welcome to the Impala shell.
+(Impala Shell v2.12.0-cdh5.15.0 (23f5745) built on Thu May 24 04:07:31 PDT 2018)
+
+When pretty-printing is disabled, you can use the '--output_delimiter' flag to set
+the delimiter for fields in the same row. The default is ','.
+***********************************************************************************
+[8f43473645b1:21000] >
+```
+
+## 2. 引擎插件部署
+
+编译 `Impala` 引擎之前需要进行 `Linkis` 项目全量编译 , `Linkis` 默认发布的安装部署包中默认不包含此引擎插件。
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/impala/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/impala/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── impala
+│ ├── dist
+│ │ └── 3.4.0
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 3.4.0
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -submitUser impala \
+-engineType impala-3.4.0 -code 'show databases;' \
+-runtimeMap linkis.es.http.method=GET \
+-runtimeMap linkis.impala.servers=127.0.0.1:21050
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 | 说明 | 是否必须 |
+| -------------------------------------- | --------------------- | ------------------------------------------- | -------- |
+| linkis.impala.default.limit | 5000 | 是 | 查询的结果集返回条数限制 |
+| linkis.impala.engine.user | ${HDFS_ROOT_USER} | 是 | 默认引擎启动用户 |
+| linkis.impala.user.isolation.mode | false | 是 | 以多用户模式启动引擎 |
+| linkis.impala.servers | 127.0.0.1:21050 | 是 | Impala服务器地址,','分隔 |
+| linkis.impala.maxConnections | 10 | 是 | 对每台Impala服务器的连接数上限 |
+| linkis.impala.ssl.enable | false | 是 | 是否启用SSL连接 |
+| linkis.impala.ssl.keystore.type | JKS | 否 | SSL Keystore类型 |
+| linkis.impala.ssl.keystore | null | 否 | SSL Keystore路径 |
+| linkis.impala.ssl.keystore.password | null | 否 | SSL Keystore密码 |
+| linkis.impala.ssl.truststore.type | JKS | 否 | SSL Truststore类型 |
+| linkis.impala.ssl.truststore | null | 否 | SSL Truststore路径 |
+| linkis.impala.ssl.truststore.password | null | 否 | SSL Truststore密码 |
+| linkis.impala.sasl.enable | false | 是 | 是否启用SASL认证 |
+| linkis.impala.sasl.mechanism | PLAIN | 否 | SASL Mechanism |
+| linkis.impala.sasl.authorizationId | null | 否 | SASL AuthorizationId |
+| linkis.impala.sasl.protocol | LDAP | 否 | SASL Protocol |
+| linkis.impala.sasl.properties | null | 否 | SASL Properties: key1=value1,key2=value2 |
+| linkis.impala.sasl.username | ${impala.engine.user}| 否 | SASL Username |
+| linkis.impala.sasl.password | null | 否 | SASL Password |
+| linkis.impala.sasl.password.cmd | null | 否 | SASL Password获取命令 |
+| linkis.impala.heartbeat.seconds | 1 | 是 | 任务状态更新间隔 |
+| linkis.impala.query.timeout.seconds | 0 | 否 | 任务执行超时时间 |
+| linkis.impala.query.batchSize | 1000 | 是 | 结果集获取批次大小 |
+| linkis.impala.query.options | null | 否 | 查询提交参数: key1=value1,key2=value2 |
+
+### 4.2 配置修改
+
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "show databases;", "runType": "sql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "linkis.impala.servers"="127.0.0.1:21050"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "impala-3.4.0",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:impala-3.4.0
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+
+```sql
+-- set variable
+SET @ENGINE_LABEL="impala-3.4.0";
+SET @ENGINE_IDE=CONCAT('*-IDE,',@ENGINE_LABEL);
+SET @ENGINE_ALL=CONCAT('*-*,',@ENGINE_LABEL);
+SET @ENGINE_NAME="impala";
+
+-- add impala engine to IDE
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @ENGINE_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @ENGINE_IDE, 'OPTIONAL', 2, now(), now());
+select @label_id := id from `linkis_cg_manager_label` where label_value = @ENGINE_IDE;
+insert into `linkis_ps_configuration_category` (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- insert configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.default.limit', '查询的结果集返回条数限制', '结果集条数限制', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.engine.user', '默认引擎启动用户', '默认启动用户', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.user.isolation.mode', '以多用户模式启动引擎', '多用户模式', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.servers', 'Impala服务器地址', '服务地址', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.maxConnections ', '对每台Impala服务器的连接数上限', '最大连接数', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.enable', '是否启用SSL连接', '启用SSL', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.keystore.type', 'SSL Keystore类型', 'SSL Keystore类型', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.keystore', 'SSL Keystore路径', 'SSL Keystore路径', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.keystore.password', 'SSL Keystore密码', 'SSL Keystore密码', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.truststore.type', 'SSL Truststore类型', 'SSL Truststore类型', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.truststore', 'SSL Truststore路径', 'SSL Truststore路径', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.truststore.password', 'SSL Truststore密码', 'SSL Truststore密码', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.enable', '是否启用SASL认证', '启用SASL', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.mechanism', 'SASL Mechanism', 'SASL Mechanism', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.authorizationId', 'SASL AuthorizationId', 'SASL AuthorizationId', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.protocol', 'SASL Protocol', 'SASL Protocol', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.properties', 'SASL Properties: key1=value1,key2=value2', 'SASL Properties', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.username', 'SASL Username', 'SASL Username', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.password', 'SASL Password', 'SASL Password', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.password.cmd', 'SASL Password获取命令', 'SASL Password获取命令', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.heartbeat.seconds', '任务状态更新间隔', '任务状态更新间隔', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.query.timeout.seconds', '任务执行超时时间', '任务执行超时时间', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.query.batchSize', '结果集获取批次大小', '结果集获取批次大小', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.query.options', '查询提交参数: key1=value1,key2=value2', '查询提交参数', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+-- impala engine -*
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as config_key_id, label.id AS engine_type_label_id FROM `linkis_ps_configuration_config_key` config
+INNER JOIN `linkis_cg_manager_label` label ON config.engine_conn_type = @ENGINE_NAME and label_value = @ENGINE_ALL);
+-- impala engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select relation.config_key_id AS config_key_id, '' AS config_value, relation.engine_type_label_id AS config_label_id FROM `linkis_ps_configuration_key_engine_relation` relation
+INNER JOIN `linkis_cg_manager_label` label ON relation.engine_type_label_id = label.id AND label.label_value = @ENGINE_ALL);
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/jdbc.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/jdbc.md
new file mode 100644
index 00000000000..b549fa7a1f2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/jdbc.md
@@ -0,0 +1,275 @@
+---
+title: JDBC
+sidebar_position: 5
+---
+
+本文主要介绍在 `Linkis` 中, `JDBC` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 环境安装
+
+如果您希望在您的服务器上使用 `JDBC` 引擎,您需要准备 `JDBC` 连接信息,如 `MySQL` 数据库的连接地址、用户名和密码等
+
+### 1.2 环境验证(以 `Mysql` 为例)
+```
+mysql -uroot -P 3306 -h 127.0.0.1 -p 123456
+```
+输出如下信息代表 `JDBC` 连接信息可用
+```
+mysql: [Warning] Using a password on the command line interface can be insecure.
+Welcome to the MySQL monitor. Commands end with ; or \g.
+Your MySQL connection id is 9
+Server version: 5.7.39 MySQL Community Server (GPL)
+
+Copyright (c) 2000, 2022, Oracle and/or its affiliates.
+
+Oracle is a registered trademark of Oracle Corporation and/or its
+affiliates. Other names may be trademarks of their respective
+owners.
+
+Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
+
+mysql>
+```
+
+## 2. 引擎插件安装
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/jdbc/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/jdbc/target/out/
+```
+
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── jdbc
+│ ├── dist
+│ │ └── 4
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 4
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType jdbc-4 \
+-codeType jdbc -code "show tables" \
+-submitUser hadoop -proxyUser hadoop \
+-runtimeMap wds.linkis.jdbc.connect.url=jdbc:mysql://127.0.0.1:3306/linkis_db \
+-runtimeMap wds.linkis.jdbc.driver=com.mysql.jdbc.Driver \
+-runtimeMap wds.linkis.jdbc.username=test \
+-runtimeMap wds.linkis.jdbc.password=123456
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过 `Linkis SDK` 提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。对于 `JDBC` 任务您只需要修改 `Demo` 中的 `EngineConnType` 和 `CodeType` 参数即可:
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "jdbc-4"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "jdbc"); // required codeType
+```
+
+### 3.3 多数据源支持
+从 `Linkis 1.2.0` 开始,提供了 `JDBC` 引擎多数据源的支持,我们首先可以在控制台管理不同的数据源。地址:登陆管理台-->数据源管理-->新增数据源
+
+![](./images/datasourcemanage.png)
+
+图3-3 数据源管理
+
+![](./images/datasourceconntest.png)
+
+图3-4 数据源连接测试
+
+数据源添加完成之后,就可以使用 `JDBC` 引擎的多数据源切换功能,有两种方式:
+1、 通过接口参数指定数据源名称参数
+参数示例:
+```json
+{
+ "executionContent": {
+ "code": "show databases",
+ "runType": "jdbc"
+ },
+ "params": {
+ "variable": {},
+ "configuration": {
+ "startup": {},
+ "runtime": {
+ "wds.linkis.engine.runtime.datasource": "test_mysql"
+ }
+ }
+ },
+ "source": {
+ "scriptPath": ""
+ },
+ "labels": {
+ "engineType": "jdbc-4",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+参数:`wds.linkis.engine.runtime.datasource` 为固定名称的配置,不要随意修改名称定义
+
+2、 通过 `DSS` 的 `Scripts` 代码提交入口下拉筛选需要提交的数据源,如下图:
+![](./images/muti-data-source-usage.png)
+当前 `dss-1.1.0` 还暂不支持下拉选择数据源名称, `PR` 在开发中,可以等后续发版或关注相关 `PR` :
+(https://github.com/WeBankFinTech/DataSphereStudio/issues/940)
+
+
+多数据源的功能说明:
+
+1)在之前的版本中, `JDBC` 引擎对数据源的支持不够完善,尤其是搭配 `Scripts` 使用的时候, `JDBC` 脚本类型只能绑定控制台的一套 `JDBC` 引擎参数,
+当我们有多数据源的切换需求时,只能修改 `JDBC` 引擎的连接参数,比较麻烦。
+
+2)配合数据源管理,我们引入 `JDBC` 引擎的多数据源切换功能,可以实现只设置数据源名称,就可把作业提交到不同的 `JDBC` 服务之上,普通用户不需要
+维护数据源的连接信息,避免了配置繁琐,也满足了数据源连接密码等配置的安全性需要。
+
+3)多数据源管理中设置的数据源,只有发布之后,并且没有过期的数据源才能被 `JDBC` 引擎加载到,否则会反馈给用户不同类型的异常提示。
+
+4) `JDBC` 引擎参数的加载优先级为:任务提交传参 > 选择数据源的参数 > 控制台JDBC引擎的参数
+
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| wds.linkis.jdbc.connect.url | jdbc:mysql://127.0.0.1:10000 |是 | jdbc连接地址 |
+| wds.linkis.jdbc.driver | 无 |是 | jdbc连接驱动 |
+| wds.linkis.jdbc.username | 无 |是 | 数据库连接用户名 |
+| wds.linknis.jdbc.password | 无 |是 | 数据库链接密码 |
+| wds.linkis.jdbc.connect.max | 10 |否 | jdbc引擎最大连接数 |
+| wds.linkis.jdbc.version | jdbc4 |否 | jdbc版本 |
+
+### 4.2 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+
+#### 4.2.1 管理台配置
+
+![jdbc](./images/jdbc-config.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE \
+-engineType jdbc-4 -codeType jdbc \
+-code "show tables" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "show databases;", "runType": "jdbc"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "wds.linkis.jdbc.connect.url":"jdbc:mysql://127.0.0.1:3306/test",
+ "wds.linkis.jdbc.driver":"com.mysql.jdbc.Driver",
+ "wds.linkis.jdbc.username":"test",
+ "wds.linkis.jdbc.password":"test23"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "jdbc-4",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:jdbc-4
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+```sql
+-- set variable
+SET @JDBC_LABEL="jdbc-4";
+SET @JDBC_ALL=CONCAT('*-*,',@JDBC_LABEL);
+SET @JDBC_IDE=CONCAT('*-IDE,',@JDBC_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @JDBC_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @JDBC_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @JDBC_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.connect.url', '例如:jdbc:mysql://127.0.0.1:10000', 'jdbc连接地址', 'jdbc:mysql://127.0.0.1:10000', 'Regex', '^\\s*jdbc:\\w+://([^:]+)(:\\d+)(/[^\\?]+)?(\\?\\S*)?$', '0', '0', '1', '数据源配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.driver', '例如:com.mysql.jdbc.Driver', 'jdbc连接驱动', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.version', '取值范围:jdbc3,jdbc4', 'jdbc版本','jdbc4', 'OFT', '[\"jdbc3\",\"jdbc4\"]', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.username', 'username', '数据库连接用户名', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.password', 'password', '数据库连接密码', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.connect.max', '范围:1-20,单位:个', 'jdbc引擎最大连接数', '10', 'NumInterval', '[1,20]', '0', '0', '1', '数据源配置', 'jdbc');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'jdbc' and label_value = @JDBC_ALL);
+
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @JDBC_ALL);
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/nebula.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/nebula.md
new file mode 100644
index 00000000000..e4f14cfccb8
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/nebula.md
@@ -0,0 +1,109 @@
+---
+title: Nebula
+sidebar_position: 17
+---
+
+本文主要介绍在 `Linkis` 中,`Nebula` 引擎插件的安装、使用和配置。
+
+
+## 1. 前置工作
+
+### 1.1 引擎安装
+
+如果您希望在您的 `Linkis` 服务上使用 `Nebula` 引擎,您需要安装 `Nebula` 服务并保证服务可用。
+
+### 1.2 服务验证
+
+```shell
+# 执行任务
+./usr/local/bin/nebula-console -u root -p password --address=graphd --port=9669
+
+CREATE SPACE IF NOT EXISTS my_space_1 (vid_type=FIXED_STRING(30));SHOW SPACES;
+
+# 得到如下输出代表服务可用
++--------------+
+| Name |
++--------------+
+| "my_space_1" |
++--------------+
+```
+
+## 2. 引擎插件部署
+
+### 2.1 引擎插件准备[非默认引擎](./overview.md)
+
+单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/nebula/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/nebula/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineplugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── nebula
+│ ├── dist
+│ │ └── 3.0.0
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 3.0.0
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType nebula-3.0.0 -codeType nebula \
+ -code 'CREATE SPACE IF NOT EXISTS my_space_1 (vid_type=FIXED_STRING(30));SHOW SPACES;' \
+ -runtimeMap linkis.nebula.port=9669 -runtimeMap linkis.nebula.host=wds07
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 | 是否必须 | 说明 |
+| -------------------------------------- |-----------|-------------|--------|
+| linkis.nebula.host | 127.0.0.1 | 否 | host |
+| linkis.nebula.port | 9669 | 否 | 端口 |
+| linkis.nebula.username | root | 否 | 用户名 |
+| linkis.nebula.password | nebula | 否 | 密码 |
+| linkis.nebula.max.conn.size | 100 | 否 | 最大连接数 |
+| linkis.nebula.reconnect.enabled | false | 否 | 连接断开后是否重试 |
+| linkis.engineconn.concurrent.limit | 100 | 否 | 引擎最大并发数 |
+| linkis.nebula.default.limit | 5000 | 否 | 结果集条数限制 |
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/openlookeng.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/openlookeng.md
new file mode 100644
index 00000000000..c851141b995
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/openlookeng.md
@@ -0,0 +1,210 @@
+---
+title: openLooKeng
+sidebar_position: 7
+---
+
+本文主要介绍在 `Linkis` `中,openLooKeng` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 环境安装
+
+如果您希望部署使用 `openLooKeng` 引擎,您需要准备一套可用的 `openLooKeng` 环境。
+
+### 1.2 服务验证
+
+```shell
+# 准备 hetu-cli
+wget https://download.openlookeng.io/1.5.0/hetu-cli-1.5.0-executable.jar
+mv hetu-cli-1.5.0-executable.jar hetu-cli
+chmod +x hetu-cli
+
+# 链接服务
+./hetu-cli --server 127.0.0.1:9090 --catalog tpcds --schema default
+
+# 执行查询语句
+lk:default> select d_date_sk, d_date_id, d_date, d_month_seq from tpcds.sf1.date_dim order by d_date limit 5;
+
+# 得到如下输出代表服务可用
+ d_date_sk | d_date_id | d_date | d_month_seq
+-----------+------------------+------------+-------------
+ 2415022 | AAAAAAAAOKJNECAA | 1900-01-02 | 0
+ 2415023 | AAAAAAAAPKJNECAA | 1900-01-03 | 0
+ 2415024 | AAAAAAAAALJNECAA | 1900-01-04 | 0
+ 2415025 | AAAAAAAABLJNECAA | 1900-01-05 | 0
+ 2415026 | AAAAAAAACLJNECAA | 1900-01-06 | 0
+(5 rows)
+
+Query 20221110_043803_00011_m9gmv, FINISHED, 1 node
+Splits: 33 total, 33 done (100.00%)
+0:00 [73K rows, 0B] [86.8K rows/s, 0B/s]
+```
+
+## 2. 引擎插件安装
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+${linkis_code_dir}/linkis-enginepconn-pugins/engineconn-plugins/openlookeng/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/openlookeng/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── openlookeng
+│ ├── dist
+│ │ └── 1.5.0
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 1.5.0
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType openlookeng-1.5.0 \
+-codeType sql -code 'select * from tpcds.sf1.date_dim;' \
+-submitUser hadoop -proxyUser hadoop \
+-runtimeMap linkis.openlookeng.url=http://127.0.0.1:8080
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过 `Linkis SDK` 提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。对于 `JDBC` 任务您只需要修改 `Demo` 中的 `EngineConnType` 和 `CodeType` 参数即可:
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "openlookeng-1.5.0"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "sql"); // required codeType
+```
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| linkis.openlookeng.url | http://127.0.0.1:8080 |是 | 链接地址 |
+| linkis.openlookeng.catalog | system |是 | catalog |
+| linkis.openlookeng.source | global |否 | source |
+
+### 4.2 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 管理台配置
+
+![](./images/openlookeng-config.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE \
+-engineType openlookeng-1.5.0 -codeType sql \
+-code 'select * from tpcds.sf1.date_dim;' \
+-submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "select * from tpcds.sf1.date_dim;", "runType": "sql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "linkis.openlookeng.url":"http://127.0.0.1:9090"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "openlookeng-1.5.0",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:openlookeng-1.5.0
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+```sql
+-- set variable
+SET @OPENLOOKENG_LABEL="openlookeng-1.5.0";
+SET @OPENLOOKENG_ALL=CONCAT('*-*,',@OPENLOOKENG_LABEL);
+SET @OPENLOOKENG_IDE=CONCAT('*-IDE,',@OPENLOOKENG_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @OPENLOOKENG_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @OPENLOOKENG_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @OPENLOOKENG_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.url', '例如:http://127.0.0.1:8080', '连接地址', 'http://127.0.0.1:8080', 'Regex', '^\\s*http://([^:]+)(:\\d+)(/[^\\?]+)?(\\?\\S*)?$', 'openlookeng', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.catalog', 'catalog', 'catalog', 'system', 'None', '', 'openlookeng', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.source', 'source', 'source', 'global', 'None', '', 'openlookeng', 0, 0, 1, '数据源配置');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'openlookeng' and label_value = @OPENLOOKENG_ALL);
+
+-- openlookeng default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @OPENLOOKENG_ALL);
+
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/overview.md
new file mode 100644
index 00000000000..5d99947915c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/overview.md
@@ -0,0 +1,27 @@
+---
+title: 总览
+sidebar_position: 0
+---
+## 1. 概述
+`Linkis` 作为一款功能强大的计算中间件,可以方便的对接不同的计算引擎,通过屏蔽不同计算引擎的使用细节,并向上提供了一套统一的使用接口,
+使得部署和应用 `Linkis` 的大数据平台的运维成本大大降低,目前, `Linkis` 已经对接了几款主流的计算引擎,基本上涵盖了上生产上对数据的需求,
+为了提供更好的可拓展性, `Linkis` 同时提供了接入新引擎的相关接口,可以利用该接口接入新的计算引擎。
+
+引擎是提供给用户数据处理和分析能力的组件,目前已经接入 `Linkis` 的引擎,有主流的大数据计算引擎 `Spark` 、 `Hive` 、 `Presto` 等,也有 `python` 、 `Shell` 这些脚本处理数据能力的引擎。
+`DataSphereStudio` 作为对接了 `Linkis` 的一站式数据操作平台,用户可以方便的在 `DataSphereStudio` 中使用 `Linkis` 支持的引擎完成交互式数据分析任务和工作流任务。
+
+支持引擎及版本信息如下:
+
+| 引擎 | 默认引擎 | 默认版本 |
+|-------------| -- | ---- |
+| [Spark](./spark.md) | 是 | 3.2.1 |
+| [Hive](./hive.md) | 是 | 3.1.3 |
+| [Python](./python.md) | 是 | python2 |
+| [Shell](./shell.md) | 是 | 1 |
+| [JDBC](./jdbc.md) | 否 | 4 |
+| [Flink](./flink.md) | 否 | 1.12.2 |
+| [openLooKeng](./openlookeng.md) | 否 | 1.5.0 |
+| [Pipeline](./pipeline.md) | 否 | 1 |
+| [Presto](./presto.md) | 否 | 0.234 |
+| [Sqoop](./sqoop.md) | 否 | 1.4.6 |
+| [Elasticsearch](./elasticsearch.md) | 否 | 7.6.2 |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/pipeline.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/pipeline.md
new file mode 100644
index 00000000000..8d550872869
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/pipeline.md
@@ -0,0 +1,175 @@
+---
+title: Pipeline
+sidebar_position: 9
+---
+`Pipeline` 主要是用来对文件进行导入和导出的。本文主要介绍在 `Linkis` 中, `Pipeline` 引擎插件的安装、使用和配置。
+
+## 1. 引擎插件安装
+
+### 1.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/pipeline/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/pipeline/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 1.2 引擎插件的上传和加载
+
+将 1.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── pipeline
+│ ├── dist
+│ │ └── 1
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 1
+```
+### 1.3 引擎刷新
+
+#### 1.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 1.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 2 引擎的使用
+
+因为 `Pipeline` 引擎主要用来导入导出文件为主,现在我们假设从A向B导入文件为介绍案例
+
+### 2.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh bin/linkis-cli -submitUser hadoop \
+-engineType pipeline-1 -codeType pipeline \
+-code "from hdfs:///000/000/000/A.dolphin to file:///000/000/000/B.csv"
+```
+`from hdfs:///000/000/000/A.dolphin to file:///000/000/000/B.csv` 该内容 2.3 有解释
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 3. 引擎配置说明
+
+### 3.1 默认配置说明
+
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| pipeline.output.mold | csv |否 |结果集导出类型 |
+| pipeline.field.split | , |否 | csv分隔符 |
+| pipeline.output.charset | gbk |否 | 结果集导出字符集 |
+| pipeline.output.isoverwrite | true |否 | 是否覆写 |
+| wds.linkis.rm.instance | 3 |否 | pipeline引擎最大并发数 |
+| pipeline.output.shuffle.null.type | NULL |否 | 空值替换 |
+| wds.linkis.engineconn.java.driver.memory | 2g |否 | pipeline引擎初始化内存大小 |
+
+### 4.2 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 管理台配置
+
+![](./images/pipeline-conf.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh bin/linkis-cli -creator IDE \
+-submitUser hadoop \
+-engineType pipeline-1 \
+-codeType pipeline \
+-code "from hdfs:///000/000/000/A.dolphin to file:///000/000/000/B.csv"
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "from hdfs:///000/000/000/A.dolphin to file:///000/000/000/B.csv", "runType": "pipeline"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "pipeline.output.mold":"csv",
+ "pipeline.output.charset":"gbk"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "pipeline-1",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:pipeline-1
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+```sql
+-- set variable
+SET @PIPELINE_LABEL="pipeline-1";
+SET @PIPELINE_ALL=CONCAT('*-*,',@PIPELINE_LABEL);
+SET @PIPELINE_IDE=CONCAT('*-IDE,',@PIPELINE_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @PIPELINE_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @PIPELINE_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @PIPELINE_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('pipeline.output.mold', '取值范围:csv或excel', '结果集导出类型','csv', 'OFT', '[\"csv\",\"excel\"]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('pipeline.field.split', '取值范围:,或\\t', 'csv分隔符',',', 'OFT', '[\",\",\"\\\\t\"]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('pipeline.output.charset', '取值范围:utf-8或gbk', '结果集导出字符集','gbk', 'OFT', '[\"utf-8\",\"gbk\"]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('pipeline.output.isoverwrite', '取值范围:true或false', '是否覆写','true', 'OFT', '[\"true\",\"false\"]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.instance', '范围:1-3,单位:个', 'pipeline引擎最大并发数','3', 'NumInterval', '[1,3]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.java.driver.memory', '取值范围:1-10,单位:G', 'pipeline引擎初始化内存大小','2g', 'Regex', '^([1-9]|10)(G|g)$', '0', '0', '1', 'pipeline资源设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('pipeline.output.shuffle.null.type', '取值范围:NULL或者BLANK', '空值替换','NULL', 'OFT', '[\"NULL\",\"BLANK\"]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'pipeline' and label_value = @PIPELINE_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @PIPELINE_ALL);
+
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/presto.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/presto.md
new file mode 100644
index 00000000000..6c5bd98b0ea
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/presto.md
@@ -0,0 +1,228 @@
+---
+title: Presto
+sidebar_position: 11
+---
+
+本文主要介绍在 `Linkis` 中,`Presto` 引擎插件的安装、使用和配置。
+
+
+## 1. 前置工作
+
+### 1.1 引擎安装
+
+如果您希望在您的 `Linkis` 服务上使用 `Presto` 引擎,您需要安装 `Presto` 服务并保证服务可用。
+
+### 1.2 服务验证
+
+```shell
+# 准备 presto-cli
+wget https://repo1.maven.org/maven2/com/facebook/presto/presto-cli/0.234/presto-cli-0.234-executable.jar
+mv presto-cli-0.234-executable.jar presto-cli
+chmod +x presto-cli
+
+# 执行任务
+./presto-cli --server localhost:8082 --execute 'show tables from system.jdbc'
+
+# 得到如下输出代表服务可用
+"attributes"
+"catalogs"
+"columns"
+"procedure_columns"
+"procedures"
+"pseudo_columns"
+"schemas"
+"super_tables"
+"super_types"
+"table_types"
+"tables"
+"types"
+"udts"
+```
+
+## 2. 引擎插件部署
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/presto/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/presto/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── presto
+│ ├── dist
+│ │ └── 0.234
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 0.234
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+ sh ./bin/linkis-cli -engineType presto-0.234 \
+ -codeType psql -code 'show tables;' \
+ -submitUser hadoop -proxyUser hadoop
+```
+
+如果管理台,任务接口,配置文件,均未配置(配置方式见 4.2 )时可在 `Linkis-cli` 客户端中通过 `-runtimeMap` 属性进行配置
+
+```shell
+sh ./bin/linkis-cli -engineType presto-0.234 \
+-codeType tsql -code 'show tables;' \
+-runtimeMap wds.linkis.presto.url=http://127.0.0.1:8080 \
+-runtimeMap wds.linkis.presto.catalog=hive \
+-runtimeMap wds.linkis.presto.schema=default \
+-submitUser hadoop -proxyUser hadoop
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 | 说明 | 是否必须 |
+| -------------------------------------- | --------------------- | ------------------------------------------- | -------- |
+| wds.linkis.presto.url | http://127.0.0.1:8080 | Presto 集群连接 | true |
+| wds.linkis.presto.username | default | Presto 集群用户名 | false |
+| wds.linkis.presto.password | 无 | Presto 集群密码 | false |
+| wds.linkis.presto.catalog | system | 查询的 Catalog | true |
+| wds.linkis.presto.schema | 无 | 查询的 Schema | true |
+| wds.linkis.presto.source | global | 查询使用的 source | false |
+| presto.session.query_max_total_memory | 8GB | 查询使用最大的内存 | false |
+| wds.linkis.presto.http.connectTimeout | 60 | Presto 客户端的 connect timeout(单位:秒) | false |
+| wds.linkis.presto.http.readTimeout | 60 | Presto 客户端的 read timeout(单位:秒) | false |
+| wds.linkis.engineconn.concurrent.limit | 100 | Presto 引擎最大并发数 | false |
+
+### 4.2 配置修改
+
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 管理台配置
+
+![](./images/presto-console.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE \
+-engineType presto-0.234 -codeType tsql \
+-code 'show tables;' \
+-submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "show teblas;", "runType": "psql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "wds.linkis.presto.url":"http://127.0.0.1:9090",
+ "wds.linkis.presto.catalog ":"hive",
+ "wds.linkis.presto.schema ":"default",
+ "wds.linkis.presto.source ":""
+ }
+ }
+ },
+ "source": {"scriptPath": "file:///mnt/bdp/hadoop/1.sql"},
+ "labels": {
+ "engineType": "presto-0.234",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+#### 4.2.3 文件配置
+通过修改目录 `install path/lib/linkis-engineconn-plugins/presto/dist/0.234/conf/` 中的 `linkis-engineconn.properties` 文件进行配置,如下图:
+
+![](./images/presto-file.png)
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:presto-0.234
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+
+```sql
+-- set variable
+SET @PRESTO_LABEL="presto-0.234";
+SET @PRESTO_ALL=CONCAT('*-*,',@PRESTO_LABEL);
+SET @PRESTO_IDE=CONCAT('*-IDE,',@PRESTO_LABEL);
+SET @PRESTO_NAME="presto";
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@PRESTO_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@PRESTO_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from `linkis_cg_manager_label` where `label_value` = @PRESTO_IDE;
+insert into `linkis_ps_configuration_category` (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('wds.linkis.presto.url', 'Presto 集群连接', 'presto连接地址', 'http://127.0.0.1:8080', 'None', NULL, @PRESTO_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('wds.linkis.presto.catalog', '查询的 Catalog ', 'presto连接的catalog', 'hive', 'None', NULL, @PRESTO_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('wds.linkis.presto.schema', '查询的 Schema ', '数据库连接schema', '', 'None', NULL, @PRESTO_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('wds.linkis.presto.source', '查询使用的 source ', '数据库连接source', '', 'None', NULL, @PRESTO_NAME, 0, 0, 1, '数据源配置');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = @PRESTO_NAME and label_value = @PRESTO_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @PRESTO_ALL);
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/python.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/python.md
new file mode 100644
index 00000000000..86e4a9847e2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/python.md
@@ -0,0 +1,182 @@
+---
+title: Python
+sidebar_position: 3
+---
+
+本文主要介绍在 `Linkis` 中, `Python` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 环境安装
+
+如果您希望在您的服务器上使用 `Python` 引擎,您需要保证用户的 `PATH` 中是有 `Python` 的执行目录和执行权限。
+
+### 1.2 环境验证
+```
+python --version
+```
+正常输出 `Python` 版本信息代表 `Python` 环境可用
+```
+Python 3.6.0
+```
+
+## 2. 引擎插件安装 [默认引擎](./overview.md)
+
+`Linkis` 发布的二进制安装包中默认包含了 `Python` 引擎插件,用户无需额外安装。
+
+[EngineConnPlugin引擎插件安装](../deployment/install-engineconn.md)
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType python-python2 \
+-codeType python -code "print(\"hello\")" \
+-submitUser hadoop -proxyUser hadoop
+```
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过 `Linkis SDK` 提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。 具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。对于 `Python` 任务您只需要修改 `EngineConnType` 和 `CodeType` 参数即可。
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "python-python2"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "python"); // required codeType
+```
+
+## 4. 引擎配置说明
+
+### 4.1 配置修改
+`Python` 引擎插件支持 `Python2` 和 `Python3` ,您可以简单更改配置就可以完成 `Python` 版本的切换,不需要重新编译 `Python` 的引擎版本。 `Python` 引擎支持多种配置修改方式,具体操作如下。
+
+#### 4.1.1 通过命令参数显示指定(仅当前命令生效)
+
+```shell
+#1:cli的方式提交任务进行版本切换,命令末端设置版本 python.version=python3 (python3:创建软连接时生成文件的名称,可自定义命名)
+sh ./bin/linkis-cli -engineType python-python2 \
+-codeType python -code "print(\"hello\")" \
+-submitUser hadoop -proxyUser hadoop \
+-confMap python.version=python3
+
+#2:cli的方式提交任务进行版本切换,命令设置加入版本路径 python.version=/usr/bin/python (/usr/bin/python:创建软连接时生成文件的路径)
+sh ./bin/linkis-cli -engineType python-python2 \
+-codeType python -code "print(\"hello\")" \
+-submitUser hadoop -proxyUser hadoop \
+-confMap python.version=/usr/bin/python
+
+```
+
+#### 4.1.2 管理台配置
+
+![](./images/python-config.png)
+
+注意: 修改IDE标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE -engineType \
+python-python2 -codeType python -code "print(\"hello\")" \
+-submitUser hadoop -proxyUser hadoop \
+-confMap python.version=python3
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "print(\"hello\")", "runType": "python"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "python.version":"python2",
+ "wds.linkis.engineconn.max.free.time":"1h"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "python-python2",
+ "userCreator": "IDE"
+ }
+}
+```
+
+#### 4.2.3 文件配置
+通过修改目录 `${LINKIS_HOME}/lib/linkis-engineconn-plugins/python/dist/python2/conf/` 中的 `linkis-engineconn.properties` 文件进行配置,如下图:
+
+![](./images/python-conf.png)
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:python-python2
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+```sql
+-- set variable
+SET @PYTHON_LABEL="python-python2";
+SET @PYTHON_ALL=CONCAT('*-*,',@PYTHON_LABEL);
+SET @PYTHON_IDE=CONCAT('*-IDE,',@PYTHON_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @PYTHON_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @PYTHON_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @PYTHON_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.client.memory.max', '取值范围:1-100,单位:G', 'python驱动器内存使用上限', '20G', 'Regex', '^([1-9]\\d{0,1}|100)(G|g)$', '0', '0', '1', '队列资源', 'python');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.client.core.max', '取值范围:1-128,单位:个', 'python驱动器核心个数上限', '10', 'Regex', '^(?:[1-9]\\d?|[1234]\\d{2}|128)$', '0', '0', '1', '队列资源', 'python');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.instance', '范围:1-20,单位:个', 'python引擎最大并发数', '10', 'NumInterval', '[1,20]', '0', '0', '1', '队列资源', 'python');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.java.driver.memory', '取值范围:1-2,单位:G', 'python引擎初始化内存大小', '1g', 'Regex', '^([1-2])(G|g)$', '0', '0', '1', 'python引擎设置', 'python');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('python.version', '取值范围:python2,python3', 'python版本','python2', 'OFT', '[\"python3\",\"python2\"]', '0', '0', '1', 'python引擎设置', 'python');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.max.free.time', '取值范围:3m,15m,30m,1h,2h', '引擎空闲退出时间','1h', 'OFT', '[\"1h\",\"2h\",\"30m\",\"15m\",\"3m\"]', '0', '0', '1', 'python引擎设置', 'python');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'python' and label_value = @PYTHON_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @PYTHON_ALL);
+```
+
+
+### 4.4 其他python样例代码
+
+```python
+import pandas as pd
+
+data = {'name': ['aaaaaa', 'bbbbbb', 'cccccc'], 'pay': [4000, 5000, 6000]}
+frame = pd.DataFrame(data)
+show.show(frame)
+
+
+print('new reuslt')
+
+from matplotlib import pyplot as plt
+
+x=[4,8,10]
+y=[12,16,6]
+x2=[6,9,11]
+y2=[6,15,7]
+plt.bar(x,y,color='r',align='center')
+plt.bar(x2,y2,color='g',align='center')
+plt.show()
+
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/repl.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/repl.md
new file mode 100644
index 00000000000..4e65f5cc363
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/repl.md
@@ -0,0 +1,124 @@
+---
+title: Repl
+sidebar_position: 16
+---
+
+# Repl 引擎使用文档
+
+本文主要介绍在 `Linkis` 中,`Repl` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+
+### 1.1 引擎验证
+
+强烈建议您在执行 `Repl` 任务之前,检查下执行用户的这些环境变量。具体方式是
+```
+sudo su - ${username}
+echo ${JAVA_HOME}
+```
+
+## 2. 引擎插件安装
+
+### 2.1 引擎插件准备[非默认引擎](./overview.md)
+
+单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/repl/
+mvn clean install
+
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/repl/target/out/
+```
+
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineplugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── repl
+│ ├── dist
+│ │ └── 1
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 1
+```
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+
+## 3. Repl引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交`java`任务
+
+单个方法
+```shell
+ sh bin/linkis-cli -engineType repl-1 -code \
+"import org.apache.commons.lang3.StringUtils;
+ public void sayHello() {
+ System.out.println(\"hello\");
+ System.out.println(StringUtils.isEmpty(\"hello\"));
+ }" \
+ -codeType repl -runtimeMap linkis.repl.type=java
+```
+
+多个方法
+```shell
+ sh bin/linkis-cli -engineType repl-1 -code \
+"import org.apache.commons.lang3.StringUtils;
+
+ public void sayHello() {
+ System.out.println(\"hello\");
+ System.out.println(StringUtils.isEmpty(\"hello\"));
+ }
+ public void sayHi() {
+ System.out.println(\"hi\");
+ System.out.println(StringUtils.isEmpty(\"hi\"));
+ }" \
+ -codeType repl -runtimeMap linkis.repl.type=java -runtimeMap linkis.repl.method.name=sayHi
+```
+
+### 3.2 通过 `Linkis-cli` 提交`scala`任务
+
+```shell
+ sh bin/linkis-cli -engineType repl-1 -code \
+"import org.apache.commons.io.FileUtils
+import java.io.File
+
+val x = 2 + 3;
+println(x);
+FileUtils.forceMkdir(new File(\"/tmp/linkis_repl_scala_test\"));" \
+ -codeType repl -runtimeMap linkis.repl.type=scala
+```
+
+更多 `Linkis-Cli` 命令参数参考: [`Linkis-Cli` 使用](../user-guide/linkiscli-manual.md)
+
+
+Repl引擎,支持的连接参数有:
+
+| 配置名称 | 备注及默认值信息 | 是否必须 |
+|-----------------|------------------------------|----------------------------------------|
+| linkis.repl.type | repl类型,支持java和scala,默认值:java | 非必须 |
+| linkis.repl.method.name | 执行的方法名称,默认值为空 | 非必须 |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/seatunnel.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/seatunnel.md
new file mode 100644
index 00000000000..e560c388ff3
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/seatunnel.md
@@ -0,0 +1,254 @@
+---
+title: Seatunnel
+sidebar_position: 13
+---
+
+本文主要介绍在 `Linkis` 中,`Seatunnel` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+
+### 1.1 引擎安装
+
+如果您希望在您的 `Linkis` 服务上使用 `Seatunnel` 引擎,您需要安装 `Seatunnel` 引擎。而且 `Seatunnel` 是依赖 `Spark` 或 `Flink` 环境,使用 `linkis-seatunnel` 引擎前,强烈建议本地跑通 `Seatunnel` 环境。
+
+`Seatunnel 2.1.2` 下载地址:https://dlcdn.apache.org/incubator/seatunnel/2.1.2/apache-seatunnel-incubating-2.1.2-bin.tar.gz
+
+| 环境变量名称 | 环境变量内容 | 是否需要 |
+|-----------------|----------------|----------------------------------------|
+| JAVA_HOME | JDK安装路径 | 需要 |
+| SEATUNNEL_HOME | Seatunnel安装路径 | 需要 |
+|SPARK_HOME| Spark安装路径 | Seatunnel执行基于Spark就需要 |
+|FLINK_HOME| Flink安装路径 | Seatunnel执行基于Flink就需要 |
+
+表1-1 环境配置清单
+
+| Linkis变量名称 | 变量内容 | 是否必须 |
+| --------------------------- | ---------------------------------------------------------- | ------------------------------------------------------------ |
+| wds.linkis.engine.seatunnel.plugin.home | Seatunnel安装路径 | 是 |
+
+### 1.2 引擎环境验证
+
+以执行 `Spark` 任务为例
+
+```shell
+cd $SEATUNNEL_HOME
+./bin/start-seatunnel-spark.sh --master local[4] --deploy-mode client --config ./config/spark.batch.conf.template
+```
+输出结果如下:
+
+![](./images/check-seatunnel.png)
+
+## 2. 引擎插件部署
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/seatunnel/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/seatunnel/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── seatunnel
+│ ├── dist
+│ │ └── 2.1.2
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 2.1.2
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+
+```shell
+sh ./bin/linkis-cli --mode once -code 'test' -engineType seatunnel-2.1.2 -codeType sspark -labelMap userCreator=hadoop-seatunnel -labelMap engineConnMode=once -jobContentMap code='env {
+ spark.app.name = "SeaTunnel"
+ spark.executor.instances = 2
+ spark.executor.cores = 1
+ spark.executor.memory = "1g"
+ }
+ source {
+ Fake {
+ result_table_name = "my_dataset"
+ }
+ }
+ transform {}
+ sink {Console {}}' -jobContentMap master=local[4] -jobContentMap deploy-mode=client -sourceMap jobName=OnceJobTest -submitUser hadoop -proxyUser hadoop
+```
+
+### 3.2 通过 OnceEngineConn 提交任务
+
+OnceEngineConn 通过 LinkisManagerClient 调用 LinkisManager 的 createEngineConn 接口,并将代码发送到创建的 Seatunnel 引擎,然后 Seatunnel 引擎开始执行。 Client 的使用也非常简单,首先创建一个新的 maven 项目,或者在项目中引入以下依赖项
+
+```xml
+
+ org.apache.linkis
+ linkis-computation-client
+ ${linkis.version}
+
+```
+
+**示例代码**
+```java
+package org.apache.linkis.computation.client;
+import org.apache.linkis.common.conf.Configuration;
+import org.apache.linkis.computation.client.once.simple.SubmittableSimpleOnceJob;
+import org.apache.linkis.computation.client.utils.LabelKeyUtils;
+public class SeatunnelOnceJobTest {
+ public static void main(String[] args) {
+ LinkisJobClient.config().setDefaultServerUrl("http://ip:9001");
+ String code =
+ "\n"
+ + "env {\n"
+ + " spark.app.name = \"SeaTunnel\"\n"
+ + " spark.executor.instances = 2\n"
+ + " spark.executor.cores = 1\n"
+ + " spark.executor.memory = \"1g\"\n"
+ + "}\n"
+ + "\n"
+ + "source {\n"
+ + " Fake {\n"
+ + " result_table_name = \"my_dataset\"\n"
+ + " }\n"
+ + "\n"
+ + "}\n"
+ + "\n"
+ + "transform {\n"
+ + "}\n"
+ + "\n"
+ + "sink {\n"
+ + " Console {}\n"
+ + "}";
+ SubmittableSimpleOnceJob onceJob =
+ LinkisJobClient.once()
+ .simple()
+ .builder()
+ .setCreateService("seatunnel-Test")
+ .setMaxSubmitTime(300000)
+ .addLabel(LabelKeyUtils.ENGINE_TYPE_LABEL_KEY(), "seatunnel-2.1.2")
+ .addLabel(LabelKeyUtils.USER_CREATOR_LABEL_KEY(), "hadoop-seatunnel")
+ .addLabel(LabelKeyUtils.ENGINE_CONN_MODE_LABEL_KEY(), "once")
+ .addStartupParam(Configuration.IS_TEST_MODE().key(), true)
+ .addExecuteUser("hadoop")
+ .addJobContent("runType", "sspark")
+ .addJobContent("code", code)
+ .addJobContent("master", "local[4]")
+ .addJobContent("deploy-mode", "client")
+ .addSource("jobName", "OnceJobTest")
+ .build();
+ onceJob.submit();
+ System.out.println(onceJob.getId());
+ onceJob.waitForCompleted();
+ System.out.println(onceJob.getStatus());
+ LinkisJobMetrics jobMetrics = onceJob.getJobMetrics();
+ System.out.println(jobMetrics.getMetrics());
+ }
+}
+```
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 | 说明 | 是否必须 |
+| -------------------------------------- | --------------------- | ------------------------------------------- | -------- |
+| wds.linkis.engine.seatunnel.plugin.home | /opt/linkis/seatunnel | Seatunnel安装路径 | true |
+### 4.2 配置修改
+
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 客户端配置参数
+
+```shell
+sh ./bin/linkis-cli --mode once -code 'test' \
+-engineType seatunnel-2.1.2 -codeType sspark \
+-labelMap userCreator=hadoop-seatunnel -labelMap engineConnMode=once \
+-jobContentMap code='env {
+ spark.app.name = "SeaTunnel"
+ spark.executor.instances = 2
+ spark.executor.cores = 1
+ spark.executor.memory = "1g"
+ }
+ source {
+ Fake {
+ result_table_name = "my_dataset"
+ }
+ }
+ transform {}
+ sink {Console {}}' -jobContentMap master=local[4] \
+ -jobContentMap deploy-mode=client \
+ -sourceMap jobName=OnceJobTest \
+ -runtimeMap wds.linkis.engine.seatunnel.plugin.home=/opt/linkis/seatunnel \
+ -submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": 'env {
+ spark.app.name = "SeaTunnel"
+ spark.executor.instances = 2
+ spark.executor.cores = 1
+ spark.executor.memory = "1g"
+ }
+ source {
+ Fake {
+ result_table_name = "my_dataset"
+ }
+ }
+ transform {}
+ sink {Console {}}',
+ "runType": "sql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "wds.linkis.engine.seatunnel.plugin.home":"/opt/linkis/seatunnel"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "seatunnel-2.1.2",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/shell.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/shell.md
new file mode 100644
index 00000000000..650540bba52
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/shell.md
@@ -0,0 +1,55 @@
+---
+title: Shell
+sidebar_position: 4
+---
+
+本文主要介绍在 `Linkis` 中, `Shell` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+
+### 1.1 环境安装
+如果您希望在您的服务器上使用 `Shell` 引擎,您需要保证用户的 `PATH` 中是有 `bash` 的执行目录和执行权限。
+
+### 1.2 环境验证
+```
+echo $SHELL
+```
+输出如下信息代表shell环境可用
+```
+/bin/bash
+```
+或
+```
+/bin/sh
+```
+
+## 2. 引擎插件安装 [默认引擎](./overview.md)
+
+`Linkis` 发布的二进制安装包中默认包含了 `Shell` 引擎插件,用户无需额外安装。
+
+[EngineConnPlugin引擎插件安装](../deployment/install-engineconn.md)
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType shell-1 \
+-codeType shell -code "echo \"hello\" " \
+-submitUser hadoop -proxyUser hadoop
+```
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过Linkis SDK提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。 对于 `Shell` 任务您只需要修改 `Demo` 中的 `EngineConnType` 和 `CodeType` 参数即可:
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "shell-1"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "shell"); // required codeType
+```
+## 4. 引擎配置说明
+
+`Shell` 引擎一般可以设置引擎 `JVM` 的最大内存。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/spark.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/spark.md
new file mode 100644
index 00000000000..7d098976e95
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/spark.md
@@ -0,0 +1,425 @@
+---
+title: Spark
+sidebar_position: 1
+---
+
+本文主要介绍在 `Linkis` 中, `Spark` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 引擎安装
+
+如果您希望在您的服务器上使用 `Spark` 引擎,您需要保证以下的环境变量已经设置正确并且引擎的启动用户是有这些环境变量的。
+
+强烈建议您在执行 `Spark` 任务之前,检查下执行用户的这些环境变量。
+
+| 环境变量名 | 环境变量内容 | 备注 |
+|-----------------|----------------|----------------------------------------|
+| JAVA_HOME | JDK安装路径 | 必须 |
+| HADOOP_HOME | Hadoop安装路径 | 必须 |
+| HADOOP_CONF_DIR | Hadoop配置路径 | 必须 |
+| HIVE_CONF_DIR | Hive配置路径 | 必须 |
+| SPARK_HOME | Spark安装路径 | 必须 |
+| SPARK_CONF_DIR | Spark配置路径 | 必须 |
+| python | python | 建议使用anaconda的python作为默认python |
+
+### 1.2 环境验证
+通过 `pyspark` 验证 `Spark` 是否安装成功
+```
+pyspark
+
+#进入pyspark虚拟环境后,出现spark的logo则说明环境安装成功
+Welcome to
+ ____ __
+ / __/__ ___ _____/ /__
+ _\ \/ _ \/ _ `/ __/ '_/
+ /__ / .__/\_,_/_/ /_/\_\ version 3.2.1
+ /_/
+
+Using Python version 2.7.13 (default, Sep 30 2017 18:12:43)
+SparkSession available as 'spark'.
+```
+
+## 2. 引擎插件安装 [默认引擎](./overview.md)
+
+`Linkis` 发布的二进制安装包中默认包含了 `Spark` 引擎插件,用户无需额外安装。
+
+理论上 `Linkis` 支持的 `Spark2.x` 以上的所有版本。默认支持的版本为 `Spark3.2.1` 。如果您想使用其他的 `Spark` 版本,如 `Spark2.1.0` ,则您仅仅需要将插件 `Spark` 的版本进行修改,然后进行编译即可。具体的,您可以找到 `linkis-engineplugin-spark` 模块,将 `maven` 依赖中 `` 标签的值改成 2.1.0 ,然后单独编译此模块即可。
+
+[EngineConnPlugin引擎插件安装](../deployment/install-engineconn.md)
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+# codeType对应关系 py-->pyspark sql-->sparkSQL scala-->Spark scala
+sh ./bin/linkis-cli -engineType spark-3.2.1 -codeType sql -code "show databases" -submitUser hadoop -proxyUser hadoop
+
+# 可以在提交参数通过-confMap wds.linkis.yarnqueue=dws 来指定yarn 队列
+sh ./bin/linkis-cli -engineType spark-3.2.1 -codeType sql -confMap wds.linkis.yarnqueue=dws -code "show databases" -submitUser hadoop -proxyUser hadoop
+```
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过 `Linkis SDK` 提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。对于 `Spark` 任务你只需要修改 `Demo` 中的 `EngineConnType` 和 `CodeType` 参数即可:
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "spark-3.2.1"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "sql"); // required codeType py,sql,scala
+```
+
+Spark还支持提交Scala代码和Pyspark代码:
+````java
+
+//scala
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "scala");
+code:
+val df=spark.sql("show tables")
+show(df)
+//pyspark
+/labels.put(LabelKeyConstant.CODE_TYPE_KEY, "py");
+code:
+df=spark.sql("show tables")
+show(df)
+````
+
+### 3.3 通过提交jar包执行任务
+
+通过 `OnceEngineConn` 提交任务(通过 spark-submit 提交 jar 包执行任务),提交方式参考 `org.apache.linkis.computation.client.SparkOnceJobTest`
+
+```java
+public class SparkOnceJobTest {
+
+ public static void main(String[] args) {
+
+ LinkisJobClient.config().setDefaultServerUrl("http://127.0.0.1:9001");
+
+ String submitUser = "linkis";
+ String engineType = "spark";
+
+ SubmittableSimpleOnceJob onceJob =
+ // region
+ LinkisJobClient.once().simple().builder()
+ .setCreateService("Spark-Test")
+ .setMaxSubmitTime(300000)
+ .setDescription("SparkTestDescription")
+ .addExecuteUser(submitUser)
+ .addJobContent("runType", "jar")
+ .addJobContent("spark.app.main.class", "org.apache.spark.examples.JavaWordCount")
+ // 提交的jar包获取的参数
+ .addJobContent("spark.app.args", "hdfs:///tmp/test_word_count.txt") // WordCount 测试文件
+ .addLabel("engineType", engineType + "-2.4.7")
+ .addLabel("userCreator", submitUser + "-IDE")
+ .addLabel("engineConnMode", "once")
+ .addStartupParam("spark.app.name", "spark-submit-jar-test-linkis") // yarn上展示的 Application Name
+ .addStartupParam("spark.executor.memory", "1g")
+ .addStartupParam("spark.driver.memory", "1g")
+ .addStartupParam("spark.executor.cores", "1")
+ .addStartupParam("spark.executor.instance", "1")
+ .addStartupParam("spark.app.resource", "hdfs:///tmp/spark/spark-examples_2.11-2.3.0.2.6.5.0-292.jar")
+ .addSource("jobName", "OnceJobTest")
+ .build();
+ // endregion
+ onceJob.submit();
+ onceJob.waitForCompleted(); // 网络临时不通会导致异常,建议后期修改 SDK,现阶段使用,需要做异常处理
+ // 网络临时不通会导致异常,建议后期修改 SDK,现阶段使用,需要做异常处理
+ onceJob.waitForCompleted();
+ }
+}
+```
+
+### 3.4 通过 Restful API 提交任务
+
+运行脚本类型包括 `sql`、`scala`、`python`、`data_calc(格式为json)`。
+
+[任务提交执行Restful API文档](../api/linkis-task-operator.md)
+
+```http request
+POST /api/rest_j/v1/entrance/submit
+Content-Type: application/json
+Token-Code: dss-AUTH
+Token-User: linkis
+
+{
+ "executionContent": {
+ // 脚本内容,可以是sql,python,scala,json
+ "code": "show databases",
+ // 运行的脚本类型 sql, py(pyspark), scala, data_calc
+ "runType": "sql"
+ },
+ "params": {
+ "variable": {
+ },
+ "configuration": {
+ // spark 启动参数,非必填
+ "startup": {
+ "spark.executor.memory": "1g",
+ "spark.driver.memory": "1g",
+ "spark.executor.cores": "1",
+ "spark.executor.instances": 1
+ }
+ }
+ },
+ "source": {
+ // 非必填,file:/// 或者 hdfs:///
+ "scriptPath": "file:///tmp/hadoop/test.sql"
+ },
+ "labels": {
+ // 格式为:引擎类型-版本
+ "engineType": "spark-3.2.1",
+ // userCreator: linkis 为用户名。IDE 是系统名,在 Linkis 后台管理。
+ "userCreator": "linkis-IDE"
+ }
+}
+```
+
+### 3.5 通过 `Linkis-cli` 提交spark yarn cluster任务
+
+上传jar包和配置
+```shell
+# 上传linkis spark引擎的lib下的jar包 (根据您的实际安装目录修改以下参数)
+cd /appcom/Install/linkis/lib/linkis-engineconn-plugins/spark/dist/3.2.1/lib
+hdfs dfs -put *.jar hdfs:///spark/cluster
+
+# 上传linkis 配置文件 (根据您的实际安装目录修改以下参数)
+cd /appcom/Install/linkis/conf
+hdfs dfs -put * hdfs:///spark/cluster
+
+# 上传hive-site.xml (根据您的实际安装目录修改以下参数)
+cd $HIVE_CONF_DIR
+hdfs dfs -put hive-site.xml hdfs:///spark/cluster
+```
+可以通过`linkis.spark.yarn.cluster.jars`参数来修改`hdfs:///spark/cluster`
+
+执行测试用例
+```shell
+# 使用 `engingeConnRuntimeMode=yarnCluster` 来指定yarn cluster模式
+sh ./bin/linkis-cli -engineType spark-3.2.1 -codeType sql -labelMap engingeConnRuntimeMode=yarnCluster -submitUser hadoop -proxyUser hadoop -code "select 123"
+```
+
+### 3.6 通过 `Linkis-cli` 提交spark k8s cluster任务
+
+提交任务前,请在Kubernetes上安装metric server,在资源校验过程中会调用到相关的API。
+
+#### 3.6.1 拓展资源配置
+
+用户首先需要在Linkis控制台中配置拓展资源信息,在**Linkis控制台->基础数据管理->拓展资源管理**中新增Kubernetes集群配置,如下图所示。其中**资源类型**必须设置为`Kubernetes`,**名称**可自定义。
+
+![k8s](./images/k8s-config.png)
+
+**配置信息**中需要设置的参数如下表所示:
+
+| 配置 | 说明 |
+| ----------------- | ------------------------------------------------------------ |
+| k8sMasterUrl | API Server的完整URL,如`https://xxx.xxx.xxx.xxx:6443`,该参数必须配置 |
+| k8sConfig | kubeconfig文件的位置,如`/home/hadoop/.kube/config`,如果配置了该参数,则不需要配置以下三个参数 |
+| k8sCaCertData | kubeconfig中集群的CA证书,对应`certificate-authority-data`,如果不配置k8sConfig,则需要配置该参数 |
+| k8sClientCertData | kubeconfig中的客户端证书,对应`client-certificate-data`,如果不配置k8sConfig,则需要配置该参数 |
+| k8sClientKeyData | kubeconfig中的客户端私钥,对应`client-key-data`,如果不配置k8sConfig,则需要配置该参数 |
+
+#### 3.6.2 ECM标签配置
+
+配置完拓展资源后,需要在**ECM管理**中配置对应ECM的集群标签信息,如图所示,其中标签类型选择`yarnCluster`,标签值填写`K8S-集群名称`,这里的集群名称指的是上一步拓展资源配置中的名称,如名称配置为`default`,则此处标签值应设置为`K8S-default`。
+
+> 由于`ClusterLabel`的兼容性问题,暂未修改其Key值(yarnCluster)。
+
+![k8s-ecm-label](./images/k8s-ecm-label.png)
+
+#### 3.6.3 提交参数说明
+
+以linkis-cli为例,提交任务需要设置的参数:
+
+* 指定执行任务的集群,如配置集群时集群名称为`default`,则提交任务时需要指定`k8sCluster`参数的值为`'K8S-default'`;
+* 为区分operator提交任务方式,需要指定`spark.master`参数为`k8s-native`;
+* 目前k8s上的once job任务仅支持cluster运行模式,需要设置`spark.submit.deployMode`为`cluster`。
+
+其他Linkis参数和Spark参数的对照如下:
+
+| Linkis参数 | Spark参数 | 默认值 |
+| --------------------------------------- | ------------------------------------------------------- | ------------------- |
+| linkis.spark.k8s.master.url | --master | 空字符串 |
+| linkis.spark.k8s.serviceAccount | spark.kubernetes.authenticate.driver.serviceAccountName | 空字符串 |
+| linkis.spark.k8s.image | spark.kubernetes.container.image | apache/spark:v3.2.1 |
+| linkis.spark.k8s.imagePullPolicy | spark.kubernetes.container.image.pullPolicy | Always |
+| linkis.spark.k8s.namespace | spark.kubernetes.namespace | default |
+| linkis.spark.k8s.ui.port | spark.ui.port | 4040 |
+| linkis.spark.k8s.executor.request.cores | spark.kubernetes.executor.request.cores | 1 |
+| linkis.spark.k8s.driver.request.cores | spark.kubernetes.driver.request.cores | 1 |
+
+#### 3.6.4 提交命令示例
+
+提交jar任务
+
+```shell
+linkis-cli --mode once \
+-engineType spark-3.2.1 \
+-labelMap engineConnMode=once \
+-k8sCluster 'K8S-default' \
+-jobContentMap runType='jar' \
+-jobContentMap spark.app.main.class='org.apache.spark.examples.SparkPi' \
+-confMap spark.master='k8s-native' \
+-confMap spark.app.name='spark-submit-jar-k8s' \
+-confMap spark.app.resource='local:///opt/spark/examples/jars/spark-examples_2.12-3.2.1.jar' \
+-confMap spark.submit.deployMode='cluster' \
+-confMap linkis.spark.k8s.serviceAccount='spark' \
+-confMap linkis.spark.k8s.master.url='k8s://https://xxx.xxx.xxx.xxx:6443' \
+-confMap linkis.spark.k8s.config.file='/home/hadoop/.kube/config' \
+-confMap linkis.spark.k8s.imagePullPolicy='IfNotPresent' \
+-confMap linkis.spark.k8s.namespace='default'
+```
+
+提交py任务
+
+```shell
+linkis-cli --mode once \
+-engineType spark-3.2.1 \
+-labelMap engineConnMode=once \
+-k8sCluster 'K8S-default' \
+-jobContentMap runType='py' \
+-confMap spark.master='k8s-native' \
+-confMap spark.app.name='spark-submit-py-k8s' \
+-confMap spark.app.resource='local:///opt/spark/examples/src/main/python/pi.py' \
+-confMap spark.submit.deployMode='cluster' \
+-confMap spark.submit.pyFiles='local:///opt/spark/examples/src/main/python/wordcount.py' \
+-confMap linkis.spark.k8s.serviceAccount='spark' \
+-confMap linkis.spark.k8s.master.url='k8s://https://xxx.xxx.xxx.xxx:6443' \
+-confMap linkis.spark.k8s.config.file='/home/hadoop/.kube/config' \
+-confMap linkis.spark.k8s.imagePullPolicy='IfNotPresent' \
+-confMap linkis.spark.k8s.namespace='default' \
+-confMap linkis.spark.k8s.image="apache/spark-py:v3.2.1"
+```
+
+#### 3.6.5 补充说明
+
+**旧版本升级说明**
+
+* 需要使用`linkis-dist/package/db/upgrade/1.5.0_schema/mysql/linkis_ddl.sql`进行升级数据库字段,具体是将`linkis_cg_manager_label`的`label_key`字段长度从32增加到50。
+
+ ```sql
+ ALTER TABLE `linkis_cg_manager_label` MODIFY COLUMN label_key varchar(50);
+ ```
+
+* 1.5.0版本以前,构建CombineLabel时是不包括ClusterLabel的,为兼容旧版本,当提交的ClusterLabel值为Yarn-default时,构建CombineLabel时仍然不包含ClusterLabel,可通过设置`linkis.combined.without.yarn.default`为false来关闭该功能(默认为true)。
+
+ > 具体原因是,如果在旧版本有提交过跟该ClusterLabel相关的任务,在数据库会有对应的资源记录,当升级到新版本之后,由于CombineLabel包含了ClusterLabel,所以在提交该类型的任务时,数据库的资源记录会发生冲突,所以为兼容旧版本,对于Yarn-default(ClusterLabel默认值)的CombineLabel构建仍然不包含ClusterLabel。
+ > 如果是直接安装的最新版本,则不需要考虑这个问题,因为数据库里没有会发生冲突的记录,可以将`linkis.combined.without.yarn.default`设置为false以提升可读性。
+
+**提交任务的校验过程**
+
+提交Spark Once Job任务到K8S要经过两层资源校验,两层校验通过后任务才会真正提交到K8S集群:
+
+1. 首先会进行用户的资源配额校验,详细过程参考[**ResourceManager 架构**](architecture/feature/computation-governance-services/linkis-manager/resource-manager.md)。
+2. 其次会进行K8S集群的资源校验,如果当前namespace下配置了resourceQuota,则优先通过resourceQuota来进行校验,否则直接通过metric server计算集群的可用资源来进行校验。
+
+## 4.引擎配置说明
+
+### 4.1 默认配置说明
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| wds.linkis.rm.instance | 10 |否 | 引擎最大并发数 |
+| spark.executor.cores | 1 |否 | spark执行器核心个数 |
+| spark.driver.memory | 1g |否 | spark执行器实例最大并发数 |
+| spark.executor.memory | 1g |否 | spark执行器内存大小 |
+| wds.linkis.engineconn.max.free.time | 1h |否 | 引擎空闲退出时间 |
+| spark.python.version | python2 |否 | python版本 |
+
+### 4.2 队列资源配置
+因为 `Spark` 任务的执行需要队列的资源,须要设置自己能够执行的队列。
+
+![yarn](./images/yarn-conf.png)
+
+
+### 4.3 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.3.1 管理台配置
+用户可以进行自定义的设置,比如 `Spark` 会话 `executor` 个数和 `executor` 的内存。这些参数是为了用户能够更加自由地设置自己的 `spark` 的参数,另外 `Spark` 其他参数也可以进行修改,比如的 `pyspark` 的 `python` 版本等。
+![spark](./images/spark-conf.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE \
+-engineType spark-3.2.1 -codeType sql \
+-code "show databases" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.3.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "show databases;", "runType": "sql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "wds.linkis.rm.instance":"10"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "spark-3.2.1",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+### 4.4 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:spark-3.2.1
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+```sql
+-- set variable
+SET @SPARK_LABEL="spark-3.2.1";
+SET @SPARK_ALL=CONCAT('*-*,',@SPARK_LABEL);
+SET @SPARK_IDE=CONCAT('*-IDE,',@SPARK_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @SPARK_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @SPARK_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @SPARK_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.instance', '范围:1-20,单位:个', 'spark引擎最大并发数', '10', 'NumInterval', '[1,20]', '0', '0', '1', '队列资源', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.executor.instances', '取值范围:1-40,单位:个', 'spark执行器实例最大并发数', '1', 'NumInterval', '[1,40]', '0', '0', '2', 'spark资源设置', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.executor.cores', '取值范围:1-8,单位:个', 'spark执行器核心个数', '1', 'NumInterval', '[1,8]', '0', '0', '1','spark资源设置', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.executor.memory', '取值范围:1-15,单位:G', 'spark执行器内存大小', '1g', 'Regex', '^([1-9]|1[0-5])(G|g)$', '0', '0', '3', 'spark资源设置', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.driver.cores', '取值范围:只能取1,单位:个', 'spark驱动器核心个数', '1', 'NumInterval', '[1,1]', '0', '1', '1', 'spark资源设置','spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.driver.memory', '取值范围:1-15,单位:G', 'spark驱动器内存大小','1g', 'Regex', '^([1-9]|1[0-5])(G|g)$', '0', '0', '1', 'spark资源设置', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.max.free.time', '取值范围:3m,15m,30m,1h,2h', '引擎空闲退出时间','1h', 'OFT', '[\"1h\",\"2h\",\"30m\",\"15m\",\"3m\"]', '0', '0', '1', 'spark引擎设置', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.tispark.pd.addresses', NULL, NULL, 'pd0:2379', 'None', NULL, '0', '0', '1', 'tidb设置', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.tispark.tidb.addr', NULL, NULL, 'tidb', 'None', NULL, '0', '0', '1', 'tidb设置', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.tispark.tidb.password', NULL, NULL, NULL, 'None', NULL, '0', '0', '1', 'tidb设置', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.tispark.tidb.port', NULL, NULL, '4000', 'None', NULL, '0', '0', '1', 'tidb设置', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.tispark.tidb.user', NULL, NULL, 'root', 'None', NULL, '0', '0', '1', 'tidb设置', 'spark');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('spark.python.version', '取值范围:python2,python3', 'python版本','python2', 'OFT', '[\"python3\",\"python2\"]', '0', '0', '1', 'spark引擎设置', 'spark');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'spark' and label.label_value = @SPARK_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @SPARK_ALL);
+
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/sqoop.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/sqoop.md
new file mode 100644
index 00000000000..1e3b43ff66a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/sqoop.md
@@ -0,0 +1,473 @@
+---
+title: Sqoop
+sidebar_position: 8
+---
+
+本文主要介绍在 `Linkis` 中, `Sqoop` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 环境安装
+
+`Sqoop` 引擎主要依赖 `Hadoop` 基础环境,如果该节点需要部署 `Sqoop` 引擎,需要部署 `Hadoop` 客户端环境,以及[下载](https://archive.apache.org/dist/sqoop/)安装 `Sqoop` 客户端。
+
+### 1.2 环境验证
+在执行 `Sqoop` 任务之前,先在该节点使用原生的 `Sqoop` 执行测试任务,以检测该节点环境是否正常。
+```shell script
+#验证sqoop环境是否可用 参考示例:将hdfs的/user/hive/warehouse/hadoop/test_linkis_sqoop文件数据导入到mysql表 test_sqoop中
+
+sqoop export \
+--connect jdbc:mysql://127.0.0.1/test \
+--username test \
+--password test123\
+--table test_sqoop \
+--columns user_id,user_code,user_name,email,status \
+--export-dir /user/hive/warehouse/hadoop/test_linkis_sqoop \
+--update-mode allowinsert \
+--verbose ;
+```
+
+| 环境变量名 | 环境变量内容 | 备注 |
+|-----------------|----------------|----------------------------------------|
+| JAVA_HOME | JDK安装路径 | 必须 |
+| HADOOP_HOME | Hadoop安装路径 | 必须 |
+| HADOOP_CONF_DIR | Hadoop配置路径 | 必须 |
+| SQOOP_HOME | Sqoop安装路径 | 必须 |
+| SQOOP_CONF_DIR | Sqoop配置路径 | 非必须 |
+| HCAT_HOME | HCAT配置路径 | 非必须 |
+| HBASE_HOME | HBASE配置路径 | 非必须 |
+
+
+| Linkis系统参数 | 参数 | 备注 |
+| --------------------------- | ------------------------------- | ------------------------------------------------------------ |
+| wds.linkis.hadoop.site.xml | 设置sqoop加载hadoop参数文件位置 | 一般不需要单独配置,默认值"core-site.xml;hdfs-site.xml;yarn-site.xml;mapred-site.xml" |
+| sqoop.fetch.status.interval | 设置获取sqoop执行状态的间隔时间 | 一般不需要单独配置,默认值为5s |
+
+
+## 2. 引擎插件部署
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/sqoop/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/sqoop/target/out/
+```
+
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── sqoop
+│ ├── dist
+│ │ └── 1.4.6
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 1.4.6
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+#### 3.1.1 `hdfs` 文件导出到 `mysql`
+
+```shell
+sh linkis-cli-sqoop export \
+-D mapreduce.job.queuename=ide \
+--connect jdbc:mysql://127.0.0.1:9600/testdb \
+--username password@123 \
+--password password@123 \
+--table test_sqoop_01_copy \
+--columns user_id,user_code,user_name,email,status \
+--export-dir /user/hive/warehouse/hadoop/test_linkis_sqoop_2 \
+--update-mode allowinsert --verbose ;
+```
+
+#### 3.1.2 `mysql` 数据导入到 `hive` 库
+```shell script
+`mysql` 导入到 `hive` 库 `linkis_test_ind.test_import_sqoop_1` ,表 `test_import_sqoop_1` 不存在 需要添加参数 `--create-hive-table`
+
+sh linkis-cli-sqoop import -D mapreduce.job.queuename=dws \
+--connect jdbc:mysql://127.0.0.1:3306/casion_test \
+--username hadoop \
+--password password@123 \
+--table test_sqoop_01 \
+--columns user_id,user_code,user_name,email,status \
+--fields-terminated-by ',' \
+--hive-import --create-hive-table \
+--hive-database casionxia_ind \
+--hive-table test_import_sqoop_1 \
+--hive-drop-import-delims \
+--delete-target-dir \
+--input-null-non-string '\\N' \
+--input-null-string '\\N' \
+--verbose ;
+
+
+`mysql` 导入到 `hive` 库 `linkis_test_ind.test_import_sqoop_1` ,表 `test_import_sqoop_1` 存在 移除参数 `--create-hive-table `
+
+sh linkis-cli-sqoop import -D mapreduce.job.queuename=dws \
+--connect jdbc:mysql://127.0.0.1:9600/testdb \
+--username testdb \
+--password password@123 \
+--table test_sqoop_01 \
+--columns user_id,user_code,user_name,email,status \
+--fields-terminated-by ',' \
+--hive-import \
+--hive-database linkis_test_ind \
+--hive-table test_import_sqoop_1 \
+--hive-overwrite \
+--hive-drop-import-delims \
+--delete-target-dir \
+--input-null-non-string '\\N' \
+--input-null-string '\\N' \
+--verbose ;
+
+```
+
+### 3.2 通过 OnceEngineConn 提交任务
+
+`OnceEngineConn` 的使用方式是通过 `LinkisManagerClient` 调用 `LinkisManager` 的 `createEngineConn` 的接口,并将代码发给创建的 `Sqoop` 引擎,然后 `Sqoop` 引擎就开始执行,此方式可以被其他系统进行调用,比如 `Exchangis` 。 `Client` 的使用方式也很简单,首先新建一个 `maven` 项目,或者在您的项目中引入以下的依赖
+```xml
+
+ org.apache.linkis
+ linkis-computation-client
+ ${linkis.version}
+
+```
+**测试用例:**
+
+```java
+
+import java.util.concurrent.TimeUnit
+
+import java.util
+
+import org.apache.linkis.computation.client.LinkisJobBuilder
+import org.apache.linkis.computation.client.once.simple.{SimpleOnceJob, SimpleOnceJobBuilder, SubmittableSimpleOnceJob}
+import org.apache.linkis.computation.client.operator.impl.{EngineConnLogOperator, EngineConnMetricsOperator, EngineConnProgressOperator}
+import org.apache.linkis.computation.client.utils.LabelKeyUtils
+
+import scala.collection.JavaConverters._
+
+object SqoopOnceJobTest extends App {
+ LinkisJobBuilder.setDefaultServerUrl("http://127.0.0.1:9001")
+ val logPath = "C:\\Users\\resources\\log4j.properties"
+ System.setProperty("log4j.configurationFile", logPath)
+ val startUpMap = new util.HashMap[String, Any]
+ startUpMap.put("wds.linkis.engineconn.java.driver.memory", "1g")
+ val builder = SimpleOnceJob.builder().setCreateService("Linkis-Client")
+ .addLabel(LabelKeyUtils.ENGINE_TYPE_LABEL_KEY, "sqoop-1.4.6")
+ .addLabel(LabelKeyUtils.USER_CREATOR_LABEL_KEY, "Client")
+ .addLabel(LabelKeyUtils.ENGINE_CONN_MODE_LABEL_KEY, "once")
+ .setStartupParams(startUpMap)
+ .setMaxSubmitTime(30000)
+ .addExecuteUser("freeuser")
+ val onceJob = importJob(builder)
+ val time = System.currentTimeMillis()
+ onceJob.submit()
+
+ println(onceJob.getId)
+ val logOperator = onceJob.getOperator(EngineConnLogOperator.OPERATOR_NAME).asInstanceOf[EngineConnLogOperator]
+ println(onceJob.getECMServiceInstance)
+ logOperator.setFromLine(0)
+ logOperator.setECMServiceInstance(onceJob.getECMServiceInstance)
+ logOperator.setEngineConnType("sqoop")
+ logOperator.setIgnoreKeywords("[main],[SpringContextShutdownHook]")
+ var progressOperator = onceJob.getOperator(EngineConnProgressOperator.OPERATOR_NAME).asInstanceOf[EngineConnProgressOperator]
+ var metricOperator = onceJob.getOperator(EngineConnMetricsOperator.OPERATOR_NAME).asInstanceOf[EngineConnMetricsOperator]
+ var end = false
+ var rowBefore = 1
+ while (!end || rowBefore > 0){
+ if(onceJob.isCompleted) {
+ end = true
+ metricOperator = null
+ }
+ logOperator.setPageSize(100)
+ Utils.tryQuietly{
+ val logs = logOperator.apply()
+ logs.logs.asScala.foreach( log => {
+ println(log)
+ })
+ rowBefore = logs.logs.size
+ }
+ Thread.sleep(3000)
+ Option(metricOperator).foreach( operator => {
+ if (!onceJob.isCompleted){
+ println(s"Metric监控: ${operator.apply()}")
+ println(s"进度: ${progressOperator.apply()}")
+ }
+ })
+ }
+ onceJob.isCompleted
+ onceJob.waitForCompleted()
+ println(onceJob.getStatus)
+ println(TimeUnit.SECONDS.convert(System.currentTimeMillis() - time, TimeUnit.MILLISECONDS) + "s")
+ System.exit(0)
+
+
+ def importJob(jobBuilder: SimpleOnceJobBuilder): SubmittableSimpleOnceJob = {
+ jobBuilder
+ .addJobContent("sqoop.env.mapreduce.job.queuename", "queue_10")
+ .addJobContent("sqoop.mode", "import")
+ .addJobContent("sqoop.args.connect", "jdbc:mysql://127.0.0.1:3306/exchangis")
+ .addJobContent("sqoop.args.username", "free")
+ .addJobContent("sqoop.args.password", "testpwd")
+ .addJobContent("sqoop.args.query", "select id as order_number, sno as time from" +
+ " exchangis where sno =1 and $CONDITIONS")
+ .addJobContent("sqoop.args.hcatalog.database", "freedb")
+ .addJobContent("sqoop.args.hcatalog.table", "zy_test")
+ .addJobContent("sqoop.args.hcatalog.partition.keys", "month")
+ .addJobContent("sqoop.args.hcatalog.partition.values", "3")
+ .addJobContent("sqoop.args.num.mappers", "1")
+ .build()
+ }
+
+ def exportJob(jobBuilder: SimpleOnceJobBuilder): SubmittableSimpleOnceJob = {
+ jobBuilder
+ .addJobContent("sqoop.env.mapreduce.job.queuename", "queue1")
+ .addJobContent("sqoop.mode", "import")
+ .addJobContent("sqoop.args.connect", "jdbc:mysql://127.0.0.1:3306/exchangis")
+ .addJobContent("sqoop.args.query", "select id as order, sno as great_time from" +
+ " exchangis_table where sno =1 and $CONDITIONS")
+ .addJobContent("sqoop.args.hcatalog.database", "hadoop")
+ .addJobContent("sqoop.args.hcatalog.table", "partition_33")
+ .addJobContent("sqoop.args.hcatalog.partition.keys", "month")
+ .addJobContent("sqoop.args.hcatalog.partition.values", "4")
+ .addJobContent("sqoop.args.num.mappers", "1")
+ .build()
+ }
+```
+
+
+## 4 引擎配置说明
+### 4.1 默认配置说明
+
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| | sqoop.mode | import/export/… |
+| -Dmapreduce.job.queuename | sqoop.env.mapreduce.job.queuename | |
+| \--connect | sqoop.args.connect | Specify JDBC connect string |
+| \--connection-manager | sqoop.args.connection.manager | Specify connection manager class name |
+| \--connection-param-file | sqoop.args.connection.param.file | Specify connection parameters file |
+| \--driver | sqoop.args.driver | Manually specify JDBC driver class to use |
+| \--hadoop-home | sqoop.args.hadoop.home | Override $HADOOP\_MAPRED\_HOME\_ARG |
+| \--hadoop-mapred-home | sqoop.args.hadoop.mapred.home | Override $HADOOP\_MAPRED\_HOME\_ARG |
+| \--help | sqoop.args.help | Print usage instructions |
+| \-P | | Read password from console |
+| \--password | sqoop.args.password | Set authentication password |
+| \--password-alias | sqoop.args.password.alias | Credential provider password alias |
+| \--password-file | sqoop.args.password.file | Set authentication password file path |
+| \--relaxed-isolation | sqoop.args.relaxed.isolation | Use read-uncommitted isolation for imports |
+| \--skip-dist-cache | sqoop.args.skip.dist.cache | Skip copying jars to distributed cache |
+| \--username | sqoop.args.username | Set authentication username |
+| \--verbose | sqoop.args.verbose | Print more information while working |
+| | | |
+### 4.2 导入导出参数
+
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \--batch | sqoop.args.batch | Indicates underlying statements to be executed in batch mode |
+| \--call | sqoop.args.call | Populate the table using this stored procedure (one call per row) |
+| \--clear-staging-table | sqoop.args.clear.staging.table | Indicates that any data in staging table can be deleted |
+| \--columns | sqoop.args.columns | Columns to export to table |
+| \--direct | sqoop.args.direct | Use direct export fast path |
+| \--export-dir | sqoop.args.export.dir | HDFS source path for the export |
+| \-m,--num-mappers | sqoop.args.num.mappers | Use 'n' map tasks to export in parallel |
+| \--mapreduce-job-name | sqoop.args.mapreduce.job.name | Set name for generated mapreduce job |
+| \--staging-table | sqoop.args.staging.table | Intermediate staging table |
+| \--table | sqoop.args.table | Table to populate |
+| \--update-key | sqoop.args.update.key | Update records by specified key column |
+| \--update-mode | sqoop.args.update.mode | Specifies how updates are performed when new rows are found with non-matching keys in database |
+| \--validate | sqoop.args.validate | Validate the copy using the configured validator |
+| \--validation-failurehandler | sqoop.args.validation.failurehandler | Validate the copy using the configured validator |
+| \--validation-threshold | sqoop.args.validation.threshold | Fully qualified class name for ValidationThreshold |
+| \--validator | sqoop.args.validator | Fully qualified class name for the Validator |
+| | | |
+### 4.3 导入控制参数
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \--append | sqoop.args.append | Imports data in append mode |
+| \--as-avrodatafile | sqoop.args.as.avrodatafile | Imports data to Avro data files |
+| \--as-parquetfile | sqoop.args.as.parquetfile | Imports data to Parquet files |
+| \--as-sequencefile | sqoop.args.as.sequencefile | Imports data to SequenceFiles |
+| \--as-textfile | sqoop.args.as.textfile | Imports data as plain text (default) |
+| \--autoreset-to-one-mapper | sqoop.args.autoreset.to.one.mapper | Reset the number of mappers to one mapper if no split key available |
+| \--boundary-query | sqoop.args.boundary.query | Set boundary query for retrieving max and min value of the primary key |
+| \--case-insensitive | sqoop.args.case.insensitive | Data Base is case insensitive, split where condition transfrom to lower case! |
+| \--columns | sqoop.args.columns | Columns to import from table |
+| \--compression-codec | sqoop.args.compression.codec | Compression codec to use for import |
+| \--delete-target-dir | sqoop.args.delete.target.dir | Imports data in delete mode |
+| \--direct | sqoop.args.direct | Use direct import fast path |
+| \--direct-split-size | sqoop.args.direct.split.size | Split the input stream every 'n' bytes when importing in direct mode |
+| \-e,--query | sqoop.args.query | Import results of SQL 'statement' |
+| \--fetch-size | sqoop.args.fetch.size | Set number 'n' of rows to fetch from the database when more rows are needed |
+| \--inline-lob-limit | sqoop.args.inline.lob.limit | Set the maximum size for an inline LOB |
+| \-m,--num-mappers | sqoop.args.num.mappers | Use 'n' map tasks to import in parallel |
+| \--mapreduce-job-name | sqoop.args.mapreduce.job.name | Set name for generated mapreduce job |
+| \--merge-key | sqoop.args.merge.key | Key column to use to join results |
+| \--split-by | sqoop.args.split.by | Column of the table used to split work units |
+| \--table | sqoop.args.table | Table to read |
+| \--target-dir | sqoop.args.target.dir | HDFS plain table destination |
+| \--validate | sqoop.args.validate | Validate the copy using the configured validator |
+| \--validation-failurehandler | sqoop.args.validation.failurehandler | Fully qualified class name for ValidationFa ilureHandler |
+| \--validation-threshold | sqoop.args.validation.threshold | Fully qualified class name for ValidationTh reshold |
+| \--validator | sqoop.args.validator | Fully qualified class name for the Validator |
+| \--warehouse-dir | sqoop.args.warehouse.dir | HDFS parent for table destination |
+| \--where | sqoop.args.where | WHERE clause to use during import |
+| \-z,--compress | sqoop.args.compress | Enable compression |
+| | | |
+
+### 4.4 增量导入参数
+
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \--check-column | sqoop.args.check.column | Source column to check for incremental change |
+| \--incremental | sqoop.args.incremental | Define an incremental import of type 'append' or 'lastmodified' |
+| \--last-value | sqoop.args.last.value | Last imported value in the incremental check column |
+| | | |
+
+### 4.5 输出行格式化参数
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \--enclosed-by | sqoop.args.enclosed.by | Sets a required field enclosing character |
+| \--escaped-by | sqoop.args.escaped.by | Sets the escape character |
+| \--fields-terminated-by | sqoop.args.fields.terminated.by | Sets the field separator character |
+| \--lines-terminated-by | sqoop.args.lines.terminated.by | Sets the end-of-line character |
+| \--mysql-delimiters | sqoop.args.mysql.delimiters | Uses MySQL's default delimiter set: fields: , lines: \\n escaped-by: \\ optionally-enclosed-by: ' |
+| \--optionally-enclosed-by | sqoop.args.optionally.enclosed.by | Sets a field enclosing character |
+| | | |
+
+### 4.6 输入解析参数
+
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \--input-enclosed-by | sqoop.args.input.enclosed.by | Sets a required field encloser |
+| \--input-escaped-by | sqoop.args.input.escaped.by | Sets the input escape character |
+| \--input-fields-terminated-by | sqoop.args.input.fields.terminated.by | Sets the input field separator |
+| \--input-lines-terminated-by | sqoop.args.input.lines.terminated.by | Sets the input end-of-line char |
+| \--input-optionally-enclosed-by | sqoop.args.input.optionally.enclosed.by | Sets a field enclosing character |
+| | | |
+
+ ### 4.7 Hive 参数
+
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \--create-hive-table | sqoop.args.create.hive.table | Fail if the target hive table exists |
+| \--hive-database | sqoop.args.hive.database | Sets the database name to use when importing to hive |
+| \--hive-delims-replacement | sqoop.args.hive.delims.replacement | Replace Hive record \\0x01 and row delimiters (\\n\\r) from imported string fields with user-defined string |
+| \--hive-drop-import-delims | sqoop.args.hive.drop.import.delims | Drop Hive record \\0x01 and row delimiters (\\n\\r) from imported string fields |
+| \--hive-home | sqoop.args.hive.home | Override $HIVE\_HOME |
+| \--hive-import | sqoop.args.hive.import | Import tables into Hive (Uses Hive's default delimiters if none are set.) |
+| \--hive-overwrite | sqoop.args.hive.overwrite | Overwrite existing data in the Hive table |
+| \--hive-partition-key | sqoop.args.hive.partition.key | Sets the partition key to use when importing to hive |
+| \--hive-partition-value | sqoop.args.hive.partition.value | Sets the partition value to use when importing to hive |
+| \--hive-table | sqoop.args.hive.table | Sets the table name to use when importing to hive |
+| \--map-column-hive | sqoop.args.map.column.hive | Override mapping for specific column to hive types. |
+
+
+### 4.8 HBase 参数
+
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \--column-family | sqoop.args.column.family | Sets the target column family for the import |
+| \--hbase-bulkload | sqoop.args.hbase.bulkload | Enables HBase bulk loading |
+| \--hbase-create-table | sqoop.args.hbase.create.table | If specified, create missing HBase tables |
+| \--hbase-row-key | sqoop.args.hbase.row.key | Specifies which input column to use as the row key |
+| \--hbase-table | sqoop.args.hbase.table | Import to in HBase |
+| | | |
+
+### 4.9 HCatalog 参数
+
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \--hcatalog-database | sqoop.args.hcatalog.database | HCatalog database name |
+| \--hcatalog-home | sqoop.args.hcatalog.home | Override $HCAT\_HOME |
+| \--hcatalog-partition-keys | sqoop.args.hcatalog.partition.keys | Sets the partition keys to use when importing to hive |
+| \--hcatalog-partition-values | sqoop.args.hcatalog.partition.values | Sets the partition values to use when importing to hive |
+| \--hcatalog-table | sqoop.args.hcatalog.table | HCatalog table name |
+| \--hive-home | sqoop.args.hive.home | Override $HIVE\_HOME |
+| \--hive-partition-key | sqoop.args.hive.partition.key | Sets the partition key to use when importing to hive |
+| \--hive-partition-value | sqoop.args.hive.partition.value | Sets the partition value to use when importing to hive |
+| \--map-column-hive | sqoop.args.map.column.hive | Override mapping for specific column to hive types. |
+| | | |
+| HCatalog import specific options: | | |
+| \--create-hcatalog-table | sqoop.args.create.hcatalog.table | Create HCatalog before import |
+| \--hcatalog-storage-stanza | sqoop.args.hcatalog.storage.stanza | HCatalog storage stanza for table creation |
+| | |
+### 4.10 Accumulo 参数
+
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \--accumulo-batch-size | sqoop.args.accumulo.batch.size | Batch size in bytes |
+| \--accumulo-column-family | sqoop.args.accumulo.column.family | Sets the target column family for the import |
+| \--accumulo-create-table | sqoop.args.accumulo.create.table | If specified, create missing Accumulo tables |
+| \--accumulo-instance | sqoop.args.accumulo.instance | Accumulo instance name. |
+| \--accumulo-max-latency | sqoop.args.accumulo.max.latency | Max write latency in milliseconds |
+| \--accumulo-password | sqoop.args.accumulo.password | Accumulo password. |
+| \--accumulo-row-key | sqoop.args.accumulo.row.key | Specifies which input column to use as the row key |
+| \--accumulo-table | sqoop.args.accumulo.table | Import to in Accumulo |
+| \--accumulo-user | sqoop.args.accumulo.user | Accumulo user name. |
+| \--accumulo-visibility | sqoop.args.accumulo.visibility | Visibility token to be applied to all rows imported |
+| \--accumulo-zookeepers | sqoop.args.accumulo.zookeepers | Comma-separated list of zookeepers (host:port) |
+| | | |
+
+### 4.11 代码生成参数
+
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \--bindir | sqoop.args.bindir | Output directory for compiled objects |
+| \--class-name | sqoop.args.class.name | Sets the generated class name. This overrides --package-name. When combined with --jar-file, sets the input class. |
+| \--input-null-non-string | sqoop.args.input.null.non.string | Input null non-string representation |
+| \--input-null-string | sqoop.args.input.null.string | Input null string representation |
+| \--jar-file | sqoop.args.jar.file | Disable code generation; use specified jar |
+| \--map-column-java | sqoop.args.map.column.java | Override mapping for specific columns to java types |
+| \--null-non-string | sqoop.args.null.non.string | Null non-string representation |
+| \--null-string | sqoop.args.null.string | Null string representation |
+| \--outdir | sqoop.args.outdir | Output directory for generated code |
+| \--package-name | sqoop.args.package.name | Put auto-generated classes in this package |
+| | | |
+### 4.12 通用 Hadoop 命令行参数
+>must preceed any tool-specific arguments,Generic options supported are
+
+| 参数 | key | 说明 |
+| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | ------------------------------------------------------------------------------------------------------------------ |
+| \-conf | sqoop.args.conf | specify an application configuration file |
+| \-D | sqoop.args.D | use value for given property |
+| \-fs | sqoop.args.fs | specify a namenode |
+| \-jt | sqoop.args.jt | specify a ResourceManager |
+| \-files | sqoop.args.files | specify comma separated files to be copied to the map reduce cluster |
+| \-libjars | sqoop.args.libjars | specify comma separated jar files to include in the classpath. |
+| \-archives | sqoop.args.archives | specify comma separated archives to be unarchived on the compute machines. |
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/trino.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/trino.md
new file mode 100644
index 00000000000..0955c422f0f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/engine-usage/trino.md
@@ -0,0 +1,243 @@
+---
+title: Trino
+sidebar_position: 12
+---
+
+本文主要介绍在 `Linkis` 中,`Trino` 引擎插件的安装、使用和配置。
+
+
+## 1. 前置工作
+
+### 1.1 引擎安装
+
+如果您希望在您的 `Linkis` 服务上使用 `Trino` 引擎,您需要安装 `Trino` 服务并保证服务可用。
+
+### 1.2 服务验证
+
+```shell
+# 准备 trino-cli
+wget https://repo1.maven.org/maven2/io/trino/trino-cli/374/trino-cli-374-executable.jar
+mv trino-cli-374-executable.jar trino-cli
+chmod +x trino-cli
+
+# 执行任务
+./trino-cli --server localhost:8080 --execute 'show tables from system.jdbc'
+
+# 得到如下输出代表服务可用
+"attributes"
+"catalogs"
+"columns"
+"procedure_columns"
+"procedures"
+"pseudo_columns"
+"schemas"
+"super_tables"
+"super_types"
+"table_types"
+"tables"
+"types"
+"udts"
+```
+
+## 2. 引擎插件部署
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/trino/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/trino/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── trino
+│ ├── dist
+│ │ └── 371
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 371
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+ sh ./bin/linkis-cli -submitUser hadoop \
+ -engineType trino-371 -codeType sql \
+ -code 'select * from system.jdbc.schemas limit 10' \
+ -runtimeMap linkis.trino.url=http://127.0.0.1:8080
+```
+
+如果管理台,任务接口,配置文件,均未配置(配置方式见 4.2 )时可在 `Linkis-cli` 客户端中通过 `-runtimeMap` 属性进行配置
+
+```shell
+sh ./bin/linkis-cli -engineType trino-371 \
+-codeType sql -code 'select * from system.jdbc.schemas limit 10;' \
+-runtimeMap linkis.trino.urll=http://127.0.0.1:8080 \
+-runtimeMap linkis.trino.catalog=hive \
+-runtimeMap linkis.trino.schema=default \
+-submitUser hadoop -proxyUser hadoop
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 | 说明 | 是否必须 |
+| -------------------------------------- | --------------------- | ------------------------------------------- | -------- |
+| linkis.trino.url | http://127.0.0.1:8080 | Trino 集群连接 URL | true |
+| linkis.trino.default.limit | 5000 | 否 | 结果集条数限制 |
+| linkis.trino.http.connectTimeout | 60 | 否 | 连接超时时间(秒) |
+| linkis.trino.http.readTimeout | 60 | 否 | 传输超时时间(秒)|
+| linkis.trino.resultSet.cache.max | 512k | 否 | 结果集缓冲区 |
+| linkis.trino.user | null | 否 | 用户名 |
+| linkis.trino.password | null | 否 | 密码 |
+| linkis.trino.passwordCmd | null | 否 | 密码回调命令 |
+| linkis.trino.catalog | system | 否 | Catalog |
+| linkis.trino.schema | null | 否 | Schema |
+| linkis.trino.ssl.insecured | false | 否 | 验证SSL证书 |
+| linkis.engineconn.concurrent.limit | 100 | 否 | 引擎最大并发数 |
+| linkis.trino.ssl.key.store | null | 否 | keystore路径 |
+| linkis.trino.ssl.keystore.password | null | 否 | keystore密码 |
+| linkis.trino.ssl.keystore.type | null | 否 | keystore类型 |
+| linkis.trino.ssl.truststore | null | 否 | truststore |
+| linkis.trino.ss..truststore.type | null | 否 | trustore类型 |
+| linkis.trino.ssl.truststore.password | null | 否 | truststore密码 |
+
+### 4.2 配置修改
+
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 管理台配置
+
+![](./images/trino-config.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE -submitUser hadoop \
+ -engineType trino-371 -codeType sql \
+ -code 'select * from system.jdbc.schemas limit 10' \
+ -runtimeMap linkis.trino.url=http://127.0.0.1:8080
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "select * from system.jdbc.schemas limit 10;", "runType": "sql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "linkis.trino.url":"http://127.0.0.1:8080",
+ "linkis.trino.catalog ":"hive",
+ "linkis.trino.schema ":"default"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "trino-371",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:trino-375
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+
+```sql
+-- set variable
+SET @TRINO_LABEL="trino-371";
+SET @TRINO_IDE=CONCAT('*-IDE,',@TRINO_LABEL);
+SET @TRINO_ALL=CONCAT('*-*,',@TRINO_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @TRINO_IDE, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @TRINO_ALL, 'OPTIONAL', 2, now(), now());
+select @label_id := id from `linkis_cg_manager_label` where label_value = @TRINO_IDE;
+insert into `linkis_ps_configuration_category` (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.default.limit', '查询的结果集返回条数限制', '结果集条数限制', '5000', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.http.connectTimeout', '连接Trino服务器的超时时间', '连接超时时间(秒)', '60', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.http.readTimeout', '等待Trino服务器返回数据的超时时间', '传输超时时间(秒)', '60', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.resultSet.cache.max', 'Trino结果集缓冲区大小', '结果集缓冲区', '512k', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.url', 'Trino服务器URL', 'Trino服务器URL', 'http://127.0.0.1:9401', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.user', '用于连接Trino查询服务的用户名', '用户名', 'null', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.password', '用于连接Trino查询服务的密码', '密码', 'null', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.passwordCmd', '用于连接Trino查询服务的密码回调命令', '密码回调命令', 'null', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.catalog', '连接Trino查询时使用的catalog', 'Catalog', 'system', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.schema', '连接Trino查询服务的默认schema', 'Schema', '', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.ssl.insecured', '是否忽略服务器的SSL证书', '验证SSL证书', 'false', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.engineconn.concurrent.limit', '引擎最大并发', '引擎最大并发', '100', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.ssl.keystore', 'Trino服务器SSL keystore路径', 'keystore路径', 'null', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.ssl.keystore.type', 'Trino服务器SSL keystore类型', 'keystore类型', 'null', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.ssl.keystore.password', 'Trino服务器SSL keystore密码', 'keystore密码', 'null', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.ssl.truststore', 'Trino服务器SSL truststore路径', 'truststore路径', 'null', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.ssl.truststore.type', 'Trino服务器SSL truststore类型', 'truststore类型', 'null', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.trino.ssl.truststore.password', 'Trino服务器SSL truststore密码', 'truststore密码', 'null', 'None', '', 'trino', 0, 0, 1, '数据源配置');
+
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as config_key_id, label.id AS engine_type_label_id FROM `linkis_ps_configuration_config_key` config
+INNER JOIN `linkis_cg_manager_label` label ON config.engine_conn_type = 'trino' and label_value = @TRINO_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select relation.config_key_id AS config_key_id, '' AS config_value, relation.engine_type_label_id AS config_label_id FROM `linkis_ps_configuration_key_engine_relation` relation
+INNER JOIN `linkis_cg_manager_label` label ON relation.engine_type_label_id = label.id AND label.label_value = @TRINO_ALL);
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/_category_.json
new file mode 100644
index 00000000000..34f26d9777c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "快速体验",
+ "position": 2.0
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/deploy-to-kubernetes.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/deploy-to-kubernetes.md
new file mode 100644
index 00000000000..884b7e2067e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/deploy-to-kubernetes.md
@@ -0,0 +1,118 @@
+---
+title: 容器化部署
+sidebar_position: 2
+---
+
+这篇文章介绍一下如何在就 Kind 的 Kubernetes 的环境中部署 Linkis 服务,以方便更轻量化的学习使用和调试。
+
+## 1. 依赖版本
+- kind github:https://github.com/kubernetes-sigs/kind
+- kind官网:[kind.sigs.k8s.io/](https://kind.sigs.k8s.io/)
+
+### 1.1 版本:
+- kind 0.14.0
+- docker 20.10.17
+- centos 7.6
+- helm 3.x
+
+### 1.2 注意:
+- 1.确保组件依赖版本
+- 2.kind 是用 docker 容器模拟节点的,机器重启回来容器都变了,调度器就不工作了,这个是kind的limitation ,官方文档有详细说明。
+
+## 2.安装docker
+### 2.1 安装教程
+```
+sudo yum install -y yum-utils device-mapper-persistent-data lvm2
+sudo yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
+sudo sed -i 's+download.docker.com+mirrors.aliyun.com/docker-ce+' /etc/yum.repos.d/docker-ce.repo
+sudo yum makecache fast
+sudo yum -y install docker-ce
+systemctl start docker
+systemctl enable docker
+```
+
+### 2.2 设置国内镜像
+```
+vi /etc/docker/daemon.json
+{
+"registry-mirrors": ["http://hub-mirror.c.163.com"],
+"insecure-registries": ["https://registry.mydomain.com","http://hub-mirror.c.163.com"]
+}
+```
+
+## 3. 安装 kind
+### 3.1 手工下载kind二进制
+```
+https://github.com/kubernetes-sigs/kind/releases
+```
+### 3.2 安装kind二进制
+```
+chmod +x ./kind
+mv kind-linux-amd64 /usr/bin/kind
+```
+## 4. 安装linkis
+### 4.1 下载或自行编译 linkis1.3.1 部署包
+使用版本:dev-1.3.1 分支编译版本
+```
+apache-linkis-1.3.1-bin.tar.gz
+```
+### 4.2 创建目录
+```
+mkdir -p /opt/data/common/extendlib
+```
+### 4.3 拷贝驱动
+
+拷贝 mysql 驱动到 /opt/data/common/extendlib
+```
+curl https://repo1.maven.org/maven2/mysql/mysql-connector-java/8.0.28/mysql-connector-java-8.0.28.jar -o /opt/data/common/extendlib/[mysql-connector-java-8.0.28.jar](https://repo1.maven.org/maven2/mysql/mysql-connector-java/8.0.28/mysql-connector-java-8.0.28.jar)
+```
+### 4.4 重置kind(非必要)
+```
+./bin/install-linkis-to-kubernetes.sh reset
+```
+### 4.5 拉取镜像
+```
+./bin/install-linkis-to-kubernetes.sh pull -mghcr.dockerproxy.com
+```
+### 4.6 安装linkis到kind中
+```
+./bin/install-linkis-to-kubernetes.sh install -l -mghcr.dockerproxy.com
+```
+### 4.7 使用命令查看服务,等待全部启动成功
+```
+kubectl get pods -A
+```
+![](/Images/deployment/kubernetes/pods.jpg)
+
+
+### 4.8 拷贝 ldh 环境到 linkis
+```
+./helm/scripts/prepare-for-spark.sh
+```
+### 4.9 开启端口映射
+```
+./helm/scripts/remote-proxy.sh start
+```
+### 4.10 访问系统
+```
+linkis-web: http://10.0.2.101:8088/
+eureka: http://10.0.2.101:20303/
+```
+
+![](/Images/deployment/kubernetes/eureka.png)
+
+### 4.11 执行 linkis-cli 执行任务
+```
+进入容器
+./helm/scripts/login-pod.sh cg-engineconnmanager
+执行shell测试
+sh ./bin/linkis-cli -engineType shell-1 -codeType shell -code "echo "hello" " -submitUser hadoop -proxyUser hadoop
+执行hive测试
+sh ./bin/linkis-cli -engineType hive-2.3.3 -codeType hql -code "show tables" -submitUser hadoop -proxyUser hadoop
+执行spark测试
+sh ./bin/linkis-cli -engineType spark-2.4.3 -codeType sql -code "show tables" -submitUser hadoop -proxyUser hadoop
+执行python测试
+sh ./bin/linkis-cli -engineType python-python2 -codeType python -code "print(\"hello\")" -submitUser hadoop -proxyUser hadoop -confMap python.version=python
+```
+
+![](/Images/deployment/kubernetes/linkis.jpg)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/deploy-without-hdfs.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/deploy-without-hdfs.md
new file mode 100644
index 00000000000..45685806725
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/deploy-without-hdfs.md
@@ -0,0 +1,104 @@
+---
+title: 无 HDFS 部署
+sidebar_position: 3
+---
+
+这篇文章介绍一下如何在没有部署 HDFS 的环境中部署 Linkis 服务,以方便更轻量化的学习使用和调试。
+
+部署整体流程参考 "快速部署",需要修改如下少许内容。
+
+去HDFS模式部署不支持 hive/spark/flink 引擎等任务
+
+## 1. 配置修改
+修改 `linkis-env.sh` 文件,修改以下内容:
+```bash
+#使用[file://]路径模式代替[hdfs://]模式
+WORKSPACE_USER_ROOT_PATH=file:///tmp/linkis/
+HDFS_USER_ROOT_PATH=file:///tmp/linkis
+RESULT_SET_ROOT_PATH=file:///tmp/linkis
+
+export ENABLE_HDFS=false
+export ENABLE_HIVE=false
+export ENABLE_SPARK=false
+```
+
+将上述的配置修改为 false 之后,就不需要再单独配置 HDFS/HIVE/SPARK 等环境了, 安装部署时也会跳过这些基础环境的检查。
+
+## 2. 拷贝 jar 包
+因为 mysql-connector-java 驱动是 GPL2.0 协议,不满足Apache开源协议关于license的政策,所以需要我们手动将其拷贝到如下两个目录下
+```bash
+${LINKIS_HOME}/lib/linkis-commons/public-module/
+${LINKIS_HOME}/lib/linkis-spring-cloud-services/linkis-mg-gateway/
+```
+
+可以直接从 maven 仓库下载,比如 https://mvnrepository.com/artifact/mysql/mysql-connector-java/5.1.49
+
+## 3. 部署和启动
+参考 "快速部署" 部分,通过执行 ${LINKIS_HOME}/bin/install.sh 命令完成部署。
+参考 "快速部署" 部分,通过执行 ${LINKIS_HOME}/sbin/linkis-start-all.sh 命令启动 Linkis 服务。
+
+
+## 4. 运行作业验证
+目前 1.1.2 版本只支持 shell 作业在非 HDFS 环境中运行,执行命令如下
+
+```bash
+$ cd ./bin
+$ chmod +x linkis-cli
+$ ./linkis-cli -engineType shell-1 -codeType shell -code "echo \"hello\" " -submitUser -proxyUser
+```
+
+正常会输出如下类似内容
+```bash
+=====Java Start Command=====
+exec /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.312.b07-2.el8_5.x86_64/jre/bin/java -server -Xms32m -Xmx2048m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/Linkis/linkis03/logs/linkis-cli -XX:ErrorFile=/Linkis/linkis03/logs/linkis-cli/ps_err_pid%p.log -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFraction=80 -XX:+DisableExplicitGC -classpath /Linkis/linkis03/conf/linkis-cli:/Linkis/linkis03/lib/linkis-computation-governance/linkis-client/linkis-cli/*:/Linkis/linkis03/lib/linkis-commons/public-module/*: -Dconf.root=/Linkis/linkis03/conf/linkis-cli -Dconf.file=linkis-cli.properties -Dlog.path=/Linkis/linkis03/logs/linkis-cli -Dlog.file=linkis-client.root.log.20220418221952287912946 org.apache.linkis.cli.application.LinkisClientApplication '-engineType shell-1 -codeType shell -code echo "hello" -submitUser test -proxyUser test'
+[INFO] LogFile path: /Linkis/linkis03/logs/linkis-cli/linkis-client.root.log.20220418221952287912946
+[INFO] User does not provide usr-configuration file. Will use default config
+[INFO] connecting to linkis gateway:http://127.0.0.1:9001
+JobId:6
+TaskId:6
+ExecId:exec_id018028linkis-cg-entranceiZbp19q51jb8p984yk2jxdZ:9104LINKISCLI_test_shell_1
+[INFO] Job is successfully submitted!
+
+2022-04-18 22:19:53.019 INFO Program is substituting variables for you
+2022-04-18 22:19:53.019 INFO Variables substitution ended successfully
+2022-04-18 22:19:53.019 WARN The code you submit will not be limited by the limit
+Job with jobId : LINKISCLI_test_shell_1 and execID : LINKISCLI_test_shell_1 submitted
+2022-04-18 22:19:53.019 INFO You have submitted a new job, script code (after variable substitution) is
+************************************SCRIPT CODE************************************
+echo "hello"
+************************************SCRIPT CODE************************************
+2022-04-18 22:19:53.019 INFO Your job is accepted, jobID is LINKISCLI_test_shell_1 and jobReqId is 6 in ServiceInstance(linkis-cg-entrance, iZbp19q51jb8p984yk2jxdZ:9104). Please wait it to be scheduled
+job is scheduled.
+2022-04-18 22:19:53.019 INFO Your job is Scheduled. Please wait it to run.
+Your job is being scheduled by orchestrator.
+2022-04-18 22:19:53.019 INFO job is running.
+2022-04-18 22:19:53.019 INFO Your job is Running now. Please wait it to complete.
+2022-04-18 22:19:53.019 INFO Job with jobGroupId : 6 and subJobId : 5 was submitted to Orchestrator.
+2022-04-18 22:19:53.019 INFO Background is starting a new engine for you,execId astJob_4_codeExec_4 mark id is mark_4, it may take several seconds, please wait
+2022-04-18 22:20:01.020 INFO Task submit to ec: ServiceInstance(linkis-cg-engineconn, iZbp19q51jb8p984yk2jxdZ:43213) get engineConnExecId is: 1
+2022-04-18 22:20:01.020 INFO EngineConn local log path: ServiceInstance(linkis-cg-engineconn, iZbp19q51jb8p984yk2jxdZ:43213) /appcom1/tmp/test/20220418/shell/cc21fbb5-3a33-471b-a565-8407ff8ebd80/logs
+iZbp19q51jb8p984yk2jxdZ:43213_0 >> echo "hello"
+2022-04-18 22:20:01.438 WARN [Linkis-Default-Scheduler-Thread-1] org.apache.linkis.engineconn.computation.executor.hook.executor.ExecuteOnceHook 50 warn - execute once become effective, register lock listener
+hello
+2022-04-18 22:20:01.020 INFO Your subjob : 5 execue with state succeed, has 1 resultsets.
+2022-04-18 22:20:01.020 INFO Congratuaions! Your job : LINKISCLI_test_shell_1 executed with status succeed and 0 results.
+2022-04-18 22:20:01.020 INFO job is completed.
+2022-04-18 22:20:01.020 INFO Task creation time(任务创建时间): 2022-04-18 22:19:53, Task scheduling time(任务调度时间): 2022-04-18 22:19:53, Task start time(任务开始时间): 2022-04-18 22: Mission end time(任务结束时间): 2022-04-18 22:20:01
+2022-04-18 22:20:01.020 INFO Your mission(您的任务) 6 The total time spent is(总耗时时间为): 8.3 秒
+2022-04-18 22:20:01.020 INFO Congratulations. Your job completed with status Success.
+
+[INFO] Job execute successfully! Will try get execute result
+============Result:================
+TaskId:6
+ExecId: exec_id018028linkis-cg-entranceiZbp19q51jb8p984yk2jxdZ:9104LINKISCLI_test_shell_1
+User:test
+Current job status:SUCCEED
+extraMsg:
+result:
+
+[INFO] Retrieving result-set, may take time if result-set is large, please do not exit program.
+============ RESULT SET 1 ============
+hello
+############Execute Success!!!########
+
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/live-demo.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/live-demo.md
new file mode 100644
index 00000000000..2bcc6a2055c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/quick/live-demo.md
@@ -0,0 +1,281 @@
+---
+title: 沙箱在线体验
+sidebar_position: 1
+---
+
+## 1. 沙箱环境使用流程
+
+### 1.1 获取邀请码
+
+扫描以下二维码,添加“开源社区小助手”,根据小助手提示,提供相关信息获取邀请码。
+
+|微信小助手|微信公众号|
+|:---|---|
+| | |
+
+
+### 1.2 注册和登录使用
+
+通过1.1获取到邀请码后,即可进行注册和使用。
+
+第一步:打开注册页面链接 https://dss-open.wedatasphere.com/#/register,填写相关信息,成功注册
+
+![图片](/Images/quick/live-demo/640-16676643563412.jpeg)
+
+第二步:打开DSS沙箱页面 https://dss-open.wedatasphere.com/#/login,用注册的账号和密码进行登录;
+
+- 登录账号:注册的手机号;
+- 登录密码:手机号后六位数字;
+
+![图片](/Images/quick/live-demo/640-16676643776464.png)
+
+### 1.3 界面说明
+
+**重要说明:出于安全考虑,沙箱环境不支持`新增/修改`等操作,仅支持查询/查看的功能。**
+
+
+
+(1)成功登陆账户之后,会跳转到DSS的首页。首页顶部默认包括了管理台和Scriptis的入口,也可以添加其他组件入口到顶部导航栏。在首页进行切换工作空间,选中工作空间中的项目。目前已配置了**AIIDEMO**供大家体验,点击对应的项目即可。
+
+![图片](/Images/quick/live-demo/640-16676644060226.png)
+
+(2)管理台:Linkis计算治理管理台,在这个页面能够看到所有脚本执行的情况、对全局资源进行管理、对参数和变量配置进行配置、进行数据源和UDF管理,是个非常重要的页面;
+
+![图片](/Images/quick/live-demo/640-16676644199108.png)
+
+(3)Scriptis:支持在线写SQL、Pyspark、HiveQL等脚本,提交给Linkis执行的数据分析Web工具,且支持UDF、函数、资源管控和智能诊断等企业级特性。目前沙箱环境出于安全考虑,没有提供python、shell的demo。
+
+![图片](/Images/quick/live-demo/640-1667665078278140.png)
+
+
+
+### 1.4 导航栏配置
+
+为了更快捷的使用Qualitis、Scheduis、Visualis、Exchangis组件,可以把相对应的入口添加到顶部导航栏。操作方法:点击左上角入口,把对应的组件添加到导航栏。
+
+![图片](/Images/quick/live-demo/640-1667665075544138.png)
+
+
+## 2. 创建项目和工作流
+
+出于安全考虑,目前沙箱环境暂不支持创建项目和工作流的功能。各位开发者可以在自行搭建的环境中按照以下步骤进行使用。
+
+DSS支持使用工作流的方式,接下来跟着我一步一步来使用。
+
+(1)在工作空间“bdapWorkspace”中点击“创建项目”;
+
+![图片](/Images/quick/live-demo/640-1667665073311136.png)
+
+(2)在弹窗中填入项目的参数,如下图
+
+![图片](/Images/quick/live-demo/640-1667665070215134.jpeg)
+
+由于沙箱环境出于安全考虑,禁止创建工程,因此会提示以下错误。自行搭建DSS环境,可以按照上述方法进行创建工程。
+
+![图片](/Images/quick/live-demo/640-1667665067662132.png)
+
+
+
+(3)创建成功后在首页可以看到项目 BI_20220804;
+
+![图片](/Images/quick/live-demo/640-1667665065638130.png)
+
+
+
+(4)点击进入创建好的项目“BI_20220804 ”,点击添加工作流
+
+![图片](/Images/quick/live-demo/640-1667665062469128.png)
+
+
+
+(5)填写工作流信息
+
+![图片](/Images/quick/live-demo/640-1667665059998126.png)
+
+
+
+
+
+(6)进入项目工作流DEMO,我们可以看到完整的工作流界面了;
+
+![图片](/Images/quick/live-demo/640-1667665057158124.png)
+
+
+
+## 3. DEMO工作流组件说明
+
+目前支持7类工作流节点,使用这类节点可以完成数据同步、数据分析、数据质量管理、数据可视化等任务。
+
+我们直接进入AIIDEMO,点击执行,运行整个DEMO。
+
+![图片](/Images/quick/live-demo/640-1667665054421122.png)
+
+
+
+### 3.1 数据交换
+
+使用sqoop节点,让dss与目标数据库之间进行数据交换。
+
+(1)双击“Data Sync”数据交换节点;
+
+![图片](/Images/quick/live-demo/640-1667665051613120.png)
+
+
+
+(2)进入到节点编辑界面,可以看到节点的详情;从Hvie同步数据到MYSQL中;
+
+![图片](/Images/quick/live-demo/640-1667665048477118.png)
+
+
+
+(3)点击数据源Hive,在弹窗中看到数据源的配置详情,数据源为:“bdptest10_db.presure_testx”
+
+![图片](/Images/quick/live-demo/640-1667665045325116.png)
+
+
+
+(4)点击要同步到的数据库为:dss_meta_open.presure_testx
+
+![图片](/Images/quick/live-demo/640-1667665042221114.png)
+
+![图片](/Images/quick/live-demo/640-1667665040045112.png)
+
+
+
+(5)同步的字段为:objectid,intcolumn、doublecolumn、floatcolumn;
+
+![图片](/Images/quick/live-demo/640-1667665037278110.png)
+
+(6)我们也可以通过顶部导航栏“Exchangis”进入组件页面,可以查看到全部的数据交换节点和进行数据交换管理。
+
+![图片](/Images/quick/live-demo/640-1667665033853108.jpeg)
+
+
+
+### 3.2 数据开发
+
+支持sql、python、pyspark、shell等语言,用于数据开发。直接把节点拖出来,然后双击进入节点的界面进行撰写代码。
+
+(1)我们在DEMO双击“source_data”节点;
+
+![图片](/Images/quick/live-demo/640-1667665030566106.png)
+
+
+
+(2)进入编辑界面,撰写对应的脚本语言,进行执行,即可得到相关的执行结果;
+
+![图片](/Images/quick/live-demo/640-1667665027816104.png)
+
+
+
+### 3.3 数据质量
+
+使用qualitis进行数据质量校验。
+
+(1)点击数据质量节点“qualitis_200”
+
+![图片](/Images/quick/live-demo/640-1667665025253102.png)
+
+
+
+(2)进入数据校验界面,看到当前配置的校验规则;
+
+![图片](/Images/quick/live-demo/640-1667665021038100.png)
+
+
+
+(3)通过点击上图中的添加规则,选择不同的校验模板;
+
+![图片](/Images/quick/live-demo/640-166766501764598.png)
+
+
+
+(4)通过点击顶部导航菜单“Qualitis”直接进入数据质量的管理台。
+
+![图片](/Images/quick/live-demo/640-166766501543896.png)
+
+
+
+### 3.4 可视化
+
+使用visualis组件进行可视化BI分析。在沙箱环境中,有**DEMO**完整的例子可以进行参考。
+
+(1)选中项目,点击“执行”;等待全部执行成功;
+
+![图片](/Images/quick/live-demo/640-166766501239894.png)
+
+
+
+(2)点击对应的数据可视化节点,可以看到已经生成的数据图表。
+
+![图片](/Images/quick/live-demo/640-166766501000692.png)
+
+![图片](/Images/quick/live-demo/640-166766500771790.png)
+
+
+
+
+
+(3)可以通过点击顶部导航菜单“Visualis”直接进入可视化管理台,里面可以看到跟可视化相关的组件。
+
+![图片](/Images/quick/live-demo/640-166766500170288.png)
+
+(4)如果想进一步详细了解可视化能力,请查看视频教程《使用 DataSphere Studio(DSS)实现大数据可视化》:https://www.bilibili.com/video/BV1xY4y1t7Ma
+
+![图片](/Images/quick/live-demo/640-166766499746286.png)
+
+###
+
+### **3.5 信号节点**
+
+目前支持三种功能节点,分别为:datachecker、eventsender、eventreceiver。信号节点常用的场景:
+
+1. 在跑批量工作任务前需要检查数据是否齐全,可以使用datachecker;
+2. 完成某项工作后,需要通知其他工作流进行工作,使用eventsender进行发送通知;
+3. 使用eventreceiver监听信号,一旦接收到eventsender发过来的信号,就执行相对应的工作任务;
+
+![图片](/Images/quick/live-demo/640-166766499277484.png)
+
+
+
+### **3.6 功能节点**
+
+支持connector和subFlow节点。
+
+(1)connector节点仅作为工作流的连接节点,不承担任何功能。
+
+(2)subFlow是子工作流节点,可以理解为单独的工作流。在复杂的工作流场景中可以使用subFlow节点简化主工作流的流程。
+
+![图片](/Images/quick/live-demo/640-166766498331782.png)
+
+
+
+### **3.7 数据输出**
+
+支持通过邮件发送的方式
+
+![图片](/Images/quick/live-demo/640-166766497457380.png)
+
+###
+
+### **3.8 调度中心**
+
+(1)当我们在编辑模式中完成了工作流开发和测试后,可以点击“发布”按钮,直接发布到调度中心。
+
+![图片](/Images/quick/live-demo/640-166766496979878.png)
+
+
+
+(2)点击“前往调度中心”或者通过导航顶部的“Schedulis”都可以进入到调度中心管理台。在调度中心中可以进行调度管理,查看工作流状态。
+
+![图片](/Images/quick/live-demo/640-166766445336610.png)
+
+## **4. 常见错误**
+
+目前沙箱环境仅开放部分功能给社区开发者进行体验,通过使用沙箱环境能有助于开发者快速了解WDS生态。
+
+出于安全考虑,沙箱环境仅提供查看/查询/执行等功能,如出现“沙箱环境仅允许执行有限的查询操作”、“沙箱环境不许创建工程”、“后台接口异常,请联系开发处理”等等的错误提示,属于正常现象。
+
+如有任何疑问,请微信联系小助手进行反馈。
+
+![图片](/Images/quick/live-demo/640.jpeg)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/_category_.json
new file mode 100644
index 00000000000..2dfb099e3a7
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "调优排障",
+ "position": 9
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/configuration.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/configuration.md
new file mode 100644
index 00000000000..9aeaea665fb
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/configuration.md
@@ -0,0 +1,342 @@
+---
+title: 参数列表
+sidebar_position: 1
+---
+
+> 在conf目录提供了一个公共配置文件 linkis.properties,避免通用的配置参数需要同时在多个微服务里面配置。本文档将会把参数分模块列举出来。
+
+请注意:本文只给出了 Linkis 所有对运行性能有影响或是环境依赖相关的配置参数,很多无需用户关心的配置参数已略去,如果用户感兴趣,可以翻阅源码查看。
+
+## 1 通用配置
+
+通用配置可在全局的`linkis.properties`当中设置即可,一处设置,各个微服务都可生效。
+
+### 1.1 全局配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.encoding | utf-8 | Linkis默认编码格式 |
+| wds.linkis.date.pattern | yyyy-MM-dd'T'HH:mm:ssZ | 默认日期格式 |
+| wds.linkis.test.mode | false | 是否打开调试模式,如果设置为 true,所有微服务都支持免密登录,且所有EngineConn打开远程调试端口 |
+| wds.linkis.test.user | 无 | 当wds.linkis.test.mode=true时,免密登录的默认登录用户 |
+| wds.linkis.home | /appcom/Install/LinkisInstall | Linkis 安装目录,如果不存在,会自动获取 LINKIS_HOME的值 |
+| wds.linkis.httpclient.default.connect.timeOut | 50000 | Linkis HttpClient的默认连接超时时间 |
+
+### 1.2 LDAP配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.ldap.proxy.url | 无 | LDAP URL地址 |
+| wds.linkis.ldap.proxy.baseDN | 无 | LDAP baseDN地址 |
+| wds.linkis.ldap.proxy.userNameFormat | 无 | |
+
+### 1.3 Hadoop配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.hadoop.root.user | hadoop | HDFS super 用户 |
+| wds.linkis.filesystem.hdfs.root.path | 无 | 用户的HDFS默认根路径 |
+| wds.linkis.keytab.enable | false | 是否打开kerberos |
+| wds.linkis.keytab.file | /appcom/keytab | kerberos的keytab路径,仅wds.linkis.keytab.enable=true时生效 |
+| wds.linkis.keytab.host.enabled | false | |
+| wds.linkis.keytab.host | 127.0.0.1 | |
+| hadoop.config.dir | 无 | 如果不配置,将从环境变量 HADOOP_CONF_DIR读取 |
+| wds.linkis.hadoop.external.conf.dir.prefix | /appcom/config/external-conf/hadoop | hadoop额外配置 |
+
+### 1.4 Linkis RPC配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.rpc.broadcast.thread.num | 10 | Linkis RPC 广播线程数量(**建议采用默认值**) |
+| wds.linkis.ms.rpc.sync.timeout | 60000 | Linkis RPC Receiver端的默认处理超时时间 |
+| wds.linkis.rpc.eureka.client.refresh.interval | 1s | Eureka client的微服务列表刷新间隔(**建议采用默认值**) |
+| wds.linkis.rpc.eureka.client.refresh.wait.time.max | 1m | 刷新最大等待时间(**建议采用默认值**) |
+| wds.linkis.rpc.receiver.asyn.consumer.thread.max | 10 | Receiver Consumer最大线程数量(**如果在线用户多,建议适当调大该参数**) |
+| wds.linkis.rpc.receiver.asyn.consumer.freeTime.max | 2m | Receiver Consumer最大空闲时间 |
+| wds.linkis.rpc.receiver.asyn.queue.size.max | 1000 | Receiver 消费队列最大缓存数(**如果在线用户多,建议适当调大该参数**) |
+| wds.linkis.rpc.sender.asyn.consumer.thread.max", 5 | Sender Consumer最大线程数量 |
+| wds.linkis.rpc.sender.asyn.consumer.freeTime.max | 2m | Sender Consumer最大空闲时间 |
+| wds.linkis.rpc.sender.asyn.queue.size.max | 300 | Sender 消费队列最大缓存数 |
+
+## 2. 计算治理配置
+
+### 2.1 Entrance配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.spark.engine.version | 2.4.3 | 当用户提交脚本没有指定版本时,采用的默认Spark版本 |
+| wds.linkis.hive.engine.version | 1.2.1 | 当用户提交脚本没有指定版本时,采用的默认Hive版本 |
+| wds.linkis.python.engine.version | python2 | 当用户提交脚本没有指定版本时,采用的默认Python版本 |
+| wds.linkis.jdbc.engine.version | 4 | 当用户提交脚本没有指定版本时,采用的默认JDBC版本 |
+| wds.linkis.shell.engine.version | 1 | 当用户提交脚本没有指定版本时,采用的默认Shell版本 |
+| wds.linkis.appconn.engine.version | v1 | 当用户提交脚本没有指定版本时,采用的默认AppConn版本|
+| wds.linkis.entrance.scheduler.maxParallelismUsers | 1000 | Entrance支持的最大并发用户数 |
+| wds.linkis.entrance.job.persist.wait.max | 5m | Entrance等待JobHistory持久化Job的最大时间 |
+| wds.linkis.entrance.config.log.path | 无 | 如果不配置,默认采用wds.linkis.filesystem.hdfs.root.path的值 |
+| wds.linkis.default.requestApplication.name | IDE | 不指定提交系统时的默认提交系统 |
+| wds.linkis.default.runType | sql | 不指定脚本类型时的默认脚本类型 |
+| wds.linkis.warn.log.exclude | org.apache,hive.ql,hive.metastore,com.netflix,org.apache | 默认不向Client端输出的实时WARN级别日志 |
+| wds.linkis.log.exclude | org.apache,hive.ql,hive.metastore,com.netflix,org.apache,com.webank | 默认不向Client端输出的实时INFO级别日志 |
+| wds.linkis.instance | 3 | 用户每个引擎的默认并发Job数 |
+| wds.linkis.max.ask.executor.time | 5m | 向LinkisManager申请可用EngineConn的最大时间 |
+| wds.linkis.hive.special.log.include | org.apache.hadoop.hive.ql.exec.Task | 向Client端推送Hive日志时,默认不过滤哪些日志 |
+| wds.linkis.spark.special.log.include | org.apache.linkis.engine.spark.utils.JobProgressUtil | 向Client端推送Spark日志时,默认不过滤哪些日志 |
+| wds.linkis.entrance.shell.danger.check.enabled | false | 是否检查并拦截Shell危险语法 |
+| wds.linkis.shell.danger.usage | rm,sh,find,kill,python,for,source,hdfs,hadoop,spark-sql,spark-submit,pyspark,spark-shell,hive,yarn | Shell默认的危险语法 |
+| wds.linkis.shell.white.usage | cd,ls | Shell白名单语法 |
+| wds.linkis.sql.default.limit | 5000 | SQL默认的最大返回结果集行数 |
+
+
+### 2.2 EngineConn配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.engineconn.resultSet.default.store.path | hdfs:///tmp | Job结果集默认存储路径 |
+| wds.linkis.engine.resultSet.cache.max | 0k | 当结果集大小低于多少时,EngineConn端不落盘直接返回给Entrance |
+| wds.linkis.engine.default.limit | 5000 | |
+| wds.linkis.engine.lock.expire.time | 120000 | 引擎锁的最大空闲时间,即Entrance申请到锁后,多久不向EngineConn提交代码则被释放 |
+| wds.linkis.engineconn.ignore.words | org.apache.spark.deploy.yarn.Client | Engine向Entrance端推送日志时,默认忽略的日志 |
+| wds.linkis.engineconn.pass.words | org.apache.hadoop.hive.ql.exec.Task | Engine向Entrance端推送日志时,默认必须推送的日志 |
+| wds.linkis.engineconn.heartbeat.time | 3m | EngineConn向LinkisManager的默认心跳间隔 |
+| wds.linkis.engineconn.max.free.time | 1h | EngineConn的最大空闲时间 |
+
+
+### 2.3 EngineConnManager配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.ecm.memory.max | 80g | ECM的最大可启动EngineConn的内存 |
+| wds.linkis.ecm.cores.max | 50 | ECM的最大可启动EngineConn的CPU个数 |
+| wds.linkis.ecm.engineconn.instances.max | 50 | 最大可启动EngineConn个数,一般建议设置与wds.linkis.ecm.cores.max相同 |
+| wds.linkis.ecm.protected.memory | 4g | ECM的保护内存,即ECM用于启动EngineConn的内存不能超过 wds.linkis.ecm.memory.max - wds.linkis.ecm.protected.memory |
+| wds.linkis.ecm.protected.cores.max | 2 | ECM的保护CPU个数,意义与wds.linkis.ecm.protected.memory相同 |
+| wds.linkis.ecm.protected.engine.instances | 2 | ECM的保护实例数 |
+| wds.linkis.engineconn.wait.callback.pid | 3s | 等待EngineConn回传pid的等待时间 |
+
+### 2.4 LinkisManager配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.manager.am.engine.start.max.time" | 10m | LinkisManager启动一个新EngineConn的最大启动时间 |
+| wds.linkis.manager.am.engine.reuse.max.time | 5m | LinkisManager复用一个已有的EngineConn的最大选择时间 |
+| wds.linkis.manager.am.engine.reuse.count.limit | 10 | LinkisManager复用一个已有的EngineConn的最大轮询次数 |
+| wds.linkis.multi.user.engine.types | jdbc,es,presto | LinkisManager在复用一个已有的EngineConn时,哪些引擎的用户不作为复用规则使用 |
+| wds.linkis.rm.instance | 10 | 每个用户在每个引擎的默认最大实例数 |
+| wds.linkis.rm.yarnqueue.cores.max | 150 | 每个用户在每个引擎的使用队列最大核数 |
+| wds.linkis.rm.yarnqueue.memory.max | 450g | 每个用户在每个引擎的使用队列的最大内存数 |
+| wds.linkis.rm.yarnqueue.instance.max | 30 | 每个用户在每个引擎的队列中最多启动的应用数 |
+
+
+## 3. 各引擎配置
+
+### 3.1 JDBC引擎配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.jdbc.default.limit | 5000 | 默认的最大返回结果集行数 |
+| wds.linkis.jdbc.support.dbs | mysql=>com.mysql.jdbc.Driver,postgresql=>org.postgresql.Driver,oracle=>oracle.jdbc.driver.OracleDriver,hive2=>org.apache.hive.jdbc.HiveDriver,presto=>com.facebook.presto.jdbc.PrestoDriver | JDBC引擎支持的驱动 |
+| wds.linkis.engineconn.jdbc.concurrent.limit | 100 | 最大并行SQL执行数 |
+
+
+### 3.2 Python引擎配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| pythonVersion | /appcom/Install/anaconda3/bin/python | Python命令路径 |
+| python.path | 无 | 指定Python额外的path,该路径只接受共享存储的路径 |
+
+### 3.3 Spark引擎配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.engine.spark.language-repl.init.time | 30s | Scala和Python命令解释器的最大初始化时间 |
+| PYSPARK_DRIVER_PYTHON | python | Python命令路径 |
+| wds.linkis.server.spark-submit | spark-submit | spark-submit命令路径 |
+
+
+## 4. PublicEnhancements配置
+
+### 4.1 BML配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.bml.dws.version | v1 | Linkis Restful请求的版本号 |
+| wds.linkis.bml.auth.token.key | Validation-Code | BML请求的免密token-key |
+| wds.linkis.bml.auth.token.value | BML-AUTH | BML请求的免密token-value |
+| wds.linkis.bml.hdfs.prefix | /tmp/linkis | BML文件存储在hdfs上的前缀文件路径 |
+
+### 4.2 Metadata配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| hadoop.config.dir | /appcom/config/hadoop-config | 如果不存在,则默认采用环境变量HADOOP_CONF_DIR的值 |
+| hive.config.dir | /appcom/config/hive-config | 如果不存在,则默认采用环境变量HIVE_CONF_DIR的值 |
+| hive.meta.url | 无 | HiveMetaStore数据库的URL。如果没有配置hive.config.dir,则该值必须配置 |
+| hive.meta.user | 无 | HiveMetaStore数据库的user |
+| hive.meta.password | 无 | HiveMetaStore数据库的password |
+
+
+### 4.3 JobHistory配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.jobhistory.admin | 无 | 默认的Admin账号,用于指定哪些用户可以查看所有人的执行历史 |
+
+
+### 4.4 FileSystem配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.filesystem.root.path | file:///tmp/linkis/ | 用户的Linux本地根目录 |
+| wds.linkis.filesystem.hdfs.root.path | hdfs:///tmp/ | 用户的HDFS根目录 |
+| wds.linkis.workspace.filesystem.hdfsuserrootpath.suffix | /linkis/ | 用户的HDFS根目录后的一级前缀,用户实际根目录为:${hdfs.root.path}\${user}\${hdfsuserrootpath.suffix} |
+| wds.linkis.workspace.resultset.download.is.limit | true | Client下载结果集时,是否限制下载条数 |
+| wds.linkis.workspace.resultset.download.maxsize.csv | 5000 | 当结果集下载为CSV文件时,限制的下载条数 |
+| wds.linkis.workspace.resultset.download.maxsize.excel | 5000 | 当结果集下载为Excel文件时,限制的下载条数 |
+| wds.linkis.workspace.filesystem.get.timeout | 2000L | 请求底层文件系统的最大超时时间。(**如果您的HDFS或Linux机器性能较低,建议适当调大该查数**) |
+
+### 4.5 UDF配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.udf.share.path | /mnt/bdap/udf | 共享UDF的存储路径,建议设置为HDFS路径 |
+
+## 5. MicroService配置
+
+### 5.1 Gateway配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.gateway.conf.enable.proxy.user | false | 是否开启代理用户模式,如果开启,则登录用户的请求都会代理到代理用户去执行 |
+| wds.linkis.gateway.conf.proxy.user.config | proxy.properties | 代理规则的存储文件 |
+| wds.linkis.gateway.conf.proxy.user.scan.interval | 600000 | 代理文件的刷新间隔 |
+| wds.linkis.gateway.conf.enable.token.auth | false | 是否开启Token登录模式,如果开启,则允许以token的方式访问Linkis |
+| wds.linkis.gateway.conf.token.auth.config | token.properties | Token规则的存储文件 |
+| wds.linkis.gateway.conf.token.auth.scan.interval | 600000 | Token文件的刷新间隔 |
+| wds.linkis.gateway.conf.url.pass.auth | /dws/ | 默认放行、不作登录校验的请求 |
+| wds.linkis.gateway.conf.enable.sso | false | 是否开启SSO用户登录模式 |
+| wds.linkis.gateway.conf.sso.interceptor | 无 | 如果开启了SSO登录模式,则需要用户实现SSOInterceptor,用于跳转SSO登录页面 |
+| wds.linkis.admin.user | hadoop | 管理员用户列表 |
+| wds.linkis.login_encrypt.enable | false | 用户登录时,密码是否开启RSA加密传输 |
+| wds.linkis.enable.gateway.auth | false | 是否开启Gateway IP白名单机制 |
+| wds.linkis.gateway.auth.file | auth.txt | IP白名单存储文件 |
+
+## 6. 数据源及元数据服务配置
+
+### 6.1 元数据服务配置
+
+|引入版本| 参数名 | 默认值 | 描述 |
+|-------| -------------------------------------------------------- | ----------------------------------------------------- | ------------------------------------------------------- |
+|v1.1.0 | wds.linkis.server.mdm.service.lib.dir | /lib/linkis-public-enhancements/linkis-ps-metadatamanager/service | 设置需要加载数据源jar包的相对路径,会通过反射调用|
+|v1.1.0 | wds.linkis.server.mdm.service.instance.expire-in-seconds | 60 | 设置加载子服务的过期时间,超过该时间将不加载该服务 |
+|v1.1.0 | wds.linkis.server.dsm.app.name | linkis-ps-data-source-manager | 设置获取数据源信息的服务 |
+|v1.1.0 | wds.linkis.server.mdm.service.kerberos.principle | hadoop/HOST@EXAMPLE.COM | set kerberos principle for linkis-metadata hive service |
+|v1.1.0 | wds.linkis.server.mdm.service.user | hadoop | 设置hive服务的访问用户 |
+|v1.1.0 | wds.linkis.server.mdm.service.kerberos.krb5.path | "" | 设置hive服务使用的kerberos krb5 路径 |
+|v1.1.0 | wds.linkis.server.mdm.service.temp.location | classpath:/tmp | 设置kafka与hive的临时路径 |
+|v1.1.0 | wds.linkis.server.mdm.service.sql.driver | com.mysql.jdbc.Driver | 设置mysql服务的驱动 |
+|v1.1.0 | wds.linkis.server.mdm.service.sql.url | jdbc:mysql://%s:%s/%s | 设置mysql服务的url格式 |
+|v1.1.0 | wds.linkis.server.mdm.service.sql.connect.timeout | 3000 | 设置mysql服务连接mysql服务的连接超时时间 |
+|v1.1.0 | wds.linkis.server.mdm.service.sql.socket.timeout | 6000 | 设置mysql服务打开mysql服务的socket超时时间 |
+|v1.1.0 | wds.linkis.server.mdm.service.temp.location | /tmp/keytab | 设置服务的本地临时存储路径,主要是存储从bml物料服务下载的认证文件|
+
+
+## 7. 常用场景参数
+
+### 7.1 开启测试模式
+开发过程需要免密接口,可在`linkis.properties`替换或追加此配置
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.test.mode | false | 是否打开调试模式,如果设置为 true,所有微服务都支持免密登录,且所有EngineConn打开远程调试端口 |
+| wds.linkis.test.user | hadoop | 当wds.linkis.test.mode=true时,免密登录的默认登录用户 |
+
+
+### 7.2 登录用户设置
+Apache Linkis 默认使用配置文件来管理admin用户,可以在`linkis-mg-gateway.properties`替换或追加此配置。如需多用户可接入LDAP实现。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.admin.user | hadoop | 管理员用户名 |
+| wds.linkis.admin.password | 123456 | 管理员用户密码 |
+
+### 7.3 LDAP设置
+Apache Linkis 可以通过参数接入LDAP实现多用户管理,可以在`linkis-mg-gateway.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.ldap.proxy.url | 无 | LDAP URL地址 |
+| wds.linkis.ldap.proxy.baseDN | 无 | LDAP baseDN地址 |
+| wds.linkis.ldap.proxy.userNameFormat | 无 | |
+
+### 7.4 关闭资源检查
+Apache Linkis 提交任务时有时会调试异常,如:资源不足;可以在`linkis-cg-linkismanager.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.manager.rm.request.enable | true | 资源检查 |
+
+### 7.5 开启引擎调试
+Apache Linkis EC可以开启调试模式,可以在`linkis-cg-linkismanager.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.engineconn.debug.enable | false | 是否开启引擎调试 |
+
+### 7.6 Hive元数据配置
+Apache Linkis 的public-service服务需要读取hive的元数据;可以在`linkis-ps-publicservice.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| hive.meta.url | 无 | HiveMetaStore数据库的URL。 |
+| hive.meta.user | 无 | HiveMetaStore数据库的user |
+| hive.meta.password | 无 | HiveMetaStore数据库的password |
+
+### 7.7 Linkis 数据库配置
+Apache Linkis 访问默认使用Mysql作为数据存储,可以在`linkis.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.server.mybatis.datasource.url | 无 | 数据库连接字符串,例如:jdbc:mysql://127.0.0.1:3306/dss?characterEncoding=UTF-8 |
+| wds.linkis.server.mybatis.datasource.username | 无 | 数据库用户名,例如:root |
+| wds.linkis.server.mybatis.datasource.password | 无 | 数据库密码,例如:root |
+
+### 7.8 Linkis Session 缓存配置
+Apache Linkis 支持使用redis进行session的共享;可以在`linkis.properties`替换或追加此配置。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| linkis.session.redis.cache.enabled | None | 是否开启 |
+| linkis.session.redis.host | 127.0.0.1 | 主机名 |
+| linkis.session.redis.port | 6379 | 端口,例如 |
+| linkis.session.redis.password | None | 密码 |
+
+
+
+### 7.9 Linkis 模块开发配置
+Apache Linkis 开发时可通过此参数,自定义加载模块的数据库、Rest接口、实体对象;可以在`linkis-ps-publicservice.properties`进行修改,多个模块之间使用逗号分割。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.server.restful.scan.packages | 无 | restful 扫描包,例如:org.apache.linkis.basedatamanager.server.restful |
+| wds.linkis.server.mybatis.mapperLocations | 无 | mybatis mapper文件路径,例如: classpath*:org/apache/linkis/basedatamanager/server/dao/mapper/*.xml|
+| wds.linkis.server.mybatis.typeAliasesPackage | 无 | 实体别名扫描包,例如:org.apache.linkis.basedatamanager.server.domain |
+| wds.linkis.server.mybatis.BasePackage | 无 | 数据库dao层扫描,例如:org.apache.linkis.basedatamanager.server.dao |
+
+### 7.10 Linkis 模块开发配置
+Apache Linkis 开发时可通过此参数,自定义加载模块的路由;可以在`linkis.properties`进行修改,多个模块之间使用逗号分割。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.gateway.conf.publicservice.list | cs,contextservice,data-source-manager,metadataQuery,metadatamanager,query,jobhistory,application,configuration,filesystem,udf,variable,microservice,errorcode,bml,datasource,basedata-manager | publicservice服务支持路由的模块 |
+
+### 7.11 Linkis 文件系统及物料存放路径
+Apache Linkis 开发时可通过此参数,自定义加载模块的路由;可以在`linkis.properties`进行修改,多个模块之间使用逗号分割。
+
+| 参数名 | 默认值 | 描述 |
+| ------------------------- | ------- | -----------------------------------------------------------|
+| wds.linkis.filesystem.root.path | file:///tmp/linkis/ | 本地用户目录,需在该目录下建立以用户名为名称的文件夹 |
+| wds.linkis.filesystem.hdfs.root.path | hdfs:///tmp/ | HDFS用户目录 |
+| wds.linkis.bml.is.hdfs | true | 是否启用hdfs |
+| wds.linkis.bml.hdfs.prefix | /apps-data | hdfs路径 |
+| wds.linkis.bml.local.prefix | /apps-data | 本地路径 |
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/error-guide/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/error-guide/_category_.json
new file mode 100644
index 00000000000..fc5eaa61ac8
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/error-guide/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "错误码",
+ "position": 3
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/error-guide/error-code.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/error-guide/error-code.md
new file mode 100644
index 00000000000..10cabb322c9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/error-guide/error-code.md
@@ -0,0 +1,1447 @@
+---
+title: 常见错误码及处理方法
+sidebar_position: 1
+---
+
+#### 错误码 01001
+
+**现象**
+
+任务执行过程中报错:错误码 01001,错误信息 您的任务没有路由到后台ECM,请联系管理员
+>The em of labels
+
+**原因1**
+
+您的任务没有路由到后台ECM
+
+**解决1**
+1. 请检查租户标签是否正确
+2. 如果正确联系管理员
+---------------------------------
+#### 错误码 01002
+
+**现象**
+
+任务执行过程中报错:错误码 01002,错误信息 Linkis服务负载过高,请联系管理员扩容
+>Unexpected end of file from server
+
+**原因1**
+
+Linkis服务负载过高,导致服务连接异常
+
+**解决1**
+
+请联系管理员
+
+---------------------------------
+
+#### 错误码 01003
+
+**现象**
+
+任务执行过程中报错:错误码 01003,错误信息 Linkis服务负载过高,请联系管理员扩容
+>failed to ask linkis Manager Can be retried SocketTimeoutException
+
+**原因1**
+
+Linkis服务负载过高,导致服务连接超时
+
+**解决1**
+
+联系管理员
+
+---------------------------------
+
+#### 错误码 01004
+
+**现象**
+
+任务执行过程中报错:错误码 01004,错误信息 引擎在启动时被Kill,请联系管理员
+>[0-9]+ Killed
+
+**原因1**
+
+引擎在启动时被Kill,这个是因为机器负载过高导致
+
+**解决1**
+1. 您可以选择重试
+2. 或者联系管理员
+
+---------------------------------
+
+#### 错误码 01005
+
+**现象**
+
+任务执行过程中报错:错误码 01005,错误信息 请求Yarn获取队列信息重试2次仍失败,请联系管理员
+>Failed to request external resourceClassCastException
+
+**原因1**
+
+请求Yarn获取队列信息失败,这个是因为配置有问题导致
+
+**解决1**
+
+请联系管理员
+
+---------------------------------
+
+#### 错误码 01101
+
+**现象**
+
+任务执行过程中报错:错误码 01101,错误信息 ECM资源不足,请联系管理员扩容
+>ECM resources are insufficient
+
+**原因1**
+
+服务器资源不足导致,可能是高峰期导致
+
+**解决1**
+1. 可以进行任务重试
+2. 或者联系管理员
+---------------------------------
+
+#### 错误码 01102
+
+**现象**
+
+任务执行过程中报错:错误码 01102,错误信息 ECM 内存资源不足,请联系管理员扩容
+>ECM memory resources are insufficient
+
+**原因1**
+
+服务器内存资源不足
+
+**解决1**
+1. 可以进行任务重试
+2. 或者联系管理员
+---------------------------------
+
+#### 错误码 01103
+
+**现象**
+
+任务执行过程中报错:错误码 01103,错误信息 ECM CPU资源不足,请联系管理员扩容
+>ECM CPU resources are insufficient
+
+**原因1**
+
+服务器CPU资源不足
+
+**解决1**
+1. 可以进行任务重试
+2. 或者联系管理员
+---------------------------------
+
+#### 错误码 01104
+
+**现象**
+
+任务执行过程中报错:错误码 01104,错误信息 实例资源不足,请联系管理员扩容
+>ECM Insufficient number of instances
+
+**原因1**
+
+服务器实例资源不足
+
+**解决1**
+1. 可以进行任务重试
+2. 或者联系管理员
+---------------------------------
+
+#### 错误码 01105
+
+**现象**
+
+任务执行过程中报错:错误码 01105,错误信息 机器内存不足,请联系管理员扩容
+>Cannot allocate memory
+
+**原因1**
+
+服务器机器内存不足
+
+**解决1**
+
+1. 可以进行任务重试
+2. 或者联系管理员
+---------------------------------
+
+#### 错误码 12001
+
+**现象**
+
+任务执行过程中报错:错误码 12001,错误信息 队列CPU资源不足,可以调整Spark执行器个数
+>Queue CPU resources are insufficient
+
+**原因1**
+
+队列CPU资源不足,超过了您设置的限制值
+
+**解决1**
+
+- 打开DSS平台,点击管理台--参数配置--IDE--Spark--显示高级设置--woker引擎资源设置(2)--调整执行器并发数[spark.executor.instances]
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkSetting.png)
+
+- 或者在管理台--参数配置-全局设置调整队列资源使用上限值
+---------------------------------
+
+#### 错误码 12002
+
+**现象**
+
+任务执行过程中报错:错误码 12002,错误信息 队列内存资源不足,可以调整Spark执行器个数
+>Insufficient queue memory
+
+**原因1**
+
+队列内存资源不足,超过了您设置的队列内存资源值
+
+**解决1**
+- 打开DSS平台,点击管理台--参数配置--IDE--Spark--显示高级设置--woker引擎资源设置(2)--调整执行器并发数[spark.executor.instances]
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkSetting.png)
+
+- 或者在管理台--参数配置-全局设置调整队列资源使用上限值
+---------------------------------
+
+#### 错误码 12003
+
+**现象**
+
+任务执行过程中报错:错误码 12003,错误信息 队列实例数超过限制
+>Insufficient number of queue instances
+
+**原因1**
+
+队列实例数超过限制值
+
+**解决1**
+
+- 打开DSS平台,点击管理台--参数配置--全局设置--队列资源--yarn队列实例最大个数[wds.linkis.rm.yarnqueue.instance.max]
+- ![](/Images/tuning-and-troubleshooting/error-guide/queueInstanceMax.png)
+
+**备注**
+
+
+涉及全局设置不推荐用户随意修改,如需修改请与运维沟通后修改。非全局设置参数,用户可自行修改
+
+---------------------------------
+
+#### 错误码 12004
+
+**现象**
+
+任务执行过程中报错:错误码 12004,错误信息 全局驱动器内存使用上限,可以设置更低的驱动内存
+>Drive memory resources are insufficient
+
+**原因1**
+
+全局驱动器内存超过上限
+
+**解决1**
+- 打开DSS平台,点击管理台--参数配置--全局设置--队列资源--yarn队列实例最大个数[wds.linkis.rm.yarnqueue.instance.max]
+- ![](/Images/tuning-and-troubleshooting/error-guide/queueInstanceMax.png)
+
+**解决2**
+
+- 如果队列可用,应用实例数过低,可联系管理员设置
+
+**备注**
+
+
+涉及全局设置不推荐用户随意修改,如需修改请与运维沟通后修改。非全局设置参数,用户可自行修改
+
+---------------------------------
+
+#### 错误码 12005
+
+**现象**
+
+任务执行过程中报错:错误码 12005,错误信息 超出全局驱动器CPU个数上限,可以清理空闲引擎
+>Drive core resources are insufficient
+
+**原因1**
+
+全局驱动器CPU个数超过上限
+
+**解决1**
+
+- 打开DSS平台,点击管理台--参数配置--全局设置--队列资源--队列CPU使用上限[wds.linkis.rm.yarnqueue.cores.max]
+- ![](/Images/tuning-and-troubleshooting/error-guide/queueCodesMax.png)
+
+**解决2**
+
+- 清理空闲引擎
+
+**备注**
+
+
+涉及全局设置不推荐用户随意修改,如需修改请与运维沟通后修改。非全局设置参数,用户可自行修改
+
+---------------------------------
+
+#### 错误码 12006
+
+**现象**
+
+任务执行过程中报错:错误码 12006,错误信息 超出引擎最大并发数上限,可以清理空闲引擎
+>Insufficient number of instances
+
+**原因1**
+
+超出引擎最大并发数上限
+
+**解决1**
+
+- 修改配置,全局配置:打开DSS平台,点击管理台--参数配置--全局设置--队列资源--全局各个引擎最大并发数[wds.linkis.rm.instance]
+- ![](/Images/tuning-and-troubleshooting/error-guide/MaxInstance.png)
+- spark引擎
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkMaxInstance.png)
+- hive引擎
+- ![](/Images/tuning-and-troubleshooting/error-guide/hiveMaxInstance.png)
+- python引擎
+- ![](/Images/tuning-and-troubleshooting/error-guide/pythonMaxInstance.png)
+- pipeline引擎
+- ![](/Images/tuning-and-troubleshooting/error-guide/pipelineMaxInstance.png)
+
+**备注**
+
+
+涉及全局设置不推荐用户随意修改,如需修改请与运维沟通后修改。非全局设置参数,用户可自行修改
+
+---------------------------------
+
+#### 错误码 12008
+
+**现象**
+
+任务执行过程中报错:错误码 12008,错误信息 获取Yarn队列信息异常,可能是您设置的yarn队列不存在
+>获取Yarn队列信息异常
+
+**原因1**
+
+获取Yarn队列信息异常
+
+**解决1**
+
+- 如果集群正常,用户队列配置错误:
+- linkis管理台/参数配置>全局设置>yarn队列名[wds.linkis.rm.yarnqueue]
+- ![](/Images/tuning-and-troubleshooting/error-guide/yarnQueue.png)
+
+**解决2**
+
+- 如果集群是新集群,先检查LinkisManager的集群配置
+ >查看hadoop集群地址: http://ip:8088/cluster
+ >
+ >查看yarn队列地址:http://ip:8888/cluster/scheduler
+>
+**备注**
+
+
+涉及全局设置不推荐用户随意修改,如需修改请与运维沟通后修改。非全局设置参数,用户可自行修改
+
+---------------------------------
+
+#### 错误码 12009
+
+**现象**
+
+任务执行过程中报错:错误码 12009,错误信息 会话创建失败,%s队列不存在,请检查队列设置是否正确
+>queue (\S+) is not exists in YARN
+
+**原因1**
+
+队列不存在,请检查队列设置是否正确
+
+**解决1**
+
+- 用户联系管理员,确认队列是否正确
+- ![](/Images/tuning-and-troubleshooting/error-guide/yarnQueue.png)
+---------------------------------
+
+#### 错误码 12010
+
+**现象**
+
+任务执行过程中报错:错误码 12010,错误信息 集群队列内存资源不足,可以联系组内人员释放资源
+>Insufficient cluster queue memory
+
+**原因1**
+
+集群队列内存资源不足
+
+**解决1**
+
+- 检查资源内存是否已满,用户联系组内人员释放资源,或者申请队列扩容
+- ![](/Images/tuning-and-troubleshooting/error-guide/queueRamResource.png)
+---------------------------------
+
+#### 错误码 12011
+
+**现象**
+
+任务执行过程中报错:错误码 12011,错误信息 集群队列CPU资源不足,可以联系组内人员释放资源
+>Insufficient cluster queue cpu
+
+**原因1**
+
+集群队列CPU资源不足
+
+**解决1**
+
+- 检查资源cpu是否已满,用户联系组内人员释放资源,或者申请队列扩容
+
+- ![](/Images/tuning-and-troubleshooting/error-guide/queueCPUResource.png)
+---------------------------------
+
+#### 错误码 12013
+
+**现象**
+
+任务执行过程中报错:错误码 12013,错误信息 资源不足导致启动引擎超时,您可以进行任务重试
+>wait for DefaultEngineConn
+
+**原因1**
+
+资源不足导致启动引擎超时
+
+**解决1**
+
+用户重试任务,如果多次出现,请联系管理员排查
+
+---------------------------------
+
+#### 错误码 12014
+
+**现象**
+
+任务执行过程中报错:错误码 12014,错误信息 请求引擎超时,可能是因为队列资源不足导致,请重试
+>wait for engineConn initial timeout
+
+**原因1**
+
+请求引擎超时
+
+**解决1**
+
+用户重试任务,如果多次出现,请联系管理员排查
+
+---------------------------------
+
+#### 错误码 13001
+
+**现象**
+
+任务执行过程中报错:错误码 13001,错误信息 Java进程内存溢出,建议优化脚本内容
+>OutOfMemoryError
+
+**原因1**
+
+Java进程内存溢出
+
+**解决1**
+
+- 用户尝试增加java管理端内存配置,如果重复出现,请联系管理员排查
+- 修改配置,打开DSS平台,点击管理台--参数配置--IDE--IDEspark--spark引擎资源设置(2)--spark引擎内存[spark.driver.memory]
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkMemory.png)
+
+---------------------------------
+
+#### 错误码 13002
+
+**现象**
+
+任务执行过程中报错:错误码 13002,错误信息 使用资源过大,请调优sql或者加大资源
+
+>Container killed by YARN for exceeding memory limits
+
+**原因1**
+
+使用资源过大
+
+**解决1**
+
+- 在管理台增加executor内存,或在提交任务中增加内存
+- 修改配置,打开DSS平台,点击管理台--参数配置--IDE--IDEspark--worker资源设置(2)--worker内存大小[spark.executor.memory]
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkExecutorMemory.png)
+---------------------------------
+
+#### 错误码 13003
+
+**现象**
+
+任务执行过程中报错:错误码 13003,错误信息 使用资源过大,请调优sql或者加大资源
+
+>read record exception
+
+**原因1**
+
+使用资源过大
+
+**解决1**
+
+- 用户与管理员确认后,在管理台增加executor内存,或在提交任务中增加内存
+- 修改配置,打开DSS平台,点击管理台--参数配置--IDE--IDEspark--worker资源设置(2)--worker内存大小[spark.executor.memory]
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkExecutorMemory.png)
+---------------------------------
+
+#### 错误码 13004
+
+**现象**
+
+任务执行过程中报错:错误码 13004,错误信息 引擎意外退出,可能是使用资源过大导致
+
+>failed because the engine quitted unexpectedly
+
+**原因1**
+
+引擎意外退出
+
+**解决1**
+
+联系管理员排查
+
+---------------------------------
+
+#### 错误码 13005
+
+**现象**
+
+任务执行过程中报错:错误码 13005,错误信息 Spark app应用退出,可能是复杂任务导致
+
+>Spark application has already stopped
+
+**原因1**
+
+Spark app应用退出,可能是复杂任务导致
+
+**解决1**
+
+- 用户尝试增加java管理端内存配置,如果重复出现,请联系管理员排查
+- 修改配置,打开DSS平台,点击管理台--参数配置--IDE--IDEspark--spark引擎资源设置(2)--spark引擎内存[spark.driver.memory]
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkMemory.png)
+
+**解决2**
+
+- 用户与管理员确认后,在管理台增加executor内存,或在提交任务中增加内存
+- 修改配置,打开DSS平台,点击管理台--参数配置--IDE--IDEspark--worker资源设置(2)--worker内存大小[spark.executor.memory]
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkExecutorMemory.png)
+
+---------------------------------
+
+#### 错误码 13006
+
+**现象**
+
+任务执行过程中报错:错误码 13006,错误信息 Spark context退出,可能是复杂任务导致
+
+>Spark application has already stopped
+
+**原因1**
+
+Spark context退出,可能是复杂任务导致
+
+**解决1**
+
+- 用户尝试增加java管理端内存配置,如果重复出现,请联系管理员排查
+- 修改配置,打开DSS平台,点击管理台--参数配置--IDE--IDEspark--spark引擎资源设置(2)--spark引擎内存[spark.driver.memory]
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkMemory.png)
+
+**解决2**
+
+- 用户与管理员确认后,在管理台增加executor内存,或在提交任务中增加内存
+- 修改配置,打开DSS平台,点击管理台--参数配置--IDE--IDEspark--worker资源设置(2)--worker内存大小[spark.executor.memory]
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkExecutorMemory.png)
+---------------------------------
+
+#### 错误码 13007
+
+**现象**
+
+任务执行过程中报错:错误码 13007,错误信息 Pyspark子进程意外退出,可能是复杂任务导致
+
+>Pyspark process has stopped
+
+**原因1**
+
+Pyspark子进程意外退出,可能是复杂任务导致
+
+**解决1**
+
+- 用户尝试增加java管理端内存配置,如果重复出现,请联系管理员排查
+- 修改配置,打开DSS平台,点击管理台--参数配置--IDE--IDEspark--spark引擎资源设置(2)--spark引擎内存[spark.driver.memory]
+- ![](/Images/tuning-and-troubleshooting/error-guide/sparkMemory.png)
+---------------------------------
+
+#### 错误码 21001
+
+**现象**
+
+任务执行过程中报错:错误码 21001,错误信息 会话创建失败,用户%s不能提交应用到队列:%s,请联系提供队列给您的人员
+
+>User (\S+) cannot submit applications to queue (\S+)
+
+**原因1**
+
+会话创建失败,用户%s不能提交应用到队列
+
+**解决1**
+
+用户队列无权限,请检查队列配置是否错误,或者申请队列权限
+
+---------------------------------
+
+#### 错误码 21002
+
+**现象**
+
+任务执行过程中报错:错误码 21002,错误信息 创建Python解释器失败,请联系管理员
+
+>initialize python executor failed
+
+**原因1**
+
+创建Python解释器失败
+
+**解决1**
+
+联系运维人员排查
+
+---------------------------------
+
+#### 错误码 21003
+
+**现象**
+
+任务执行过程中报错:错误码 21003,错误信息 创建单机Python解释器失败,请联系管理员
+
+>PythonSession process cannot be initialized
+
+**原因1**
+
+创建Python解释器失败
+
+**解决1**
+
+联系运维人员排查
+
+---------------------------------
+
+#### 错误码 22001
+
+**现象**
+
+任务执行过程中报错:错误码 22001,错误信息 %s无权限访问,请申请开通数据表权限,请联系您的数据管理人员
+
+>Permission denied:\s*user=[a-zA-Z0-9_]+,\s*access=[A-Z]+\s*,\s*inode="([a-zA-Z0-9/_\.]+)
+
+**原因1**
+
+无权限访问
+
+**解决1**
+
+- 数据库表权限需要到进行申请
+---------------------------------
+
+#### 错误码 22003
+
+**现象**
+
+任务执行过程中报错:错误码 22003,错误信息 所查库表无权限
+
+>Authorization failed:No privilege
+
+**原因1**
+
+无权限访问
+
+**解决1**
+
+- 数据库表权限需要到进行申请
+
+---------------------------------
+
+#### 错误码 22004
+
+**现象**
+
+任务执行过程中报错:错误码 22004,错误信息 用户%s在机器不存在,请确认是否申请了相关权限
+
+>user (\S+) does not exist
+
+**原因1**
+
+无权限访问
+
+**解决1**
+
+
+- 用户服务
+---------------------------------
+
+#### 错误码 22005
+
+**现象**
+
+任务执行过程中报错:错误码 22005,错误信息 用户在机器不存在,请确认是否申请了相关权限
+
+>engineConnExec.sh: Permission denied
+
+**原因1**
+
+无权限访问
+
+**解决1**
+
+
+- 用户服务
+---------------------------------
+
+#### 错误码 22006
+
+**现象**
+
+任务执行过程中报错:错误码 22006,错误信息 用户在机器不存在,请确认是否申请了相关权限
+
+>at com.sun.security.auth.UnixPrincipal
+
+**原因1**
+
+无权限访问
+
+**解决1**
+
+
+- 用户服务
+---------------------------------
+
+#### 错误码 22007
+
+**现象**
+
+任务执行过程中报错:错误码 22007,错误信息 用户在机器不存在,请确认是否申请了相关权限
+
+>LoginException: java.lang.NullPointerException: invalid null input: name
+
+**原因1**
+
+无权限访问
+
+**解决1**
+
+
+- 用户服务
+---------------------------------
+
+#### 错误码 22008
+
+**现象**
+
+任务执行过程中报错:错误码 22008,错误信息 用户在机器不存在,请确认是否申请了相关权限
+
+>User not known to the underlying authentication module
+
+**原因1**
+
+无权限访问
+
+**解决1**
+
+
+- 用户服务
+---------------------------------
+
+#### 错误码 30001
+
+**现象**
+
+任务执行过程中报错:错误码 30001,错误信息 库超过限制
+
+>is exceeded
+
+**原因1**
+
+库超过限制
+
+**解决1**
+
+用户自行清理数据
+
+**解决2**
+
+申请数据库扩容
+
+---------------------------------
+
+#### 错误码 31001
+
+**现象**
+
+任务执行过程中报错:错误码 31001,错误信息 用户主动kill任务
+
+>is killed by user
+
+**原因1**
+
+用户主动kill任务
+
+**解决1**
+
+- 如果确认用户未主动kill,请联系运维人员排查
+---------------------------------
+
+#### 错误码 31002
+
+**现象**
+
+任务执行过程中报错:错误码 31002,错误信息 您提交的EngineTypeLabel没有对应的引擎版本
+
+>EngineConnPluginNotFoundException
+
+**原因1**
+
+EngineTypeLabel没有对应的引擎版本
+
+**解决1**
+
+- 用户检查传的EngineTypeLabel是否正确,如果正确,请联系运维人员排查
+- 运维人员检查方法:在linkis ecp节点 lib/linkis-engineconn-plugins/是所有可用引擎插件的本地缓存。这个没有可能是引擎对应版本没有,或者引擎文件里面放了其它非正常格式文件,比如 .bak ,不该放zip的放了zip等等
+
+---------------------------------
+
+#### 错误码 41001
+
+**现象**
+
+任务执行过程中报错:错误码 41001,错误信息 数据库%s不存在,请检查引用的数据库是否有误
+
+>Database '([a-zA-Z_0-9]+)' not found
+
+**原因1**
+
+数据库%s不存在
+
+**解决1**
+
+- 用户检查数据库是否存在及权限
+- >show databases
+
+---------------------------------
+
+#### 错误码 41001
+
+**现象**
+
+任务执行过程中报错:错误码 41001,错误信息 数据库%s不存在,请检查引用的数据库是否有误
+
+>Database does not exist: ([a-zA-Z_0-9]+)
+
+**原因1**
+
+数据库%s不存在
+
+**解决1**
+
+- 用户检查数据库是否存在及权限
+- >show databases
+
+---------------------------------
+
+#### 错误码 41003
+
+**现象**
+
+任务执行过程中报错:错误码 41003,错误信息 字段%s不存在,请检查引用的字段是否有误
+
+>cannot resolve '`(.+)`' given input columns
+
+**原因1**
+
+字段%s不存在
+
+**解决1**
+
+- 用户检查字段是否存在
+>desc tabl_name
+---------------------------------
+
+#### 错误码 41003
+
+**现象**
+
+任务执行过程中报错:错误码 41003,错误信息 字段%s不存在,请检查引用的字段是否有误
+
+>Column '(.+)' cannot be resolved
+
+**原因1**
+
+字段%s不存在
+
+**解决1**
+
+- 用户检查字段是否存在
+>desc tabl_name
+---------------------------------
+
+#### 错误码 41003
+
+**现象**
+
+任务执行过程中报错:错误码 41003,错误信息 字段%s不存在,请检查引用的字段是否有误
+
+> Invalid table alias or column reference '(.+)':
+
+**原因1**
+
+字段%s不存在
+
+**解决1**
+
+- 用户检查字段是否存在
+>desc tabl_name
+---------------------------------
+
+#### 错误码 41004
+
+**现象**
+
+任务执行过程中报错:错误码 41004,错误信息 分区字段%s不存在,请检查引用的表是否为分区表或分区字段有误
+
+>Partition spec \{(\S+)\} contains non-partition columns
+
+**原因1**
+
+分区字段%s不存在
+
+**解决1**
+
+- 用户检查分区字段填写是否正确
+
+---------------------------------
+
+#### 错误码 41004
+
+**现象**
+
+任务执行过程中报错:错误码 41004,错误信息 分区字段%s不存在,请检查引用的表是否为分区表或分区字段有误
+
+>table is not partitioned but partition spec exists:\{(.+)\}
+
+**原因1**
+
+分区字段%s不存在
+
+**解决1**
+
+- 用户检查分区字段填写是否正确
+
+---------------------------------
+
+#### 错误码 41004
+
+**现象**
+
+任务执行过程中报错:错误码 41004,错误信息 表对应的路径不存在,请联系您的数据管理人员
+
+>Path does not exist: viewfs
+
+**原因1**
+
+分区路径不存在导致
+
+**解决1**
+
+- 请尝试refresh table XXX,或者kill引擎重跑,仍有异常,请联系数据管理人员排查
+
+---------------------------------
+
+#### 错误码 41004
+
+**现象**
+
+任务执行过程中报错:错误码 41004,错误信息 字段%s不存在,请检查引用的表%s是否为分区表或分区字段有误
+
+>([a-zA-Z_0-9]+) is not a valid partition column in table ([`\.a-zA-Z_0-9]+)
+
+**原因1**
+
+字段%s不存在
+
+**解决1**
+
+- 用户检查分区字段填写是否正确
+
+---------------------------------
+
+#### 错误码 41005
+
+**现象**
+
+任务执行过程中报错:错误码 41005,错误信息 文件%s不存在
+
+>Caused by:\s*java.io.FileNotFoundException
+
+**原因1**
+
+文件%s不存在
+
+**解决1**
+
+- 请尝试refresh table XXX,或者kill引擎重跑,仍有异常,请联系数据管理人员排查
+
+
+---------------------------------
+
+#### 错误码 42003
+
+**现象**
+
+任务执行过程中报错:错误码 42003,错误信息 未知函数%s,请检查代码中引用的函数是否有误
+
+>Undefined function: '(\S+)'
+
+**原因1**
+
+引用的函数有误
+
+**解决1**
+
+- 如果是udf,请检查函数,如果是公共函数,请联系运维人员排查
+- udf函数地址:![](/Images/tuning-and-troubleshooting/error-guide/udf.png)
+
+---------------------------------
+
+#### 错误码 42003
+
+**现象**
+
+任务执行过程中报错:错误码 42003,错误信息 未知函数%s,请检查代码中引用的函数是否有误
+
+>Invalid function '(\S+)'
+
+**原因1**
+
+引用的函数有误
+
+**解决1**
+
+- 如果是udf,请检查函数,如果是公共函数,请联系运维人员排查
+- udf函数地址:![](/Images/tuning-and-troubleshooting/error-guide/udf.png)
+
+---------------------------------
+
+#### 错误码 42004
+
+**现象**
+
+任务执行过程中报错:错误码 42004,错误信息 字段%s存在名字冲突,请检查子查询内是否有同名字段
+
+>Ambiguous column Reference '(\S+)' in subquery
+
+**原因1**
+
+字段%s存在名字冲突
+
+**解决1**
+
+- 用户检查是否有重名字段
+
+---------------------------------
+
+#### 错误码 42004
+
+**现象**
+
+任务执行过程中报错:错误码 42004,错误信息 字段%s存在名字冲突,请检查子查询内是否有同名字段
+
+>Reference '(\S+)' is ambiguous
+
+**原因1**
+
+字段%s存在名字冲突
+
+**解决1**
+
+- 用户检查是否有重名字段
+
+---------------------------------
+
+#### 错误码 42005
+
+**现象**
+
+任务执行过程中报错:错误码 42005,错误信息 字段%s必须指定表或者子查询别名,请检查该字段来源
+
+>Column '(\S+)' Found in more than One Tables/Subqueries
+
+**原因1**
+
+字段未指定表
+
+**解决1**
+
+- 用户增加字段来源
+
+---------------------------------
+
+#### 错误码 42006
+
+**现象**
+
+任务执行过程中报错:错误码 42006,错误信息 表%s在数据库中已经存在,请删除相应表后重试
+
+>Table already exists
+
+**原因1**
+
+表%s在数据库中已经存在
+
+**解决1**
+
+- 用户需要清理表再重试
+
+---------------------------------
+
+#### 错误码 42006
+
+**现象**
+
+任务执行过程中报错:错误码 42006,错误信息 表%s在数据库中已经存在,请删除相应表后重试
+
+>AnalysisException: (S+) already exists
+
+**原因1**
+
+表%s在数据库中已经存在
+
+**解决1**
+
+- 用户需要清理表再重试
+
+---------------------------------
+
+#### 错误码 42006
+
+**现象**
+
+任务执行过程中报错:错误码 42006,错误信息 表%s在数据库中已经存在,请删除相应表后重试
+
+>Table (\S+) already exists
+
+**原因1**
+
+表%s在数据库中已经存在
+
+**解决1**
+
+- 用户需要清理表再重试
+
+
+---------------------------------
+
+#### 错误码 42006
+
+**现象**
+
+任务执行过程中报错:错误码 42006,错误信息 表%s在数据库中已经存在,请删除相应表后重试
+
+>Table or view '(\S+)' already exists in database '(\S+)'
+
+**原因1**
+
+表%s在数据库中已经存在
+
+**解决1**
+
+- 用户需要清理表再重试
+
+
+---------------------------------
+
+#### 错误码 42007
+
+**现象**
+
+任务执行过程中报错:错误码 42007,错误信息 插入目标表字段数量不匹配,请检查代码!
+
+>requires that the data to be inserted have the same number of columns as the target table
+
+**原因1**
+
+插入目标表字段数量不匹配
+
+**解决1**
+
+- 用户检查代码
+
+
+---------------------------------
+
+#### 错误码 42008
+
+**现象**
+
+任务执行过程中报错:错误码 42008,错误信息 数据类型不匹配,请检查代码!
+
+>due to data type mismatch: differing types in
+
+**原因1**
+
+数据类型不匹配
+
+**解决1**
+
+- 用户检查代码
+
+
+---------------------------------
+
+#### 错误码 42009
+
+**现象**
+
+任务执行过程中报错:错误码 42009,错误信息 字段%s引用有误,请检查字段是否存在!
+
+>Invalid column reference (S+)
+
+**原因1**
+
+字段%s引用有误
+
+**解决1**
+
+- 用户检查字段是否存在
+
+
+---------------------------------
+
+#### 错误码 42010
+
+**现象**
+
+任务执行过程中报错:错误码 42010,错误信息 字段%s提取数据失败
+
+>Can't extract value from (S+): need
+
+**原因1**
+
+字段%s提取数据失败
+
+**解决1**
+
+- 检查select 的字段是否有误
+
+
+---------------------------------
+
+#### 错误码 42012
+
+**现象**
+
+任务执行过程中报错:错误码 42012,错误信息 group by 位置2不在select列表中,请检查代码!
+
+>GROUP BY position (S+) is not in select list
+
+**原因1**
+
+group by 的字段不在select列表中
+
+**解决1**
+
+- 用户检查代码
+
+
+---------------------------------
+
+#### 错误码 42014
+
+**现象**
+
+任务执行过程中报错:错误码 42014,错误信息 插入数据未指定目标表字段%s,请检查代码!
+
+>Cannot insert into target table because column number/types are different '(S+)'
+
+**原因1**
+
+插入数据和目标表的字段对应不上
+
+**解决1**
+
+- 用户检查代码
+
+
+---------------------------------
+
+#### 错误码 42016
+
+**现象**
+
+任务执行过程中报错:错误码 42016,错误信息 UDF函数未指定参数,请检查代码!
+
+>UDFArgumentException Argument expected
+
+**原因1**
+
+UDF函数未指定完整参数
+
+**解决1**
+
+- 用户检查代码
+
+
+---------------------------------
+
+#### 错误码 42017
+
+**现象**
+
+任务执行过程中报错:错误码 42017,错误信息 聚合函数%s不能写在group by 中,请检查代码!
+
+>aggregate functions are not allowed in GROUP BY
+
+**原因1**
+
+聚合函数%s不能写在group by 中,请检查代码!
+
+**解决1**
+
+- 用户检查代码
+
+
+---------------------------------
+
+#### 错误码 43007
+
+**现象**
+
+任务执行过程中报错:错误码 43007,错误信息 pyspark执行失败,可能是语法错误或stage失败
+
+>Py4JJavaError: An error occurred
+
+**原因1**
+
+语法错误或stage失败
+
+**解决1**
+
+- 如果是语法错误需要检查代码进行修改
+- 如果是stage失败可以选择重试
+
+
+---------------------------------
+
+#### 错误码 43011
+
+**现象**
+
+任务执行过程中报错:错误码 43011,错误信息 导出Excel表超过最大限制1048575
+
+>Invalid row number
+
+**原因1**
+
+数据量超过单个sheet的限制
+
+**解决1**
+
+- 减少数据量进行导出,或者导出为CSV格式
+
+
+---------------------------------
+
+#### 错误码 43040
+
+**现象**
+
+任务执行过程中报错:错误码 43040,错误信息 Presto查询一定要指定数据源和库信息
+
+>Schema must be specified when session schema is not set
+
+**原因1**
+
+数据源配置错误
+
+**解决1**
+
+- 检查管理台Presto数据源配置
+- 修改配置,打开DSS平台,点击管理台--参数配置--IDE--IDEpresto--数据源配置
+- ![](/Images/tuning-and-troubleshooting/error-guide/presto.png)
+
+
+---------------------------------
+
+#### 错误码 46001
+
+**现象**
+
+任务执行过程中报错:错误码 46001,错误信息 找不到导入文件地址:%s
+
+>java.io.FileNotFoundException: (\S+) \(No such file or directory\)
+
+**原因1**
+
+文件不存在
+
+**解决1**
+
+- 请检查工作空间,或检查HDFS目录下文件是否存在
+- ![](/Images/tuning-and-troubleshooting/error-guide/hdfs.png)
+
+
+---------------------------------
+
+#### 错误码 46002
+
+**现象**
+
+任务执行过程中报错:错误码 46002,错误信息 导出为excel时临时文件目录权限异常
+
+>java.io.IOException: Permission denied(.+) at org.apache.poi.xssf.streaming.SXSSFWorkbook.createAndRegisterSXSSFSheet
+
+**原因1**
+
+文件目录异常,或者文件读写权限不足
+
+**解决1**
+
+- 请确认文件有读写权限,如有异常请联系运维人员处理
+
+
+---------------------------------
+
+#### 错误码 46003
+
+**现象**
+
+任务执行过程中报错:错误码 46003,错误信息 导出文件时无法创建目录:%s
+
+>java.io.IOException: Mkdirs failed to create (\S+) (.+)
+
+**原因1**
+
+无法创建目录
+
+**解决1**
+
+- 联系运维人员排查
+
+
+---------------------------------
+
+#### 错误码 46004
+
+**现象**
+
+任务执行过程中报错:错误码 46004,错误信息 导入模块错误,系统没有%s模块,请联系运维人员安装
+
+>ImportError: No module named (S+)
+
+**原因1**
+
+系统没有%s模块
+
+**解决1**
+
+- 联系运维人员排查
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/error-guide/interface.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/error-guide/interface.md
new file mode 100644
index 00000000000..2697608d8ff
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/error-guide/interface.md
@@ -0,0 +1,133 @@
+---
+title: 接口错误排查
+sidebar_position: 3
+---
+
+针对接口错误,如何快速定位接口,快速查询日志,进行介绍
+
+## 如何定位
+
+### 1. 前端F12 接口报错
+**错误信息排查**
+![](/Images/tuning-and-troubleshooting/error-guide/errorMsg.png)
+发现错误信息,按F12--network--过滤请求信息Fetch/XHR--对单次请求进行检查--priview--定位报错请求
+
+**查找url**
+![](/Images/tuning-and-troubleshooting/error-guide/findUrl.png)
+点击单次请求的Headers,就会看到general 这里将会看到请求地址:
+>Request URL :XXXXX /api/rest_j/v1/data-source-manager/op/connect/json
+
+### 2. 找到应用名
+某个接口请求报错,URL规范进行定位应用名。
+Linkis接口URL遵循设计规范:
+>/api/rest_j/v1/{applicationName}/.
+
+applicationName是应用名,通过应用名查找归属的微服务,去对应的微服务下查看log日志。
+
+#### 应用名和微服务的对应关系
+
+|ApplicationName(应用名)|Microservice(微服务)|
+|:----:|:----:|
+|linkismanager|cg-linkismanager|
+|engineplugin|cg-engineplugin|
+|cg-engineconnmanager|cg-engineconnmanager|
+|entrance|cg-entrance|
+|bml|ps-bml|
+|contextservice|ps-cs|
+|datasource|ps-datasource|
+|configuration||
+|microservice||
+|jobhistory|ps-publicservice|
+|variable||
+|udf||
+
+
+### 3. 找到日志路径
+用户服务地址存在不一样的情况,我们需先定位日志地址
+> ps -ef | grep ps-datasource
+
+![](/Images/tuning-and-troubleshooting/error-guide/logs.png)
+
+- cg-linkismanager:
+>GC日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-linkismanager-gc.log`
+>
+>服务日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-linkismanager.log`
+>
+>服务的System.out日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-linkismanager.out`
+
+- cg-engineplugin:
+>GC日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-engineplugin-gc.log`
+>
+>服务日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-engineplugin.log`
+>
+>服务的System.out日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-engineplugin.out`
+
+- cg-engineconnmanager:
+>GC日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-engineconnmanager-gc.log`
+>
+>服务日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-engineconnmanager.log`
+>
+>服务的System.out日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-engineconnmanager.out`
+
+- cg-entrance:
+>GC日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-entrance-gc.log`
+>
+>服务日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-entrance.log`
+>
+>服务的System.out日志:` /${LINKIS_HOME}/logs/linkis/linkis-cg-entrance.out`
+
+- ps-bml:
+>GC日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-bml-gc.log`
+>
+>服务日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-bml.log`
+>
+>服务的System.out日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-bml.out`
+
+- ps-cs:
+>GC日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-cs-gc.log`
+>
+>服务日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-cs.log`
+>
+>服务的System.out日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-cs.out`
+
+- ps-datasource:
+>GC日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-datasource-gc.log`
+>
+>服务日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-datasource.log`
+>
+>服务的System.out日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-datasource.out`
+
+- ps-publicservice:
+>GC日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-publicservice-gc.log`
+>
+>服务日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-publicservice.log`
+>
+>服务的System.out日志:` /${LINKIS_HOME}/logs/linkis/linkis-ps-publicservice.out`
+
+### 4. 查看日志
+展示接口对应的报错信息
+
+找到请求日志,日志中会展示出服务调用的其他服务,或者展示自己服务中处理的逻辑日志
+>tail -fn200 linkis-ps-data-source-manager.log
+
+![](/Images/tuning-and-troubleshooting/error-guide/datasourcemanager.png)
+
+**上图展示的是服务调用其他服务的日志,可根据此信息查询另外服务的日志**
+
+**下图展示的是真正报错的服务日志**
+
+>tail -fn200 linkis-ps-metadataquery.log
+
+![](/Images/tuning-and-troubleshooting/error-guide/errorMsgFromMeta.png)
+
+前端报错展示
+
+![](/Images/tuning-and-troubleshooting/error-guide/errorMsg.png)
+
+
+### 5. 异常定位
+`ECMResourceClear failed, ecm current resource:bdpuje
+s110003:9102{"instance":0,"memory":"0.0 B","cpu":0} org.apache.linkis.manager.exception.PersistenceErrorException: errCode: 210001 ,desc: label not found, this label may be removed a
+lready. , ip: localhost110003 ,port: 9101 ,serviceKind: linkis-cg-linkismanager`
+
+其中IP和端口是对应的服务地址,serviceKind是对应的服务名称,如果是RPC调用的日志失败,可以通过这个信息找到对应的服务
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/images/engine-log.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/images/engine-log.png
new file mode 100644
index 00000000000..3a4c5ee0fb3
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/images/engine-log.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/overview.md
new file mode 100644
index 00000000000..158e556a4eb
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/overview.md
@@ -0,0 +1,170 @@
+---
+title: 总览
+sidebar_position: 0
+---
+## 调优排障
+
+> 建议的排查基本优先级可以按照:**社区issue专栏搜索关键词—\>在社区查阅《Q\&A问题总结》文档—\>定位系统日志—\>社区用户群咨询交流—\>定位源码远程debug**
+
+
+## 1. 社区Issue搜索关键词
+
+在[issue专栏](https://github.com/apache/linkis/issues), filter过滤器中搜索关键词。如:
+filter:`is:issue spark3`
+![](/Images-zh/tuning-and-troubleshooting/issue-searching-keywords.png)
+
+
+
+## 2. 常见Q&A问题集
+
+将issue中常见的问题以及解决方案整理成文档,放在了官网页面《 [常见问题](/faq/main) 》
+
+
+## 3. 如何定位错误
+
+### 3.1 编译阶段异常排查
+> 如果是自行编译
+
+通常会出现的问题:
+- 编译前,未执行`mvn -N install`, 导致linkis自身依赖没法获取
+- 升级部分依赖组件后,导致函数报错 如使用spark3
+
+定位异常的手段:
+可以在mvn 运行命令后面加上 -e 参数 如`mvn clean install -e`
+
+### 3.2 安装阶段异常排查
+
+如果出现报错,又不清楚具体是执行什么命令报错,可以加 -x 参数`sh -x bin/install.sh`,将shell脚本执行过程日志打印出来,方便定位问题
+
+### 3.3 启动微服务阶段异常排查
+所有微服务的日志文件统一放入了logs目录,日志目录层级如下:
+
+```html
+├── logs 日志目录
+│ ├── linkis-cg-engineconnmanager-gc.log
+│ ├── linkis-cg-engineconnmanager.log
+│ ├── linkis-cg-engineconnmanager.out
+│ ├── linkis-cg-engineplugin-gc.log
+│ ├── linkis-cg-engineplugin.log
+│ ├── linkis-cg-engineplugin.out
+│ ├── linkis-cg-entrance-gc.log
+│ ├── linkis-cg-entrance.log
+│ ├── linkis-cg-entrance.out
+│ ├── linkis-cg-linkismanager-gc.log
+│ ├── linkis-cg-linkismanager.log
+│ ├── linkis-cg-linkismanager.out
+│ ├── linkis-cli
+│ │ ├── linkis-client.hadoop.log.20220409162400037523664
+│ │ ├── linkis-client.hadoop.log.20220409162524417944443
+│ ├── linkis-mg-eureka-gc.log
+│ ├── linkis-mg-eureka.log
+│ ├── linkis-mg-eureka.out
+│ ├── linkis-mg-gateway-gc.log
+│ ├── linkis-mg-gateway.log
+│ ├── linkis-mg-gateway.out
+│ ├── linkis-ps-cs-gc.log
+│ ├── linkis-ps-cs.log
+│ ├── linkis-ps-cs.out
+│ ├── linkis-ps-data-source-manager-gc.log
+│ ├── linkis-ps-data-source-manager.log
+│ ├── linkis-ps-data-source-manager.out
+│ ├── linkis-ps-metadatamanager-gc.log
+│ ├── linkis-ps-metadatamanager.log
+│ ├── linkis-ps-metadatamanager.out
+│ ├── linkis-ps-publicservice-gc.log
+│ ├── linkis-ps-publicservice.log
+│ └── linkis-ps-publicservice.out
+```
+
+包含计算治理、公共增强、微服务管理三大微服务模块。每个微服务下包含`linkis-xxx-gc.log`、`linkis-xxx.log`、``linkis-xxx.out`三个日志。
+分别对应服务的GC日志、服务日志、服务的System.out日志。
+
+通常情况下,启动某个微服务出错时,可以在log目录查看对应服务 查看详细日志排查问题
+
+但因为服务之间是存在相互调用,linkis的微服务比较多,若对系统不熟悉,有时候无法定位到具体哪个模块出现了异常,可以通过全局日志搜索方式,拉取关键异常信息,进行排查
+
+```shell script
+tail -f log/* |grep -5n exception(或则tail -f log/* |grep -5n ERROR)
+less log/* |grep -5n exception(或则less log/* |grep -5n ERROR)
+```
+
+
+### 3.4 运行阶段
+
+#### 3.4.1 接口异常排查
+
+如果某个接口请求报错,可以根据接口的返回加过中定位出现问题的微服务,
+一般情况下可以**根据URL规范进行定位,**Linkis接口中的URL都遵循着一定的设计规范,
+即**/api/rest_j/v1/{applicationName}/.+的格式**,通过applicationName可以定位应用名,部分应用本身是一个微服务,
+这时候应用名和微服务名相同,部分应用归属于某个微服务,此时应该通过应用名查找归属的微服务,
+去对应的微服务下查看log日志,下面给出微服务和应用名的对应关系。
+
+| **请求路径中的ApplicationName** | **服务的提供方** |
+|-------------------------------------|---------------------------------|
+| /api/rest_j/v1/linkisManager/* | linkis-cg-linkismanager |
+| /api/rest_j/v1/entrance/* | linkis-cg-entrance |
+| /api/rest_j/v1/bml/* | linkis-ps-publicservice |
+| /api/rest_j/v1/configuration/* | linkis-ps-publicservice |
+| /api/rest_j/v1/jobhistory/* | linkis-ps-publicservice |
+| /api/rest_j/v1/filesystem/* | linkis-ps-publicservice |
+| /api/rest_j/v1/variable/* | linkis-ps-publicservice |
+| /api/rest_j/v1/microservice/* | linkis-ps-publicservice |
+| /api/rest_j/v1/errorcode/* | linkis-ps-publicservice |
+| /api/rest_j/v1/udf/* | linkis-ps-publicservice |
+| /api/rest_j/v1/datasource/* | linkis-ps-publicservice |
+| /api/rest_j/v1/metadatamanager/* | linkis-ps-metadatamanager |
+| /api/rest_j/v1/data-source-manager/*| linkis-ps-data-source-manager |
+| /api/rest_j/v1/engineplugin/* | linkis-engineconn-plugin |
+| /api/rest_j/v1/contextservice/*(暂未使用到) | linkis-ps-cs |
+
+对于请求异常的定位,可以根据上表的对应关系,去对应的服务日志中进行查看
+
+#### 3.4.2 执行引擎任务的异常排查
+
+** step1:找到EngineConn的启动部署目录 **
+
+- 方式1:如果执行日志中有显示,可以在管理台上查看到 如下图:
+![engine-log](images/engine-log.png)
+- 方式2:如果方式1中没有找到,可以通过找到`conf/linkis-cg-engineconnmanager.properties`配置的`wds.linkis.engineconn.root.dir`的参数,该值就是引擎启动部署的目录,子目录按执行引擎的用户进行了隔离
+
+```shell script
+# 如果不清楚taskid,可以按时间排序后进行选择 ll -rt /appcom/tmp/${执行的用户}/${日期}/${引擎}/
+cd /appcom/tmp/${执行的用户}/${日期}/${引擎}/${taskId}
+例如一个Spark 引擎的启动目录如下:
+/appcom/tmp/hadoop/20210824/spark/6a09d5fb-81dd-41af-a58b-9cb5d5d81b5a
+```
+
+目录大体如下
+```shell script
+conf -> /appcom/tmp/engineConnPublickDir/6a09d5fb-81dd-41af-a58b-9cb5d5d81b5a/v000002/conf #引擎的配置文件
+engineConnExec.sh #生成的引擎的启动脚本
+lib -> /appcom/tmp/engineConnPublickDir/45bf0e6b-0fa5-47da-9532-c2a9f3ec764d/v000003/lib #引擎依赖的包
+logs #引擎启动执行的相关日志
+```
+
+** step2:查看引擎的日志 **
+```shell script
+less logs/stdout
+less logs/stderr
+```
+
+** step3:尝试手动执行脚本(如果需要) **
+可以通过尝试手动执行脚本,进行调试
+```
+sh -x engineConnExec.sh
+```
+
+### 4. 问题反馈
+
+对于按上述排查方式排查后,仍然没解决的问题,可以通过[需求帮助](/community/how-to-ask-for-help)指引方式进行反馈和需求帮助
+
+
+### 5. 定位源码远程debug
+
+通常情况下,对源码远程debug是定位问题最有效的方式,但相对查阅文档来说,需要用户对源码结构有一定的了解,
+这里建议您在远程debug前查阅《 [Linkis源码层级结构详解](../development/directory-structure.md) 》,对项目的源码结构进行初步的了解,
+有一定程度上的熟悉之后,可以参考《 [如何DebugLinkis](../development/debug.md) 》一文 调试对应微服务下的代码。
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/tuning.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/tuning.md
new file mode 100644
index 00000000000..ed6eb0f172e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/tuning-and-troubleshooting/tuning.md
@@ -0,0 +1,55 @@
+---
+title: 调优手册
+sidebar_position: 2
+---
+
+> Linkis0.x版本在微众银行生产上稳定运行,并支撑着各种业务,Linkis1.0作为0.x的优化版本,相关调优逻辑并没有改变,所以本文档会介绍几个生产上Linkis部署调优的建议,由于篇幅有限,本文并不能覆盖到所有的优化场景,相关调优指南也会补充更新,当然也希望社区用户为Linkis1.0的调优文档提出建议。
+
+## 1. 概述
+ 本文档将会按照生产的经验,介绍几个调优的手段,分别是生产上部署时Jvm堆大小选取,任务提交的并发量设置,任务运行资源申请参阅介绍。文档中叙述的参数设置,并不是建议设置的参数值,用户需要根据自己真实地生产环境,对参数进行选取。
+
+
+## 2. Jvm堆大小调优
+ 在安装Linkis时,可以在linkis-env.sh中找到以下变量:
+```shell
+SERVER_HEAP_SIZE="512M"
+```
+ 设置该变量,在安装后,会加入到每个微服务的java启动参数中,用来控制Jvm启动堆大小,虽然在java启动时,需要设置xms和xmx两个参数,但是通常会设置成一样的值,在生产上,随着使用人数的增多,该参数需要调整大一些才能满足生产的需求。当然设置更大的堆栈内存,需要更大的服务器配置,当然,单机部署存在局限性,在生产上,可以采用分布式部署的方式,用多台服务器分别部署不同的Linkis和DSS微服务,同时调整堆栈大小,达到满足生产的需求。
+
+## 3. 任务提交的并发量调优
+ Linkis的一些任务并发参数都会有一个默认值,大多数场景下默认值都可以满足需求,但是有时,默认值并不能满足需求,所以需要通过改变参数的大小进行调整,本文会介绍几个调整任务并发的参数。方便用户对生产上的并发任务进行优化。
+
+ 因为任务的提交都是采用RPC的方式,在linkis-common/linkis-rpc模块中,可以通过配置如下几个参数提高rpc的并发数量:
+```shell
+wds.linkis.rpc.receiver.asyn.consumer.thread.max=400
+wds.linkis.rpc.receiver.asyn.queue.size.max=5000
+wds.linkis.rpc.sender.asyn.consumer.thread.max=100
+wds.linkis.rpc.sender.asyn.queue.size.max=2000
+```
+
+ 在Linkis源码中,我们对提交任务的并发数设置了一个默认值,该值在绝大多数场景下都能很好的满足需求,但是在有些场景出现大量并发任务提交执行时,比如用Qualitis(微众银行另一款开源项目)进行大批量数据校验时,这个参数在目前的版本中并没有提升为可配置项,分别是initCapacity,maxCapacity两个参数,需要用户进行改造,提高这两个参数,可以提高并发数,当然也需要更高的服务器配置。
+```java
+ private val groupNameToGroups = new JMap[String, Group]
+ private val labelBuilderFactory = LabelBuilderFactoryContext.getLabelBuilderFactory
+
+ override def getOrCreateGroup(groupName: String): Group = {
+ if (!groupNameToGroups.containsKey(groupName)) synchronized {
+ val initCapacity = 100
+ val maxCapacity = 100
+ // 其它代码...
+ }
+ }
+```
+
+## 4. 任务运行时资源设置
+ 在提交任务运行在Yarn上时,Yarn提供了可配置的接口,Linkis作为一个可拓展性强的框架,同样也可以通过Linkis的配置来设置资源配置。
+ Spark的相关配置和Hive的相关配置如下:
+在linkis-engineconn-plugins/engineconn-plugins里的Spark的部分配置,可以调整该配置改变提交到Yarn上的任务运行时环境,由于篇幅有限,如更多有关Hive,Yarn配置需要用户参考源码和参数文档:
+```shell
+"spark.driver.memory" = 2 //单位为G
+"wds.linkis.driver.cores" = 1
+"spark.executor.memory" = 4 //单位为G
+"spark.executor.cores" = 2
+"spark.executor.instances" = 3
+"wds.linkis.rm.yarnqueue" = "default"
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/_category_.json
new file mode 100644
index 00000000000..57d35113b8b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "升级指南",
+ "position": 10
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/upgrade-from-0.X-to-1.0-guide.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/upgrade-from-0.X-to-1.0-guide.md
new file mode 100644
index 00000000000..6712753c386
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/upgrade-from-0.X-to-1.0-guide.md
@@ -0,0 +1,78 @@
+---
+title: 0.x到1.0的升级指南
+sidebar_position: 1
+---
+
+> 本文简单介绍Linkis从0.X升级到1.0.0(1.0.1/1.0.2)的注意事项,Linkis1.0 对Linkis的多个服务进行了调整,改动较大,本文将介绍从0.X到1.X升级过程中的注意事项。
+
+## 1. 注意事项
+
+**如果您是首次接触并使用Linkis,您可以忽略该章节。**。
+
+## 2. 服务升级安装
+
+因为1.0基本上对所有服务进行了升级,包括服务名进行了修改,所以0.X到1.X升级时服务需要进行重新安装。
+
+在安装时如果需要保留0.X的数据,一定要选择1跳过建表语句(见下面代码)。
+
+Linkis1.0 的安装可以参考[如何快速安装](../deployment/deploy-quick.md)
+
+```
+Do you want to clear Linkis table information in the database?
+ 1: Do not execute table-building statements
+ 2: Dangerous! Clear all data and rebuild the tables
+ other: exit
+
+Please input the choice: ## choice 1
+```
+## 3. 数据库升级
+
+ 服务安装完成后,需要对数据库进行结构修改,包括进行表结构变更和新增表和数据:
+
+### 3.1 表结构修改部分:
+
+ linkis_task 表新增了submit_user和label_json字段,更新语句是:
+
+```mysql-sql
+ ALTER TABLE linkis_task ADD submit_user varchar(50) DEFAULT NULL COMMENT 'submitUser name';
+ ALTER TABLE linkis_task ADD `label_json` varchar(200) DEFAULT NULL COMMENT 'label json';
+```
+
+### 3.2 需要新执行的sql:
+
+```mysql-sql
+ cd db/module
+ ##新增enginePlugin服务依赖的表:
+ source linkis_ecp.sql
+ ##新增public service-instanceLabel 服务依赖的表
+ source linkis_instance_label.sql
+ ##新增linkis-manager服务依赖的表
+ source linkis-manager.sql
+```
+
+### 3.3 publicservice-Configuration表修改
+
+ 为了支持Linkis1.X 的全标签化能力,configuration模块相关数据表已全部升级为标签化,和0.X的Configuration表完全不同,需要重新执行建表语句和初始化语句。
+
+ 这意味着,**Linkis0.X 用户已有的引擎配置参数,已无法迁移到Linkis1.0之中**(建议用户重新配置一次引擎参数)。
+
+ 执行建表语句如下:
+
+```mysql-sql
+ source linkis_configuration.sql
+```
+
+ 执行初始化语句,因为 Linkis1.0 支持对接多版本的引擎,所以执行初始化语句时,一定需要修改对应引擎的版本,如下所示。
+
+```mysql-sql
+ vim linkis_configuration_dml.sql
+ ## 修改对应引擎的默认版本
+ SET @SPARK_LABEL="spark-2.4.3";
+ SET @HIVE_LABEL="hive-1.2.1";
+ ## 保存执行初始化语句
+ source linkis_configuration_dml.sql
+```
+
+## 4. 安装Linkis1.0
+
+ 启动Linkis1.0,验证服务是否已正常启动并对外提供服务,具体请参考: [如何快速安装](../deployment/deploy-quick.md)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/upgrade-guide.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/upgrade-guide.md
new file mode 100644
index 00000000000..3835026d896
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/upgrade-guide.md
@@ -0,0 +1,176 @@
+---
+title: 1.0.3以上的版本升级
+sidebar_position: 2
+---
+
+> 本文简单介绍1.0.3以上的版本的升级大体流程
+
+
+## 1 升级说明
+
+- 如果是第一次安装使用 Linkis,或重装 Linkis,无需关注 Linkis 升级指南。
+- 如果涉及到其他平台的组件(DataSphereStudio/Qualitis/Visualis等),升级前,请确认版本之间的兼容性,最好使用推荐的版本,可参考 https://github.com/apache/linkis#ecosystem。
+- 建议通过软链方式来进行版本管控,可以通过修改软链的目标地址 来切换版本 如:`linkis -> /appcom/Install/LinkisInstall/linkis-1.1.3.20220615210213`
+- 升级过程主要是需要关注数据库表结构的调整和部分配置参数的调整
+- 除了后端服务的升级,linkis的管理台资源也需要一并升级
+- 每个版本的主要变动点 可以查阅版本的总览信息`https://linkis.apache.org/zh-CN/docs/x.x.x /release` 以及版本的[Release-Note](https://linkis.apache.org/zh-CN/download/main):https://linkis.apache.org/zh-CN/download/main
+- 每个版本的数据库变化/配置参数变化 都是基于上一个版本
+
+## 2 服务升级安装
+
+按[部署指引文档](../deployment/deploy-quick)(文档中关于管理台的安装可以跳过),进行新版本的安装。
+
+安装服务时,如果历史数据保留,请保留历史数据,如果无需保留数据,直接重装即可,也无需关注升级流程
+```shell script
+Do you want to clear Linkis table information in the database?
+ 1: Do not execute table-building statements
+ 2: Dangerous! Clear all data and rebuild the tables
+ other: exit
+
+Please input the choice: ## choice 1
+```
+
+## 3. 数据库表升级
+>服务安装完成后,需要对数据库进行结构修改,包括进行表结构变更和表数据变更
+
+
+找到对应的版本`db/upgrade/x.x.x-schema/` sql变动文件
+
+如果是跨多个版本执行,请按版本顺序,依次执行,
+如果某些版本没有x.x.x_schema(linkis>=1.1.0版本后,只要涉及到数据库表的调整,都会有对应版本的schema文件),则表示该版本没有数据表的变化
+
+:::caution 注意
+执行upgrade下的1.1.1_schema中的ddl升级脚本,如若执行到linkis_cg_rm_resource_action_record相关的错误,请检查创建该表的语句是否缺少ENGINE=InnoDB DEFAULT CHARSET=utf8; 如果缺少,请加上再执行
+:::
+
+```shell script
+├── linkis_ddl.sql # 当前版本的全量ddl 数据库定义语言 建表语句
+├── linkis_dml.sql # 当前版本的全量dml 数据操纵语言 数据的增改
+└── upgrade
+ ├── 1.1.0_schema # 对应版本的sql
+ │ └── mysql
+ │ ├── linkis_ddl.sql
+ │ └── linkis_dml.sql
+ ├── 1.1.1_schema
+ │ └── mysql
+ │ ├── linkis_ddl.sql
+ │ └── linkis_dml.sql
+ └── 1.1.3_schema
+ └── mysql
+ └── linkis_ddl.sql
+```
+
+```mysql-sql
+ #如果是跨多个版本执行,请按版本顺序,依次执行 先执行ddl 再执行dml
+ #比如当前从linkis-1.0.3 升级到linkis-1.1.2
+ source upgrade/1.1.0_schema/mysql/linkis_ddl.sql
+ source upgrade/1.1.0_schema/mysql/linkis_dml.sql
+
+ source upgrade/1.1.1_schema/mysql/linkis_ddl.sql
+ source upgrade/1.1.1_schema/mysql/linkis_dml.sql
+
+```
+## 4 数据的调整(可选)
+>按实际情况,决定是否需要做如下调整
+
+### 4.1 TOKEN 配置
+> 用于接口调用时的认证
+
+1.1.1 版本调整将原来的TOKEN配置从`${LINKIS_HOME}/conf/token.properties`迁移到数据库表`linkis_mg_gateway_auth_token`,
+对于原来在`token.properties`额外配置的TOKEN,需要手动迁移表中
+
+### 4.2 UDF 调整
+1.1.1 中支持支持UDF多版本控制、UDF存储到BML的功能特性,UDF函数存储的表结构有调整,UDF的历史数据,需要单独进行迁移
+
+### 4.3 Session 字段key配置
+
+1.1.1 版本中调整了session字段的key,从`bdp-user-ticket-id`-> 调整为 `linkis_user_session_ticket_id_v1`,
+如果是对Linkis的升级。同时部署DSS或者其他项目,但他们服务lib包中,所依赖的Linkis的linkis-module-x.x.x.jar包 <1.1.1,则需要修改位于`${LINKIS_HOME}/conf/linkis.properties`文件
+```shell
+echo "wds.linkis.session.ticket.key=bdp-user-ticket-id" >> linkis.properties
+```
+### 4.4 默认队列的调整
+1.1.1 开始调整了yarn队列默认集群名`wds.linkis.rm.cluster` sit调整为default,如果一直使用的sit,请修改表数据
+`linkis_cg_rm_external_resource_provider`中的集群名
+
+### 4.5 其他相关包的拷贝
+
+如果之前老版本Linkis中`${LINKIS_HOME_OLD}/lib/linkis-engineconn-plugins`有安装第三方appconn插件,需要拷贝至新版本中,
+最好通过软链链接到appconn路径上
+如:
+```
+#查看老版本是否有安装第三方appconn
+cd ${LINKIS_HOME_OLD}/lib/linkis-engineconn-plugins/
+ll
+ appconn -> /appcom/Install/LinkisInstall/appconn
+
+
+#新版本保持一致
+cd ${LINKIS_HOME}/lib/linkis-engineconn-plugins/
+#软链
+ln -snf /appcom/Install/LinkisInstall/appconn appconn
+```
+
+
+如果原来版本有安装dss,需要拷贝原来包中的`dss-gateway-support-x.x.x.jar` 至linkis的`./lib/linkis-spring-cloud-services/linkis-mg-gateway/`目录下
+如:
+```shell script
+cp ${LINKIS_HOME_OLD}/lib/linkis-spring-cloud-services/linkis-mg-gateway/dss-gateway-support-1.1.3.jar ${LINKIS_HOME}/lib/linkis-spring-cloud-services/linkis-mg-gateway/dss-gateway-support-1.1.3.jar
+
+```
+
+## 5 管理台的更新
+
+> 升级后端,同时也需要升级对应的管理台资源,无需执行管理台的安装,直接替换掉静态资源即可
+
+### 5.1 下载前端安装包并解压
+上传至管理台所在的服务器上 ,解压
+```shell script
+tar -xvf apache-linkis-x.x.x-web-bin.tar.gz
+```
+
+
+### 5.2 升级
+>管理台升级方式比较多,因为只是资源的更新,可以通过管理台安装脚本来进行,也可以直接覆盖掉原有的资源,
+>推荐使用软链方式来进行,只需要修改软链的目标地址即可,下面以新建版本资源路径方式为例
+
+nginx配置文件默认是 在`/etc/nginx/conf.d/*`
+nginx的日志文件在 `/var/log/nginx/access.log` 和`/var/log/nginx/error.log`
+
+场景1: 如果是集成再DSS项目中,修改DSS项目中linkis管理台资源的地址指向
+dss的nginx配置文件默认是 在`/etc/nginx/conf.d/dss.conf`
+```nginx
+#示例
+ server {
+ ......
+ location dss/linkis {
+ alias /appcom/Install/linkis-web-newversion/dist; # 静态文件目录
+ index index.html index.html;
+ }
+ .....
+ }
+```
+
+场景2:如果linkis是独立部署
+修改Nginx的配置,静态资源地址 指向新版本的linkis管理台
+linkis的nginx配置文件默认是 在`/etc/nginx/conf.d/dss.conf`
+```nginx
+#示例
+ server {
+ ......
+ location dss/linkis {
+ alias /appcom/Install/linkis-web-newversion/dist; # 静态文件目录
+ index index.html index.html;
+ }
+ ......
+ }
+```
+
+重新加载nginx 配置
+```
+sudo nginx -s reload
+```
+
+### 5.3 注意事项
+
+- 管理台升级后,因为浏览器可能存在缓存,如果要验证效果,最好清空下浏览器缓存
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/upgrade-to-1.4.0-guide.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/upgrade-to-1.4.0-guide.md
new file mode 100644
index 00000000000..6f8cdb01da2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/upgrade/upgrade-to-1.4.0-guide.md
@@ -0,0 +1,193 @@
+---
+title: 1.4.0 的升级指南
+sidebar_position: 3
+---
+
+> Linkis1.4.0 对 Linkis 的服务及代码进行了较多调整,本文介绍升级到 Linkis 1.4.0 的相关注意事项。
+
+## 1. 注意事项
+
+**1) 如果您是首次接触并使用Linkis,您可以忽略该章节,参考[单机部署](../deployment/deploy-quick.md)指南部署 Linkis 即可。**
+
+**2) 如果您已安装 Likis 1.4.0 之前的版本但不想保留原有数据,也可参考[单机部署](../deployment/deploy-quick.md)指南重新部署,安装时选择 2 清理所有数据并重建表即可(见下面代码)。**
+```
+Do you want to clear Linkis table information in the database?
+ 1: Do not execute table-building statements
+ 2: Dangerous! Clear all data and rebuild the tables
+ other: exit
+
+Please input the choice: ## choice 2
+```
+**3) 如果您已安装 Likis 1.4.0 之前的版本但需要保留原有版本数据,可参考本文档指引进行升级。**
+
+****
+
+## 2. 环境升级
+
+Linkis 1.4.0 将默认的依赖环境 Hadoop、Hive、Spark 版本升级为 3.x。分别为 Hadoop 升级为 3.3.4、Hive 升级为 3.1.3、Spark升级为 3.2.1。请将这些环境进行升级后再进行后续操作。
+
+通过如下命令验证升级后版本
+```
+echo $HADOOP_HOME
+/data/hadoop-3.3.4
+echo $HIVE_HOME
+/data/apache-hive-3.1.3-bin
+echo $SPARK_HOME
+/data/spark-3.2.1-bin-hadoop3.2
+```
+
+安装前请修改 deploy-config/linkis-env.sh 文件中 Hadoop、Hive、Spark 相关配置为升级后目录,具体修改项如下:
+
+```
+#HADOOP
+HADOOP_HOME=${HADOOP_HOME:-"/appcom/Install/hadoop"}
+HADOOP_CONF_DIR=${HADOOP_CONF_DIR:-"/appcom/config/hadoop-config"}
+
+## Hadoop env version
+HADOOP_VERSION=${HADOOP_VERSION:-"3.3.4"}
+
+#Hive
+HIVE_HOME=/appcom/Install/hive
+HIVE_CONF_DIR=/appcom/config/hive-config
+
+#Spark
+SPARK_HOME=/appcom/Install/spark
+SPARK_CONF_DIR=/appcom/config/spark-config
+
+```
+
+## 3. 服务升级安装
+
+因为 1.4.0 版本量改动较大,所以旧版本到 1.4.0 版本升级时服务需要进行重新安装。
+
+在安装时如果需要保留旧版本的数据,一定要选择 1 跳过建表语句(见下面代码)。
+
+Linkis 1.4.0 的安装可以参考[如何快速安装](../deployment/deploy-quick.md)
+
+```
+Do you want to clear Linkis table information in the database?
+ 1: Do not execute table-building statements
+ 2: Dangerous! Clear all data and rebuild the tables
+ other: exit
+
+Please input the choice: ## choice 1
+```
+
+## 4. 数据库升级
+ 服务安装完成后,需要对数据库的数据表进行修改,包括表结构变更和表数据更新。执行对应升级版本的 DDL 和 DML 脚本即可。
+ ```
+ #表结构变更
+ linkis-dist\package\db\upgrade\${version}_schema\mysql\linkis_ddl.sql
+ #表数据变更
+ linkis-dist\package\db\upgrade\${version}_schema\mysql\linkis_dml.sql
+ ```
+注意升级时请依次往上执行升级脚本,如从当前版本 1.3.1,升级到 1.4.0 版本。需要先执行 1.3.2 升级的 DDL 和 DML 脚本,再执行 1.4.0 升级的 DDL 和 DML脚本。本文以 1.3.2 升级到 1.4.0 为例进行说明
+
+### 4.1 表结构修改部分:
+
+连接 mysql 数据库执行 linkis-dist\package\db\upgrade\1.3.2_schema\mysql\linkis_ddl.sql 脚本内容,具体内容如下:
+
+```mysql-sql
+ALTER TABLE `linkis_cg_manager_service_instance` ADD COLUMN `identifier` varchar(32) COLLATE utf8_bin DEFAULT NULL;
+ALTER TABLE `linkis_cg_manager_service_instance` ADD COLUMN `ticketId` varchar(255) COLLATE utf8_bin DEFAULT NULL;
+ALTER TABLE `linkis_cg_ec_resource_info_record` MODIFY COLUMN metrics TEXT DEFAULT NULL COMMENT 'ec metrics';
+```
+
+### 4.2 需要新执行的sql:
+
+连接 mysql 数据库执行 linkis-dist\package\db\upgrade\1.3.2_schema\mysql\linkis_dml.sql 脚本内容,具体内容如下:
+```sql
+-- 默认版本升级
+UPDATE linkis_ps_configuration_config_key SET default_value = 'python3' WHERE `key` = 'spark.python.version';
+UPDATE linkis_cg_manager_label SET label_value = '*-*,hive-3.1.3' WHERE label_value = '*-*,hive-2.3.3';
+UPDATE linkis_cg_manager_label SET label_value = '*-IDE,hive-3.1.3' WHERE label_value = '*-IDE,hive-2.3.3';
+UPDATE linkis_cg_manager_label SET label_value = '*-nodeexecution,hive-3.1.3' WHERE label_value = '*-nodeexecution,hive-2.3.3';
+UPDATE linkis_cg_manager_label SET label_value = '*-*,spark-3.2.1' WHERE label_value = '*-*,spark-2.4.3';
+UPDATE linkis_cg_manager_label SET label_value = '*-IDE,spark-3.2.1' WHERE label_value = '*-IDE,spark-2.4.3';
+UPDATE linkis_cg_manager_label SET label_value = '*-Visualis,spark-3.2.1' WHERE label_value = '*-Visualis,spark-2.4.3';
+UPDATE linkis_cg_manager_label SET label_value = '*-nodeexecution,spark-3.2.1' WHERE label_value = '*-nodeexecution,spark-2.4.3';
+
+-- 支持不同的数据源
+INSERT INTO `linkis_ps_dm_datasource_type` (`name`, `description`, `option`, `classifier`, `icon`, `layers`, `description_en`, `option_en`, `classifier_en`) VALUES ('tidb', 'tidb数据库', 'tidb', '关系型数据库', '', 3, 'TiDB Database', 'TiDB', 'Relational Database');
+
+select @data_source_type_id := id from `linkis_ps_dm_datasource_type` where `name` = 'tidb';
+INSERT INTO `linkis_ps_dm_datasource_type_key`
+(`data_source_type_id`, `key`, `name`, `name_en`, `default_value`, `value_type`, `scope`, `require`, `description`, `description_en`, `value_regex`, `ref_id`, `ref_value`, `data_source`, `update_time`, `create_time`)
+VALUES (@data_source_type_id, 'address', '地址', 'Address', NULL, 'TEXT', NULL, 0, '地址(host1:port1,host2:port2...)', 'Address(host1:port1,host2:port2...)', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'host', '主机名(Host)', 'Host', NULL, 'TEXT', NULL, 1, '主机名(Host)', 'Host', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'port', '端口号(Port)', 'Port', NULL, 'TEXT', NULL, 1, '端口号(Port)', 'Port', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'driverClassName', '驱动类名(Driver class name)', 'Driver class name', 'com.mysql.jdbc.Driver', 'TEXT', NULL, 1, '驱动类名(Driver class name)', 'Driver class name', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'params', '连接参数(Connection params)', 'Connection params', NULL, 'TEXT', NULL, 0, '输入JSON格式(Input JSON format): {"param":"value"}', 'Input JSON format: {"param":"value"}', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'username', '用户名(Username)', 'Username', NULL, 'TEXT', NULL, 1, '用户名(Username)', 'Username', '^[0-9A-Za-z_-]+$', NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'password', '密码(Password)', 'Password', NULL, 'PASSWORD', NULL, 0, '密码(Password)', 'Password', '', NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'instance', '实例名(instance)', 'Instance', NULL, 'TEXT', NULL, 1, '实例名(instance)', 'Instance', NULL, NULL, NULL, NULL, now(), now());
+
+INSERT INTO `linkis_ps_dm_datasource_type` (`name`, `description`, `option`, `classifier`, `icon`, `layers`, `description_en`, `option_en`, `classifier_en`) VALUES ('starrocks', 'starrocks数据库', 'starrocks', 'olap', '', 4, 'StarRocks Database', 'StarRocks', 'Olap');
+
+select @data_source_type_id := id from `linkis_ps_dm_datasource_type` where `name` = 'starrocks';
+INSERT INTO `linkis_ps_dm_datasource_type_key`
+(`data_source_type_id`, `key`, `name`, `name_en`, `default_value`, `value_type`, `scope`, `require`, `description`, `description_en`, `value_regex`, `ref_id`, `ref_value`, `data_source`, `update_time`, `create_time`)
+VALUES (@data_source_type_id, 'address', '地址', 'Address', NULL, 'TEXT', NULL, 0, '地址(host1:port1,host2:port2...)', 'Address(host1:port1,host2:port2...)', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'host', '主机名(Host)', 'Host', NULL, 'TEXT', NULL, 1, '主机名(Host)', 'Host', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'port', '端口号(Port)', 'Port', NULL, 'TEXT', NULL, 1, '端口号(Port)', 'Port', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'driverClassName', '驱动类名(Driver class name)', 'Driver class name', 'com.mysql.jdbc.Driver', 'TEXT', NULL, 1, '驱动类名(Driver class name)', 'Driver class name', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'params', '连接参数(Connection params)', 'Connection params', NULL, 'TEXT', NULL, 0, '输入JSON格式(Input JSON format): {"param":"value"}', 'Input JSON format: {"param":"value"}', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'username', '用户名(Username)', 'Username', NULL, 'TEXT', NULL, 1, '用户名(Username)', 'Username', '^[0-9A-Za-z_-]+$', NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'password', '密码(Password)', 'Password', NULL, 'PASSWORD', NULL, 0, '密码(Password)', 'Password', '', NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'instance', '实例名(instance)', 'Instance', NULL, 'TEXT', NULL, 1, '实例名(instance)', 'Instance', NULL, NULL, NULL, NULL, now(), now());
+
+INSERT INTO `linkis_ps_dm_datasource_type` (`name`, `description`, `option`, `classifier`, `icon`, `layers`, `description_en`, `option_en`, `classifier_en`) VALUES ('gaussdb', 'gaussdb数据库', 'gaussdb', '关系型数据库', '', 3, 'GaussDB Database', 'GaussDB', 'Relational Database');
+
+select @data_source_type_id := id from `linkis_ps_dm_datasource_type` where `name` = 'gaussdb';
+INSERT INTO `linkis_ps_dm_datasource_type_key`
+(`data_source_type_id`, `key`, `name`, `name_en`, `default_value`, `value_type`, `scope`, `require`, `description`, `description_en`, `value_regex`, `ref_id`, `ref_value`, `data_source`, `update_time`, `create_time`)
+VALUES (@data_source_type_id, 'address', '地址', 'Address', NULL, 'TEXT', NULL, 0, '地址(host1:port1,host2:port2...)', 'Address(host1:port1,host2:port2...)', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'host', '主机名(Host)', 'Host', NULL, 'TEXT', NULL, 1, '主机名(Host)', 'Host', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'port', '端口号(Port)', 'Port', NULL, 'TEXT', NULL, 1, '端口号(Port)', 'Port', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'driverClassName', '驱动类名(Driver class name)', 'Driver class name', 'org.postgresql.Driver', 'TEXT', NULL, 1, '驱动类名(Driver class name)', 'Driver class name', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'params', '连接参数(Connection params)', 'Connection params', NULL, 'TEXT', NULL, 0, '输入JSON格式(Input JSON format): {"param":"value"}', 'Input JSON format: {"param":"value"}', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'username', '用户名(Username)', 'Username', NULL, 'TEXT', NULL, 1, '用户名(Username)', 'Username', '^[0-9A-Za-z_-]+$', NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'password', '密码(Password)', 'Password', NULL, 'PASSWORD', NULL, 1, '密码(Password)', 'Password', '', NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'instance', '实例名(instance)', 'Instance', NULL, 'TEXT', NULL, 1, '实例名(instance)', 'Instance', NULL, NULL, NULL, NULL, now(), now());
+
+INSERT INTO `linkis_ps_dm_datasource_type` (`name`, `description`, `option`, `classifier`, `icon`, `layers`, `description_en`, `option_en`, `classifier_en`) VALUES ('oceanbase', 'oceanbase数据库', 'oceanbase', 'olap', '', 4, 'oceanbase Database', 'oceanbase', 'Olap');
+
+select @data_source_type_id := id from `linkis_ps_dm_datasource_type` where `name` = 'oceanbase';
+INSERT INTO `linkis_ps_dm_datasource_type_key`
+(`data_source_type_id`, `key`, `name`, `name_en`, `default_value`, `value_type`, `scope`, `require`, `description`, `description_en`, `value_regex`, `ref_id`, `ref_value`, `data_source`, `update_time`, `create_time`)
+VALUES (@data_source_type_id, 'address', '地址', 'Address', NULL, 'TEXT', NULL, 0, '地址(host1:port1,host2:port2...)', 'Address(host1:port1,host2:port2...)', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'host', '主机名(Host)', 'Host', NULL, 'TEXT', NULL, 1, '主机名(Host)', 'Host', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'port', '端口号(Port)', 'Port', NULL, 'TEXT', NULL, 1, '端口号(Port)', 'Port', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'driverClassName', '驱动类名(Driver class name)', 'Driver class name', 'com.mysql.jdbc.Driver', 'TEXT', NULL, 1, '驱动类名(Driver class name)', 'Driver class name', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'params', '连接参数(Connection params)', 'Connection params', NULL, 'TEXT', NULL, 0, '输入JSON格式(Input JSON format): {"param":"value"}', 'Input JSON format: {"param":"value"}', NULL, NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'username', '用户名(Username)', 'Username', NULL, 'TEXT', NULL, 1, '用户名(Username)', 'Username', '^[0-9A-Za-z_-]+$', NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'password', '密码(Password)', 'Password', NULL, 'PASSWORD', NULL, 1, '密码(Password)', 'Password', '', NULL, NULL, NULL, now(), now()),
+ (@data_source_type_id, 'instance', '实例名(instance)', 'Instance', NULL, 'TEXT', NULL, 1, '实例名(instance)', 'Instance', NULL, NULL, NULL, NULL, now(), now());
+```
+
+## 4. 添加mysql驱动包
+linkis 升级为 1.4.0 版本时 mysql 驱动包需使用 8.x 版本,以 8.0.28 版本为例:[下载连接](https://repo1.maven.org/maven2/mysql/mysql-connector-java/8.0.28/mysql-connector-java-8.0.28.jar)拷贝驱动包至lib包下
+
+```
+cp mysql-connector-java-8.0.28.jar ${LINKIS_HOME}/lib/linkis-spring-cloud-services/linkis-mg-gateway/
+cp mysql-connector-java-8.0.28.jar ${LINKIS_HOME}/lib/linkis-commons/public-module/
+```
+
+## 5. 启动服务
+
+```shell
+sh linkis-start-all.sh
+```
+
+## 6. 注意事项
+
+1. Spark 升级为 3.x 后,不兼容 python2,因此在执行 pyspark 任务时需要安装 python3,并执行如下操作
+```shell
+sudo ln -snf /usr/bin/python3 /usr/bin/python2
+```
+并且在 spark 引擎配置 $LINKIS_HOME/lib/linkis-engineconn-plugins/spark/dist/3.2.1/conf/linkis-engineconn.properties 中添加如下配置,指定python安装路径
+```
+pyspark.python3.path=/usr/bin/python3
+```
+2. 升级时配置文件中 Token 值没法自动与原数据库 Token 值统一。需要手动修改 `linkis.properties` 和 `linkis-cli/linkis-cli.properties` 文件中的Token 值为与数据表 `linkis_mg_gateway_auth_token` 相对应的 Token 值。
+3. 低版本升级高版本时请逐级执行数据库升级脚本。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/_category_.json
new file mode 100644
index 00000000000..3f03c3eaa4a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "使用指南",
+ "position": 4
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/_category_.json
new file mode 100644
index 00000000000..b0a16d92f70
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "管理台的使用",
+ "position": 8
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/basicdata-management.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/basicdata-management.md
new file mode 100644
index 00000000000..edd0e2b9a2f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/basicdata-management.md
@@ -0,0 +1,36 @@
+---
+title: 基础数据管理
+sidebar_position: 8
+---
+
+数据源管理页面可以对用户令牌、错误码、扩展资源、引擎物料等数据进行管理。
+
+## 1. 令牌管理
+
+用于管理各应用 Token 信息。
+
+![](../images/basic-token.png)
+
+## 2. 错误码管理
+
+### 2.1 错误码列表
+
+列出错误码信息,可以根据错误码或错误描述进行查询。
+
+![](../images/basic-code.png)
+
+### 2.1 常见错误码问题解决
+
+[常见错误码及处理方法](../../tuning-and-troubleshooting/error-guide/error-code.md)
+
+## 3. 扩展资源管理
+
+用于管理扩展资源,例如 yarn 链接 url 等。
+
+![](../images/basic-ext.png)
+
+## 4. 引擎物料管理
+
+用于管理 Linkis 引擎物料,包括引擎插件的创建、更新以及删除。
+
+![](../images/basic-bml.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/datasource-management.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/datasource-management.md
new file mode 100644
index 00000000000..ef421d96d73
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/datasource-management.md
@@ -0,0 +1,32 @@
+---
+title: 数据源管理
+sidebar_position: 7
+---
+
+数据源管理可以对数据源链接信息、数据源环境、数据源分类以及数据源权限进行处理。
+
+## 1. 数据源管理
+
+数据源管理界面可以查看 Linkis 管理的数据源。并对数据源进行管理,包括创建、修改、测试连接、修改数据源状态等。
+
+![](../images/datasource-manage.png)
+
+## 2. 数据源环境
+
+数据源环境页面可以查看数据源环境,并且可以修改所管理环境的参数。
+
+![](../images/env-list.png)
+
+![](../images/env-edit.png)
+
+## 3. 数据源分类
+
+数据源分类页面用于管理数据源的类型,该分类在数据源管理、数据源权限页面都有使用。
+
+![](../images/ds-class.png)
+
+## 4. 数据源权限
+
+该页面对数据源权限进行管理。
+
+![](../images/ds-auth.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/ecm-management.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/ecm-management.md
new file mode 100644
index 00000000000..1740b069e56
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/ecm-management.md
@@ -0,0 +1,31 @@
+---
+title: ECM 管理
+sidebar_position: 5
+---
+
+ECM 管理界面仅 Linkis 计算治理台管理员可见,该页面用于管理 ECM 和所有引擎。该界面可以查看到ECM的状态信息、修改ECM标签信息、修改ECM状态信息以及查询各个ECM下的所有引擎信息。
+
+## 1. 实例查看
+一个 ECM 实例就是一个 ECM服务。用户可以根据需求启动多个 ECM 服务来提高请求处理效率。该页面可以查看 ECM 实例信息,包括名称、标签以及资源等信息。并且可以通过实例名称、状态、创建者等关键字对 ECM 实例进行过虑。
+
+![](../images/ecm-management.png)
+
+
+## 2. 标签管理
+ECM 服务是根据标签进行请求过虑和处理的。每个服务包含默认标签和用户自定义标签。只有携带 ECM 服务所属标签信息的请求才会被当前服务处理。点击编辑按钮,可以编辑ECM的标签信息(仅允许编辑用户自定义标签),以及修改ECM的状态。
+
+![](../images/edit-label.png)
+
+最常用的是租户标签 tenant,用户可以通过该标签进行租户请求隔离。
+
+## 3. ECM 下的引擎信息
+
+点击 ECM 的实例名称,可以查看该 ECM 下所有的引擎信息。并对引擎进行管理,包括引擎停止、添加或删除用户自定义标签、查看引擎日志等操作。
+
+![](../images/ecm-btn.png)
+
+![](../images/ecm-engine.png)
+
+![](../images/ecm-engine-label.png)
+
+同样的给 ECM 实例下的引擎打标签后,可以更细粒度的控制处理请求的具体引擎。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/global-history.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/global-history.md
new file mode 100644
index 00000000000..77af7562874
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/global-history.md
@@ -0,0 +1,24 @@
+---
+title: 全局历史
+sidebar_position: 1
+---
+
+## 1. 历史任务
+
+全局历史界面提供了用户自身的linkis任务提交记录,各个任务的创建时间、执行语句、状态都可以在此显示。并且可以根据任务ID、时间、引擎、状态等关键字过滤。
+
+> ![](../images/history-interface.png)
+
+
+## 2. 任务详情
+点击左侧按钮可以查看任务执行日志、任务详情以及任务结果。任务执行失败可以通过任务日志排查问题。
+![../images/image2.png](../images/global-history.png)
+
+
+![./media/image3.png](../images/task-log.png)
+
+## 3. 管理员视图
+对于linkis计算治理台管理员来说,管理员可以通过点击页面的切换管理员视图查看所有用户的历史任务。
+
+![./media/image4.png](../images/administrator-view.png)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/global-variable.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/global-variable.md
new file mode 100644
index 00000000000..e04f01295e4
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/global-variable.md
@@ -0,0 +1,9 @@
+---
+title: 全局变量
+sidebar_position: 4
+---
+
+全局变量界面用户可以自定义变量用于代码编写,点击编辑按钮新增参数,添加完保存即可。
+
+![](../images/global-var.png)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/microservice-management.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/microservice-management.md
new file mode 100644
index 00000000000..f4febc1a633
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/microservice-management.md
@@ -0,0 +1,22 @@
+---
+title: 微服务管理
+sidebar_position: 6
+---
+
+Linkis 是基于 Spring Cloud 构建的分布式微服务系统。注册中心服务使用的是 Eureka。微服务管理界面仅对管理员可见。
+
+## 1. 服务查看
+
+微服务管理界面可以查看 Linkis 下的所有微服务信息,可以通过实例名称,引擎类型关键字过滤服务。并且可以通过编辑按钮管理服务下的标签。
+
+![](../images/microservice-list.png)
+
+![](../images/ms-edit.png)
+
+## 2. 注册中心
+
+Linkis 自身的微服务可以点击Eureka注册中心查看,与 Linkis 关联的微服务会直接在该界面列出。
+
+![](../images/eureka-btn.png)
+
+![](../images/eureka.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/overview.md
new file mode 100644
index 00000000000..1b0bac3a9fd
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/overview.md
@@ -0,0 +1,94 @@
+---
+title: 管理台主要接口说明
+sidebar_position: 0
+---
+
+### 1 全局历史
+#### 1.1 主要功能
+- 执行任务的查询:支持根据时间/任务ID/引擎类型/任务状态查询历史任务。
+- 运行态任务的强制停止
+- 管理员用户可以切换管理员视图,查看所有的用户任务
+- 查看任务详细执行日志以及执行结果
+
+#### 1.2 主要接口
+
+- 历史任务的分页查询 /api/rest_j/v1/jobhistory/list
+- 历史任务的详细查询 /api/rest_j/v1/jobhistory/{taskId}/get
+- 日志的查看 /api/rest_j/v1/filesystem/openLog?path=hdfs:%2F%2F%2Ftmp%2Flinkis%2Flog%2F2022-04-12%2FIDE%2Fhadoop%2F466.log
+- 结果集文件列表 /api/rest_j/v1/filesystem/getDirFileTrees?path=hdfs:%2F%2F%2Ftmp%2Flinkis%2Fhadoop%2Flinkis%2F20220412_173302%2FIDE%2F466
+- 执行结果集数据 /api/rest_j/v1/filesystem/openFile?path=hdfs:%2F%2F%2Ftmp%2Flinkis%2Fhadoop%2Flinkis%2F20220412_173302%2FIDE%2F466%2F_0.dolphin&page=1&pageSize=5000
+- 任务的强制kill接口 /api/rest_j/v1/entrance/killJobs
+
+
+### 2 资源管理
+#### 2.1 主要功能
+- 查看登录用户当前启动的引擎状态,占用资源情况
+- 能够通过界面操作停止引擎
+- 管理员用户可以切换管理员视图,查看yarn队列资源,以及资源重置
+
+#### 2.2 主要接口
+- 资源查询接口 /api/rest_j/v1/linkisManager/rm/userresources
+- 详细的资源使用的引擎实例信息 api/rest_j/v1/linkisManager/rm/applicationlist
+- 引擎停止接口 /api/rest_j/v1/linkisManager/rm/enginekill
+- 资源重置接口 /api/rest_j/v1/linkisManager/rm/resetResource?resourceId=2
+- 所有使用资源列表 /api/rest_j/v1/linkisManager/rm/allUserResource?page=1&size=15
+
+
+### 3 参数配置
+#### 3.1 主要功能
+- 用户自定义参数管理的功能
+- 用户可以在该界面管理引擎的相关配置
+- 管理员还能在这里新增应用类型和引擎
+
+#### 3.2 主要接口
+- 查看配置的树形列表 /api/rest_j/v1/configuration/getFullTreesByAppName?creator=%E5%85%A8%E5%B1%80%E8%AE%BE%E7%BD%AE
+- 新建二级引擎配置 /api/rest_j/v1/configuration/createSecondCategory
+- 配置的保存/api/rest_j/v1/configuration/saveFullTree
+
+
+### 4 全局变量
+#### 4.1 主要功能
+- 支持用户可以自定义变量的新增和修改,在任务提交时能够根据配置的变量值进行自动替换。能够进行常用变量的复用
+
+#### 4.2 主要接口
+- 全局变量的保存 /api/rest_j/v1/variable/saveGlobalVariable
+- 全局变量的查询 /api/rest_j/v1/variable/listGlobalVariable
+
+### 5 ECM管理
+> **仅linkis计算治理台管理员可见**
+#### 5.1 主要功能
+- 管理员可以管理ECM和所有引擎,
+- 可以查看到ECM的状态信息、修改ECM标签信息、修改ECM状态信息以及查询各个ECM下的所有引擎信息
+- 可以编辑ECM的标签信息(仅允许编辑部分标签),以及修改ECM的状态。
+- 可以查看该ECM下所有的引擎信息,以及可以针对单个引擎进行的停止操作,查看运行日志,并且可以编辑引擎的标签信息。
+
+最大可用资源通过配置文件参数配置 默认值
+wds.linkis.ecm.memory.max 100g
+wds.linkis.ecm.cores.max 100
+wds.linkis.ecm.engineconn.instances.max 50
+
+
+#### 5.2 主要接口
+- 查询ECM列表 api/rest_j/v1/linkisManager/listAllEMs
+- 修改ECM信息 api/rest_j/v1/linkisManager/modifyEMInfo
+- 查询ecm下的引擎数据 /api/rest_j/v1/linkisManager/listEMEngines
+- 修改引擎信息 api/rest_j/v1/linkisManager/modifyEngineInfo
+- 引擎停止接口 /api/rest_j/v1/linkisManager/rm/enginekill
+- 引擎日志查询接口 /api/rest_j/v1/linkisManager/openEngineLog
+
+
+### 6 微服务管理
+
+#### 6.1 主要功能
+
+可以查看Linkis下的所有微服务信息,仅linkis计算治理台管理员可见。
+
+#### 6.2 主要接口
+- 服务查询 /api/rest_j/v1/microservice/allInstance
+- label的更新 api/rest_j/v1/microservice/instanceLabel
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/param-conf.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/param-conf.md
new file mode 100644
index 00000000000..7a3d03c7745
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/param-conf.md
@@ -0,0 +1,69 @@
+---
+title: 参数配置
+sidebar_position: 3
+---
+
+参数配置界面提供了用户自定义参数管理的功能,用户可以在该界面管理引擎的相关配置。默认提供了 `IDE`、`Visualis`、`nodeexecution` 应用的引擎配置,用户以可以根据需求增删应用和引擎。
+
+## 1. 参数配置说明
+参数配置页主要是对 `Linkis` 各引擎插件的参数进行管理。`Linkis` 中引擎配置是通过标签进行管理的,不同应用下的引擎配置参数是相互隔离的。对于未显示配置的引擎参数,执行任务时会调用系统初始化时默认引擎参数配置。
+
+
+## 2. 新增应用(仅管理员)
+管理员可以通过新增应用类型按钮,新增应用。
+
+![](../images/add-app.png)
+
+## 3. 新增引擎
+
+引擎是跟应用相关联的,在新增引擎前必须先选中对应的引用,如在 `Visualis` 应用下新增引擎。
+
+![](../images/add-engine-btn.png)
+
+![](../images/add-engine.png)
+
+**注意:**引擎版本需要填写 [Linkis 支持的引擎版本](./overview.md)。否则执行 `Linkis` 任务时会报错。
+
+
+## 4. 编辑应用和引擎(仅管理员)
+管理员可以通过编辑目录按钮删除已有的应用和引擎配置(注意!直接删除应用会删除该应用下所有的引擎配置,并且不可恢复),或者添加引擎。
+
+![](../images/del-app.png)
+
+## 5. 全局设置
+
+全局设置主要是对队列资源的参数进行配置,配置后对所有应用任务生效。
+
+![](../images/global-conf.png)
+
+### 5.1 队列设置
+
+**1. 查看可用的队列**
+
+访问 hadoop 集群查看可用队列,地址:http://ip:port/cluster/scheduler
+
+![](../images/yarn-deque.png)
+
+**2. 设置队列**
+
+设置步骤1中查询的可用队列名称,并保存。
+![](../images/yarn-write.png)
+
+**3. 查看设置队列可用资源**
+
+点击右下角按钮查看队列可用资源。
+![](../images/click-yarn.png)
+![](../images/deque-resource.png)
+
+**4. 设置资源限制**
+
+根据步骤3中查询的队列可用资源(CPU、内存)设置资源限制,包括队列实例最大个数、队列CPU使用上限、队列内存使用上限、全局各个引擎内存使用上限等。
+
+
+
+## 6. 引擎参数修改
+
+用户点击对应应用下的引擎标签后,可以对引擎参数进行修改,如修改 `IDE` 应用下的 `JDBC` 引擎。修改完成后点击保存按钮。
+
+![](../images/engine-conf.png)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/permission-instructions-console.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/permission-instructions-console.md
new file mode 100644
index 00000000000..edf05eb55c4
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/permission-instructions-console.md
@@ -0,0 +1,124 @@
+---
+title: 管理台用户权限说明
+sidebar_position: 10
+---
+
+## 1.角色类型
+
+- 管理员(Admin):能够查看所有菜单入口,管理员角色权限最大,包含了历史管理员权限
+- 历史管理员(historyAdmin):除了自己提交的任务之外,还可以查看其他历史任务
+- 普通用户:查看自己提交的任务信息
+
+## 2.功能角色权限图表说明
+
+不同角色在功能中拥有的权限
+
+| 功能名称| 管理员(Admin) | 历史管理员(historyAdmin) | 普通用户 |
+| -------- | -------- | ----- |----- |
+| 管理员视图(全局历史) | √ | √ | |
+| 搜索栏(资源管理) | √ | | |
+| 参数配置 | √ | | |
+| 全局变量 | √ | √ | √ |
+| ECM管理 | √ | | |
+| 微服务管理 | √ | | |
+| 数据源管理 | √ | √ | √ |
+| 数据源环境管理 | √ | | |
+| 数据源类型 | √ | | |
+| UDF管理 | √ | √ | √ |
+| 函数管理 | √ | √ | √ |
+| 租户标签管理 | √ | | |
+| 白名单管理 | √ | | |
+| 代码检索(管理员视图) | √ | | |
+| 代码检索(其他功能) | √ | √ | √ |
+
+## 3.功能权限区分
+
+### 3.1 全局历史
+管理员视图仅历史管理员or管理员可查看
+
+![](/Images-zh/control-panel/qhgly-img.png)
+
+### 3.2 资源管理
+
+搜索栏仅管理员可见
+
+![](/Images-zh/control-panel/sslkj-img.png)
+
+### 3.3 参数配置
+
+仅管理员可以编辑应用
+
+![](/Images-zh/control-panel/glybj-img.png)
+
+### 3.4 全局变量
+
+皆可编辑
+
+![](/Images-zh/control-panel/jksy-img.png)
+
+### 3.5 ECM管理(Admin)
+
+只有管理员才有权限
+
+![](/Images-zh/control-panel/ecmgl-img.png)
+
+### 3.6 微服务管理(Admin)
+
+只有管理员才有权限
+
+![](/Images-zh/control-panel/wfwgl-img.png)
+
+### 3.7 数据源管理
+
+#### 3.7.1 数据源管理
+
+都有权限
+
+![](/Images-zh/control-panel/sou-img.png)
+
+#### 3.7.2 数据源环境管理(Admin)
+
+只有管理员才有权限
+
+![](/Images-zh/control-panel/hj-img.png)
+
+
+#### 3.7.3 数据源类型(Admin)
+
+只有管理员才有权限
+
+![](/Images-zh/control-panel/pzx-img.png)
+
+### 3.8 UDF管理
+
+#### 3.8.1 UDF管理
+
+都有权限
+
+![](/Images-zh/control-panel/udfgl-img.png)
+
+#### 3.8.2 函数管理
+
+都有权限
+
+![](/Images-zh/control-panel/fun-img.png)
+
+### 3.9 基础数据管理(Admin)
+
+#### 3.9.1 租户标签管理
+
+只有管理员才有权限
+
+![](/Images-zh/control-panel/zhbj-img.png)
+
+#### 3.9.2 白名单管理
+
+只有管理员才有权限
+
+![](/Images-zh/control-panel/bmdgl-img.png)
+
+### 3.10 代码检索
+
+其中管理员视图仅管理员可查看
+
+![](/Images-zh/control-panel/dmjs-img.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/resource-limit.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/resource-limit.md
new file mode 100644
index 00000000000..f733c72dca2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/resource-limit.md
@@ -0,0 +1,58 @@
+---
+title: 限制参数调整
+sidebar_position: 5
+---
+
+本文介绍对于内存、CPU等资源不足时如何进行参数调整。
+
+## 1. 队列资源不足
+任务执行过程中报错:错误码 12001,错误信息 队列CPU资源不足,可以调整Spark执行器个数
+
+点击管理台--参数配置--IDE--Spark--显示高级设置--woker引擎资源设置(2)--调整执行器并发数
+![](../images/spark-resource.png)
+
+或者全局设置调整队列资源使用上限。
+
+![](../images/global-limit.png)
+
+## 2. 队列实例数超过限制
+
+任务执行过程中报错:错误码 12003,错误信息 队列实例数超过限制
+
+点击管理台--参数配置--全局设置--队列资源--yarn队列实例最大个数[wds.linkis.rm.yarnqueue.instance.max]
+
+![](../images/yarn-instance.png)
+
+## 3. 全局驱动器内存使用上限
+任务执行过程中报错:错误码 12004,错误信息 全局驱动器内存使用上限,可以设置更低的驱动内存
+
+点击管理台--参数配置--全局设置--队列资源--队列内存使用上限[wds.linkis.rm.yarnqueue.memory.max]
+
+![](../images/engine-memory.png)
+
+## 4. 超出全局驱动器CPU个数上限
+
+任务执行过程中报错:错误码 12005,错误信息 超出全局驱动器CPU个数上限,可以清理空闲引擎
+
+点击管理台--参数配置--全局设置--队列资源--全局各个引擎核心个数上限[wds.linkis.rm.client.core.max]
+
+![](../images/global-core.png)
+
+或者通过清理空闲引擎解决。
+
+## 5. 超出引擎最大并发数上限
+
+任务执行过程中报错:错误码 12006,错误信息 超出引擎最大并发数上限,可以清理空闲引擎
+
+点击管理台--参数配置--全局设置--队列资源--全局各个引擎最大并发数[wds.linkis.rm.instance]
+
+![](../images/global-con.png)
+
+**Spark 引擎**
+![](../images/spark-con.png)
+
+**Hive 引擎**
+
+![](../images/hive-con.png)
+
+其他引擎设置类似 Spark 和 Hive 引擎。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/resource-manager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/resource-manager.md
new file mode 100644
index 00000000000..4e9487ad937
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/resource-manager.md
@@ -0,0 +1,26 @@
+---
+title: 资源管理
+sidebar_position: 2
+---
+
+资源管理页面可以查看历史启动的引擎,以及对现有引擎资源状态进行管理。
+
+## 1. 历史引擎
+
+资源管理的历史引擎栏,用户可以看到自己当前已经启动的引擎状态,包括引擎类型、创建者、以及占用资源的情况。同时也可以根据实例名称、创建用户、引擎类型等关键字进行过滤。
+
+![./media/image5.png](../images/history-engine.png)
+
+## 2. 引擎日志
+点击历史引擎右侧查看日志按钮可以查看引擎启动日志。如果引擎启动失败,也可以通过错误日志排查失败原因。
+![./media/image5.png](../images/engine-view-log.png)
+![./media/image5.png](../images/engine-log.png)
+
+## 3. 资源管理
+资源管理的历史引擎栏,用户可以看到自己当前启动的引擎状态,以及占用资源的情况,也能够通过页面停止引擎。
+![./media/image5.png](../images/resource-management.png)
+
+## 4. 管理员视图
+对于linkis计算治理台管理员来说,可以通过点击资源管理页面的切换管理员视图查看所有用户的引擎资源。
+![./media/image5.png](../images/resource-management-button.png)
+![./media/image5.png](../images/resource-management-administrator.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/spark-param.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/spark-param.md
new file mode 100644
index 00000000000..dffdf001f08
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/spark-param.md
@@ -0,0 +1,27 @@
+---
+title: Spark 引擎参数调整
+sidebar_position: 4
+---
+
+本文介绍如何对 Spark 引擎进行参数调整。
+
+
+## 1. 调整引擎参数
+
+用户可以根据需求在管理台调整 Spark 参数。Linkis 管理台 ==》 参数设置 ==》 选择相应应用 ==》 点击 Spark 引擎会显示 Spark 可设置的参数。
+
+![](../images/set-spark-param.png)
+
+## 2. 增加引擎执行速度
+
+如果想要引擎执行的更快,可以调整执行器个数,执行器核心个数越多执行效率越高。
+
+![](../images/executor-count.png)
+
+## 3. Driver 处理大数据
+
+如果需要拉取大数据再 Driver 处理,需要调整驱动内存参数。
+
+![](../images/executor-memory.png)
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/udf-function.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/udf-function.md
new file mode 100644
index 00000000000..f239291d9c2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/control-panel/udf-function.md
@@ -0,0 +1,176 @@
+---
+title: UDF 的使用
+sidebar_position: 9
+---
+
+## 1.UDF简介
+UDF:User Defined Function,用户自定义函数。某些场景我们需要使用hive的函数来处理一些数据,像count(),sum()这些函数都是内置的。如果我们想要使用一些没有自带的函数功能,则需要自定义功能函数,就可以通过写UDF来完成。
+
+### 1.1 UDF 函数实现
+
+实现一个UDF的方式较为简单:只需要继承UDF类,并重写evaluate方法。
+
+```
+public class HelloUDF extends UDF{
+ public String evaluate(String str){
+ try {
+ return "Hello " + str;
+ } catch (Exception e) {
+ // TODO: handle exception
+ e.printStackTrace();
+ return "ERROR";
+ }
+ }
+```
+
+
+### 1.2 UDF 的几种类型
+
+- UDF 函数(需要注册后才能使用):
+ - 通用类型的UDF函数:指Hive的hql和Spark的sql都可以用的UDF函数,一般编译成jar包
+ - Spark类型的UDF函数:Spark专用的UDF,需要先建立好相应的scala/python脚本,通过scala或python函数来注册,注册之后也可以在sql中使用
+
+- 自定义函数 PythonUDF和ScalaUDF只能在Spark引擎中使用
+ - python函数,基于python编写的函数
+ - scala 函数,基于scala编写的函数
+
+
+## 2.UDF增删改
+点击linkis管理台:首页>>UDF管理
+![](/Images/udf/udf_01.png)
+
+
+进入有"UDF管理"和"函数管理"两栏,其中在函数管理栏是一般的方法函数,比如python和scala函数,这种不需要注册即可在脚本里像普通函数一样使用,UDF则需要注册后才能使用。
+![](/Images/udf/udf_02.png)
+
+
+### 2.1 UDF新增
+新增通用类型的UDF函数:
+
+需要先编译好相应的Jar包,并上传至对应用户的工作空间中(如果是使用的dss全家桶,可以通过scriptis进行上传,如果单独至使用了linkis,需要手动上传至对应的目录)
+
+![](/Images/udf/udf_09.png)
+
+点击新增UDF按钮,有两种类型的UDF可以新增,选“通用”类型及为通过jar包方式注册,注册格式需要写UDF实现类的全限定类名。
+
+![](/Images/udf/udf_03.png)
+
+例如下图 UDFServiceImpl 的全限定类名就是:org.apache.linkis.udf.service.impl.UDFServiceImpl
+
+![](../images/udf-cllass.png)
+
+新增Spark类型的UDF函数:
+
+如果是选择“spark”类型,则选择定义好的scala或python函数来注册,自定义函数需要写 scala 或 python 类型脚本。注册之后也可以在sql中使用,类似:select hello("abc")。
+
+注意:
+1. 注册时应该填写新建脚本中的方法名。
+2. 新增udf后对应的jar包或者脚本内容会上传到bml存储。如果本地修改了资源需要更新后才能生效。
+
+![](/Images/udf/udf_04.png)
+
+### 2.2 UDF修改
+
+点击对应udf的编辑按钮。
+
+![](/Images/udf/udf_05.png)
+
+
+如果需要更新udf的内容,则需要编辑该udf重新上传,并对该udf生成一个新的版本。如果脚本内容没有改变,而只是修改了其他内容如:使用格式,则只更新信息,不会生成新的版本。
+
+![](/Images/udf/udf_06.png)
+
+### 2.3 UDF删除
+
+点击对应udf的删除按钮即可,注意:会删除该udf的所有版本。
+
+![](/Images/udf/udf_07.png)
+
+## 3.UDF使用
+如果要使你创建的UDF生效在程序中使用,则需要加载该UDF。“加载”/“取消加载”的入口处为:进入scriptis左侧UDF函数->个人函数,创建的UDF均在个人函数列表处。
+
+**注1:新增UDF时如果没有在页面上主动取消勾选,则会默认勾选加载。此时需要kill掉对应引擎使之新起一个引擎,操作才会生效。**
+
+**注2:加载/取消加载udf的操作,需要kill掉对应引擎使之新起一个引擎,操作才会生效。**
+
+列表中非个人函数介绍:
+
+BDAP函数:由bdap创建的给用户使用的函数,如脱敏函数等。注:bdap函数需要主动加载才能使用。
+
+系统函数:系统默认的自带函数,不需要用户自己加载就能在代码中使用。
+
+共享函数:其他人共享给你的函数,你需要加载它就能使用
+
+过期函数:也是共享函数,只不过共享者标记了它为过期,暂不影响使用
+
+**按照参数中的 ids 加载udf**
+
+| 参数名 | 说明 | 默认值|
+|--------------------------- |------------------------|--------|
+|`linkis.user.udf.all.load` | 是否加载用户选中的所有 UDF | true |
+|`linkis.user.udf.custom.ids`| UDF ID 列表,用 `,` 分隔 | - |
+
+调用样例:
+
+```http request
+POST /api/rest_j/v1/entrance/submit
+Content-Type: application/json
+Token-Code: dss-AUTH
+Token-User: linkis
+
+{
+ "executionContent": {
+ "code": "show databases",
+ "runType": "sql"
+ },
+ "params": {
+ "configuration": {
+ "startup": {
+ "linkis.user.udf.all.load": false
+ "linkis.user.udf.custom.ids": "1,2,3"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "spark-2.4.3",
+ "userCreator": "linkis-IDE"
+ }
+}
+```
+
+
+## 4.UDF共享
+前提:共享功能需要用户为管理员才能使用,否则前端页面不会提供操作入口。
+
+点击udf的共享按钮:会弹出内容框,输入你想要共享的用户列表(逗号分隔)。
+
+注:共享给他人后需要他人主动加载该UDF才能使用。
+
+
+
+共享之后,被共享用户可以在“共享函数”中找到,勾选加载即可使用。
+
+## 5.其他功能介绍
+### 5.1 UDF移交
+
+如用户离职时可能需要移交个人udf给他人。点击移交按钮,选择你的移交对象,点击确定。
+
+
+
+### 5.2 UDF过期
+
+对于共享给他人的UDF,如果已经被共享用户所加载,则不能直接删除该udf,只能标记该udf为过期。暂时只作标记作用,不影响使用。
+
+### 5.3 UDF版本列表
+
+点击某udf的“版本列表”按钮,可以查看该udf的所有版本。对于每个版本提供如下功能:
+
+创建新版本:将对应版本拷贝一份至最新版本。
+
+下载:将udf文件从bml下载至本地。
+
+查看源码:对于python/scala脚本类型则可以直接查看源码,jar类型不支持。
+
+发布:共享udf可以对其点击发布某个版本,使该版本对被共享用户生效。注:被共享用户使用的是udf已发布的最新版本,个人用户使用的始终是最新版本。
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/datasource-client.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/datasource-client.md
new file mode 100644
index 00000000000..f6355c32b41
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/datasource-client.md
@@ -0,0 +1,143 @@
+---
+title: 数据源 SDK
+sidebar_position: 6
+---
+
+> Linkis DataSource 提供了方便的JAVA和SCALA调用的Client SDK 接口,只需要引入linkis-datasource-client的模块就可以进行使用,
+
+## 1. 引入依赖模块
+```
+
+ org.apache.linkis
+ linkis-datasource-client
+ ${linkis.version}
+
+如:
+
+ org.apache.linkis
+ linkis-datasource-client
+ 1.1.0
+
+```
+
+## 2. Scala测试代码
+建立Scala的测试类LinkisDataSourceClientTest,具体接口含义可以见注释:
+```java
+
+import com.fasterxml.jackson.databind.ObjectMapper
+import org.apache.linkis.common.utils.JsonUtils
+import org.apache.linkis.datasource.client.impl.{LinkisDataSourceRemoteClient, LinkisMetaDataRemoteClient}
+import org.apache.linkis.datasource.client.request.{CreateDataSourceAction, GetAllDataSourceTypesAction, MetadataGetDatabasesAction, UpdateDataSourceParameterAction}
+import org.apache.linkis.datasourcemanager.common.domain.{DataSource, DataSourceType}
+import org.apache.linkis.httpclient.dws.authentication.StaticAuthenticationStrategy
+import org.apache.linkis.httpclient.dws.config.{DWSClientConfig, DWSClientConfigBuilder}
+
+import java.io.StringWriter
+import java.util
+import java.util.concurrent.TimeUnit
+
+
+object LinkisDataSourceClientTest {
+
+ def main(args: Array[String]): Unit = {
+ val clientConfig =DWSClientConfigBuilder.newBuilder
+ .addServerUrl("http://127.0.0.1:9001") //set linkis-mg-gateway url: http://{ip}:{port}
+ .connectionTimeout(30000) //connection timtout
+ .discoveryEnabled(false) //disable discovery
+ .discoveryFrequency(1, TimeUnit.MINUTES) // discovery frequency
+ .loadbalancerEnabled(true) // enable loadbalance
+ .maxConnectionSize(5) // set max Connection
+ .retryEnabled(false) // set retry
+ .readTimeout(30000) //set read timeout
+ .setAuthenticationStrategy(new StaticAuthenticationStrategy) //AuthenticationStrategy Linkis authen suppory static and Token
+ .setAuthTokenKey("hadoop") // set submit user
+ .setAuthTokenValue("xxx") // set passwd or token
+ .setDWSVersion("v1") //linkis rest version v1
+ .build
+ //init datasource remote client
+ val dataSourceClient = new LinkisDataSourceRemoteClient(clientConfig)
+ //init metadata remote client
+ val metaDataClient = new LinkisMetaDataRemoteClient(clientConfig)
+ //get all datasource type
+ testGetAllDataSourceTypes(dataSourceClient)
+ //create kafka datasource
+ testCreateDataSourceForKafka(dataSourceClient)
+ //create es datasource
+ testCreateDataSourceForEs(dataSourceClient)
+ //update datasource parameter for kafka
+ testUpdateDataSourceParameterForKafka(dataSourceClient)
+ //update datasource parameter for es
+ testUpdateDataSourceParameterForEs(dataSourceClient)
+ //get hive metadata database list
+ testMetadataGetDatabases(metaDataClient)
+ }
+
+def testGetAllDataSourceTypes(client:LinkisDataSourceRemoteClient): Unit ={
+ val getAllDataSourceTypesResult = client.getAllDataSourceTypes(GetAllDataSourceTypesAction.builder().setUser("hadoop").build()).getAllDataSourceType
+ System.out.println(getAllDataSourceTypesResult)
+ }
+
+def testCreateDataSourceForKafka(client:LinkisDataSourceRemoteClient): Unit ={
+ val dataSource = new DataSource();
+ val dataSourceType = new DataSourceType
+ dataSourceType.setName("kafka")
+ dataSourceType.setId("2")
+ dataSourceType.setLayers(2)
+ dataSourceType.setClassifier("消息队列")
+ dataSourceType.setDescription("kafka")
+ dataSource.setDataSourceType(dataSourceType)
+ dataSource.setDataSourceName("kafka-test")
+ dataSource.setCreateSystem("client")
+ dataSource.setDataSourceTypeId(2l);
+
+ val dsJsonWriter = new StringWriter
+
+ val mapper = new ObjectMapper
+ JsonUtils.jackson.writeValue(dsJsonWriter, dataSource)
+ val map = mapper.readValue(dsJsonWriter.toString,new util.HashMap[String,Any]().getClass)
+ val id = client.createDataSource(CreateDataSourceAction.builder().setUser("hadoop").addRequestPayloads(map).build()).getInsert_id
+ System.out.println(id)
+
+ }
+
+def testCreateDataSourceForEs(client:LinkisDataSourceRemoteClient): Unit ={
+ val dataSource = new DataSource();
+ dataSource.setDataSourceName("es-test")
+ dataSource.setCreateSystem("client")
+ dataSource.setDataSourceTypeId(7l);
+ val dsJsonWriter = new StringWriter
+ val mapper = new ObjectMapper
+ JsonUtils.jackson.writeValue(dsJsonWriter, dataSource)
+ val map = mapper.readValue(dsJsonWriter.toString,new util.HashMap[String,Any]().getClass)
+ val id = client.createDataSource(CreateDataSourceAction.builder().setUser("hadoop").addRequestPayloads(map).build()).getInsert_id
+ System.out.println(id)
+
+ }
+
+def testUpdateDataSourceParameterForKafka(client:LinkisDataSourceRemoteClient): Unit ={
+ val params = new util.HashMap[String,Any]()
+ val connParams = new util.HashMap[String,Any]()
+ connParams.put("brokers","127.0.0.1:9092")
+ params.put("connectParams",connParams)
+ params.put("comment","kafka data source")
+ client.updateDataSourceParameter(UpdateDataSourceParameterAction.builder().setUser("hadoop").setDataSourceId("7").addRequestPayloads(params).build())
+ }
+
+def testUpdateDataSourceParameterForEs(client:LinkisDataSourceRemoteClient): Unit ={
+ val params = new util.HashMap[String,Any]()
+ val connParams = new util.HashMap[String,Any]()
+ val elasticUrls = new util.ArrayList[String]()
+ elasticUrls.add("http://127.0.0.1:9200")
+ connParams.put("elasticUrls",elasticUrls)
+ params.put("connectParams",connParams)
+ params.put("comment","es data source")
+ client.updateDataSourceParameter(UpdateDataSourceParameterAction.builder().setUser("hadoop").setDataSourceId("8").addRequestPayloads(params).build())
+ }
+
+
+ def testMetadataGetDatabases(client:LinkisMetaDataRemoteClient): Unit ={
+ client.getDatabases(MetadataGetDatabasesAction.builder().setUser("hadoop").setDataSourceId(9l).setUser("hadoop").setSystem("client").build()).getDbs
+ }
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/datasource-manual.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/datasource-manual.md
new file mode 100644
index 00000000000..f579d47206b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/datasource-manual.md
@@ -0,0 +1,536 @@
+---
+title: 数据源功能
+sidebar_position: 4
+---
+
+> 介绍一下如何使用1.1.0版本的新特性功能数据源
+
+## 1.数据源功能介绍
+
+### 1.1 概念
+
+- 数据源:我们将能提供数据存储的数据库服务称为数据库,如mysql/hive/kafka,数据源定义的是连接到实际数据库的配置信息,配置信息主要是连接需要的地址,用户认证信息,连接参数等。存储与linkis的数据库的linkis_ps_dm_datasource_*相关的表中
+- 元数据:单指数据库的元数据,是指定义数据结构的数据,数据库各类对象结构的数据。 例如数据库中的数据库名,表名,列名,字段的长度、类型等信息数据。
+
+### 1.2 三个主要模块
+
+** linkis-datasource-client **
+客户端模块,用户数据源的基本管理的DataSourceRemoteClient,以及进行元数据的查询操作的MetaDataRemoteClient.
+
+** linkis-datasource-manager-server **
+数据源管理模块,服务名ps-data-source-manager。对数据源的进行基本的管理,对外提供数据源的新增,查询,修改,连接测试等http接口。对内提供了rpc服务 ,方便元数据查询模块通过rpc调用,查询数据库建立连接需要的必要信息。
+
+- [http接口文档](/api/http/linkis-ps-publicservice-api/data-source-manager-api.md)
+- http接口类 org.apache.linkis.metadatamanager.server.restful
+- rpc接口类 org.apache.linkis.metadatamanager.server.receiver
+
+** linkis-metedata-manager-server **
+元数据查询模块,服务名ps-metadatamanager。提供对数据库元数据的基本查询功能,对外提供了http接口,对内提供了rpc服务,方便数据源管理模块,通过rpc调用,进行该数据源的连通性测试。
+- [http接口文档](/api/http/linkis-ps-publicservice-api/metadatamanager-api.md)
+- http接口类 org.apache.linkis.datasourcemanager.core.restful
+- rpc接口类 org.apache.linkis.datasourcemanager.core.receivers
+
+
+### 1.3 处理逻辑
+#### 1.3.1 LinkisDataSourceRemoteClient
+功能结构图如下:
+![datasource](/Images-zh/deployment/datasource/datasource.png)
+
+- LinkisDataSourceRemoteClient客户端根据请求参数,组装http请求,
+- HTTP请求发送到linkis-ps-data-source-manager
+- linkis-ps-data-source-manager 会进行基本参数校验,部分接口只能管理员角色能操作
+- linkis-ps-data-source-manager 与数据库进行基本的数据操作
+- linkis-ps-data-source-manager 提供的数据源测试连接的接口 内部通过rpc方式,调用ps-metadatamanager方法进行连接测试
+- http请求处理后的数据结果,会通过注解DWSHttpMessageResult功能,进行结果集到实体类的映射转化
+
+LinkisDataSourceRemoteClient接口
+- GetAllDataSourceTypesResult getAllDataSourceTypes(GetAllDataSourceTypesAction) 查询所有数据源类型
+- QueryDataSourceEnvResult queryDataSourceEnv(QueryDataSourceEnvAction) 查询数据源可使用的集群配置信息
+- GetInfoByDataSourceIdResult getInfoByDataSourceId(GetInfoByDataSourceIdAction): 通过数据源id查询数据源信息
+- QueryDataSourceResult queryDataSource(QueryDataSourceAction) 查询数据源信息
+- GetConnectParamsByDataSourceIdResult getConnectParams(GetConnectParamsByDataSourceIdAction) 获取连接配置参数
+- CreateDataSourceResult createDataSource(CreateDataSourceAction) 创建数据源
+- DataSourceTestConnectResult getDataSourceTestConnect(DataSourceTestConnectAction) 测试数据源是否能正常建立连接
+- DeleteDataSourceResult deleteDataSource(DeleteDataSourceAction) 删除数据源
+- ExpireDataSourceResult expireDataSource(ExpireDataSourceAction) 设置数据源为过期状态
+- GetDataSourceVersionsResult getDataSourceVersions(GetDataSourceVersionsAction) 查询数据源配置的版本列表
+- PublishDataSourceVersionResult publishDataSourceVersion(PublishDataSourceVersionAction) 发布数据源配置版本
+- UpdateDataSourceResult updateDataSource(UpdateDataSourceAction) 更新数据源
+- UpdateDataSourceParameterResult updateDataSourceParameter(UpdateDataSourceParameterAction) 更新数据源配置参数
+- GetKeyTypeDatasourceResult getKeyDefinitionsByType(GetKeyTypeDatasourceAction) 查询某数据源类型需要的配置属性
+
+
+#### 1.3.2 LinkisMetaDataRemoteClient
+功能结构图如下:
+![metadata](/Images-zh/deployment/datasource/metadata.png)
+
+- LinkisMetaDataRemoteClient客户端,根据请求参数,组装http请求,
+- HTTP请求发送到ps-metadatamanager
+- ps-metadatamanager 会进行基本参数校验,
+- 请求会根据参数 datasourceId,发送RPC请求到linkis-ps-data-source-manager,获取该数据源的类型,连接参数如用户名密码等信息
+- 拿到连接需要的信息后,根据数据源类型,加载对应目录下的lib包,通过反射机制调用对应的函数方法,从而查询到元数据信息
+- http请求处理后的数据结果,会通过注解DWSHttpMessageResult功能,进行结果集到实体类的映射转化
+
+LinkisMetaDataRemoteClient接口
+- MetadataGetDatabasesResult getDatabases(MetadataGetDatabasesAction) 查询数据库列表
+- MetadataGetTablesResult getTables(MetadataGetTablesAction) 查询table数据
+- MetadataGetTablePropsResult getTableProps(MetadataGetTablePropsAction)
+- MetadataGetPartitionsResult getPartitions(MetadataGetPartitionsAction) 查询分区表
+- MetadataGetColumnsResult getColumns(MetadataGetColumnsAction) 查询数据表字段
+
+### 1.3 源码模块目录结构
+```shell script
+linkis-public-enhancements/linkis-datasource
+
+├── linkis-datasource-client //客户端代码
+├── linkis-datasource-manager //数据源管理模块
+│ ├── common //数据源管理公共模块
+│ └── server //数据源管理服务模块
+├── linkis-metadata //旧版本已有的模块,保留
+├── linkis-metadata-manager //元数据查询模块
+│ ├── common //元数据查询公共模块
+│ ├── server //元数据查询服务模块
+│ └── service //支持的数据源类型
+│ ├── elasticsearch
+│ ├── hive
+│ ├── kafka
+│ └── jdbc
+
+
+```
+### 1.4 安装包目录结构
+
+```shell script
+/lib/linkis-public-enhancements/
+
+├── linkis-ps-data-source-manager
+├── linkis-ps-metadatamanager
+│ └── service
+│ ├── elasticsearch
+│ ├── hive
+│ ├── kafka
+│ └── jdbc
+```
+`wds.linkis.server.mdm.service.lib.dir` 控制反射调用时加载的类路径,参数默认值是`/lib/linkis-public-enhancements/linkis-ps-metadatamanager/service`
+
+### 1.5 配置参数
+
+参见[调优排障>参数列表#datasource配置参数](/docs/1.1.0/tuning-and-troubleshooting/configuration/#6-数据源及元数据服务配置参数)
+
+### 1.6 新增数据驱动
+1.背景说明:由于某些数据库驱动程序包与Apache许可证不兼容,需要自己引入驱动程序
+
+2.新驱动程序目录:./lib/linkis-public-enhancements/linkis-ps-publicservice
+
+3.驱动程序列表
+
+| Driver Name | Driver Version | Download Link |
+| ----------- | ----------- |----------- |
+| db2 | db2jcc4 | https://www.ibm.com/support/pages/db2-jdbc-driver-versions-and-downloads |
+| dameng | DmJdbcDriver18 | https://download.dameng.com/eco/docs/JAVA_Mybatis_lib.zip |
+| mysql | 5.1.34 | https://repo1.maven.org/maven2/mysql/mysql-connector-java/5.1.34/mysql-connector-java-5.1.34.jar |
+|kingbase| kingbase8 | http://maven.jeecg.org/nexus/content/repositories/jeecg/kingbase/kingbase8/8/kingbase8-8.jar |
+|greenplum | 5.1.4 | https://network.pivotal.io/products/vmware-tanzu-greenplum#/releases/985537/file_groups/5749 |
+| postgresql | 42.3.1 | https://repo1.maven.org/maven2/org/postgresql/postgresql/42.3.1/postgresql-42.3.1.jar|
+| sqlserver | sqlserver2000 | https://www.microsoft.com/en-us/download/details.aspx?id=11774 |
+| oracle | 11.2.0.3 | http://www.datanucleus.org/downloads/maven2/oracle/ojdbc6/11.2.0.3/ojdbc6-11.2.0.3.jar |
+
+
+
+## 2. 数据源功能的启用
+
+linkis的启动脚本中默认不会启动数据源相关的服务两个服务(ps-data-source-manager,ps-metadatamanager),
+如果想使用数据源服务,可以通过如下方式进行开启:
+修改`$LINKIS_CONF_DIR/linkis-env.sh`中的 `export ENABLE_METADATA_MANAGER=true`值为true。
+通过linkis-start-all.sh/linkis-stop-all.sh 进行服务启停时,会进行数据源服务的启动与停止。
+
+通过eureka页面查看服务是否正常启动
+
+![datasource eureka](/Images-zh/deployment/datasource/eureka.png)
+
+:::caution 注意
+- 1.linkis的管理台web版本需要配合升级至1.1.0版本才能在linkis管理台上使用数据源管理页面功能。
+- 2.目前数据源中已有mysql/hive/kafak/elasticsearch的jar包, 但是kafak/elasticsearch数据源未经过严格的测试,不保证功能的完整可用性。
+:::
+
+## 3. 数据源的使用
+数据源的使用分为三步:
+- step 1. 创建数据源/配置连接参数
+- step 2. 发布数据源,选择要使用的连接配置版本
+- step 3. 数据源使用,查询元数据信息
+,hive/kafka/elasticsearch配置是关联对应的集群环境配置.
+
+### 3.1 jdbc 数据源
+#### 3.1.1 通过管理台创建
+>只能创建配置数据源,以及测试数据源是否能正常连接,无法进行直接进行元数据查询
+
+底层实现一个通用jdbc模块,web界面上可以选择下表中任意一种数据源
+
+| Data Source | Link |
+| ----------- |----------- |
+| mysql | https://www.mysql.com |
+| oracle | https://www.oracle.com/database/technologies |
+| kingbase | https://www.kingbase.com.cn |
+| postgresql | https://www.postgresql.org |
+| sqlserver | https://www.microsoft.com/en-us/sql-server |
+| db2 | https://www.ibm.com/products/db2/database |
+| greenplum | https://greenplum.org |
+| dm | https://dmdatabases.com |
+| doris | https://doris.apache.org |
+| clickhouse | https://clickhouse.com |
+
+
+以mysql为例:
+
+> 数据源管理>新增数据源>选择mysql类型
+
+
+输入相关的配置信息
+
+![create mysql](/Images-zh/deployment/datasource/create_mysql.png)
+
+录入成功后可以通过连接测试验证是否能够正常进行连接
+
+
+:::caution 注意
+- 通过管理台创建的数据源归属的system是Linkis
+- 创建成功后,还需要进行发布(发布时进行配置参数版本的切换和选择),才能被正常使用
+:::
+
+配置的发布(使用那个配置进行数据源的建连):
+
+点击版本后再弹窗页面选择合适的配置进行发布
+
+![publish](/Images-zh/deployment/datasource/publish_version.png)
+
+
+#### 3.1.2 使用客户端
+
+scala 代码示例:
+```scala
+package org.apache.linkis.datasource.client
+import java.util
+import java.util.concurrent.TimeUnit
+
+import org.apache.linkis.common.utils.JsonUtils
+import org.apache.linkis.datasource.client.impl.{LinkisDataSourceRemoteClient, LinkisMetaDataRemoteClient}
+import org.apache.linkis.datasource.client.request._
+import org.apache.linkis.datasource.client.response._
+import org.apache.linkis.datasourcemanager.common.domain.DataSource
+import org.apache.linkis.httpclient.dws.authentication.StaticAuthenticationStrategy
+import org.apache.linkis.httpclient.dws.config.DWSClientConfigBuilder
+import org.junit.jupiter.api.{Disabled, Test}
+
+object TestMysqlClient {
+
+ val gatewayUrl = "http://127.0.0.1:9001"
+ val clientConfig = DWSClientConfigBuilder.newBuilder
+ .addServerUrl(gatewayUrl)
+ .connectionTimeout(30000)
+ .discoveryEnabled(false)
+ .discoveryFrequency(1, TimeUnit.MINUTES)
+ .loadbalancerEnabled(true)
+ .maxConnectionSize(1)
+ .retryEnabled(false)
+ .readTimeout(30000)
+ .setAuthenticationStrategy(new StaticAuthenticationStrategy)
+ .setAuthTokenKey("hadoop")
+ .setAuthTokenValue("xxxxx")
+ .setDWSVersion("v1")
+
+ val dataSourceclient = new LinkisDataSourceRemoteClient(clientConfig.build())
+
+ val clientConfig2 = DWSClientConfigBuilder.newBuilder
+ .addServerUrl(gatewayUrl)
+ .connectionTimeout(30000)
+ .discoveryEnabled(false)
+ .discoveryFrequency(1, TimeUnit.MINUTES)
+ .loadbalancerEnabled(true)
+ .maxConnectionSize(1)
+ .retryEnabled(false)
+ .readTimeout(30000)
+ .setAuthenticationStrategy(new StaticAuthenticationStrategy)
+ .setAuthTokenKey("hadoop")
+ .setAuthTokenValue("xxxxx")
+ .setDWSVersion("v1")
+
+ val metaDataClient = new LinkisMetaDataRemoteClient(clientConfig2.build())
+
+ @Test
+ @Disabled
+ def testCreateDataSourceMysql: Unit = {
+ val user = "hadoop"
+ val system = "Linkis"
+
+ //创建数据源
+ val dataSource = new DataSource();
+ val dataSourceName = "for-mysql-test"
+ dataSource.setDataSourceName(dataSourceName)
+ dataSource.setDataSourceDesc("this is for mysql test")
+ dataSource.setCreateSystem(system)
+ dataSource.setDataSourceTypeId(1L)
+
+ val map = JsonUtils.jackson.readValue(JsonUtils.jackson.writeValueAsString(dataSource), new util.HashMap[String, Any]().getClass)
+ val createDataSourceAction: CreateDataSourceAction = CreateDataSourceAction.builder()
+ .setUser(user)
+ .addRequestPayloads(map)
+ .build()
+ val createDataSourceResult: CreateDataSourceResult = dataSourceclient.createDataSource(createDataSourceAction)
+ val dataSourceId = createDataSourceResult.getInsertId
+
+
+ //设置连接参数
+ val params = new util.HashMap[String, Any]
+
+ val connectParams = new util.HashMap[String, Any]
+ connectParams.put("host", "127.0.0.1")
+ connectParams.put("port", "36000")
+ connectParams.put("username", "db username")
+ connectParams.put("password", "db password")
+
+ params.put("connectParams", connectParams)
+ params.put("comment", "init")
+
+ val updateParameterAction: UpdateDataSourceParameterAction = UpdateDataSourceParameterAction.builder()
+ .setUser(user)
+ .setDataSourceId(dataSourceId)
+ .addRequestPayloads(params)
+ .build()
+ val updateParameterResult: UpdateDataSourceParameterResult = dataSourceclient.updateDataSourceParameter(updateParameterAction)
+
+ val version: Long = updateParameterResult.getVersion
+
+ //发布配置版本
+ dataSourceclient.publishDataSourceVersion(
+ PublishDataSourceVersionAction.builder()
+ .setDataSourceId(dataSourceId)
+ .setUser(user)
+ .setVersion(version)
+ .build())
+
+ //使用示例
+ val metadataGetDatabasesAction: MetadataGetDatabasesAction = MetadataGetDatabasesAction.builder()
+ .setUser(user)
+ .setDataSourceName(dataSourceName)
+ .setSystem(system)
+ .build()
+ val metadataGetDatabasesResult: MetadataGetDatabasesResult = metaDataClient.getDatabases(metadataGetDatabasesAction)
+
+ val metadataGetTablesAction: MetadataGetTablesAction = MetadataGetTablesAction.builder()
+ .setUser(user)
+ .setDataSourceName(dataSourceName)
+ .setDatabase("linkis")
+ .setSystem(system)
+ .build()
+ val metadataGetTablesResult: MetadataGetTablesResult = metaDataClient.getTables(metadataGetTablesAction)
+
+ val metadataGetColumnsAction = MetadataGetColumnsAction.builder()
+ .setUser(user)
+ .setDataSourceName(dataSourceName)
+ .setDatabase("linkis")
+ .setSystem(system)
+ .setTable("linkis_datasource")
+ .build()
+ val metadataGetColumnsResult: MetadataGetColumnsResult = metaDataClient.getColumns(metadataGetColumnsAction)
+
+ }
+}
+
+```
+#### 3.1.3 Linkis已支持的JDBC EngineConn
+- MySQL
+- Oracle
+- KingBase
+- PostgreSQL
+- SQLServer
+- DB2
+- Greenplum
+- DM
+- Doris
+- ClickHouse
+- TiDB
+- Starrocks
+- Gaussdb
+- OceanBase
+
+### 3.2 Hive 数据源
+
+#### 3.2.1 通过管理台创建
+
+>只能创建配置数据源,以及测试数据源是否能正常连接,无法进行直接进行元数据查询
+
+先需要进行集群环境信息的配置
+
+表`linkis_ps_dm_datasource_env`
+```roomsql
+INSERT INTO `linkis_ps_dm_datasource_env`
+(`env_name`, `env_desc`, `datasource_type_id`, `parameter`,`create_user`,`modify_user`)
+VALUES
+('testEnv', '测试环境', 4,
+'{\r\n "uris": "thrift://clustername:9083",\r\n "keytab": "4dd408ad-a2f9-4501-83b3-139290977ca2",\r\n "principle":"hadoop@WEBANK.COM",\r\n "hadoopConf":{"hive.metastore.execute.setugi":"true"}\r\n}',
+'user','user');
+```
+主键id作为envId,在建立连接时,需要通过此envId参数,获取集群配置相关信息。
+配置字段解释:
+```
+{
+ "uris": "thrift://clustername:9083", # 必选 如果未开启kerberos认证 下列[keytab][principle]参数可以为空
+ "keytab": "bml resource id",//keytab 存储再物料库中的resourceId,目前需要通过http接口手动上传。
+ "principle":"hadoop@WEBANK.COM" //认证的principle
+ "hadoopConf":{} //额外的连接参数 可选
+}
+```
+
+keytab的resourceId获取方式,目前基础数据管理功能还在规划中,可以通过http接口请求获取到
+参考示例
+```shell script
+curl --form "file=@文件路径" \
+--form system=子系统名 \
+-H "Token-Code:认证token" \
+-H "Token-User:认证用户名" \
+http://linkis-gatewayip:port/api/rest_j/v1/bml/upload
+
+示例:
+curl --form "file=@/appcom/keytab/hadoop.keytab" \
+--form system=ABCD \
+-H "Token-Code:QML-AUTH" \
+-H "Token-User:hadoop" \
+http://127.0.0.1:9001/api/rest_j/v1/bml/upload
+
+请求结果中的resourceId 即为对应的`bml resource id`值
+{"method":"/bml/upload","status":0,"message":"The task of submitting and uploading resources was successful(提交上传资源任务成功)","data":{"resourceId":"6e4e54fc-cc97-4d0d-8d5e-a311129ec84e","version":"v000001","taskId":35}}
+```
+
+
+web端创建:
+
+![create_hive](/Images-zh/deployment/datasource/create_hive.png)
+
+#### 3.2.2 使用客户端
+```scala
+package org.apache.linkis.datasource.client
+
+import java.util
+import java.util.concurrent.TimeUnit
+
+import org.apache.linkis.common.utils.JsonUtils
+import org.apache.linkis.datasource.client.impl.{LinkisDataSourceRemoteClient, LinkisMetaDataRemoteClient}
+import org.apache.linkis.datasource.client.request._
+import org.apache.linkis.datasource.client.response._
+import org.apache.linkis.datasourcemanager.common.domain.DataSource
+import org.apache.linkis.httpclient.dws.authentication.StaticAuthenticationStrategy
+import org.apache.linkis.httpclient.dws.config.DWSClientConfigBuilder
+import org.junit.jupiter.api.{Disabled, Test}
+
+object TestHiveClient {
+ val gatewayUrl = "http://127.0.0.1:9001"
+ val clientConfig = DWSClientConfigBuilder.newBuilder
+ .addServerUrl(gatewayUrl)
+ .connectionTimeout(30000)
+ .discoveryEnabled(false)
+ .discoveryFrequency(1, TimeUnit.MINUTES)
+ .loadbalancerEnabled(true)
+ .maxConnectionSize(1)
+ .retryEnabled(false)
+ .readTimeout(30000)
+ .setAuthenticationStrategy(new StaticAuthenticationStrategy)
+ .setAuthTokenKey("hadoop")
+ .setAuthTokenValue("xxxxx")
+ .setDWSVersion("v1")
+
+ val dataSourceclient = new LinkisDataSourceRemoteClient(clientConfig.build())
+
+ val clientConfig2 = DWSClientConfigBuilder.newBuilder
+ .addServerUrl(gatewayUrl)
+ .connectionTimeout(30000)
+ .discoveryEnabled(false)
+ .discoveryFrequency(1, TimeUnit.MINUTES)
+ .loadbalancerEnabled(true)
+ .maxConnectionSize(1)
+ .retryEnabled(false)
+ .readTimeout(30000)
+ .setAuthenticationStrategy(new StaticAuthenticationStrategy)
+ .setAuthTokenKey("hadoop")
+ .setAuthTokenValue("xxxxx")
+ .setDWSVersion("v1")
+
+ val metaDataClient = new LinkisMetaDataRemoteClient(clientConfig2.build())
+
+
+ @Test
+ @Disabled
+ def testCreateDataSourceMysql: Unit = {
+ val user = "hadoop"
+ val system = "Linkis"
+
+ //创建数据源
+ val dataSource = new DataSource();
+ val dataSourceName = "for-hive-test"
+ dataSource.setDataSourceName(dataSourceName)
+ dataSource.setDataSourceDesc("this is for hive test")
+ dataSource.setCreateSystem(system)
+ dataSource.setDataSourceTypeId(4L)
+
+ val map = JsonUtils.jackson.readValue(JsonUtils.jackson.writeValueAsString(dataSource), new util.HashMap[String, Any]().getClass)
+ val createDataSourceAction: CreateDataSourceAction = CreateDataSourceAction.builder()
+ .setUser(user)
+ .addRequestPayloads(map)
+ .build()
+ val createDataSourceResult: CreateDataSourceResult = dataSourceclient.createDataSource(createDataSourceAction)
+ val dataSourceId = createDataSourceResult.getInsertId
+
+ //设置连接参数
+ val params = new util.HashMap[String, Any]
+ val connectParams = new util.HashMap[String, Any]
+ connectParams.put("envId", "3")
+ params.put("connectParams", connectParams)
+ params.put("comment", "init")
+
+ val updateParameterAction: UpdateDataSourceParameterAction = UpdateDataSourceParameterAction.builder()
+ .setUser(user)
+ .setDataSourceId(dataSourceId)
+ .addRequestPayloads(params)
+ .build()
+ val updateParameterResult: UpdateDataSourceParameterResult = dataSourceclient.updateDataSourceParameter(updateParameterAction)
+
+ val version: Long = updateParameterResult.getVersion
+
+ //发布配置版本
+ dataSourceclient.publishDataSourceVersion(
+ PublishDataSourceVersionAction.builder()
+ .setDataSourceId(dataSourceId)
+ .setUser(user)
+ .setVersion(version)
+ .build())
+
+ //使用示例
+ val metadataGetDatabasesAction: MetadataGetDatabasesAction = MetadataGetDatabasesAction.builder()
+ .setUser(user)
+ .setDataSourceName(dataSourceName)
+ .setSystem(system)
+ .build()
+ val metadataGetDatabasesResult: MetadataGetDatabasesResult = metaDataClient.getDatabases(metadataGetDatabasesAction)
+
+ val metadataGetTablesAction: MetadataGetTablesAction = MetadataGetTablesAction.builder()
+ .setUser(user)
+ .setDataSourceName(dataSourceName)
+ .setDatabase("linkis_test_ind")
+ .setSystem(system)
+ .build()
+ val metadataGetTablesResult: MetadataGetTablesResult = metaDataClient.getTables(metadataGetTablesAction)
+
+
+
+ val metadataGetColumnsAction = MetadataGetColumnsAction.builder()
+ .setUser(user)
+ .setDataSourceName(dataSourceName)
+ .setDatabase("linkis_test_ind")
+ .setSystem(system)
+ .setTable("test")
+ .build()
+ val metadataGetColumnsResult: MetadataGetColumnsResult = metaDataClient.getColumns(metadataGetColumnsAction)
+
+ }
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/dynamic-variables.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/dynamic-variables.md
new file mode 100644
index 00000000000..3810b8674bb
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/dynamic-variables.md
@@ -0,0 +1,342 @@
+---
+title: 内置时间变量
+sidebar_position: 7
+---
+
+## 1. 总述
+### 需求
+1. 用户希望Linkis能够提供一些公共变量然后执行的时候进行替换,比如用户每天都会批量跑同一段sql,需要指定上一天的分区时间,如果基于sql去写会比较复杂如果系统提供一个run_date的变量将会非常方便使用。
+2. 用户希望Linkis支持date pattern计算,支持在代码中写&{YYYY-MM-DD}等变量计算时间变量
+3. 用户希望自己定义变量,比如定一个一个float变量,然后在代码中进行使用
+
+### 目标
+1. 支持任务代码的变量替换
+2. 支持自定义变量,支持用户在脚本和提交给Linkis的任务参数定义自定义变量,支持简单的+,-等计算
+3. 预设置系统变量:run_date,run_month,run_today等系统变量
+4. 支持date pattern变量,支持pattern的+,-操作
+
+具体技术架构可以参考:
+[Linkis自定义变量](https://linkis.apache.org/docs/latest/architecture/commons/variable/)
+
+## 2 自定义变量功能介绍
+ Linkis支持的变量类型分为自定义变量和系统内置变量,内部变量是Linkis预先定义好的,可以直接进行使用。然后不同的变量类型支持不同的计算格式:String支持+、整数小数支持+-*/,日期支持+-。
+
+### 2.1 内置变量
+目前已支持的内置变量如下:
+(下表中的变量值举例以闰年的20240229作为特殊日期)
+
+| 变量名 | 变量类型 | 变量含义 | 变量值举例 |
+| ------ | -------- | -------- | ---------- |
+| run\_date | String | 数据统计时间(支持用户自己设定,默认设置为当前时间的前一天),如今天执行昨天的数据,则为昨天的时间,格式为 yyyyMMdd | 20240229 |
+| run\_date\_std | String | 数据统计时间(标准日期格式),如今天执行昨天数据,则为昨天的时间,格式为 yyyy-MM-dd | 2024-02-29 |
+| run_today | String | run_date (数据统计时间) 的后一天,格式为 yyyyMMdd | 20240301 |
+| run_today_std | String | run_date (数据统计时间) 的后一天(标准格式),格式为 yyyy-MM-dd | 2024-03-01 |
+| run_mon | String | run_date所在月,格式为 yyyyMM | 202402 |
+| run_mon_std | String | run_date所在月(标准格式),格式为 yyyy-MM | 2024-02 |
+| run\_month\_begin | String | 数据统计时间所在月的第一天,格式为 yyyyMMdd | 20240201 |
+| run\_month\_begin\_std | String | run_date 所在月的第一天(标准日期格式),格式为 yyyy-MM-dd | 2024-02-01 |
+| run_month_now_begin | String | run_today所在上月的第一天,格式为 yyyyMMdd | 20240201 |
+| run_month_now_begin_std | String | run_today所在上月的第一天(标准格式),格式为 yyyy-MM-dd | 2024-02-01 |
+| run\_month\_end | String | run_date所在月的最后一天,格式为 yyyyMMdd | 20240229 |
+| run\_month\_end\_std | String | run_date 所在月的最后一天(标准日期格式),格式为 yyyy-MM-dd | 2024-02-29 |
+| run_month_now_end | String | run_today 所在上月的最后一天,格式为 yyyyMMdd | 20240229 |
+| run_month_now_end_std | String | run_today 所在上月的最后一天(标准日期格式),格式为 yyyy-MM-dd | 2024-02-29 |
+| run_quarter_begin | String | run_date所在季度的第一天,格式为 yyyyMMdd | 20240101 |
+| run_quarter_end | String | run_date 所在季度的最后一天,格式为 yyyyMMdd | 20240331 |
+| run_half_year_begin | String | run_date 所在半年的第一天,格式为 yyyyMMdd | 20240101 |
+| run_half_year_end | String | run_date所在半年的最后一天,格式为 yyyyMMdd | 20240630 |
+| run_year_begin | String | run_date所在年的第一天,格式为 yyyyMMdd | 20240101 |
+| run_year_end | String | run_date所在年的最后一天,格式为 yyyyMMdd | 20241231 |
+| run_quarter_begin_std | String | run_date所在季度的第一天(标准格式),格式为 yyyy-MM-dd | 2024-01-01 |
+| run_quarter_end_std | String | run_date所在季度的最后一天(标准格式),格式为 yyyy-MM-dd | 2024-03-31 |
+| run_half_year_begin_std | String | run_date所在半年的第一天(标准格式),格式为 yyyy-MM-dd | 2024-01-01 |
+| run_half_year_end_std | String | run_date所在半年的最后一天(标准格式),格式为 yyyy-MM-dd | 2024-06-30 |
+| run_year_begin_std | String | run_date所在年的第一天(标准格式),格式为 yyyy-MM-dd | 2024-01-01 |
+| run_year_end_std | String | run_date所在年的最后一天(标准格式),格式为 yyyy-MM-dd | 2024-12-31 |
+| run_tody_h | String | run_today任务运行的时间, yyyyMMddHH | 2024030111 |
+| run_tody_h_std | String | run_today任务运行的时间 yyyy-MM-dd HH | 2024-03-01 11 |
+
+具体细节:
+
+1、run_date为核心自带日期变量,支持用户自定义日期,如果不指定默认为当前系统时间的前一天。
+2、其他衍生内置日期变量定义:其他日期内置变量都是相对run_date计算出来的,一旦run_date变化,其他变量值也会自动跟着变化,其他日期变量不支持设置初始值,只能通过修改run_date进行修改。
+3、内置变量支持更加丰富的使用场景:${run_date-1}为run_data的前一天;${run_month_begin-1}为run_month_begin的上个月的第一天,这里的-1表示减一个月。
+
+以sql为例的例子:
+```
+--@set run_date=20240229
+select
+"${run_date}" as run_date,
+"${run_date_std}" as run_date_std,
+"${run_today}" as run_today,
+"${run_today_std}" as run_today_std,
+"${run_mon}" as run_mon,
+"${run_mon_std}" as run_mon_std,
+"${run_month_begin}" as run_month_begin,
+"${run_month_begin_std}" as run_month_begin_std,
+"${run_month_now_begin}" as run_month_now_begin,
+"${run_month_now_begin_std}" as run_month_now_begin_std,
+"${run_month_end}" as run_month_end,
+"${run_month_end_std}" as run_month_end_std,
+"${run_month_now_end}" as run_month_now_end,
+"${run_month_now_end_std}" as run_month_now_end_std,
+"${run_quarter_begin}" as run_quarter_begin,
+"${run_quarter_end}" as run_quarter_end,
+"${run_half_year_begin}" as run_half_year_begin,
+"${run_half_year_end}" as run_half_year_end,
+"${run_year_begin}" as run_year_begin,
+"${run_year_end}" as run_year_end,
+"${run_quarter_begin_std}" as run_quarter_begin_std,
+"${run_quarter_end_std}" as run_quarter_end_std,
+"${run_half_year_begin_std}" as run_half_year_begin_std,
+"${run_half_year_end_std}" as run_half_year_end_std,
+"${run_year_begin_std}" as run_year_begin_std,
+"${run_year_end_std}" as run_year_end_std,
+"${run_today_h}" as run_tody_h,
+"${run_today_h_std}" as run_tody_h_std
+
+编译替换后的内容:
+select
+"20240229" as run_date,
+"2024-02-29" as run_date_std,
+"20240301" as run_today,
+"2024-03-01" as run_today_std,
+"202402" as run_mon,
+"2024-02" as run_mon_std,
+"20240201" as run_month_begin,
+"2024-02-01" as run_month_begin_std,
+"20240201" as run_month_now_begin,
+"2024-02-01" as run_month_now_begin_std,
+"20240229" as run_month_end,
+"2024-02-29" as run_month_end_std,
+"20240229" as run_month_now_end,
+"2024-02-29" as run_month_now_end_std,
+"20240101" as run_quarter_begin,
+"20240331" as run_quarter_end,
+"20240101" as run_half_year_begin,
+"20240630" as run_half_year_end,
+"20240101" as run_year_begin,
+"20241231" as run_year_end,
+"2024-01-01" as run_quarter_begin_std,
+"2024-03-31" as run_quarter_end_std,
+"2024-01-01" as run_half_year_begin_std,
+"2024-06-30" as run_half_year_end_std,
+"2024-01-01" as run_year_begin_std,
+"2024-12-31" as run_year_end_std,
+"2024030111" as run_tody_h,
+"2024-03-01 11" as run_tody_h_std
+
+```
+
+### 2.2 自定义变量
+ 什么是自定义变量?先定义,后使用的用户变量。用户自定义变量暂时支持字符串,整数,浮点数变量的定义,其中字符串支持+法,整数和浮点数支持+-*/方法。用户自定义变量与SparkSQL和HQL本身支持的set变量语法不冲突,但是不允许同名。如何定义和使用自定义变量?如下:
+```
+## 代码中定义,在任务代码前进行指定
+sql类型定义方式:
+--@set f=20.1
+python/Shell类型定义如下:
+#@set f=20.1
+注意:只支持一行定义一个变量
+```
+使用都是直接在代码中使用通过 ```{varName表达式},如${f*2}```
+
+### 2.3 变量作用域
+在linkis中自定义变量也有作用域,优先级为脚本中定义的变量大于在任务参数中定义的Variable大于内置的run_date变量。任务参数中定义如下:
+```
+## restful
+{
+ "executionContent": {"code": "select \"${f-1}\";", "runType": "sql"},
+ "params": {
+ "variable": {f: "20.1"},
+ "configuration": {
+ "runtime": {
+ "linkis.openlookeng.url":"http://127.0.0.1:9090"
+ }
+ }
+ },
+ "source": {"scriptPath": "file:///mnt/bdp/hadoop/1.sql"},
+ "labels": {
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+## java SDK
+JobSubmitAction.builder
+ .addExecuteCode(code)
+ .setStartupParams(startupMap)
+ .setUser(user) //submit user
+ .addExecuteUser(user) //execute user
+ .setLabels(labels)
+ .setVariableMap(varMap) //setVar
+ .build
+```
+
+## 3. Date Pattern变量介绍
+
+### 3.1 功能
+
+* 支持Pattern格式时间且用户可以自行随意指定
+* Pattern日期变量都是相对run_date计算出来的
+* 支持±y/±M/±d/±H等等
+* 其中+-是先对linkis内置参数run_date进行运算,然后将%之前的pattern字段进行替换,非Pattern字符不支持运算替换。
+
+Pattern格式对照表:
+
+Letter| Date or Time Component| Presentation| Examples
+----- | ----- | ----- | -----
+G |Era designator |Text |AD
+y |Year |Year |1996; 96
+Y |Week year |Year |2009; 09
+M |Month in year |Month| July; Jul; 07
+w |Week in year |Number |27
+W |Week in month |Number |2
+D |Day in year |Number| 189
+d |Day in month |Number |10
+F |Day of week in month| Number |2
+E |Day name in week |Text |Tuesday; Tue
+u |Day number of week (1 = Monday, …, 7 = Sunday) |Number |1
+a |Am/pm marker |Text |PM
+H |Hour in day (0-23) |Number| 0
+k |Hour in day (1-24)| Number |24
+K |Hour in am/pm (0-11)| Number |0
+h |Hour in am/pm (1-12) |Number |12
+m |Minute in hour |Number |30
+s |Second in minute |Number| 55
+S |Millisecond |Number |978
+z |Time zone |General time zone |Pacific Standard Time; PST; GMT-08:00
+Z |Time zone |RFC 822 time zone |-0800
+X |Time zone |ISO 8601 time zone |-08; -0800; -08:00
+
+
+### 3.2 Date Pattern变量举例
+可以根据自己的喜好/业务实际情况定义需要动态渲染的参数
+
+variable | result
+--- | ---
+&{yyyy-01-01} | 2021-01-01
+&{yyyy-01-01%-2y} | 2019-01-01
+&{yyyy-MM-01%-2M} | 2021-02-01
+&{yyyy-MM-dd%-2d} | 2021-03-31
+&{yyyy MM ----- HH%-1H} | 2021 04 ----- 14
+&{yyyyMMdd%-1d} | 20210401
+&{yyyyMM01%-1M} | 20210301
+&{HH%-1H} | 14
+
+### 3.3 Date Pattern变量使用实例
+
+* 例子1: sql
+```sql
+SELECT * FROM hive.tmp.fund_nav_histories
+WHERE dt <= DATE_FORMAT(DATE_ADD('day', -1, DATE(Date_parse('&{yyyyMMdd%-1d}', '%Y%m%d'))), '%Y%m%d')
+```
+渲染后
+```sql
+SELECT * FROM hive.tmp.fund_nav_histories
+WHERE dt <= DATE_FORMAT(DATE_ADD('day', -1, DATE(Date_parse('20220705', '%Y%m%d'))), '%Y%m%d')
+```
+
+* 例子2: shell
+```shell
+aws s3 ls s3://***/ads/tmp/dws_member_active_detail_d_20210601_20211231/pt=&{yyyyMMdd%-1d}/
+```
+渲染后
+```shell
+aws s3 ls s3://***/ads/tmp/dws_member_active_detail_d_20210601_20211231/pt=20220705/
+```
+
+* 例子3: datax json
+```json
+{
+ "job": {
+ "setting": {
+ "speed": {
+ "channel": 1
+ }
+ },
+ "content": [
+ {
+ "reader": {
+ "name": "s3reader",
+ "parameter": {
+ "bucket": "**************",
+ "path": [
+ "ads/tmp/ccass_tm_announcements/&{yyyyMMdd%-1d}/"
+ ],
+ "stored": "parquet",
+ "compression": "NONE",
+ "column": [
+ {
+ "index": 0,
+ "type": "int"
+ },
+ {
+ "index": 1,
+ "type": "string",
+ "constant": "&{yyyyMMdd%-1d}"
+ }
+ ]
+ }
+ },
+ "writer": {
+ "name": "streamwriter",
+ "parameter": {
+ "print": true
+ }
+ }
+ }
+ ]
+ }
+}
+```
+渲染后
+```json
+{
+ "job": {
+ "setting": {
+ "speed": {
+ "channel": 1
+ }
+ },
+ "content": [
+ {
+ "reader": {
+ "name": "s3reader",
+ "parameter": {
+ "bucket": "**************",
+ "path": [
+ "ads/tmp/ccass_tm_announcements/20220705/"
+ ],
+ "stored": "parquet",
+ "compression": "NONE",
+ "column": [
+ {
+ "index": 0,
+ "type": "int"
+ },
+ {
+ "index": 1,
+ "type": "string",
+ "constant": "20220705"
+ }
+ ]
+ }
+ },
+ "writer": {
+ "name": "streamwriter",
+ "parameter": {
+ "print": true
+ }
+ }
+ }
+ ]
+ }
+}
+```
+* 例子4:python
+```python
+print(&{yyyyMMdd%-1d})
+```
+渲染后
+```
+ 20220705
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/how-to-use.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/how-to-use.md
new file mode 100644
index 00000000000..218d437b290
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/how-to-use.md
@@ -0,0 +1,24 @@
+---
+title: 如何使用 Linkis
+sidebar_position: 1
+---
+
+ Linkis为了满足不同的使用场景需求,提供多种使用和接入方式,概括为三类,分别是Client端使用、Scriptis端使用、DataSphere Studio端使用,其中Scriptis和DataSphere Studio是微众银行大数据平台室开源的数据分析平台,由于这两个项目本质上完全兼容Linkis,所以通过Scriptis和DataSphere Studio使用Linkis最为简单。
+## 1. Client端使用
+
+ 如果需要在Linkis的基础上,接入其它应用,需要针对Linkis提供的接口进行开发,Linkis提供了多种客户端接入接口,更详细的使用介绍可以参考以下内容:
+- [**Restful API使用方式**](api/linkis-task-operator.md)
+- [**JDBC API使用方式**](api/jdbc-api.md)
+- [**Java SDK使用方式**](../user-guide/sdk-manual.md)
+## 2. Scriptis使用Linkis
+ 如果需要使用Linkis完成交互式在线分析处理的工作,并且不需要诸如工作流开发、工作流调度、数据服务等数据分析应用工具,可以单独安装[**Scriptis**](https://github.com/WeBankFinTech/Scriptis),详细安装教程可参考其对应的安装部署文档。
+### 2.1. 使用Scriptis执行脚本
+ 目前Scriptis支持向Linkis提交多种任务类型,包括Spark SQL、Hive SQL、Scala、PythonSpark等,为了满足数据分析的需求,Scriptis左侧,提供查看用户工作空间信息、用户数据库和表信息、用户自定义函数,以及HDFS目录,同时支持上传下载,结果集导出等功能。Scriptis使用Linkis十分简单,可以很方便的在编辑栏书写脚本,提交到Linkis运行。
+![Scriptis使用Linkis](/Images-zh/EngineUsage/sparksql-run.png)
+### 2.2. Scriptis管理台
+ Linkis提供资源配置和管理的接口,如果希望对任务资源进行配置管理,可以在Scriptis的管理台界面进行设置,包括队列设置、资源配置、引擎实例个数等。通过管理台,可以很方便的配置向Linkis提交任务的资源,使得更加方便快捷。
+![Scriptis使用Linkis](/Images-zh/EngineUsage/queue-set.png)
+
+## 3. DataSphere Studio使用Linkis
+ [**DataSphere Studio**](https://github.com/WeBankFinTech/DataSphereStudio)简称DSS,是微众银行大数据平台开源的一站式数据分析处理平台,DSS交互式分析模块集成了Scriptis,使用DSS进行交互式分析和Scriptis一样,除了提供Scriptis的基本功能外,DSS提供和集成了更加丰富和强大的数据分析功能,包括用于数据提取的数据服务、开发报表的工作流、可视化分析软件Visualis等。由于原生的支持,目前DSS是与Linkis集成度最高的软件,如果希望使用完整的Linkis功能,建议使用DSS搭配Linkis一起使用。
+![DSS运行工作流](/Images-zh/EngineUsage/workflow.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-app.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-app.png
new file mode 100644
index 00000000000..b7cb3d5edd3
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-app.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-engine-btn.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-engine-btn.png
new file mode 100644
index 00000000000..aae816f7958
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-engine-btn.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-engine.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-engine.png
new file mode 100644
index 00000000000..09cb047501d
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-engine.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-spark-engine.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-spark-engine.png
new file mode 100644
index 00000000000..83301467232
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/add-spark-engine.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/administrator-view.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/administrator-view.png
new file mode 100644
index 00000000000..f5b7041b3d1
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/administrator-view.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-bml.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-bml.png
new file mode 100644
index 00000000000..95ccfc4dd6b
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-bml.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-code.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-code.png
new file mode 100644
index 00000000000..831aadfcce3
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-code.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-ext.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-ext.png
new file mode 100644
index 00000000000..2c14c8eb621
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-ext.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-token.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-token.png
new file mode 100644
index 00000000000..7508b371f62
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/basic-token.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/click-yarn.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/click-yarn.png
new file mode 100644
index 00000000000..020bc40d29c
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/click-yarn.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/configuration-interface.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/configuration-interface.png
new file mode 100644
index 00000000000..deadf64dfbf
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/configuration-interface.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/datasource-manage.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/datasource-manage.png
new file mode 100644
index 00000000000..aed522b52f8
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/datasource-manage.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/del-app.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/del-app.png
new file mode 100644
index 00000000000..88644c4ee23
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/del-app.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/deque-resource.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/deque-resource.png
new file mode 100644
index 00000000000..7297571d749
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/deque-resource.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ds-auth.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ds-auth.png
new file mode 100644
index 00000000000..b5ba7720592
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ds-auth.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ds-class.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ds-class.png
new file mode 100644
index 00000000000..4ae4b5d43ab
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ds-class.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-btn.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-btn.png
new file mode 100644
index 00000000000..e5dbdd6b951
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-btn.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-engine-label.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-engine-label.png
new file mode 100644
index 00000000000..2dcbcb23486
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-engine-label.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-engine.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-engine.png
new file mode 100644
index 00000000000..1cd79648d5e
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-engine.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-management.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-management.png
new file mode 100644
index 00000000000..e53f4e7b2a7
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ecm-management.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/edit-directory.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/edit-directory.png
new file mode 100644
index 00000000000..7a30e3e8da0
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/edit-directory.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/edit-label.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/edit-label.png
new file mode 100644
index 00000000000..d0ddc0ce512
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/edit-label.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/editing-interface.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/editing-interface.png
new file mode 100644
index 00000000000..e611e3e0efd
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/editing-interface.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-conf.png
new file mode 100644
index 00000000000..8df8b3e0ef1
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-information.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-information.png
new file mode 100644
index 00000000000..a182e840367
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-information.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-log.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-log.png
new file mode 100644
index 00000000000..926aa57be35
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-log.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-memory.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-memory.png
new file mode 100644
index 00000000000..a99b95034d4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-memory.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-view-log.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-view-log.png
new file mode 100644
index 00000000000..290b9bb5c82
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/engine-view-log.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/env-edit.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/env-edit.png
new file mode 100644
index 00000000000..5845f7339fd
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/env-edit.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/env-list.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/env-list.png
new file mode 100644
index 00000000000..fd60c8109d8
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/env-list.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/eureka-btn.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/eureka-btn.png
new file mode 100644
index 00000000000..82e52b6c8c2
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/eureka-btn.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/eureka-registration-center.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/eureka-registration-center.png
new file mode 100644
index 00000000000..9585c20747f
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/eureka-registration-center.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/eureka.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/eureka.png
new file mode 100644
index 00000000000..dc2a5f6b83c
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/eureka.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/executor-count.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/executor-count.png
new file mode 100644
index 00000000000..1063b956715
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/executor-count.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/executor-memory.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/executor-memory.png
new file mode 100644
index 00000000000..e3647e921c1
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/executor-memory.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-con.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-con.png
new file mode 100644
index 00000000000..92d397bd241
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-con.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-conf.png
new file mode 100644
index 00000000000..b83545c2344
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-core.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-core.png
new file mode 100644
index 00000000000..0bf8f819fa1
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-core.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-cpu.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-cpu.png
new file mode 100644
index 00000000000..7d4c4cb1eec
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-cpu.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-history-interface.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-history-interface.png
new file mode 100644
index 00000000000..59eee9b142f
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-history-interface.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-history-query-button.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-history-query-button.png
new file mode 100644
index 00000000000..eec31de51a1
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-history-query-button.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-history.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-history.png
new file mode 100644
index 00000000000..eec31de51a1
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-history.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-limit.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-limit.png
new file mode 100644
index 00000000000..502599ac32d
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-limit.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-var.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-var.png
new file mode 100644
index 00000000000..410590a663d
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-var.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-variable-interface.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-variable-interface.png
new file mode 100644
index 00000000000..89b1cf2686f
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/global-variable-interface.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/history-engine.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/history-engine.png
new file mode 100644
index 00000000000..1d1807f0d5b
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/history-engine.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/history-interface.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/history-interface.png
new file mode 100644
index 00000000000..59eee9b142f
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/history-interface.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/hive-con.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/hive-con.png
new file mode 100644
index 00000000000..5ab196f758b
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/hive-con.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/list-app.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/list-app.png
new file mode 100644
index 00000000000..0bf230d699f
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/list-app.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/management-interface.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/management-interface.png
new file mode 100644
index 00000000000..47647324d0e
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/management-interface.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/microservice-Interface.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/microservice-Interface.png
new file mode 100644
index 00000000000..593edb40da3
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/microservice-Interface.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/microservice-list.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/microservice-list.png
new file mode 100644
index 00000000000..f12164294ed
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/microservice-list.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ms-edit.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ms-edit.png
new file mode 100644
index 00000000000..b6f414db1ad
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/ms-edit.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/new-application-type.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/new-application-type.png
new file mode 100644
index 00000000000..f260c3df520
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/new-application-type.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management-administrator.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management-administrator.png
new file mode 100644
index 00000000000..574fe9c2006
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management-administrator.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management-button.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management-button.png
new file mode 100644
index 00000000000..5beb5678bab
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management-button.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management-interface.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management-interface.png
new file mode 100644
index 00000000000..a4a76435f59
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management-interface.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management.png
new file mode 100644
index 00000000000..a4a76435f59
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/resource-management.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/set-spark-param.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/set-spark-param.png
new file mode 100644
index 00000000000..11845f95c51
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/set-spark-param.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/spark-con.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/spark-con.png
new file mode 100644
index 00000000000..3f754a9b110
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/spark-con.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/spark-resource.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/spark-resource.png
new file mode 100644
index 00000000000..e89a314d5ed
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/spark-resource.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/task-log-single.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/task-log-single.png
new file mode 100644
index 00000000000..ff0ed867f7c
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/task-log-single.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/task-log.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/task-log.png
new file mode 100644
index 00000000000..ff0ed867f7c
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/task-log.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/udf-cllass.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/udf-cllass.png
new file mode 100644
index 00000000000..91956c33a07
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/udf-cllass.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/view-engine-information.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/view-engine-information.png
new file mode 100644
index 00000000000..2ecd27c9861
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/view-engine-information.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-cpu.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-cpu.png
new file mode 100644
index 00000000000..8861efe8f01
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-cpu.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-deque.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-deque.png
new file mode 100644
index 00000000000..f73920afe28
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-deque.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-instance.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-instance.png
new file mode 100644
index 00000000000..ab8763b9e1f
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-instance.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-write.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-write.png
new file mode 100644
index 00000000000..0fd6c1b4876
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/images/yarn-write.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/linkiscli-manual.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/linkiscli-manual.md
new file mode 100644
index 00000000000..720ca41ee8c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/linkiscli-manual.md
@@ -0,0 +1,238 @@
+---
+title: Shell 方式
+sidebar_position: 2
+---
+
+## 1. 介绍
+
+Linkis-Cli 是一个用于向Linkis提交任务的Shell命令行程序。
+
+## 2. 基础案例
+
+您可以参照下面的例子简单地向Linkis提交任务
+
+第一步,检查conf/目录下是否存在默认配置文件`linkis-cli.properties`,且包含以下配置:
+
+```properties
+ #linkis-mg-gateway服务地址
+ wds.linkis.client.common.gatewayUrl=http://127.0.0.1:9001
+ #认证鉴权策略 token/static
+ wds.linkis.client.common.authStrategy=token
+ #static 模式下为用户名/密码,token模式下为linkis-mg-gateway_auth_token表中token_name 和logal_users
+ wds.linkis.client.common.tokenKey=Validation-Code
+ wds.linkis.client.common.tokenValue=BML-AUTH
+```
+
+第二步,进入linkis安装目录,输入指令:
+
+```bash
+ sh ./bin/linkis-cli -engineType spark-2.4.3 -codeType sql -code "select count(*) from testdb.test;" -submitUser hadoop -proxyUser hadoop
+```
+
+第三步,您会在控制台看到任务被提交到linkis,并开始执行的信息。
+
+linkis-cli目前仅支持同步提交,即向linkis提交任务后,不断询问任务状态、拉取任务日志,直至任务结束。任务结束时状态如果为成功,linkis-cli还会主动拉取结果集并输出。
+
+
+## 3. 使用方式
+
+```bash
+ sh ./bin/linkis-cli [客户端参数][引擎参数] [启动运行参数]
+```
+
+## 4. 支持的参数列表
+
+* 客户端参数
+
+ | 参数 | 说明 | 数据类型 | 是否必填 |
+ | ----------- | -------------------------- | -------- | ---- |
+ | --gatewayUrl | 手动指定linkis-mg-gateway服务的地址 | String | 否 |
+ | --authStg | 指定认证策略 token/static | String | 否 |
+ | --authKey | 指定认证key | String | 否 |
+ | --authVal | 指定认证value | String | 否 |
+ | --userConf | 指定配置文件位置 | String | 否 |
+ | --kill | 指定kill的taskId,执行任务停止命令 | String | 否 |
+ | --log | 指定执行的相关日志路径 | String | 否 |
+ | --result | | String | 否 |
+ | --status | | String | 否 |
+ | --async | | String | 否 |
+ | --mode | ujes/once | String | 否 |
+
+* 引擎相关参数
+
+ | 参数 | 说明 | 数据类型 | 是否必填 |
+ | ----------- | -------------------------- | -------- | ---- |
+ | -engineType | 指定此任务的引擎类型,带版本号 如 hive-2.3.3 | String | 是 |
+ | -codeType | 为此作业指定 linkis的runType 如sql/hql/shell | String | 否 |
+ | -codePath | 本地执行代码文件路径 | String | 否 |
+ | -code | 要执行的代码 | String | 否 |
+ | -scriptPath | 为上传的脚本指定远程路径 | String | 否 |
+ | -submitUser | 提交的用户 | String | 否 |
+ | -proxyUser | 指定在 Linkis 服务器端执行您的代码的代理用户 | String | 否 |
+ | -creator | 指定此任务的创建者,系统级别 如 IDE/LINKISCLI | String | 否 |
+ | -outPath | 指定结果集的输出路径。 如果未指定,则输出重置为屏幕(标准输出) | String | 否 |
+
+
+* Map启动运行参数
+
+ | 参数 | 说明 | 数据类型 | 是否必填 |
+ | ----------- | -------------------------- | -------- | ---- |
+ | -confMap | 启动参数,可以将任何启动参数放入此 Map(例如 spark.executor.instances),输入格式:-confMap key1=value1 -confMap key2=value2 | String | 是 |
+ | -runtimeMap | 运行参数,可以将任何运行参数放入此 Map(例如 jdbc.url=jdbc:hive2://xxx:10000), 输入格式:-runtimeMap key1=value1 -runtimeMap key2=value2| String | 是 |
+ | -varMap | 指定变量映射,变量用于关键字替换。如执行语句'select form ${table_x} limit ${limit_y}' 通过varMap指定关键字变量替换, -varMap table_x=test -varMap limit_y=100 | String | 否 |
+ | -labelMap | 标签映射| String | 否 |
+ | -jobContentMap| jobContent 映射 | String | 否 |
+
+
+
+## 5. 详细示例
+
+### 5.1 客户端参数
+
+客户端参数可以通过手动指定的方式传入,此方式会覆盖默认配置文件`linkis-cli.properties`中的冲突配置项
+可以通过配置文件进行配置
+```bash
+ sh ./bin/linkis-cli --gatewayUrl http://127.0.0.1:9001 --authStg token --authKey [tokenKey] --authVal [tokenValue] -engineType spark-2.4.3 -codeType sql -code "select count(*) from testdb.test;" -submitUser hadoop -proxyUser hadoop
+```
+
+### 5.2 添加引擎启动参数
+>按实际使用场景如果不涉及 可以不配置
+
+引擎的初始参数可以通过`-confMap`参数添加,注意参数的数据类型是Map,命令行的输入格式如下:
+```html
+-confMap key1=val1 -confMap key2=val2 ...
+```
+
+
+例如:以下示例设置了引擎启动的yarn队列、spark executor个数等启动参数:
+
+```bash
+ sh ./bin/linkis-cli -engineType spark-2.4.3 -codeType sql -confMap wds.linkis.yarnqueue=q02 -confMap spark.executor.instances=3 -code "select count(*) from testdb.test;" -submitUser hadoop -proxyUser hadoop
+```
+
+当然,这些参数也支持以配置文件的方式读取,见【5.5 使用用户的配置文件】
+
+### 5.2 添加引擎运行参数
+>按实际使用场景,如果不涉及 可以不配置
+
+引擎的初始参数可以通过`-runtimeMap`参数添加,注意参数的数据类型是Map,命令行的输入格式如下:
+```html
+-runtimeMap key1=val1 -confMap key2=val2 ...
+```
+
+
+例如:以下示例设置了jdbc引擎运行是需要的连接地址/用户名/密码 等参数
+
+```bash
+ sh ./bin/linkis-cli -submitUser hadoop -engineType jdbc-4 -codeType jdbc -code "show tables" -runtimeMap jdbc.url=jdbc:mysql://127.0.0.1:36000/hive_meta -runtimeMap jdbc.username=test -runtimeMap jdbc.password=test@123
+```
+
+当然,这些参数也支持以配置文件的方式读取,见【5.5 使用用户的配置文件】
+
+
+### 5.3 添加标签
+
+标签可以通过`-labelMap`参数添加,与`-confMap`一样,`-labelMap`参数的类型也是Map:
+
+```bash
+ sh /bin/linkis-cli -engineType spark-2.4.3 -codeType sql -labelMap labelKey=labelVal -code "select count(*) from testdb.test;" -submitUser hadoop -proxyUser hadoop
+```
+
+### 5.4 变量替换
+
+Linkis-cli的变量替换通过`${}`符号和`-varMap`共同实现
+
+```bash
+ sh ./bin/linkis-cli -engineType spark-2.4.3 -codeType sql -code "select count(*) from \${key};" -varMap key=testdb.test -submitUser hadoop -proxyUser hadoop
+```
+
+执行过程中sql语句会被替换为:
+
+```mysql-sql
+ select count(*) from testdb.test
+```
+
+注意`'\$'`中的转义符是为了防止参数被linux提前解析,如果是`-codePath`指定本地脚本方式,则不需要转义符
+
+### 5.5 使用用户的配置文件
+
+1. linkis-cli支持加载用户自定义配置文件,配置文件路径通过`--userConf`参数指定,配置文件需要是`.properties`文件格式,默认是使用 `conf/linkis-cli/linkis-cli.properties` 配置文件
+
+```bash
+ sh ./bin/linkis-cli -engineType spark-2.4.3 -codeType sql -code "select count(*) from testdb.test;" -submitUser hadoop -proxyUser hadoop --userConf [配置文件路径]
+```
+
+2. 哪些参数可以配置?
+
+所有参数都可以配置化,例如:
+
+cli参数:
+
+```properties
+ wds.linkis.client.common.gatewayUrl=http://127.0.0.1:9001
+ wds.linkis.client.common.authStrategy=static
+ wds.linkis.client.common.tokenKey=[静态认证key]
+ wds.linkis.client.common.tokenValue=[静态认证value]
+```
+
+参数:
+
+```properties
+ wds.linkis.client.label.engineType=spark-2.4.3
+ wds.linkis.client.label.codeType=sql
+```
+
+Map类参数配置化时,key的格式为
+
+ [Map前缀] + [key]
+
+>通过前缀区分参数的类型(启动参数,运行参数等)
+
+Map前缀包括:
+
+ - executionMap前缀: wds.linkis.client.exec
+ - sourceMap前缀: wds.linkis.client.source
+ - confMap前缀: wds.linkis.client.param.conf
+ - runtimeMap前缀: wds.linkis.client.param.runtime
+ - labelMap前缀: wds.linkis.client.label
+
+
+注意:
+
+1. variableMap不支持配置化
+
+2. 当配置的key和指令参数中已输入的key存在冲突时,优先级如下:
+
+ 指令参数 > 指令Map类型参数中的key > 用户配置 > 默认配置
+
+示例:
+
+配置引擎启动参数:
+
+```properties
+ wds.linkis.client.param.conf.spark.executor.instances=3
+ wds.linkis.client.param.conf.wds.linkis.yarnqueue=q02
+```
+
+配置labelMap参数:
+
+```properties
+ wds.linkis.client.label.myLabel=label123
+```
+
+### 5.6 输出结果集到文件
+
+使用`-outPath`参数指定一个输出目录,linkis-cli会将结果集输出到文件,每个结果集会自动创建一个文件,输出形式如下:
+
+ task-[taskId]-result-[idx].txt
+
+例如:
+```html
+ task-906-result-1.txt
+ task-906-result-2.txt
+ task-906-result-3.txt
+```
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/sdk-manual.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/sdk-manual.md
new file mode 100644
index 00000000000..808fbea0aab
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/sdk-manual.md
@@ -0,0 +1,534 @@
+---
+title: SDK 方式
+sidebar_position: 3
+---
+
+> Linkis 提供了方便的JAVA和SCALA调用的接口,只需要引入linkis-computation-client的模块就可以进行使用,1.0后新增支持带Label提交的方式,下面将对 SDK 使用方式进行介绍。
+
+
+**Linkis 支持的引擎版本及脚本类型**
+
+
+
+ 引擎插件
+ 默认支持的版本
+ 脚本类型
+ 类型说明
+
+
+ Spark
+ 2.4.3
+ py
+ python脚本
+
+
+ scala
+ scala脚本
+
+
+ sql
+ sql脚本
+
+
+ Hive
+ 2.3.3
+ hql
+ hql脚本
+
+
+ Python
+ python2
+ python
+ python脚本
+
+
+ Shell
+ 1
+ shell
+ shell脚本
+
+
+ JDBC
+ 4
+ jdbc
+ sql脚本名
+
+
+ Flink
+ 1.12.2
+ sql
+ sql脚本
+
+
+ openLooKeng
+ 1.5.0
+ sql
+ sql脚本
+
+
+ Pipeline
+ 1
+ pipeline
+ 文件导入导出
+
+
+ Presto
+ 0.234
+ psql
+ sql脚本
+
+
+ Sqoop
+ 1.4.6
+ appconn
+ 文件导入导出
+
+
+ Elasticsearch
+ 7.6.2
+ esjson
+ json脚本
+
+
+ essql
+ sql脚本
+
+
+ trino
+ 371
+ tsql
+ sql脚本
+
+
+
+**Linkis 常用标签**
+
+|标签键|标签值|说明|
+|:-|:-|:-|
+|engineType| spark-2.4.3 | 指定引擎类型和版本|
+|userCreator| user + "-AppName" | 指定运行的用户和您的APPName|
+|codeType| sql | 指定运行的脚本类型|
+|jobRunningTimeout| 10 | job运行10s没完成自动发起Kill,单位为s|
+|jobQueuingTimeout| 10| job排队超过10s没完成自动发起Kill,单位为s|
+|jobRetryTimeout| 10000| job因为资源等原因失败重试的等待时间,单位为ms,如果因为队列资源不足的失败,会默认按间隔发起10次重试|
+|tenant| hduser02| 租户标签,设置前需要和BDP沟通需要单独机器进行隔离,则任务会被路由到单独的机器|
+
+
+## 1. 引入依赖模块
+```
+
+ org.apache.linkis
+ linkis-computation-client
+ ${linkis.version}
+
+如:
+
+ org.apache.linkis
+ linkis-computation-client
+ 1.0.3
+
+```
+
+## 2. Java测试代码
+建立Java的测试类LinkisClientTest,具体接口含义可以见注释:
+```java
+package org.apache.linkis.client.test;
+
+import org.apache.linkis.common.utils.Utils;
+import org.apache.linkis.httpclient.dws.authentication.StaticAuthenticationStrategy;
+import org.apache.linkis.httpclient.dws.config.DWSClientConfig;
+import org.apache.linkis.httpclient.dws.config.DWSClientConfigBuilder;
+import org.apache.linkis.manager.label.constant.LabelKeyConstant;
+import org.apache.linkis.protocol.constants.TaskConstant;
+import org.apache.linkis.ujes.client.UJESClient;
+import org.apache.linkis.ujes.client.UJESClientImpl;
+import org.apache.linkis.ujes.client.request.JobSubmitAction;
+import org.apache.linkis.ujes.client.request.JobExecuteAction;
+import org.apache.linkis.ujes.client.request.ResultSetAction;
+import org.apache.linkis.ujes.client.response.*;
+import org.apache.commons.io.IOUtils;
+
+import java.util.HashMap;
+import java.util.Map;
+import java.util.concurrent.TimeUnit;
+
+public class LinkisClientTest {
+
+ // 1. build config: linkis gateway url
+ private static DWSClientConfig clientConfig = ((DWSClientConfigBuilder) (DWSClientConfigBuilder.newBuilder()
+ .addServerUrl("http://127.0.0.1:9001/") //set linkis-mg-gateway url: http://{ip}:{port}
+ .connectionTimeout(30000) //connectionTimeOut
+ .discoveryEnabled(false) //disable discovery
+ .discoveryFrequency(1, TimeUnit.MINUTES) // discovery frequency
+ .loadbalancerEnabled(true) // enable loadbalance
+ .maxConnectionSize(5) // set max Connection
+ .retryEnabled(false) // set retry
+ .readTimeout(30000) //set read timeout
+ .setAuthenticationStrategy(new StaticAuthenticationStrategy()) //AuthenticationStrategy Linkis authen suppory static and Token
+ .setAuthTokenKey("hadoop") // set submit user
+ .setAuthTokenValue("123456"))) // set passwd or token (setAuthTokenValue("test"))
+ .setDWSVersion("v1") //linkis rest version v1
+ .build();
+
+ // 2. new Client(Linkis Client) by clientConfig
+ private static UJESClient client = new UJESClientImpl(clientConfig);
+
+ public static void main(String[] args) {
+
+ String user = "hadoop"; // 用户需要和AuthTokenKey的值保持一致
+ String executeCode = "df=spark.sql(\"show tables\")\n" +
+ "show(df)"; // code support:sql/hql/py/scala
+ try {
+
+ System.out.println("user : " + user + ", code : [" + executeCode + "]");
+ // 3. build job and execute
+ JobExecuteResult jobExecuteResult = toSubmit(user, executeCode);
+ System.out.println("execId: " + jobExecuteResult.getExecID() + ", taskId: " + jobExecuteResult.taskID());
+ // 4. get job jonfo
+ JobInfoResult jobInfoResult = client.getJobInfo(jobExecuteResult);
+ int sleepTimeMills = 1000;
+ int logFromLen = 0;
+ int logSize = 100;
+ while (!jobInfoResult.isCompleted()) {
+ // 5. get progress and log
+ JobProgressResult progress = client.progress(jobExecuteResult);
+ System.out.println("progress: " + progress.getProgress());
+ JobLogResult logRes = client.log(jobExecuteResult, logFromLen, logSize);
+ logFromLen = logRes.fromLine();
+ // 0: info 1: warn 2: error 3: all
+ System.out.println(logRes.log().get(3));
+ Utils.sleepQuietly(sleepTimeMills);
+ jobInfoResult = client.getJobInfo(jobExecuteResult);
+ }
+
+ JobInfoResult jobInfo = client.getJobInfo(jobExecuteResult);
+ // 6. Get the result set list (if the user submits multiple SQLs at a time,
+ // multiple result sets will be generated)
+ String resultSet = jobInfo.getResultSetList(client)[0];
+ // 7. get resultContent
+ ResultSetResult resultSetResult = client.resultSet(ResultSetAction.builder().setPath(resultSet).setUser(jobExecuteResult.getUser()).build());
+ System.out.println("metadata: " + resultSetResult.getMetadata()); // column name type
+ System.out.println("res: " + resultSetResult.getFileContent()); //row data
+ } catch (Exception e) {
+ e.printStackTrace();// please use log
+ IOUtils.closeQuietly(client);
+ }
+ IOUtils.closeQuietly(client);
+ }
+
+
+ private static JobExecuteResult toSubmit(String user, String code) {
+ // 1. build params
+ // set label map :EngineTypeLabel/UserCreatorLabel/EngineRunTypeLabel/Tenant
+ Map labels = new HashMap();
+ labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "spark-2.4.3"); // required engineType Label
+ labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, user + "-APPName");// required execute user and creator eg:hadoop-IDE
+ labels.put(LabelKeyConstant.CODE_TYPE_KEY, "py"); // required codeType
+ // set start up map :engineConn start params
+ Map startupMap = new HashMap(16);
+ // Support setting engine native parameters,For example: parameters of engines such as spark/hive
+ startupMap.put("spark.executor.instances", 2);
+ // setting linkis params
+ startupMap.put("wds.linkis.rm.yarnqueue", "dws");
+
+ // 2. build jobSubmitAction
+ JobSubmitAction jobSubmitAction = JobSubmitAction.builder()
+ .addExecuteCode(code)
+ .setStartupParams(startupMap)
+ .setUser(user) //submit user
+ .addExecuteUser(user) // execute user
+ .setLabels(labels)
+ .build();
+ // 3. to execute
+ return client.submit(jobSubmitAction);
+ }
+}
+```
+
+运行上述的代码即可以完成任务提交/执行/日志/结果集获取等
+
+## 3. Scala测试代码
+
+```scala
+package org.apache.linkis.client.test
+
+import org.apache.commons.io.IOUtils
+import org.apache.commons.lang3.StringUtils
+import org.apache.linkis.common.utils.Utils
+import org.apache.linkis.httpclient.dws.authentication.StaticAuthenticationStrategy
+import org.apache.linkis.httpclient.dws.config.DWSClientConfigBuilder
+import org.apache.linkis.manager.label.constant.LabelKeyConstant
+import org.apache.linkis.ujes.client.request._
+import org.apache.linkis.ujes.client.response._
+import java.util
+import java.util.concurrent.TimeUnit
+
+import org.apache.linkis.ujes.client.UJESClient
+
+object LinkisClientTest {
+ // 1. build config: linkis gateway url
+ val clientConfig = DWSClientConfigBuilder.newBuilder()
+ .addServerUrl("http://127.0.0.1:8088/") //set linkis-mg-gateway url: http://{ip}:{port}
+ .connectionTimeout(30000) //connectionTimeOut
+ .discoveryEnabled(false) //disable discovery
+ .discoveryFrequency(1, TimeUnit.MINUTES) // discovery frequency
+ .loadbalancerEnabled(true) // enable loadbalance
+ .maxConnectionSize(5) // set max Connection
+ .retryEnabled(false) // set retry
+ .readTimeout(30000) //set read timeout
+ .setAuthenticationStrategy(new StaticAuthenticationStrategy()) //AuthenticationStrategy Linkis authen suppory static and Token
+ .setAuthTokenKey("hadoop") // set submit user
+ .setAuthTokenValue("hadoop") // set passwd or token (setAuthTokenValue("BML-AUTH"))
+ .setDWSVersion("v1") //linkis rest version v1
+ .build();
+
+ // 2. new Client(Linkis Client) by clientConfig
+ val client = UJESClient(clientConfig)
+
+ def main(args: Array[String]): Unit = {
+ val user = "hadoop" // execute user 用户需要和AuthTokenKey的值保持一致
+ val executeCode = "df=spark.sql(\"show tables\")\n" +
+ "show(df)"; // code support:sql/hql/py/scala
+ try {
+ // 3. build job and execute
+ println("user : " + user + ", code : [" + executeCode + "]")
+ // 推荐使用submit,支持传递任务label
+ val jobExecuteResult = toSubmit(user, executeCode)
+ println("execId: " + jobExecuteResult.getExecID + ", taskId: " + jobExecuteResult.taskID)
+ // 4. get job jonfo
+ var jobInfoResult = client.getJobInfo(jobExecuteResult)
+ var logFromLen = 0
+ val logSize = 100
+ val sleepTimeMills: Int = 1000
+ while (!jobInfoResult.isCompleted) {
+ // 5. get progress and log
+ val progress = client.progress(jobExecuteResult)
+ println("progress: " + progress.getProgress)
+ val logObj = client.log(jobExecuteResult, logFromLen, logSize)
+ logFromLen = logObj.fromLine
+ val logArray = logObj.getLog
+ // 0: info 1: warn 2: error 3: all
+ if (logArray != null && logArray.size >= 4 && StringUtils.isNotEmpty(logArray.get(3))) {
+ println(s"log: ${logArray.get(3)}")
+ }
+ Utils.sleepQuietly(sleepTimeMills)
+ jobInfoResult = client.getJobInfo(jobExecuteResult)
+ }
+ if (!jobInfoResult.isSucceed) {
+ println("Failed to execute job: " + jobInfoResult.getMessage)
+ throw new Exception(jobInfoResult.getMessage)
+ }
+
+ // 6. Get the result set list (if the user submits multiple SQLs at a time,
+ // multiple result sets will be generated)
+ val jobInfo = client.getJobInfo(jobExecuteResult)
+ val resultSetList = jobInfoResult.getResultSetList(client)
+ println("All result set list:")
+ resultSetList.foreach(println)
+ val oneResultSet = jobInfo.getResultSetList(client).head
+ // 7. get resultContent
+ val resultSetResult: ResultSetResult = client.resultSet(ResultSetAction.builder.setPath(oneResultSet).setUser(jobExecuteResult.getUser).build)
+ println("metadata: " + resultSetResult.getMetadata) // column name type
+ println("res: " + resultSetResult.getFileContent) //row data
+ } catch {
+ case e: Exception => {
+ e.printStackTrace() //please use log
+ }
+ }
+ IOUtils.closeQuietly(client)
+ }
+
+
+ def toSubmit(user: String, code: String): JobExecuteResult = {
+ // 1. build params
+ // set label map :EngineTypeLabel/UserCreatorLabel/EngineRunTypeLabel/Tenant
+ val labels: util.Map[String, AnyRef] = new util.HashMap[String, AnyRef]
+ labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "spark-2.4.3"); // required engineType Label
+ labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, user + "-APPName"); // 请求的用户和应用名,两个参数都不能少,其中APPName不能带有"-"建议替换为"_"
+ labels.put(LabelKeyConstant.CODE_TYPE_KEY, "py"); // 指定脚本类型
+
+ val startupMap = new java.util.HashMap[String, AnyRef]()
+ // Support setting engine native parameters,For example: parameters of engines such as spark/hive
+ val instances: Integer = 2
+ startupMap.put("spark.executor.instances", instances)
+ // setting linkis params
+ startupMap.put("wds.linkis.rm.yarnqueue", "default")
+ // 2. build jobSubmitAction
+ val jobSubmitAction = JobSubmitAction.builder
+ .addExecuteCode(code)
+ .setStartupParams(startupMap)
+ .setUser(user) //submit user
+ .addExecuteUser(user) //execute user
+ .setLabels(labels)
+ .build
+ // 3. to execute
+ client.submit(jobSubmitAction)
+ }
+}
+```
+
+## 4. Once SDK 使用
+Linkis-cli客户端支持提交Once类型的任务,引擎进程启动后只运行一次任务,任务结束后自动销毁
+
+OnceEngineConn 通过 LinkisManagerClient 调用 LinkisManager 的 createEngineConn 接口,并将代码发送到用户创建的引擎,然后引擎开始执行
+
+
+## Once模式使用:
+
+1.首先创建一个新的 maven 项目或者在项目中引入以下依赖项
+
+```plain
+
+ org.apache.linkis
+ linkis-computation-client
+ ${linkis.version}
+
+```
+2.编写一个测试类
+使用clien条件
+
+```plain
+1.配置正确可用的gatew地址:
+LinkisJobClient.config().setDefaultServerUrl("http://ip:9001");
+2.将引擎参数,配置项,执行code写在code里面:
+ String code = "env {
+ + " spark.app.name = \"SeaTunnel\"\n"
+ + " spark.executor.instances = 2\n"
+ + " spark.executor.cores = 1\n"
+ + " spark.executor.memory = \"1g\"\n"
+ + "}\n"
+ + "\n"
+ + "source {\n"
+ + " Fake {\n"
+ + " result_table_name = \"my_dataset\"\n"
+ + " }\n"
+ + "\n"
+ + "}\n"
+ + "\n"
+ + "transform {\n"
+ + "}\n"
+ + "\n"
+ + "sink {\n"
+ + " Console {}\n"
+ + "}";
+3.创建Once模式对象:SubmittableSimpleOnceJob :
+SubmittableSimpleOnceJob = LinkisJobClient.once()
+ .simple()
+ .builder()
+ .setCreateService("seatunnel-Test")
+ .setMaxSubmitTime(300000) 超时时间
+ .addLabel(LabelKeyUtils.ENGINE_TYPE_LABEL_KEY(), "seatunnel-2.1.2") 引擎标签
+ .addLabel(LabelKeyUtils.USER_CREATOR_LABEL_KEY(), "hadoop-seatunnel") 用户标签
+ .addLabel(LabelKeyUtils.ENGINE_CONN_MODE_LABEL_KEY(), "once") 引擎模式标签
+ .addStartupParam(Configuration.IS_TEST_MODE().key(), true) 是否开启测试模式
+ .addExecuteUser("hadoop") 执行用户
+ .addJobContent("runType", "spark") 执行引擎
+ .addJobContent("code", code) 执行代码
+ .addJobContent("master", "local[4]")
+ .addJobContent("deploy-mode", "client")
+ .addSource("jobName", "OnceJobTest") 名称
+ .build();
+```
+## 测试类示例代码:
+
+```plain
+package org.apache.linkis.ujes.client
+
+import org.apache.linkis.common.utils.Utils
+import java.util.concurrent.TimeUnit
+import java.util
+import org.apache.linkis.computation.client.LinkisJobBuilder
+import org.apache.linkis.computation.client.once.simple.{SimpleOnceJob, SimpleOnceJobBuilder, SubmittableSimpleOnceJob}
+import org.apache.linkis.computation.client.operator.impl.{EngineConnLogOperator, EngineConnMetricsOperator, EngineConnProgressOperator}
+import org.apache.linkis.computation.client.utils.LabelKeyUtils
+import scala.collection.JavaConverters._
+@Deprecated
+object SqoopOnceJobTest extends App {
+ LinkisJobBuilder.setDefaultServerUrl("http://gateway地址:9001")
+ val logPath = "C:\\Users\\resources\\log4j.properties"
+ System.setProperty("log4j.configurationFile", logPath)
+ val startUpMap = new util.HashMap[String, AnyRef]
+ startUpMap.put("wds.linkis.engineconn.java.driver.memory", "1g")
+ val builder = SimpleOnceJob.builder().setCreateService("Linkis-Client")
+ .addLabel(LabelKeyUtils.ENGINE_TYPE_LABEL_KEY, "sqoop-1.4.6")
+ .addLabel(LabelKeyUtils.USER_CREATOR_LABEL_KEY, "hadoop-Client")
+ .addLabel(LabelKeyUtils.ENGINE_CONN_MODE_LABEL_KEY, "once")
+ .setStartupParams(startUpMap)
+ .setMaxSubmitTime(30000)
+ .addExecuteUser("hadoop")
+ val onceJob = importJob(builder)
+ val time = System.currentTimeMillis()
+ onceJob.submit()
+ println(onceJob.getId)
+ val logOperator = onceJob.getOperator(EngineConnLogOperator.OPERATOR_NAME).asInstanceOf[EngineConnLogOperator]
+ println(onceJob.getECMServiceInstance)
+ logOperator.setFromLine(0)
+ logOperator.setECMServiceInstance(onceJob.getECMServiceInstance)
+ logOperator.setEngineConnType("sqoop")
+ logOperator.setIgnoreKeywords("[main],[SpringContextShutdownHook]")
+ var progressOperator = onceJob.getOperator(EngineConnProgressOperator.OPERATOR_NAME).asInstanceOf[EngineConnProgressOperator]
+ var metricOperator = onceJob.getOperator(EngineConnMetricsOperator.OPERATOR_NAME).asInstanceOf[EngineConnMetricsOperator]
+ var end = false
+ var rowBefore = 1
+ while (!end || rowBefore > 0) {
+ if (onceJob.isCompleted) {
+ end = true
+ metricOperator = null
+ }
+ logOperator.setPageSize(100)
+ Utils.tryQuietly {
+ val logs = logOperator.apply()
+ logs.logs.asScala.foreach(log => {
+ println(log)
+ })
+ rowBefore = logs.logs.size
+ }
+ Thread.sleep(3000)
+ Option(metricOperator).foreach(operator => {
+ if (!onceJob.isCompleted) {
+ println(s"Metric监控: ${operator.apply()}")
+ println(s"进度: ${progressOperator.apply()}")
+ }
+ })
+ }
+ onceJob.isCompleted
+ onceJob.waitForCompleted()
+ println(onceJob.getStatus)
+ println(TimeUnit.SECONDS.convert(System.currentTimeMillis() - time, TimeUnit.MILLISECONDS) + "s")
+ System.exit(0)
+
+ def importJob(jobBuilder: SimpleOnceJobBuilder): SubmittableSimpleOnceJob = {
+ jobBuilder
+ .addJobContent("sqoop.env.mapreduce.job.queuename", "queue_1003_01")
+ .addJobContent("sqoop.mode", "import")
+ .addJobContent("sqoop.args.connect", "jdbc:mysql://数据库地址/库名")
+ .addJobContent("sqoop.args.username", "数据库账户")
+ .addJobContent("sqoop.args.password", "数据库密码")
+ .addJobContent("sqoop.args.query", "select * from linkis_ps_udf_manager where 1=1 and $CONDITIONS")
+ #表一定要存在 $CONDITIONS不可缺少
+ .addJobContent("sqoop.args.hcatalog.database", "janicegong_ind")
+ .addJobContent("sqoop.args.hcatalog.table", "linkis_ps_udf_manager_sync2")
+ .addJobContent("sqoop.args.hcatalog.partition.keys", "ds")
+ .addJobContent("sqoop.args.hcatalog.partition.values", "20220708")
+ .addJobContent("sqoop.args.num.mappers", "1")
+ .build()
+ }
+ def exportJob(jobBuilder: SimpleOnceJobBuilder): SubmittableSimpleOnceJob = {
+ jobBuilder
+ .addJobContent("sqoop.env.mapreduce.job.queuename", "queue_1003_01")
+ .addJobContent("sqoop.mode", "import")
+ .addJobContent("sqoop.args.connect", "jdbc:mysql://数据库地址/库名")
+ .addJobContent("sqoop.args.username", "数据库账户")
+ .addJobContent("sqoop.args.password", "数据库密码")
+ .addJobContent("sqoop.args.query", "select * from linkis_ps_udf_manager where 1=1 and $CONDITIONS")
+ #表一定要存在 $CONDITIONS不可缺少
+ .addJobContent("sqoop.args.hcatalog.database", "janicegong_ind")
+ .addJobContent("sqoop.args.hcatalog.table", "linkis_ps_udf_manager_sync2")
+ .addJobContent("sqoop.args.hcatalog.partition.keys", "ds")
+ .addJobContent("sqoop.args.hcatalog.partition.values", "20220708")
+ .addJobContent("sqoop.args.num.mappers", "1")
+ .build
+ }
+}
+```
+3.测试程序完成,引擎会自动销毁,不用手动清除
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/udf-function.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/udf-function.md
new file mode 100644
index 00000000000..975aad8e934
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/current/user-guide/udf-function.md
@@ -0,0 +1,175 @@
+---
+title: UDF功能
+sidebar_position: 5
+---
+
+> 详细介绍一下如何使用UDF功能
+
+## 1.UDF创建的整体步骤说明
+### 1 通用类型的UDF函数
+整体步骤说明
+- 在本地按UDF函数格式 编写udf 函数 ,并打包称jar包文件
+- 在【Scriptis >> 工作空间】上传至工作空间对应的目录
+- 在 【管理台>>UDF函数】 创建udf (默认加载)
+- 在任务代码中使用(对于新起的引擎才生效)
+
+**Step1 本地编写jar包**
+
+Hive UDF示例:
+1. 引入 hive 依赖
+```xml
+
+ org.apache.hive
+ hive-exec
+ 3.1.3
+
+```
+2. 编写UDF 类
+```java
+import org.apache.hadoop.hive.ql.exec.UDF;
+
+public class UDFExample extends UDF {
+ public Integer evaluate(Integer value) {
+ return value == null ? null : value + 1;
+ }
+}
+
+3. 编译打包
+```shell
+mvn package
+```
+
+**Step2【Scriptis >> 工作空间】上传jar包**
+选择对应的文件夹 鼠标右键 选择上传
+
+![](/Images/udf/udf_14.png)
+
+**Step3【管理台>>UDF函数】 创建UDF**
+- 函数名称:符合规则即可,如test_udf_jar 在sql等脚本中使用
+- 函数类型:通用
+- 脚本路径:选择jar包存放的共享目录路径 如 ../../../wds_functions_1_0_0.jar
+- 注册格式:包名+类名,如 com.webank.wedatasphere.willink.bdp.udf.ToUpperCase
+- 使用格式:输入类型与返回类型,需与jar包里定义一致
+- 分类:下拉选择;或者输入自定义目录(会在个人函数下新建目标一级目录)
+
+![](/Images/udf/udf_15.png)
+
+注意 新建的udf 函数 是默认加载的 可以在 【Scriptis >> UDF函数】 页面查看到,方便大家在Scriptis 任务编辑时 方便查看,勾选中的UDF函数 表明是会被加载使用的
+
+![](/Images/udf/udf_16.png)
+
+**Step4 使用该udf函数**
+
+在任务中 使用上述步骤创新的udf 函数
+函数名为 【创建UDF】 函数名称
+在pyspark中:
+print (sqlContext.sql("select test_udf_jar(name1) from stacyyan_ind.result_sort_1_20200226").collect())
+
+### 2 Spark类型的UDF函数
+整体步骤说明
+- 在【Scriptis >> 工作空间】在需要的目录下新建Spark脚本文件
+- 在 【管理台>>UDF函数】 创建udf (默认加载)
+- 在任务代码中使用(对于新起的引擎才生效)
+
+**Step1 dss-scriptis-新建scala脚本**
+
+![](/Images/udf/udf_17.png)
+
+def helloWorld(str: String): String = "hello, " + str
+
+**Step2 创建UDF**
+- 函数名称:符合规则即可,如test_udf_scala
+- 函数类型:spark
+- 脚本路径:../../../b
+- 注册格式:输入类型与返回类型,需与定义一致;注册格式需定义的函数名严格保持一致,如helloWorld
+- 分类:下拉选择dss-scriptis-UDF函数-个人函数下存在的一级目录;或者输入自定义目录(会在个人函数下新建目标一级目录)
+
+![](/Images/udf/udf_18.png)
+
+
+**Step3 使用该udf函数**
+
+在任务中 使用上述步骤创建新的udf 函数
+函数名为 【创建UDF】 函数名称
+- 在scala中
+ val s=sqlContext.sql("select test_udf_scala(name1)
+ from stacyyan_ind.result_sort_1_20200226")
+ show(s)
+- 在pyspark中
+ print(sqlContext.sql("select test_udf_scala(name1)
+ from stacyyan_ind.result_sort_1_20200226").collect());
+- 在sql中
+ select test_udf_scala(name1) from stacyyan_ind.result_sort_1_20200226;
+
+### 3 python函数
+整体步骤说明
+- 在【Scriptis >> 工作空间】在需要的目录下新建Python脚本文件
+- 在 【管理台>>UDF函数】 创建udf (默认加载)
+- 在任务代码中使用(对于新起的引擎才生效)
+
+**Step1 dss-scriptis-新建pyspark脚本**
+
+![](/Images/udf/udf_19.png)
+
+def addation(a, b):
+return a + b
+**Step2 创建UDF**
+- 函数名称:符合规则即可,如test_udf_py
+- 函数类型:spark
+- 脚本路径:../../../a
+- 注册格式:需定义的函数名严格保持一致,如addation
+- 使用格式:输入类型与返回类型,需与定义一致
+- 分类:下拉选择dss-scriptis-UDF函数-个人函数下存在的一级目录;或者输入自定义目录(会在个人函数下新建目标一级目录)
+
+![](/Images/udf/udf_20.png)
+
+**Step3 使用该udf函数**
+在任务中 使用上述步骤创建新的udf 函数
+函数名为 【创建UDF】 函数名称
+- 在pyspark中
+ print(sqlContext.sql("select test_udf_py(pv,impression) from neiljianliu_ind.alias where entityid=504059 limit 50").collect());
+- 在sql中
+ select test_udf_py(pv,impression) from neiljianliu_ind.alias where entityid=504059 limit 50
+
+### 4 scala函数
+整体步骤说明
+- 在【Scriptis >> 工作空间】在需要的目录下新建Spark Scala脚本文件
+- 在 【管理台>>UDF函数】 创建udf (默认加载)
+- 在任务代码中使用(对于新起的引擎才生效)
+
+**Step1 dss-scriptis-新建scala脚本**
+def hellozdy(str:String):String = "hellozdy,haha " + str
+
+**Step2 创建函数**
+- 函数名称:需与定义的函数名严格保持一致,如hellozdy
+- 函数类型:自定义函数
+- 脚本路径:../../../d
+- 使用格式:输入类型与返回类型,需与定义一致
+- 分类:下拉选择dss-scriptis-方法函数-个人函数下存在的一级目录;或者输入自定义目录(会在个人函数下新建目标一级目录)
+
+**Step3 使用该函数**
+在任务中 使用上述步骤创建新的udf 函数
+函数名为 【创建UDF】 函数名称
+val a = hellozdy("abcd");
+print(a)
+
+### 5 常见的使用问题
+#### 5.1 UDF函数加载失败
+"FAILED: SemanticException [Error 10011]: Invalid function xxxx"
+
+![](/Images/udf/udf_10.png)
+
+- 首先检查UDF函数配置是否正确:
+
+ ![](/Images/udf/udf_11.png)
+
+- 注册格式即为函数路径名称:
+
+ ![](/Images/udf/udf_12.png)
+
+- 检查scriptis-udf函数-查看加载的函数是否勾选,当函数未勾选时,引擎启动时将不会加载udf
+
+ ![](/Images/udf/udf_13.png)
+
+- 检查引擎是否已加载UDF,如果未加载,请重新另起一个引擎或者重启当前引擎
+ 备注:只有当引擎初始化时,才会加载UDF,中途新增UDF,当前引擎将无法感知并且无法进行加载
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/_category_.json
new file mode 100644
index 00000000000..2d42788825d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "部署指南",
+ "position": 3.0
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/deploy-cluster.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/deploy-cluster.md
new file mode 100644
index 00000000000..ba837895e9c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/deploy-cluster.md
@@ -0,0 +1,176 @@
+---
+title: 分布式部署
+sidebar_position: 2
+---
+
+Linkis的单机部署方式简单,过多的进程在同一个服务器上会让服务器压力过大,生产环境为了保证服务的高可用,推荐使用分部署部署。
+部署方案的选择,和公司的用户规模、用户使用习惯、集群同时使用人数都有关,一般来说,我们会以使用Linkis的同时使用人数和用户对执行引擎的偏好来做依据进行部署方式的选择。
+
+## 1 多节点部署方式计算模型参考
+
+Linkis的每个微服务都支持多活的部署方案,当然不同的微服务在系统中承担的角色不一样,有的微服务调用频率很高,资源会处于高负荷的情况,
+**在安装EngineConnManager的机器上,由于会启动用户的引擎进程,机器的内存负载会比较高,其他类型的微服务对机器的负载则相对不会很高,
+**对于这类微服务我们建议启动多个进行分布式部署,Linkis动态使用的总资源可以按照如下方式计算。
+
+**EngineConnManager**使用总资源
+= 总内存 + 总核数
+= **同时在线人数 \* (所有类型的引擎占用内存) \*单用户最高并发数+ 同时在线人数 \*
+(所有类型的引擎占用核数) \*单用户最高并发数**
+
+例如:
+```html
+
+只使用spark、hive、python引擎且单用户最高并发数为1的情况下,同时使用人数50人,
+spark的Driver内存1G,hive client内存1G,python client 1G,每个引擎都使用1个核
+
+EngineConnManager(ECM)使用总资源
+= 50 *(1+1+1)G *1 + 50 *(1+1+1)核*1
+= 150G 内存 + 150 CPU核
+```
+
+
+分布式部署时微服务本身占用的内存可以按照每个2G计算,对于使用人数较多的情况下建议调大ps-publicservice的内存至6G,同时建议预留10G内存作为buffer。
+
+以下配置假设**每个用户同时启动两个引擎为例**,**对于64G内存的机器**,参考配置如下:
+
+### 1.1 同时在线人数10-50
+**EngineConnManager**使用总资源 = 总内存 + 总核数 =
+**同时在线人数 \* (所有类型的引擎占用内存) \*单用户最高并发数+ 同时在线人数 \*
+(所有类型的引擎占用核数) \*单用户最高并发数**
+
+总内存:同时在线人数 50 * 单个引擎 1G内存 * 每个用户同时启动两个引擎 2 = 100G内存
+
+> **服务器配置推荐**4台服务器,分别命名为S1,S2,S3,S4
+
+| Service | Host name | Remark |
+|----------------------|-----------|------------------|
+| cg-engineconnmanager | S1、S2(共128G)| 每台机器单独部署 |
+| Other services | S3、S4 | Eureka高可用部署 |
+
+### 1.2 同时在线人数50-100
+
+总内存:同时在线人数 100 * 单个引擎 1G内存 * 每个用户同时启动两个引擎 2 = 200G内存
+
+> **服务器配置推荐**:6台服务器,分别命名为S1,S2,S3,S4,S5,S6
+
+| Service | Host name | Remark |
+|----------------------|-----------|------------------|
+| cg-engineconnmanager | S1-S4(共256G)| 每台机器单独部署 |
+| Other services | S5、S6 | Eureka高可用部署 |
+
+### 1.3 同时使用人数 100-300
+
+
+总内存:同时在线人数 300 * 单个引擎 1G内存 * 每个用户同时启动两个引擎 2 = 600G内存
+
+**服务器配置推荐**:12台服务器,分别命名为S1,S2..S12
+
+| Service | Host name | Remark |
+|----------------------|-----------|------------------|
+| cg-engineconnmanager | S1-S10(共640G)| 每台机器单独部署 |
+| Other services | S11、S12 | Eureka高可用部署 |
+
+### 1.4 同时使用人数300-500
+
+> **服务器配置推荐**:20台服务器,分别命名为S1,S2..S20
+
+| Service | Host name | Remark |
+|----------------------|-----------|----------------------------------------------------------------------------------------------|
+| cg-engineconnmanager | S1-S18 | 每台机器单独部署 |
+| Other services | S19、S20 | Eureka高可用部署,部分微服务如果请求量上万可以考虑扩容,目前双活部署可以支持行内上千用户使用 |
+
+### 1.5 同时使用人数500以上
+> 按照同时在线800人估算
+> **服务器配置推荐**:34台服务器,分别命名为S1,S2..S34
+
+| Service | Host name | Remark |
+|----------------------|-----------|----------------------------------------------------------------------------------------------|
+| cg-engineconnmanager | S1-S32 | 每台机器单独部署 |
+| Other services | S33、S34 | Eureka高可用部署,部分微服务如果请求量上万可以考虑扩容,目前双活部署可以支持行内上千用户使用 |
+
+
+## 2 分布式部署的流程
+
+>Linkis的所有服务都支持分布式、多集群部署,建议在分布式部署前,先在一台机器上完成单机部署,并保证 Linkis 各功能正常使用。
+
+目前一键安装脚本对分布式部署还没有很好的支持,需要手动进行调整部署。具体分布式部署,可以参考以下步骤,假设用户已经在 A 机器上完成了单机部署。
+
+
+### 2.1 分布式部署的环境准备
+和服务器A一样,服务器B需要进行基础的环境准备,请参考[Linkis环境准备](deploy-quick#3-linkis%E7%8E%AF%E5%A2%83%E5%87%86%E5%A4%87)
+
+**网络检查**
+
+检查需要分布式部署的各服务机器是否网络互通,可用 ping 命令进行检查
+```
+ping IP
+```
+
+**权限检查**
+
+检查各机器上是否有 hadoop 用户以及hadoop用户是否有 sudo 权限。
+
+**必要的环境检查**
+
+Linkis各服务启动前或任务执行时会依赖一些基础环境,请根据下表检查各机器基础环境,具体检查方法参考[Linkis环境准备](deploy-quick#3-linkis%E7%8E%AF%E5%A2%83%E5%87%86%E5%A4%87)
+
+|服务名称|依赖环境|
+|-|-|
+|mg-eureka|Java|
+|mg-gateway|Java|
+|ps-publicservice|Java、Hadoop|
+|cg-linkismanager|Java|
+|cg-entrance|Java|
+|cg-engineconnmanager|Java、Hive、Spark、Python、Shell|
+
+
+注意:如需使用其它非默认引擎,还需要检查cg-engineconnmanager服务所在机器上对应引擎的环境是否OK,引擎环境可参考各[引擎使用中](https://linkis.apache.org/zh-CN/docs/latest/engine-usage/overview)中的前置工作进行检查。
+
+### 2.2 Eureka多活配置调整
+
+修改 A 机器上 Eureka 配置文件,把所有机器的 Eureka 的配置地址都加上,让 Eureka 服务之间相互注册。
+在服务器A上,进行如下配置修改,以两台 Eureka 集群为例。
+
+```
+修改 $LINKIS_HOME/conf/application-eureka.yml和$LINKIS_HOME/conf/application-linkis.yml配置
+
+eureka:
+ client:
+ serviceUrl:
+ defaultZone: http:/eurekaIp1:port1/eureka/,http:/eurekaIp2:port2/eureka/
+
+
+修改 $LINKIS_HOME/conf/linkis.properties 配置
+
+wds.linkis.eureka.defaultZone=http:/eurekaIp1:port1/eureka/,http:/eurekaIp2:port2/eureka/
+```
+
+### 2.3 安装物料的同步
+在其它所有机器上创建同机器 A 上相同的目录 `$LINKIS_HOME` 。在服务器A上,将linkis的成功安装的目录`$LINKIS_HOME` 打包,然后拷贝并解压到其它机器相同目录下。
+此时,如果在服务器A上以及其它机器上,执行`sbin/linkis-start-all.sh`脚本启动所有服务,那么所有服务都有n个实例,n为机器数量。 可以访问eureka服务展示页面 `http:/eurekaIp1:port1,或http:/eurekaIp2:port2` 查看
+
+### 2.4 调整启动脚本
+根据实际情况,确定各机器上需要部署的Linkis服务,
+比如 微服务`linkis-cg-engineconnmanager` 不会部署在服务器A上,
+则修改服务器A的一键启停脚本,`sbin/linkis-start-all.sh`,`sbin/linkis-stop-all.sh`,将`cg-engineconnmanager`服务相关的启停命令,注释掉
+```html
+sbin/linkis-start-all.sh
+#linkis-cg-linkismanage
+#SERVER_NAME="cg-linkismanager"
+#SERVER_IP=$MANAGER_INSTALL_IP
+#startApp
+
+sbin/linkis-stop-all.sh
+#linkis-cg-engineconnmanager(ecm)
+#SERVER_NAME="cg-engineconnmanager"
+#SERVER_IP=$ENGINECONNMANAGER_INSTALL_IP
+#stopApp
+
+```
+
+
+## 3 注意事项
+- 分部署部署时,linkis的安装目录建议保持一致,方便统一管控,相关的配置文件最好也保持一致
+- 如果某些服务器,端口已被其他应用占用,无法使用时,需要调整该服务端口
+- mg-gateway的多活部署,目前因为登陆session不支持分布式,用一个用户的请求,需要请求到同一个gateway实例上,可以通过nginx的ip hash负载均衡方式来支持
+- 一键启停脚本,根据实际情况,进行调整,对于不再本服务器上部署的微服务,需要在一键启动脚本中,将对应的启停命令注释掉。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/deploy-console.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/deploy-console.md
new file mode 100644
index 00000000000..a276d8022fd
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/deploy-console.md
@@ -0,0 +1,205 @@
+---
+title: 管理台部署
+sidebar_position: 3
+---
+> web端是使用nginx作为静态资源服务器的,访问请求流程是:`Linkis管理台请求->nginx ip:port->linkis-gateway ip:port-> 其他服务`
+
+
+Linkis 提供了单独的前端管理台功能,提供了展示历史任务的全局历史、修改用户参数、管理ECM和微服务等功能,部署前端管理台前需要先将Linkis后端进行部署,Linkis的部署手册见:[Linkis部署手册](deploy-quick.md)
+
+
+## 1 准备工作
+
+1. 从linkis的release页面([点击这里进入下载页面](https://linkis.apache.org/zh-CN/download/main))下载web安装包`apache-linkis-x.x.x-web-bin.tar.gz`
+手动解压:`tar -xvf apache-linkis-x.x.x-web-bin.tar.gz`,
+
+解压后目录为:
+```
+├── config.sh
+├── dist
+├── install.sh
+├── LICENSE
+├── licenses
+└── NOTICE
+```
+
+## 2 部署
+
+> 分为两种部署方式,自动化部署和手动部署
+
+### 2.1 自动化部署(推荐)
+
+#### 2.1.1 修改配置config.sh
+```shell script
+#linkis-mg-gateway服务地址
+linkis_url="http://127.0.0.1:9001"
+
+#可以配置为安装机器的ip 也可以使用默认值
+linkis_ipaddr=127.0.0.1
+# 访问管理台的端口
+linkis_port=8088
+
+```
+
+#### 2.1.2 执行部署脚本
+
+```shell script
+# nginx 需要sudo权限进行安装
+sudo sh install.sh
+```
+安装后,linkis的nginx配置文件默认是 在`/etc/nginx/conf.d/linkis.conf`
+nginx的日志文件在 `/var/log/nginx/access.log` 和`/var/log/nginx/error.log`
+生成的linkis管理台的nginx配置文件示例如下:
+```nginx
+
+ server {
+ listen 8188;# 访问端口 如果端口被占用,则需要修改
+ server_name localhost;
+ #charset koi8-r;
+ #access_log /var/log/nginx/host.access.log main;
+ location / {
+ root /appcom/Install/linkis-web/dist; # 静态文件目录
+ index index.html index.html;
+ }
+ location /ws {
+ proxy_pass http://localhost:9020;#后端Linkis的地址
+ proxy_http_version 1.1;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+
+ location /api {
+ proxy_pass http://localhost:9020; #后端Linkis的地址
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header x_real_ipP $remote_addr;
+ proxy_set_header remote_addr $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_http_version 1.1;
+ proxy_connect_timeout 4s;
+ proxy_read_timeout 600s;
+ proxy_send_timeout 12s;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+
+ #error_page 404 /404.html;
+ # redirect server error pages to the static page /50x.html
+ #
+ error_page 500 502 503 504 /50x.html;
+ location = /50x.html {
+ root /usr/share/nginx/html;
+ }
+ }
+```
+
+
+### 2.2 手动部署
+
+#### 2.2.1 安装Nginx
+>如果已经安装过nginx 可以跳过
+
+```shell script
+sudo yum install nginx -y
+```
+
+#### 2.2.2 修改配置文件
+```shell script
+sudo vi /etc/nginx/conf.d/linkis.conf
+```
+
+添加如下内容:
+```
+server {
+ listen 8080;# 访问端口
+ server_name localhost;
+ #charset koi8-r;
+ #access_log /var/log/nginx/host.access.log main;
+ location / {
+ root /appcom/Install/linkis/dist; # 前端包解压的目录
+ index index.html index.html;
+ }
+
+ location /api {
+ proxy_pass http://192.168.xxx.xxx:9001; # linkis-gateway服务的ip端口
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header x_real_ipP $remote_addr;
+ proxy_set_header remote_addr $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_http_version 1.1;
+ proxy_connect_timeout 4s;
+ proxy_read_timeout 600s;
+ proxy_send_timeout 12s;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+ #error_page 404 /404.html;
+ # redirect server error pages to the static page /50x.html
+ #
+ error_page 500 502 503 504 /50x.html;
+ location = /50x.html {
+ root /usr/share/nginx/html;
+ }
+ }
+
+```
+
+#### 2.2.3 资源部署
+
+将前端包拷贝到对应的目录:`/appcom/Install/linkis/dist`
+
+#### 2.2.4 启动服务
+
+```
+sudo systemctl restart nginx
+```
+
+
+## 3 登录管理台
+
+浏览器访问`http://linkis_ipaddr:linkis_port` 其中linkis_port为config.sh里面配置的端口,linkis_ipaddr为安装机器的IP
+
+用户名/密码在`${LINKIS_HOME}/conf/linkis-mg-gateway.properties`中查看
+```shell script
+wds.linkis.admin.user= #用户
+wds.linkis.admin.password= #密码
+
+```
+
+## 4 注意事项
+
+如果需要修改端口或则静态资源目录等,请修改`/etc/nginx/conf.d/linkis.conf` 文件后执行 `sudo nginx -s reload` 命令
+:::caution 注意
+- 目前暂未集成visualis功能,安装过程中如果提示安装linkis/visualis失败,可以忽略
+- 查看nginx是否正常启动:检查nginx进程是否存在 `ps -ef |grep nginx`
+- 检查nginx的配置是否正确 `sudo nginx -T `
+- 如果端口被占用,可以修改nginx启动的服务端口`/etc/nginx/conf.d/linkis.conf`listen端口值,保存后重新启动
+- 如果访问管理台出现接口502,或则`Unexpected token < in JSON at position 0`异常,请确认linkis-mg-gateway是否正常启动,如果正常启动,查看nginx配置文件中配置的linkis-mg-gateway服务地址是否正确
+:::
+
+
+## 5 常见问题
+
+### 5.1 上传文件大小限制
+
+```
+sudo vi /etc/nginx/nginx.conf
+```
+
+更改上传大小
+
+```
+client_max_body_size 200m
+```
+
+### 5.2 接口超时
+
+```
+sudo vi /etc/nginx/conf.d/linkis.conf
+```
+更改接口超时时间
+
+```
+proxy_read_timeout 600s
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/deploy-quick.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/deploy-quick.md
new file mode 100644
index 00000000000..608f7db07af
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/deploy-quick.md
@@ -0,0 +1,824 @@
+---
+title: 单机部署
+sidebar_position: 1
+---
+
+## 1. 首次安装准备事项
+
+### 1.1 Linux服务器
+
+**硬件要求**
+安装linkis 微服务近6个,至少3G内存。每个微服务默认配置启动的jvm -Xmx 内存大小为 512M(内存不够的情况下,可以尝试调小至256/128M,内存足够情况下也可以调大)。
+
+
+### 1.2 添加部署用户
+
+> 部署用户: linkis核心进程的启动用户,同时此用户会默认作为管理员权限,部署过程中会生成对应的管理员登录密码,位于`conf/linkis-mg-gateway.properties`文件中
+> Linkis支持指定提交、执行的用户。linkis主要进程服务会通过`sudo -u ${linkis-user}` 切换到对应用户下,然后执行对应的引擎启动命令,所以引擎`linkis-engine`进程归属的用户是任务的执行者(因此部署用户需要有sudo权限,而且是免密的)。
+
+以hadoop用户为例(linkis中很多配置用户默认都使用hadoop用户,建议初次安装者使用hadoop用户,否则在安装过程中可能会遇到很多意想不到的错误 ):
+
+先查看系统中是否已经有 hadoop 用户,若已经存在,则直接授权即可,若不存在,先创建用户,再授权。
+
+查看是否已存在 hadoop 用户
+```shell script
+$ id hadoop
+uid=2001(hadoop) gid=2001(hadoop) groups=2001(hadoop)
+```
+
+若不存在,则需要创建 hadoop 用户,并加入 hadoop 用户组
+```shell script
+$ sudo useradd hadoop -g hadoop
+$ vi /etc/sudoers
+#免密配置
+hadoop ALL=(ALL) NOPASSWD: NOPASSWD: ALL
+```
+
+以下操作都是在hadoop用户下进行
+
+### 1.3 依赖环境
+
+Linkis需要的环境引擎如下列表所示,这些必需的引擎在安装检查脚本`${LINKIS_HOME}/bin/checkENv.sh`中检查。
+
+| 引擎类型 | 是否必装 | 安装直通车 |
+|----------------|------|-------------------------------------------------------------------------------------------------------------|
+| JDK(1.8.0 141) | 必需 | [安装JDK和设置JAVA_HOME](https://docs.oracle.com/cd/E19509-01/820-5483/6ngsiu065/index.html) |
+| mysql(5.5+) | 必需 | [安装MySQL](https://docs.oracle.com/cd/E69403_01/html/E56873/mysql.html) |
+| Python(3.6.8) | 必需 | [Python安装和使用](https://docs.python.org/zh-cn/3/using/index.html) |
+| Nginx(1.14.1) | 必需 | [Nginx安装指南](http://nginx.org/en/linux_packages.html#instructions) |
+| Hadoop((2.7.2) | 必需 | [Hadoop快速入门](https://hadoop.apache.org/docs/r1.0.4/cn/quickstart.html#%E5%AE%89%E8%A3%85%E8%BD%AF%E4%BB%B6) |
+| Spark(2.4.3) | 必需 | [Spark安装入门](https://spark.apache.org/downloads.html) |
+| Hive(3.1.3) | 必需 | [Hive安装指南](https://cwiki.apache.org/confluence/display/hive/adminmanual+installation) |
+
+## 2. 配置修改
+
+### 2.1 安装包准备
+
+- 方式1:从官网[下载地址](https://linkis.apache.org/zh-CN/download/main):https://linkis.apache.org/zh-CN/download/main
+,下载对应的安装包(项目安装包和管理台安装包)。
+- 方式2:根据[Linkis 编译打包](../development/build)和[前端管理台编译](../development/build-console) 自行编译出项目安装包和管理台安装包。
+
+上传安装包`apache-linkis-x.x.x-bin.tar.gz`后,进行解压安装包
+
+```shell script
+$ tar -xvf apache-linkis-x.x.x-bin.tar.gz
+```
+
+解压后的目录结构如下
+```shell script
+-rw-r--r-- 1 hadoop hadoop 518192043 Jun 20 09:50 apache-linkis-x.x.x-bin.tar.gz
+drwxrwxr-x 2 hadoop hadoop 4096 Jun 20 09:56 bin //执行环境检查和安装的脚本
+drwxrwxr-x 2 hadoop hadoop 4096 Jun 20 09:56 deploy-config // 部署时依赖的DB等环境配置信息
+drwxrwxr-x 4 hadoop hadoop 4096 Jun 20 09:56 docker
+drwxrwxr-x 4 hadoop hadoop 4096 Jun 20 09:56 helm
+-rwxrwxr-x 1 hadoop hadoop 84732 Jan 22 2020 LICENSE
+drwxr-xr-x 2 hadoop hadoop 20480 Jun 20 09:56 licenses
+drwxrwxr-x 7 hadoop hadoop 4096 Jun 20 09:56 linkis-package // 实际的软件包,包括lib/服务启动脚本工具/db的初始化脚本/微服务的配置文件等
+-rwxrwxr-x 1 hadoop hadoop 119503 Jan 22 2020 NOTICE
+-rw-r--r-- 1 hadoop hadoop 11959 Jan 22 2020 README_CN.md
+-rw-r--r-- 1 hadoop hadoop 12587 Jan 22 2020 README.md
+
+```
+
+### 2.2 配置数据库信息
+
+`vim deploy-config/linkis-env.sh`
+
+```shell script
+# 选择linkis业务数据库类型,默认mysql
+# 如果使用postgresql,请改为postgresql
+# 注意: 当前配置只适用于linkis>=1.4.0
+dbType=mysql
+```
+
+`vim deploy-config/db.sh`
+
+```shell script
+# Linkis自身业务的数据库信息 - mysql
+MYSQL_HOST=xx.xx.xx.xx
+MYSQL_PORT=3306
+MYSQL_DB=linkis_test
+MYSQL_USER=test
+MYSQL_PASSWORD=xxxxx
+
+# Linkis自身业务的数据库信息 - postgresql
+# 注意: 以下配置只适用于linkis>=1.4.0
+PG_HOST=xx.xx.xx.xx
+PG_PORT=5432
+PG_DB=linkis_test
+PG_SCHEMA=linkis_test
+PG_USER=test
+PG_PASSWORD=123456
+
+# 提供 Hive 元数据数据库的 DB 信息,如果不涉及hive引擎(或则只是简单试用),可以不配置
+#主要是配合scriptis一起使用,如果不配置,会默认尝试通过$HIVE_CONF_DIR 中的配置文件获取
+HIVE_META_URL="jdbc:mysql://10.10.10.10:3306/hive_meta_demo?useUnicode=true&characterEncoding=UTF-8"
+HIVE_META_USER=demo # HiveMeta元数据库的用户
+HIVE_META_PASSWORD=demo123 # HiveMeta元数据库的密码
+```
+
+
+### 2.3 配置基础变量
+
+文件位于`deploy-config/linkis-env.sh`。
+
+#### 部署用户
+```shell script
+deployUser=hadoop #执行部署的用户,为 1.2 步骤给中创建的用户
+```
+
+#### 基础目录配置(可选)
+:::caution 注意
+根据实际情况确定是否需要调整,可以选择使用默认值
+:::
+
+
+```shell script
+
+# 指定用户使用的目录路径,一般用于存储用户的脚本文件和日志文件等,是用户的工作空间。 对应的配置文件配置项为 wds.linkis.filesystem.root.path(linkis.properties)
+WORKSPACE_USER_ROOT_PATH=file:///tmp/linkis
+
+# 结果集日志等文件路径,用于存储Job的结果集文件 wds.linkis.resultSet.store.path(linkis-cg-entrance.properties) //如果未配置 使用HDFS_USER_ROOT_PATH的配置
+RESULT_SET_ROOT_PATH=file:///tmp/linkis
+
+# 结果集日志等文件路径,用于存储Job的结果集文件 wds.linkis.filesystem.hdfs.root.path(linkis.properties)
+HDFS_USER_ROOT_PATH=hdfs:///tmp/linkis
+
+# 存放执行引擎的工作路径,需要部署用户有写权限的本地目录 wds.linkis.engineconn.root.dir(linkis-cg-engineconnmanager.properties)
+ENGINECONN_ROOT_PATH=/appcom/tmp
+```
+
+#### Yarn的ResourceManager的地址
+
+:::caution 注意
+如果需要使用Spark引擎 则需要配置
+:::
+
+```shell script
+
+#可以通过访问http://xx.xx.xx.xx:8088/ws/v1/cluster/scheduler 接口确认是否可以正常访问
+YARN_RESTFUL_URL=http://xx.xx.xx.xx:8088
+```
+执行spark任务时,需要使用到yarn的ResourceManager,linkis默认它是未开启权限验证的,如果ResourceManager开启了密码权限验证,请安装部署后,
+修改数据库表 `linkis_cg_rm_external_resource_provider` 插入yarn数据信息,详细可以参考[查看yarn地址是否配置正确](#811-查看yarn地址是否配置正确)
+
+#### 基础组件环境信息
+
+:::caution 注意
+可以通过用户的系统环境变量配置, 如果通过系统环境变量配置的,deploy-config/linkis-env.sh配置文件中可以不进行配置 直接注释掉。
+:::
+
+```shell script
+##如果不使用Hive、Spark等引擎且不依赖Hadoop,则不需要配置以下环境变量
+
+#HADOOP
+HADOOP_HOME=/appcom/Install/hadoop
+HADOOP_CONF_DIR=/appcom/config/hadoop-config
+
+#Hive
+HIVE_HOME=/appcom/Install/hive
+HIVE_CONF_DIR=/appcom/config/hive-config
+
+#Spark
+SPARK_HOME=/appcom/Install/spark
+SPARK_CONF_DIR=/appcom/config/spark-config
+```
+
+
+#### LDAP 登录配置(可选)
+
+:::caution 注意
+默认是使用静态用户和密码,静态用户即部署用户,静态密码会在执行部署是随机生成一个密码串,存储于`${LINKIS_HOME}/conf/linkis-mg-gateway.properties`(>=1.0.3版本)。
+:::
+
+
+```shell script
+#LDAP配置,默认Linkis只支持部署用户登录,如果需要支持多用户登录可以使用LDAP,需要配置以下参数:
+#LDAP_URL=ldap://localhost:1389/
+#LDAP_BASEDN=dc=webank,dc=com
+```
+
+
+#### JVM内存配置(可选)
+>微服务启动jvm内存配置,可以根据机器实际情况进行调整,如果机器内存资源较少,可以尝试调小至256/128M
+```shell script
+## java application default jvm memory
+export SERVER_HEAP_SIZE="512M"
+```
+
+#### 安装目录配置(可选)
+> Linkis最终会被安装到此目录下,不配置默认是与当前安装包同一级目录下
+
+```shell script
+##The decompression directory and the installation directory need to be inconsistent
+LINKIS_HOME=/appcom/Install/LinkisInstall
+```
+
+#### 无HDFS模式部署(可选 >1.1.2版本支持)
+
+> 在没有HDFS 的环境中部署 Linkis 服务,以方便更轻量化的学习使用和调试。去HDFS模式部署不支持hive/spark/flink引擎等任务
+
+修改 `linkis-env.sh` 文件,修改以下内容
+```bash
+#使用[file://]路径模式代替[hdfs://]模式
+WORKSPACE_USER_ROOT_PATH=file:///tmp/linkis/
+HDFS_USER_ROOT_PATH=file:///tmp/linkis
+RESULT_SET_ROOT_PATH=file:///tmp/linkis
+
+export ENABLE_HDFS=false
+export ENABLE_HIVE=false
+export ENABLE_SPARK=false
+```
+
+#### kerberos 认证(可选)
+
+> 默认 Linkis 未开启 kerberos 认证,如果使用的hive集群开启了 kerberos 模式认证,需要配置如下参数。
+
+修改 `linkis-env.sh` 文件,修改内容如下
+```bash
+#HADOOP
+HADOOP_KERBEROS_ENABLE=true
+HADOOP_KEYTAB_PATH=/appcom/keytab/
+```
+
+### 2.4 配置 Token
+文件位于 `bin/install.sh`
+
+Linkis 1.3.2 版本为保证系统安全性已将 Token 值改为32位随机生成,具体可查看[Token变更说明](https://linkis.apache.org/zh-CN/docs/1.3.2/feature/update-token/)。
+
+使用随机生成Token,初次与[WDS其它组件](https://github.com/WeDataSphere/DataSphereStudio/blob/master/README-ZH.md)对接时会遇到很多 Token 验证失败的问题,建议初次安装时不使用随机生成Token,修改如下配置为 true 即可。
+
+```
+DEBUG_MODE=true
+```
+
+### 2.5 注意事项
+
+**全量安装**
+
+对于全量安装新版本 Linkis 时, install.sh 脚本中会自动处理配置文件和数据库 Token 保持一致。因此 Linkis 服务自身 Token 无需修改。各应用可通过管理台查询并使用新 Token。
+
+**版本升级**
+
+版本升级时,数据库 Token 并未修改,因此无需修改配置文件和应用 Token。
+
+**Token 过期问题**
+
+当遇到 Token 令牌无效或已过期问题时可以检查 Token 是否配置正确,可通过管理台 ==> 基础数据管理 ==> 令牌管理,查询 Token。
+
+**Python 版本问题**
+Linkis 升级为 1.4.0 后默认 Spark 版本升级为 3.x,无法兼容 python2。因此如果需要使用 pyspark 功能需要做如下修改。
+1. 映射 python2 命令为 python3
+```
+sudo ln -snf /usr/bin/python3 /usr/bin/python2
+```
+2. spark 引擎连接器配置 $LINKIS_HOME/lib/linkis-engineconn-plugins/spark/dist/3.2.1/conf/linkis-engineconn.properties 中添加如下配置,指定python安装路径
+```
+pyspark.python3.path=/usr/bin/python3
+```
+
+## 3. 安装和启动
+
+### 3.1 执行安装脚本:
+
+```bash
+ sh bin/install.sh
+```
+
+install.sh脚本会询问您是否需要初始化数据库并导入元数据。如果选择初始化,会把数据库中的表数据清空重新初始化。
+
+**第一次安装必须选清空数据库 **
+
+:::tip 注意
+- 如果出现报错,又不清楚具体是执行什么命令报错,可以加 -x 参数`sh -x bin/install.sh`,将shell脚本执行过程日志打印出来,方便定位问题。
+- 权限问题:`mkdir: cannot create directory ‘xxxx’: Permission denied`,请确认部署用户是否拥有该路径的读写权限。
+:::
+
+执行成功提示如下:
+```shell script
+`Congratulations! You have installed Linkis x.x.x successfully, please use sh /data/Install/linkis/sbin/linkis-start-all.sh to start it!
+Your default account password is [hadoop/5e8e312b4]`
+```
+
+### 3.2 添加mysql驱动包
+
+:::caution 注意
+因为mysql-connector-java驱动是GPL2.0协议,不满足Apache开源协议关于license的政策,因此从1.0.3版本开始,提供的Apache版本官方部署包,默认是没有mysql-connector-java-x.x.x.jar的依赖包(**若是通过集成的全家桶物料包安装,则无需手动添加**),安装部署时需要自行添加依赖到对应的lib包中。 可以在对应的目录下查看是否存在,如果不存在则需要添加。
+
+:::
+
+下载mysql驱动 以 8.0.28 版本为例:[下载链接](https://repo1.maven.org/maven2/mysql/mysql-connector-java/8.0.28/mysql-connector-java-8.0.28.jar)
+
+拷贝mysql 驱动包至lib包下
+```
+cp mysql-connector-java-8.0.28.jar ${LINKIS_HOME}/lib/linkis-spring-cloud-services/linkis-mg-gateway/
+cp mysql-connector-java-8.0.28.jar ${LINKIS_HOME}/lib/linkis-commons/public-module/
+```
+### 3.3 添加postgresql驱动包 (可选)
+如果选择使用postgresql作为业务数据库,需要手动添加postgresql驱动
+下载postgresql驱动 以42.5.4版本为例:[下载链接](https://repo1.maven.org/maven2/org/postgresql/postgresql/42.5.4/postgresql-42.5.4.jar)
+拷贝postgresql驱动包至lib包下
+```
+cp postgresql-42.5.4.jar ${LINKIS_HOME}/lib/linkis-spring-cloud-services/linkis-mg-gateway/
+cp postgresql-42.5.4.jar ${LINKIS_HOME}/lib/linkis-commons/public-module/
+```
+### 3.4 配置调整(可选)
+> 以下操作,跟依赖的环境有关,根据实际情况,确定是否需要操作
+
+#### 3.4.1 Yarn的认证
+
+执行spark任务时,需要使用到yarn的ResourceManager,通过配置项`YARN_RESTFUL_URL=http://xx.xx.xx.xx:8088 `控制。
+执行安装部署时,会将`YARN_RESTFUL_URL=http://xx.xx.xx.xx:8088` 信息更新到数据库表中 `linkis_cg_rm_external_resource_provider`中时候,默认访问yarn资源是不需权限验证的,
+如果yarn的ResourceManager开启了密码权限验证,请安装部署后,修改数据库表 `linkis_cg_rm_external_resource_provider` 中生成的yarn数据信息,
+详细可以参考[查看yarn地址是否配置正确](#811-查看yarn地址是否配置正确)。
+
+#### 3.4.2 session
+如果您是对Linkis的升级。同时部署DSS或者其他项目,但其它软件中引入的依赖linkis版本<1.1.1(主要看lib包中,所依赖的Linkis的linkis-module-x.x.x.jar包 <1.1.1),则需要修改位于`${LINKIS_HOME}/conf/linkis.properties`文件。
+```shell
+echo "wds.linkis.session.ticket.key=bdp-user-ticket-id" >> linkis.properties
+```
+
+#### 3.4.3 S3 模式
+> 目前支持将引擎执行日志和结果存储到 S3 文件系统
+>
+> 注意: linkis没有对 S3 做权限适配,所以无法对其做赋权操作
+
+`vim $LINKIS_HOME/conf/linkis.properties`
+```shell script
+# s3 file system
+linkis.storage.s3.access.key=xxx
+linkis.storage.s3.secret.key=xxx
+linkis.storage.s3.endpoint=http://xxx.xxx.xxx.xxx:xxx
+linkis.storage.s3.region=xxx
+linkis.storage.s3.bucket=xxx
+```
+
+`vim $LINKIS_HOME/conf/linkis-cg-entrance.properties`
+```shell script
+wds.linkis.entrance.config.log.path=s3:///linkis/logs
+wds.linkis.resultSet.store.path=s3:///linkis/results
+```
+
+### 3.5 启动服务
+```shell script
+sh sbin/linkis-start-all.sh
+```
+
+### 3.6 安装后配置的修改
+安装完成后,如果需要修改配置(因端口冲突或则某些配置有问题需要调整配置),可以重新执行安装,或则修改对应服务的配置`${LINKIS_HOME}/conf/*properties`文件后,重启对应的服务,如:`sh sbin/linkis-daemon.sh start ps-publicservice`。
+
+
+### 3.7 检查服务是否正常启动
+访问eureka服务页面(http://eurekaip:20303),
+默认会启动6个 Linkis 微服务,其中下图linkis-cg-engineconn服务为运行任务才会启动。
+![Linkis1.0_Eureka](./images/eureka.png)
+
+```shell script
+LINKIS-CG-ENGINECONNMANAGER 引擎管理服务
+LINKIS-CG-ENTRANCE 计算治理入口服务
+LINKIS-CG-LINKISMANAGER 计算治理管理服务
+LINKIS-MG-EUREKA 微服务注册中心服务
+LINKIS-MG-GATEWAY 网关服务
+LINKIS-PS-PUBLICSERVICE 公共服务
+```
+
+注意:在 Linkis 1.3.1 中已将 LINKIS-PS-CS、LINKIS-PS-DATA-SOURCE-MANAGER、LINKIS-PS-METADATAMANAGER服务合并到LINKIS-PS-PUBLICSERVICE,将LINKIS-CG-ENGINEPLUGIN服务合并到LINKIS-CG-LINKISMANAGER。
+
+如果有服务未启动,可以在对应的log/${服务名}.log文件中查看详细异常日志。
+
+### 3.8 配置 Token
+
+Linkis 原有默认 Token 固定且长度太短存在安全隐患。因此 Linkis 1.3.2 将原有固定 Token 改为随机生成,并增加 Token 长度。
+
+新 Token 格式:应用简称-32 位随机数,如BML-928a721518014ba4a28735ec2a0da799。
+
+Token 可能在 Linkis 服务自身使用,如通过 Shell 方式执行任务、BML 上传等,也可能在其它应用中使用,如 DSS、Qualitis 等应用访问 Linkis。
+
+#### 查看 Token
+**通过 SQL 语句查看**
+```sql
+select * from linkis_mg_gateway_auth_token;
+```
+**通过管理台查看**
+
+登录管理台 -> 基础数据管理 -> 令牌管理
+![](/Images-zh/deployment/token-list.png)
+
+#### 检查 Token 配置
+
+Linkis 服务本身使用 Token 时,配置文件中 Token 需与数据库中 Token 一致。通过应用简称前缀匹配。
+
+$LINKIS_HOME/conf/linkis.properties文件 Token 配置
+
+```
+linkis.configuration.linkisclient.auth.token.value=BML-928a721518014ba4a28735ec2a0da799
+wds.linkis.client.common.tokenValue=BML-928a721518014ba4a28735ec2a0da799
+wds.linkis.bml.auth.token.value=BML-928a721518014ba4a28735ec2a0da799
+wds.linkis.context.client.auth.value=BML-928a721518014ba4a28735ec2a0da799
+wds.linkis.errorcode.auth.token=BML-928a721518014ba4a28735ec2a0da799
+
+wds.linkis.client.test.common.tokenValue=LINKIS_CLI-215af9e265ae437ca1f070b17d6a540d
+
+wds.linkis.filesystem.token.value=WS-52bce72ed51741c7a2a9544812b45725
+wds.linkis.gateway.access.token=WS-52bce72ed51741c7a2a9544812b45725
+
+wds.linkis.server.dsm.auth.token.value=DSM-65169e8e1b564c0d8a04ee861ca7df6e
+```
+
+$LINKIS_HOME/conf/linkis-cli/linkis-cli.properties文件 Token 配置
+```
+wds.linkis.client.common.tokenValue=BML-928a721518014ba4a28735ec2a0da799
+```
+
+其它应用使用 Token 时,需要修改其 Token 配置与数据库中 Token 一致。
+
+## 4. 安装web前端
+web端是使用nginx作为静态资源服务器的,访问请求流程是:
+`Linkis管理台请求->nginx ip:port->linkis-gateway ip:port-> 其他服务`
+
+### 4.1 下载前端安装包并解压
+```shell script
+tar -xvf apache-linkis-x.x.x-web-bin.tar.gz
+```
+
+### 4.2 修改配置config.sh
+```shell script
+#访问管理台的端口
+linkis_port="8188"
+
+#linkis-mg-gateway服务地址
+linkis_url="http://localhost:9020"
+```
+
+### 4.3 执行部署脚本
+
+```shell script
+# nginx 需要sudo权限进行安装
+sudo sh install.sh
+```
+安装后,linkis的nginx配置文件默认是 在`/etc/nginx/conf.d/linkis.conf`
+nginx的日志文件在 `/var/log/nginx/access.log` 和`/var/log/nginx/error.log`
+生成的linkis管理台的nginx配置文件示例如下:
+```nginx
+
+ server {
+ listen 8188;# 访问端口 如果端口被占用,则需要修改
+ server_name localhost;
+ #charset koi8-r;
+ #access_log /var/log/nginx/host.access.log main;
+ location / {
+ root /appcom/Install/linkis-web/dist; # 静态文件目录
+ index index.html index.html;
+ }
+ location /ws {
+ proxy_pass http://localhost:9020;#后端Linkis的地址
+ proxy_http_version 1.1;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+
+ location /api {
+ proxy_pass http://localhost:9020; #后端Linkis的地址
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header x_real_ipP $remote_addr;
+ proxy_set_header remote_addr $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_http_version 1.1;
+ proxy_connect_timeout 4s;
+ proxy_read_timeout 600s;
+ proxy_send_timeout 12s;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+
+ #error_page 404 /404.html;
+ # redirect server error pages to the static page /50x.html
+ #
+ error_page 500 502 503 504 /50x.html;
+ location = /50x.html {
+ root /usr/share/nginx/html;
+ }
+ }
+```
+
+如果需要修改端口或则静态资源目录等,请修改`/etc/nginx/conf.d/linkis.conf` 文件后执行 `sudo nginx -s reload` 命令
+:::caution 注意
+- 目前暂未集成visualis功能,安装过程中如果提示安装linkis/visualis失败,可以忽略 。
+- 查看nginx是否正常启动:检查nginx进程是否存在 `ps -ef |grep nginx` 。
+- 检查nginx的配置是否正确 `sudo nginx -T ` 。
+- 如果端口被占用,可以修改nginx启动的服务端口`/etc/nginx/conf.d/linkis.conf`listen端口值,保存后重新启动。
+- 如果访问管理台出现接口502,或则`Unexpected token < in JSON at position 0`异常,请确认linkis-mg-gateway是否正常启动,如果正常启动,查看nginx配置文件中配置的linkis-mg-gateway服务地址是否正确。
+:::
+
+### 4.4 登录管理台
+
+浏览器登陆 `http://xx.xx.xx.xx:8188/#/login`
+用户名/密码在`{LINKIS_HOME}/conf/linkis-mg-gateway.properties`中查看。
+```shell script
+wds.linkis.admin.user= #用户
+wds.linkis.admin.password= #密码
+
+```
+
+## 5. 验证基础功能
+>根据实际需求,验证对应的引擎任务
+
+```
+#引擎的engineType 拼接的版本号,一定要与实际的相匹配,以下示例是默认的版本号
+#shell 引擎任务
+sh bin/linkis-cli -submitUser hadoop -engineType shell-1 -codeType shell -code "whoami"
+
+#hive引擎任务
+sh bin/linkis-cli -submitUser hadoop -engineType hive-3.1.3 -codeType hql -code "show tables"
+
+#spark引擎任务
+sh bin/linkis-cli -submitUser hadoop -engineType spark-3.2.1 -codeType sql -code "show tables"
+
+#python引擎任务
+sh bin/linkis-cli -submitUser hadoop -engineType python-python2 -codeType python -code 'print("hello, world!")'
+```
+如果验证失败,请参考【步骤8】进行排查。
+
+## 6. 开发工具IDE(Scriptis)的安装(可选)
+安装Scripti工具后,可以支持在web页面在线写SQL、Pyspark、HiveQL等脚本,详细指引见[工具Scriptis的安装部署](integrated/install-scriptis)。
+
+## 7. 支持的引擎
+
+### 7.1 引擎适配列表
+
+请注意:Linkis的单独安装包默认只包含Python、Shell、Hive、Spark四个引擎,如果有其他的引擎(如jdbc/flink/sqoop等引擎)使用场景,可以手动安装,具体请参考 [EngineConnPlugin引擎插件安装文档](install-engineconn)。
+
+本版本已适配的支持引擎列表如下:
+
+| 引擎类型 | 适配情况 | 官方安装包是否包含 |
+|---------------|-------------------|------|
+| Python | >=1.0.0 已适配 | 包含 |
+| Shell | >=1.0.0 已适配 | 包含 |
+| Hive | >=1.0.0 已适配 | 包含 |
+| Spark | >=1.0.0 已适配 | 包含 |
+| Pipeline | >=1.0.0 已适配 | **不包含** |
+| JDBC | >=1.0.0 已适配 | **不包含** |
+| Flink | >=1.0.0 已适配 | **不包含** |
+| openLooKeng | >=1.1.1 已适配 | **不包含** |
+| Sqoop | >=1.1.2 已适配 | **不包含** |
+| Trino | >=1.3.2 已适配 | **不包含** |
+| Presto | >=1.3.2 已适配 | **不包含** |
+| Elasticsearch | >=1.3.2 已适配 | **不包含** |
+| Seatunnel | >=1.3.2 已适配 | **不包含** |
+| Impala | >=1.4.0 已适配 | **不包含** |
+
+
+
+### 7.2 查看部署的引擎
+
+#### 方式1: 查看引擎lib包目录
+
+```
+$ tree linkis-package/lib/linkis-engineconn-plugins/ -L 3
+linkis-package/lib/linkis-engineconn-plugins/
+├── hive
+│ ├── dist
+│ │ └── 3.1.3 #版本为 3.1.3 engineType 为hive-3.1.3
+│ └── plugin
+│ └── 3.1.3
+├── python
+│ ├── dist
+│ │ └── python2
+│ └── plugin
+│ └── python2 #版本为python2 engineType 为python-python2
+├── shell
+│ ├── dist
+│ │ └── 1
+│ └── plugin
+│ └── 1
+└── spark
+ ├── dist
+ │ └── 3.2.1
+ └── plugin
+ └── 3.2.1
+```
+
+#### 方式2: 查看linkis的数据库表
+```shell script
+select * from linkis_cg_engine_conn_plugin_bml_resources
+```
+### 7.3 非默认引擎检查
+非默认引擎的检查通过手工执行脚本`sh $LINKIS_HOME/bin/checkAdd.sh ${engineType}`来检查,具体脚本参见目录(`$LINKIS_HOME/bin/checkAdd.sh`) 。具体的检查方法如下:
+
+```shell script
+function print_usage(){
+ echo "Usage: checkAdd [EngineName]"
+ echo " EngineName : The Engine name that you want to check"
+ echo " Engine list as bellow: JDBC Flink openLooKeng Presto Sqoop Elasticsearch "
+}
+```
+
+非默认引擎检查过程中使用到的参数分为两类:一类是数据引擎连接信息,在`$LINKIS_HOME/deploy-config/db.sh`中定义;另一类是引用参数,包括检查开关、版本定义、java路径等,在`$LINKIS_HOME/deploy-config/db.sh`定义。相关的引擎及参数描述如下:
+
+| 引擎类型 | 使用到的参数 | 参数描述 |
+|---------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------|
+| JDBC | ${MYSQL_HOST}, ${MYSQL_PORT}, ${MYSQL_DB}, ${MYSQL_USER}, ${MYSQL_PASSWORD} | MySQL引擎连接信息,包括主机IP、端口、数据库名、用户、密码 |
+| JDBC | ${MYSQL_CONNECT_JAVA_PATH} | MySQL驱动连接所在目录 |
+| Flink | ${FLINK_HOME} | 定义 FLink 安装所在目录,包含Flink执行脚本和样例 |
+| openLooKeng | ${OLK_HOST}, ${OLK_PORT}, ${OLK_CATALOG}, ${OLK_SCHEMA}, {OLK_USER}, ${OLK_PASSWORD} | openLooKeng引擎连接信息,包括主机IP、端口、编目、模式、用户名、密码 |
+| openLooKeng | ${OLK_JDBC_PATH} | openLooKeng连接器目录 |
+| Presto | ${PRESTO_HOST}, ${PRESTO_PORT}, ${PRESTO_CATALOG}, ${PRESTO_SCHEMA} | Presto引擎连接信息,包括主机IP、端口、编目、模式 |
+| Sqoop | ${HIVE_META_URL}, ${HIVE_META_USER}, ${HIVE_META_PASSWORD} | sqoop连接hive的连接信息,包括服务地址、用户名、密码 |
+| Elasticsearch | ${ES_RESTFUL_URL} | Elasticsearch服务地址 |
+| Impala | ${IMPALA_HOST}, ${IMPALA_PORT} | impala连接信息,包括主机 IP 、端口 |
+| Trino | ${TRINO_COORDINATOR_HOST}, ${TRINO_COORDINATOR_PORT}, ${TRINO_COORDINATOR_CATALOG}, ${TRINO_COORDINATOR_SCHEMA} | trino连接信息,包括主机IP、端口、类别、编目、模式 |
+| Seatunnel | ${SEATUNNEL_HOST}, ${SEATUNNEL_PORT} | Seatunnel连接信息,包括主机IP、端口 |
+
+## 8. 常见异常问题排查指引
+### 8.1. Yarn队列检查
+
+>如果需要使用到spark/hive/flink引擎
+
+登录后查看能否正常显示yarn队列资源(点击页面右下角按钮)(需要先安装前端)。
+
+正常如下图所示:
+![yarn-normal](images/yarn-normal.png)
+
+若如果无法显示:可以按以下指引调整
+
+#### 8.1.1 查看yarn地址是否配置正确
+数据库表 `linkis_cg_rm_external_resource_provider` `
+插入yarn数据信息
+```sql
+INSERT INTO `linkis_cg_rm_external_resource_provider`
+(`resource_type`, `name`, `labels`, `config`) VALUES
+('Yarn', 'default', NULL,
+'{\r\n"rmWebAddress": "http://xx.xx.xx.xx:8088",\r\n"hadoopVersion": "3.3.4",\r\n"authorEnable":false,\r\n"user":"hadoop",\r\n"pwd":"123456"\r\n}'
+);
+
+config字段属性
+
+"rmWebAddress": "http://xx.xx.xx.xx:8088", #需要带上http以及端口
+"hadoopVersion": "3.3.4",
+"authorEnable":true, //是否需要认证 可以在浏览器中通过访问http://xx.xx.xx.xx:8088验证用户名和密码
+"user":"user",//用户名
+"pwd":"pwd"//密码
+
+```
+更新后,因为程序中有使用到缓存,想要立即生效,需要重启linkis-cg-linkismanager服务。
+```shell script
+sh sbin/linkis-daemon.sh restart cg-linkismanager
+```
+
+#### 8.1.2 查看yarn队列是否存在
+异常信息:`desc: queue ide is not exists in YARN.`表明配置的yarn队列不存在,需要进行调整。
+
+修改方式:`linkis管理台/参数配置>全局设置>yarn队列名[wds.linkis.rm.yarnqueue]`,修改一个可以使用的yarn队列,以使用的yarn 队列可以在 `rmWebAddress:http://xx.xx.xx.xx:8088/cluster/scheduler` 上查看到。
+
+查看可用的yarn队列
+- 查看yarn队列地址:http://ip:8888/cluster/scheduler
+
+### 8.2 检查引擎物料资源是否上传成功
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources
+```
+
+正常如下:
+![bml](images/bml.png)
+
+查看引擎的物料记录是否存在(如果有更新,查看更新时间是否正确)
+
+- 如果不存在或则未更新,先尝试手动刷新物料资源(详细见[引擎物料资源刷新](install-engineconn#23-引擎刷新))。
+- 通过`log/linkis-cg-linkismanager.log`日志,查看物料失败的具体原因,很多时候可能是hdfs目录没有权限导致。
+- 检查gateway地址配置是否正确`conf/linkis.properties`的配置项`wds.linkis.gateway.url`。
+
+引擎的物料资源默认上传到hdfs目录为 `/apps-data/${deployUser}/bml`。
+
+```shell script
+hdfs dfs -ls /apps-data/hadoop/bml
+#如果没有该目录 请手动创建目录并授予${deployUser}读写权限
+hdfs dfs -mkdir /apps-data
+hdfs dfs -chown hadoop:hadoop /apps-data
+```
+
+### 8.3 登陆密码问题
+
+linkis默认是使用静态用户和密码,静态用户即部署用户,静态密码会在执行部署是随机生成一个密码串,存储于
+
+`${LINKIS_HOME}/conf/linkis-mg-gateway.properties`(>=1.0.3版本)。
+
+### 8.4 版本兼容性问题
+
+linkis默认支持的引擎,与dss兼容关系可以查看[此文档](https://github.com/apache/linkis/blob/master/README.md) 。
+
+
+### 8.5 如何定位服务端异常日志
+
+linkis的微服务比较多,若对系统不熟悉,有时候无法定位到具体哪个模块出现了异常,可以通过全局日志搜索方式。
+```shell script
+tail -f log/* |grep -5n exception(或则tail -f log/* |grep -5n ERROR)
+less log/* |grep -5n exception(或则less log/* |grep -5n ERROR)
+```
+
+
+### 8.6 执行引擎任务的异常排查
+
+** step1:找到引擎的启动部署目录 **
+
+- 方式1:如果执行日志中有显示,可以在管理台上查看到 如下图:
+![engine-log](images/engine-log.png)
+- 方式2:如果方式1中没有找到,可以通过找到`conf/linkis-cg-engineconnmanager.properties`配置的`wds.linkis.engineconn.root.dir`的参数,该值就是引擎启动部署的目录,子目录按执行引擎的用户进行了隔离
+
+```shell script
+# 如果不清楚taskid,可以按时间排序后进行选择 ll -rt /appcom/tmp/${执行的用户}/${日期}/${引擎}/
+cd /appcom/tmp/${执行的用户}/${日期}/${引擎}/${taskId}
+```
+目录大体如下
+```shell script
+conf -> /appcom/tmp/engineConnPublickDir/6a09d5fb-81dd-41af-a58b-9cb5d5d81b5a/v000002/conf #引擎的配置文件
+engineConnExec.sh #生成的引擎的启动脚本
+lib -> /appcom/tmp/engineConnPublickDir/45bf0e6b-0fa5-47da-9532-c2a9f3ec764d/v000003/lib #引擎依赖的包
+logs #引擎启动执行的相关日志
+```
+
+**step2:查看引擎的日志**
+```shell script
+less logs/stdout
+```
+
+**step3:尝试手动执行脚本(如果需要)**
+可以通过尝试手动执行脚本,进行调试
+```
+sh -x engineConnExec.sh
+```
+
+### 8.7 如何修改注册中心eureka的端口
+有时候当eureka的端口被其他服务占用,无法使用默认的eureka端口的时候,需要对eureka端口进行修改,这里把对eureka端口的修改分为执行安装之前和执行安装之后两种情况。
+
+1.执行安装之前修改注册中心eureka端口
+```
+1. 进入apache-linkis-x.x.x-bin.tar.gz的解压目录
+2. 执行 vi deploy-config/linkis-env.sh
+3. 修改EUREKA_PORT=20303为EUREKA_PORT=端口号
+```
+2.执行安装之后修改注册中心eureka端口
+```
+1. 进入${LINKIS_HOME}/conf目录
+
+2. 执行grep -r 20303 ./* ,查询结果如下所示:
+ ./application-eureka.yml: port: 20303
+ ./application-eureka.yml: defaultZone: http://ip:20303/eureka/
+ ./application-linkis.yml: defaultZone: http://ip:20303/eureka/
+ ./linkis-env.sh:EUREKA_PORT=20303
+ ./linkis.properties:wds.linkis.eureka.defaultZone=http://ip:20303/eureka/
+
+3. 将对应位置的端口修改为新的端口,并且重启所有服务sh restart sbin/linkis-start-all.sh
+```
+
+
+### 8.8 CDH适配版本的注意事项
+
+CDH本身不是使用的官方标准的hive/spark包,进行适配时,最好修改linkis的源码中的hive/spark版本的依赖,进行重新编译部署。
+具体可以参考CDH适配博文
+[【Linkis1.0——CDH5环境中的安装与踩坑】](https://mp.weixin.qq.com/s/__QxC1NoLQFwme1yljy-Nw)
+[【DSS1.0.0+Linkis1.0.2——CDH5环境中的试用记录】](https://mp.weixin.qq.com/s/9Pl9P0hizDWbbTBf1yzGJA)
+[【DSS1.0.0与Linkis1.0.2——JDBC引擎相关问题汇总】](https://mp.weixin.qq.com/s/vcFge4BNiEuW-7OC3P-yaw)
+[【DSS1.0.0与Linkis1.0.2——Flink引擎相关问题汇总】](https://mp.weixin.qq.com/s/VxZ16IPMd1CvcrvHFuU4RQ)
+
+### 8.9 Http接口的调试
+
+- 方式1 可以开启[免登陆模式指引](/docs/latest/api/login-api/#2免登录配置)
+- 方式2 postman中的,请求头带上登陆成功的cookie值
+ cookie值可以在浏览器端登陆成功后,获取
+ ![bml](images/bml-cookie.png)
+
+```shell script
+Cookie: bdp-user-ticket-id=xxxxxxxxxxxxxxxxxxxxxxxxxxx
+```
+- 方式3 http请求头添加静态的Token令牌
+ Token在conf/linkis.properties进行配置
+ 如:TEST-AUTH=hadoop,root,user01
+```shell script
+Token-Code:TEST-AUTH
+Token-User:hadoop
+```
+
+### 8.10 异常问题的排查流程
+
+首先要按上述步骤检查服务/环境等是否都正常启动,然后按上述罗列的一些场景的方式进行基础问题的排查 。
+
+[QA文档](https://docs.qq.com/doc/DSGZhdnpMV3lTUUxq)中查找是否有解决方案,链接:https://docs.qq.com/doc/DSGZhdnpMV3lTUUxq
+通过搜索issue中的内容,看是否能找到解决方案。
+![issues](images/issues.png)
+通过官网文档搜索,对于某些问题,可以通过官网搜索关键字进行查询,比如搜索"部署"相关。(如果出现404,请浏览器中刷新一下)
+![search](images/search.png)
+
+
+## 9. 相关的资料如何获取
+linkis官网文档正在不断的完善,可以在本官网查看相关文档。
+
+相关博文链接如下。
+- Linkis的技术博文集 https://github.com/apache/linkis/issues/1233
+- 公众号技术博文https://mp.weixin.qq.com/mp/homepage?__biz=MzI4MDkxNzUxMg==&hid=1&sn=088cbf2bbed1c80d003c5865bc92ace8&scene=18
+- 官网文档 https://linkis.apache.org/zh-CN/docs/latest/about/introduction
+- bili技术分享视频 https://space.bilibili.com/598542776?spm_id_from=333.788.b_765f7570696e666f.2
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/directory-linkis.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/directory-linkis.md
new file mode 100644
index 00000000000..8811c13cb62
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/directory-linkis.md
@@ -0,0 +1,295 @@
+---
+title: 目录结构
+sidebar_position: 7
+---
+
+> Linkis代码层级目录结构,以及安装包目录结构和部署后的目录结构说明,如果想详细了解各个模块,请查看[Linkis的相关架构设计](architecture/overview.md)
+## 1. 源码目录结构
+
+```html
+├── docs
+│ ├── configuration //linkis所有模块的配置项文档
+│ ├── errorcode //linkis所有模块的错误码文档
+│ ├── configuration-change-records.md
+│ ├── index.md
+│ ├── info-1.1.3.md
+│ ├── info-1.2.1.md
+│ ├── info-1.3.1.md
+│ └── trino-usage.md
+├── linkis-commons //核心抽象,里面放有所有的公用模块
+│ ├── linkis-common //通用模块,内置很多通用工具类
+│ ├── linkis-hadoop-common
+│ ├── linkis-httpclient //Java SDK顶层接口 对httpclient的进一步封装
+│ ├── linkis-module // linkis的服务顶层公用模块 涉及到服务启动时的参数和服务初始化 统一的Restful处理 登录态校验等
+│ ├── linkis-mybatis //SpringCloud的Mybatis模块
+│ ├── linkis-protocol //服务请求/响应的一些接口和实体类
+│ ├── linkis-rpc //RPC模块,基于Feign实现的复杂双向通信
+│ ├── linkis-scheduler //通用调度模块
+│ ├── linkis-storage //文件操作工具集
+├── linkis-computation-governance //计算治理服务
+│ ├── linkis-client //Java SDK,用户通过Client可直接访问Linkis
+│ ├── linkis-computation-governance-common
+│ ├── linkis-engineconn
+│ ├── linkis-engineconn-manager
+│ ├── linkis-entrance //通用底层entrance模块
+│ ├── linkis-jdbc-driver //可以类似jdbc sdk方式连接使用linkis
+│ ├── linkis-manager
+├── linkis-dist //编译打包最后阶段步骤 整合所有lib包和安装部署脚本配置等
+│ ├── bin
+│ │ ├── checkEnv.sh
+│ │ ├── common.sh
+│ │ └── install.sh //安装脚本
+│ ├── deploy-config
+│ │ ├── db.sh //数据库配置
+│ │ └── linkis-env.sh //linkis 启动相关配置
+│ ├── docker
+│ │ └── scripts
+│ ├── helm
+│ │ ├── charts
+│ │ ├── scripts
+│ │ ├── README_CN.md
+│ │ └── README.md
+│ ├── package
+│ │ ├── bin
+│ │ ├── conf
+│ │ ├── db
+│ │ └── sbin
+│ ├── release-docs
+│ │ ├── licenses
+│ │ ├── LICENSE
+│ │ └── NOTICE
+│ ├── src
+│ └── pom.xml
+├── linkis-engineconn-plugins // 引擎
+│ ├── elasticsearch
+│ ├── flink
+│ ├── hive
+│ ├── io_file
+│ ├── jdbc
+│ ├── openlookeng
+│ ├── pipeline
+│ ├── presto
+│ ├── python
+│ ├── seatunnel
+│ ├── shell
+│ ├── spark
+│ ├── sqoop
+├── linkis-extensions // 扩展功能增强插件模块
+│ ├── linkis-io-file-client // 对linkis-storage的功能扩展
+├── linkis-orchestrator //服务的编排
+│ ├── linkis-code-orchestrator
+│ ├── linkis-computation-orchestrator
+│ ├── linkis-orchestrator-core
+├── linkis-public-enhancements //公共增强服务
+│ ├── linkis-basedata-manager
+│ ├── linkis-bml // 物料库
+│ ├── linkis-configuration
+│ ├── linkis-context-service //统一上下文
+│ ├── linkis-datasource //数据源服务
+│ ├── linkis-error-code
+│ ├── linkis-instance-label
+│ ├── linkis-jobhistory
+│ ├── linkis-ps-common-lock
+│ ├── linkis-script-dev
+│ ├── linkis-udf
+│ ├── linkis-variable
+├── linkis-spring-cloud-services //微服务治理
+│ ├── linkis-service-discovery
+│ ├── linkis-service-gateway //网关Gateway
+├── linkis-web //linkis的管理台代码
+│ ├── release-docs
+│ │ ├── licenses
+│ │ └── LICENSE
+│ ├── src
+│ ├── config.sh
+│ ├── install.sh
+│ ├── package.json
+│ ├── pom.xml
+│ └── vue.config.js
+├── tool
+│ ├── dependencies
+│ │ ├── known-dependencies.txt
+│ │ └── regenerate_konwn_dependencies_txt.sh
+│ ├── code-style-idea.xml
+│ ├── license-header
+│ └── modify_license.sh
+├── CONTRIBUTING_CN.md
+├── CONTRIBUTING.md
+├── linkis-tree.txt
+├── mvnw
+├── mvnw.cmd
+├── pom.xml
+├── README_CN.md
+├── README.md
+└── scalastyle-config.xml
+
+```
+
+## 2. 安装包目录结构
+```html
+
+├── bin
+│ ├── checkEnv.sh ── 环境变量检测
+│ ├── common.sh ── 部分公共shell函数
+│ └── install.sh ── Linkis安装的主脚本
+├── deploy-config
+│ ├── db.sh //数据库连接配置
+│ └── linkis-env.sh //相关环境配置信息
+├── docker
+├── helm
+├── licenses
+├── linkis-package //微服务相关的启动配置文件,依赖,脚本,linkis-cli等
+│ ├── bin
+│ ├── conf
+│ ├── db
+│ ├── lib
+│ └── sbin
+├── NOTICE
+├── LICENSE
+├── README_CN.md
+└── README.md
+
+```
+
+
+## 3. 部署后的目录结构
+
+
+```html
+├── bin ── linkis-cli 用于向Linkis提交任务的Shell命令行程序
+│ ├── linkis-cli
+│ ├── linkis-cli-hive
+│ ├── linkis-cli-pre
+│ ├── linkis-cli-spark-sql
+│ ├── linkis-cli-spark-submit
+│ └── linkis-cli-sqoop
+├── conf 配置目录
+│ ├── application-eureka.yml
+│ ├── application-linkis.yml ── 微服务通用yml
+│ ├── linkis-cg-engineconnmanager.properties
+│ ├── linkis-cg-engineplugin.properties
+│ ├── linkis-cg-linkismanager.properties
+│ │── linkis-cli
+│ │ ├── linkis-cli.properties
+│ │ └── log4j2.xml
+│ ├── linkis-env.sh ── linkis 环境变量配置
+│ ├── linkis-mg-gateway.properties
+│ ├── linkis.properties ── linkis 服务的全局配合,所有微服务启动都会加载使用
+│ ├── linkis-ps-publicservice.properties
+│ ├── log4j2.xml
+├── db 数据库DML和DDL文件目录
+│ ├── linkis_ddl.sql ── 数据库表定义SQL
+│ ├── linkis_dml.sql ── 数据库表初始化SQL
+│ └── module ── 包含各个微服务的DML和DDL文件
+│ └── upgrade ── 针对每个版本 增量DML/DDL
+├── lib lib目录
+│ ├── linkis-commons ── 公共依赖包 大多服务启动时(linkis-mg-gateway除外) -cp 路径参数 都会加载这个目录
+│ ├── linkis-computation-governance ──计算治理模块的lib目录
+│ ├── linkis-engineconn-plugins ──所有引擎插件的lib目录
+│ ├── linkis-public-enhancements ──公共增强服务的lib目录
+│ └── linkis-spring-cloud-services ──SpringCloud的lib目录
+├── logs 日志目录
+│ ├── linkis-cg-engineconnmanager-gc.log
+│ ├── linkis-cg-engineconnmanager.log
+│ ├── linkis-cg-engineconnmanager.out
+│ ├── linkis-cg-engineplugin-gc.log
+│ ├── linkis-cg-engineplugin.log
+│ ├── linkis-cg-engineplugin.out
+│ ├── linkis-cg-entrance-gc.log
+│ ├── linkis-cg-entrance.log
+│ ├── linkis-cg-entrance.out
+│ ├── linkis-cg-linkismanager-gc.log
+│ ├── linkis-cg-linkismanager.log
+│ ├── linkis-cg-linkismanager.out
+│ ├── linkis-cli
+│ │ ├── linkis-client.hadoop.log.20220409162400037523664
+│ │ ├── linkis-client.hadoop.log.20220409162524417944443
+│ ├── linkis-mg-eureka-gc.log
+│ ├── linkis-mg-eureka.log
+│ ├── linkis-mg-eureka.out
+│ ├── linkis-mg-gateway-gc.log
+│ ├── linkis-mg-gateway.log
+│ ├── linkis-mg-gateway.out
+│ ├── linkis-ps-publicservice-gc.log
+│ ├── linkis-ps-publicservice.log
+│ └── linkis-ps-publicservice.out
+├── pid 所有微服务的进程ID
+│ ├── linkis_cg-engineconnmanager.pid ──引擎管理器微服务
+│ ├── linkis_cg-engineconnplugin.pid ──引擎插件微服务
+│ ├── linkis_cg-entrance.pid ──引擎入口微服务
+│ ├── linkis_cg-linkismanager.pid ──linkis管理器微服务
+│ ├── linkis_mg-eureka.pid ──eureka微服务
+│ ├── linkis_mg-gateway.pid ──gateway微服务
+│ └── linkis_ps-publicservice.pid ──公共微服务
+└── sbin 微服务启停脚本目录
+ ├── ext ──各个微服务的启停脚本目录
+ ├── linkis-daemon.sh ── 快捷启停、重启单个微服务脚本
+ ├── linkis-start-all.sh ── 一键启动全部微服务脚本
+ └── linkis-stop-all.sh ── 一键停止全部微服务脚本
+
+```
+
+### 3.1 配置项修改
+
+在执行完Linkis安装后,所有配置项位于conf目录下,
+如果需要进行配置项修改,修改配置`${LINKIS_HOME}/conf/*properties`文件后,重启对应的服务,
+如:`sh sbin/linkis-daemon.sh start ps-publicservice`。
+如果修改的是公共配置文件`application-eureka.yml/application-linkis.yml/linkis.properties`,需要重启所有服务`sh sbin/linkis-start-all.sh`
+
+
+
+
+### 3.2 微服务启停
+
+所有微服务名称如下:
+ ```
+├── linkis-cg-engineconnmanager 引擎管理服务
+├── linkis-cg-engineplugin 引擎插件管理服务
+├── linkis-cg-entrance 计算治理入口服务
+├── linkis-cg-linkismanager 计算治理管理服务
+├── linkis-mg-eureka 微服务注册中心服务
+├── linkis-mg-gateway Linkis网关服务
+├── linkis-ps-publicservice 公共服务
+ ```
+
+**微服务简称**:
+
+| 简称 | 英文全称 | 中文全称 |
+ |------|-------------------------|------------|
+| cg | Computation Governance | 计算治理 |
+| mg | Microservice Covernance | 微服务治理 |
+| ps | Public Enhancement Service | 公共增强服务 |
+
+
+
+```
+# 一次性启动所有微服务:
+
+ sh linkis-start-all.sh
+
+# 一次性关停所有微服务
+
+ sh linkis-stop-all.sh
+
+# 启动单个微服务(服务名需要去掉linkis前缀如:mg-eureka)
+
+ sh linkis-daemon.sh start service-name
+
+ 例如: sh linkis-daemon.sh start mg-eureka
+
+# 关闭单个微服务
+
+ sh linkis-daemon.sh stop service-name
+
+ 例如: sh linkis-daemon.sh stop mg-eureka
+
+# 重启单个微服务
+
+ sh linkis-daemon.sh restart service-name
+
+ 例如: sh linkis-daemon.sh restart mg-eureka
+# 查看单个微服务的状态
+
+ sh linkis-daemon.sh status service-name
+
+ 例如: sh linkis-daemon.sh status mg-eureka
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/bml-cookie.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/bml-cookie.png
new file mode 100644
index 00000000000..67dc0be98f8
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/bml-cookie.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/bml.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/bml.png
new file mode 100644
index 00000000000..ca9290f945d
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/bml.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/engine-log.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/engine-log.png
new file mode 100644
index 00000000000..3a4c5ee0fb3
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/engine-log.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/eureka.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/eureka.png
new file mode 100644
index 00000000000..3b3f24a4b0e
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/eureka.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/hive-lineage-log.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/hive-lineage-log.png
new file mode 100644
index 00000000000..57caf1f9769
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/hive-lineage-log.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/issues.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/issues.png
new file mode 100644
index 00000000000..b84a711452c
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/issues.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/search.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/search.png
new file mode 100644
index 00000000000..632763a293b
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/search.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/spark-lineage-kafka.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/spark-lineage-kafka.png
new file mode 100644
index 00000000000..3f387f6e62e
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/spark-lineage-kafka.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/spark-lineage-log.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/spark-lineage-log.png
new file mode 100644
index 00000000000..5e9b7cb092c
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/spark-lineage-log.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/yarn-normal.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/yarn-normal.png
new file mode 100644
index 00000000000..fefc3110524
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/images/yarn-normal.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/install-engineconn.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/install-engineconn.md
new file mode 100644
index 00000000000..e09ef0efc5c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/install-engineconn.md
@@ -0,0 +1,182 @@
+---
+title: 引擎的安装
+sidebar_position: 4
+---
+
+> 本文主要介绍对于官方安装包中,未包含的引擎物料(jdbc/sqoop/flink等)/或则自定义实现的新引擎,如何进行安装部署,以支持对应的任务
+
+## 1. 引擎插件目录结构
+
+Linkis的引擎物料包安装目录为`${LINKIS_HOME}/lib/linkis-engineconn-plugins`,目录结构如下:
+
+```html
+hive #引擎主目录,必须为引擎的名字
+│ ├── dist # 引擎启动需要的jar包依赖和配置,不同的版本需要在该目录放置对应的版本目录
+│ │ └── 2.3.3 # 版本号 版本为2.3.3 任务请求参数的engineType 为hive-2.3.3
+│ │ └── conf # 引擎需要的配置文件目录
+│ │ └── lib # 引擎插件需要的依赖包
+│ ├── plugin #引擎插件目录,该目录用于引擎管理服务封装引擎的启动命令和资源申请
+│ └── 2.3.3 # 引擎版本
+│ └── linkis-engineplugin-hive-1.0.0.jar #引擎模块包(只需要放置单独的引擎包)
+├── python
+│ ├── dist
+│ │ └── python2
+│ └── plugin
+│ └── python2 #版本为python2 任务请求参数的engineTypee 为python-python2
+
+```
+
+这里的物料包文件会在Linkis服务启动时候,会根据目录,解析出引擎和版本号,进行引擎物料的持久化存储(HDFS/本地文件系统中),并将持久化存储信息(引擎类型和版本资源索引)
+记录到数据库表`linkis_cg_engine_conn_plugin_bml_resources`中。
+
+示例数据如下:
+
+| engine_conn_type | version | file_name | file_size | last_modified | bml_resource_id | bml_resource_version | create_time | last_update_time |
+| --- | --- | --- | ---: | ---: | --- | --- | --- | --- |
+| hive | v2.3.4 | conf.zip | 2046 | 1651925378000 | 4f0353ac-5703-4b4d-942d-dbaead38b506 | v000001 | 2022-05-07 20:17:45 | 2022-05-07 20:17:45 |
+| hive | v2.3.4 | lib.zip | 137715715 | 1651925379000 | 762595b5-a6d3-4311-8133-4f8d4e0c3aa0 | v000001 | 2022-05-07 20:17:52 | 2022-05-07 20:17:52 |
+
+提交任务执行时,会通过请求的参数`engineType`,从`linkis_cg_engine_conn_plugin_bml_resources`中查询到对应的资源索引,
+通过索引下载对应的引擎物料,并部署启动对应的引擎进程,再进行任务的处理。
+
+如 linkis-cli 提交hive查询示例
+```shell
+sh ./bin/linkis-cli -engineType hive-2.3.3 -codeType hql -code "show tables" -submitUser hadoop -proxyUser hadoop
+```
+
+:::caution 注意
+因为引擎执行时传递的参数`engineType:hive-2.3.3` 是通过-来进行拆分出引擎和版本的,所以版本号里面不能出现`-`,
+如果出现可以通过用其他符号代替,比如`engineType:hive-cdh-2.3.3`,会拆分错,可以直接使用这个:2.3.3 或则cdh_2.3.3 来命名引擎目录
+:::
+
+
+Linkis项目中包含的引擎模块`linkis-engineconn-plugins/engineconn-plugins`都是按这个目录进行打包配置的,
+如果是自己实现的新增引擎,需要按照上述的目录结构进行打包,可以参考hive的assembly配置方式来配置打包流程和配置,
+源码目录:`linkis-engineconn-plugins/hive/src/main/assembly/distribution.xml`
+
+## 2. 引擎的安装
+
+### 2.1 引擎包的准备
+
+#### 方式1
+如果 [非默认引擎物料包](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)中有满足条件的,可以直接下载使用
+
+#### 方式2 手动编译获取
+
+全量编译(首次编译时需要)
+```shell script
+cd ${linkis_code_dir}
+mvn -N install
+mvn clean install
+```
+
+编译引擎
+```shell script
+cd linkis-enginepconn-pugins/engineconn-plugins/pipeline/
+mvn clean install
+```
+
+编译出来的引擎包,位于
+```bash
+${linkis_code_dir}/linkis-engineconn-plugins/{插件模块名}/target/out/{插件模块名}
+```
+
+### 2.2 部署和加载
+
+将 2.1 步编译出来的引擎包,上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+
+### 2.4 并配置默认的引擎版本(可选)
+
+> 主要是配置默认版本,当请求未带版本时 会使用默认版本
+
+修改`$LINKIS_HOME/conf/linkis.properties` 配置文件
+```html
+wds.linkis.hive.engine.version=2.3.3
+```
+
+### 2.5 管理台Configuration配置修改(可选)
+管理台的配置是按照引擎标签来进行管理的,如果新增的引擎,有配置参数需要配置的话,需要修改对应的表的元数据
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:hive-2.3.3
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+以openLooKeng引擎 1.5.0版本 为例
+```html
+
+SET @OPENLOOKENG_LABEL="openlookeng-1.5.0";
+SET @OPENLOOKENG_ALL=CONCAT('*-*,',@OPENLOOKENG_LABEL);
+SET @OPENLOOKENG_IDE=CONCAT('*-IDE,',@OPENLOOKENG_LABEL);
+
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@OPENLOOKENG_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@OPENLOOKENG_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @OPENLOOKENG_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.url', '例如:http://127.0.0.1:8080', '连接地址', 'http://127.0.0.1:8080', 'Regex', '^\\s*http://([^:]+)(:\\d+)(/[^\\?]+)?(\\?\\S*)?$', 'openlookeng', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.catalog', 'catalog', 'catalog', 'system', 'None', '', 'openlookeng', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.source', 'source', 'source', 'global', 'None', '', 'openlookeng', 0, 0, 1, '数据源配置');
+
+
+-- openlookeng-*
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'openlookeng' and label_value = @OPENLOOKENG_ALL);
+
+-- openlookeng default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @OPENLOOKENG_ALL);
+
+```
+
+### 2.6 引擎刷新
+
+#### 2.6.1 方式1 接口刷新
+引擎支持实时刷新,引擎放置到对应目录后,通过http接口向`linkis-cg-engineconnplugin` 服务发送刷新请求即可。
+
+- 接口 `http://${engineconn-plugin-server-IP}:${port}/api/rest_j/v1/rpc/receiveAndReply`
+
+- 请求方式 `POST`
+
+```json
+{
+ "method": "/enginePlugin/engineConn/refreshAll"
+}
+```
+
+#### 2.6.2 方式2 重启刷新
+
+通过重启`linkis-cg-engineconnplugin` 服务,也可以强制刷新引擎目录
+
+```bash
+### cd到sbin目录下,重启linkis-cg-engineconnplugin服务
+
+cd ${LINKIS_HOME}/sbin
+
+## 执行linkis-daemon脚本
+
+sh linkis-daemon.sh restart linkis-cg-linkismanager
+
+```
+
+#### 2.6.3 检查引擎是否刷新成功
+
+如果在刷新过程中遇到问题,需要确认是否刷新成功,则可以查看数据库中的`linkis_engine_conn_plugin_bml_resources`这张表的last_update_time是否为触发刷新的时间。
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources
+```
+
+正常如下:
+![bml](images/bml.png)
+
+查看引擎的物料记录是否存在(如果有更新,查看更新时间是否正确)。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/_category_.json
new file mode 100644
index 00000000000..7cd78cc67d9
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "集成",
+ "position": 9
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/hive-lineage.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/hive-lineage.md
new file mode 100644
index 00000000000..c2c17eaf3f5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/hive-lineage.md
@@ -0,0 +1,140 @@
+---
+title: 集成 Hive血缘
+sidebar_position: 1
+---
+
+本文主要介绍在 `Linkis` 中, `Hive` 引擎血缘采集方案。
+
+
+## 1. 介绍
+
+Hive 提供了一个内置的Hook LineageLogger,它用于记录查询执行期间生成的血缘信息。通过使用 LineageLogger Hook,你可以捕获和记录查询的输入和输出表以及列级别的血缘关系
+
+## 2. 将hive血缘采集至日志
+
+### 2.1 修改`hive-site.xml`
+
+```shell
+vim $HIVE_HOME/conf/hive-site.xml
+
+增加如下配置
+
+ hive.exec.post.hooks
+ org.apache.hadoop.hive.ql.hooks.LineageLogger
+
+```
+
+### 2.2 修改`hive-log4j2.properties`
+
+```shell
+vim $HIVE_HOME/conf/hive-log4j2.properties
+
+增加如下配置
+log4j.logger.org.apache.hadoop.hive.ql.hooks.LineageLogger=INFO
+```
+
+### 2.3 提交任务
+```shell
+sh ./bin/linkis-cli -engineType hive-3.1.3 \
+-codeType hql -code \
+"CREATE TABLE input_table (
+ column1 INT,
+ column2 STRING
+);
+CREATE TABLE output_table (
+ column3 INT,
+ column4 STRING
+);
+INSERT INTO TABLE output_table
+SELECT column1, column2
+FROM input_table;" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+### 2.4 查看日志
+```shell
+cat /appcom/tmp/hadoop/20230922/hive/946375fe-f189-487c-b3a7-f9fa821edace/logs/stdout
+```
+
+输出结果如下:
+![hive-lineage-log](../images/hive-lineage-log.png)
+
+详细信息如下:
+```json
+{
+ "version":"1.0",
+ "user":"hadoop",
+ "timestamp":1695354104,
+ "duration":15318,
+ "jobIds":[
+ "job_1691375506204_0488"
+ ],
+ "engine":"mr",
+ "database":"default",
+ "hash":"dbb11fce57f10dccb6ef724f66af611c",
+ "queryText":"INSERT INTO TABLE output_table\nSELECT column1, column2\nFROM input_table",
+ "edges":[
+ {
+ "sources":[
+ 2
+ ],
+ "targets":[
+ 0
+ ],
+ "edgeType":"PROJECTION"
+ },
+ {
+ "sources":[
+ 3
+ ],
+ "targets":[
+ 1
+ ],
+ "edgeType":"PROJECTION"
+ },
+ {
+ "sources":[
+ 2
+ ],
+ "targets":[
+ 0
+ ],
+ "expression":"compute_stats(default.input_table.column1, 'hll')",
+ "edgeType":"PROJECTION"
+ },
+ {
+ "sources":[
+ 3
+ ],
+ "targets":[
+ 1
+ ],
+ "expression":"compute_stats(default.input_table.column2, 'hll')",
+ "edgeType":"PROJECTION"
+ }
+ ],
+ "vertices":[
+ {
+ "id":0,
+ "vertexType":"COLUMN",
+ "vertexId":"default.output_table.column3"
+ },
+ {
+ "id":1,
+ "vertexType":"COLUMN",
+ "vertexId":"default.output_table.column4"
+ },
+ {
+ "id":2,
+ "vertexType":"COLUMN",
+ "vertexId":"default.input_table.column1"
+ },
+ {
+ "id":3,
+ "vertexType":"COLUMN",
+ "vertexId":"default.input_table.column2"
+ }
+ ]
+}
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/install-scriptis.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/install-scriptis.md
new file mode 100644
index 00000000000..ff08cb83b59
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/install-scriptis.md
@@ -0,0 +1,205 @@
+---
+title: 集成 Scriptis
+sidebar_position: 4.1
+---
+
+## 1. 介绍
+
+> 在 Apache Linkis >= 1.1.1 和 DSS >= 1.1.0 之后,支持将 scriptis 单独部署和 Linkis 进行搭配使用,使用 scriptis 的交互式分析的功能,可以在 web 页面在线写 SQL、Pyspark、HiveQL 等脚本,提交给 Linkis 执行且支持 UDF、函数、资源管控和自定义变量等特性,本文将介绍如何单独部署 Web 组件-scriptis,并通过 scriptis 这种 Web 页面来使用 Apache Linkis 。
+
+
+前提:已经成功安装并可以正常使用了 Linkis 服务(后端和管理台服务),Linkis 的部署流程可以见[Apache Linkis 的快速部署 ](../deploy-quick.md)
+
+示例说明:
+
+- linkis-gateway 服务的地址为 10.10.10.10 端口为 9001
+- Linkis 的管理台 nginx 部署在 10.10.10.10 端口为 8080
+
+
+## 2 物料准备 方式1-直接下载
+
+| **DSS版本** | **DSS源码** | **Linkis版本要求** |**下载连接** |
+|:---- |:---- |:---- |:---- |
+|1.1.0 |[dss branch-1.1.0](https://github.com/WeBankFinTech/DataSphereStudio/tree/branch-1.1.0) |>=1.1.1|[scriptis-web 1.1.0](https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeDatasphere/Linkis/scriptis-web/scriptis-1.1.0.tar) |
+
+
+## 3 物料准备 方式2-自行编译
+> 如果不自行编译,可以直接下载编译好的静态资源包,跳过此步
+
+### 3.1 环境准备
+
+> 首次编译时需要安装
+
+#### 3.1.1 安装 node.js
+```shell script
+将 node.js 下载,安装即可。下载地址:http://nodejs.cn/download/ ( 建议使用node v16版本) 该步骤仅第一次使用时需要执行
+```
+#### 3.1.2 安装 learn
+```shell script
+#等待安装完即可,安装 liarn 仅第一次使用时需要执行
+npm install lerna -g
+```
+
+### 3.2 获取 Scriptis 代码
+> scriptis 是一个纯前端的项目,作为一个组件集成在 DSS 的 web 代码组件中,我们只需要将 DSS web 项目进行单独的 scriptis 模块编译
+
+```shell script
+#通过git下载 >=dss 1.1.0 版本来编译scriptis组件
+git clone -b branch-1.1.0 https://github.com/WeBankFinTech/DataSphereStudio
+# 或则直接下载 zip 包 后解压
+https://github.com/WeBankFinTech/DataSphereStudio/archive/refs/heads/branch-1.1.0.zip
+
+#进入 web 目录
+cd DataSphereStudio/web
+
+#该步骤仅第一次使用时需要执行
+lerna init
+
+#添加依赖 注意:这里不是通过 npm install 而是 lerna bootstrap 需先安装 learn 该步骤仅第一次使用时需要执行
+lerna bootstrap
+```
+
+### 3.3 本地运行项目(可选)
+
+> 如果不需要本地运行调试查看,可以跳过此步
+
+#### 3.3.1 配置 linkis-gateway 服务地址配置
+
+如果是在本地启动服务,需要在代码中配置后端 linkis-gateway 服务地址,在`web/packages/dss/`目录下的`.env`文件,
+打包部署时不需要进行配置
+```shell script
+// 后端 linkis-gatway 服务地址
+VUE_APP_HOST=http://10.10.10.10:9001
+VUE_APP_MN_CONFIG_PREFIX=http://10.10.10.10:9001/api/rest_j/v1
+```
+#### 3.3.2 运行 Scriptis 模块
+
+```shell script
+cd DataSphereStudio/web
+# 运行 scriptis 组件
+npm run serve --module=scriptis --micro_module=scriptis
+```
+
+打开浏览器,通过链接`http://localhost:8080`(本地请求默认端口是 8080) 访问应用 scriptis ,因为会请求到远端的 linkis-gatway 服务接口,这会存在跨域问题,chrome 浏览器解决跨域问题可参考[解决 Chrome 跨域问题 ](https://www.jianshu.com/p/56b1e01e6b6a)
+
+
+### 3.4 打包
+```shell script
+#指定 scriptis 模块
+cd DataSphereStudio/web
+
+#该指令成功执行后,web 目录下会出现一个名叫 `dist` 的文件夹,该文件夹即为打包好 scriptis 的组件资源代码。我们需要将该前端资源部署到 linkis-web 所在的 nginx 服务器上
+npm run build --module=scriptis --micro_module=scriptis
+```
+
+## 4 部署 Scriptis
+
+将直接下载(或编译)的静态资源 上传至 Linkis 管理台所在的服务器上,存放于`/data/Install/scriptis-web/dist/`,
+在安装 Linkis 管理台的 nginx 服务器配置中,添加 scriptis 的静态资源访问规则,Linkis 管理台部署的 nginx 配置一般位于 `/etc/nginx/conf.d/linkis.conf`
+
+```shell script
+ location /scriptis {
+ alias /data/Install/scriptis-web/dist/ ;
+ index index.html ;
+}
+```
+
+sudo vim `/etc/nginx/conf.d/linkis.conf`
+
+```shell script
+server {
+ listen 8080;# 访问端口
+ server_name localhost;
+ #charset koi8-r;
+ #access_log /var/log/nginx/host.access.log main;
+
+ location / {
+ root /appcom/Install/linkis-web/dist/; # 静态文件目录
+ index index.html;
+ }
+
+ location /scriptis { #scriptis 的资源带有 scriptis 前缀与 linkis 管理台区分开
+ alias /data/Install/scriptis-web/dist/ ; #nginx scriptis 静态文件存放路径 (可自定义)
+ index index.html ;
+ }
+
+ .......
+
+location /api {
+ proxy_pass http://10.10.10.10:9001; #gatway 的地址
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header x_real_ipP $remote_addr;
+ proxy_set_header remote_addr $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_http_version 1.1;
+ proxy_connect_timeout 4s;
+ proxy_read_timeout 600s;
+ proxy_send_timeout 12s;
+ proxy_set_header Upgrade $http_upgrade;
+ proxy_set_header Connection upgrade;
+ }
+
+ #error_page 404 /404.html;
+ # redirect server error pages to the static page /50x.html
+ #
+ error_page 500 502 503 504 /50x.html;
+ location = /50x.html {
+ root /usr/share/nginx/html;
+ }
+ }
+
+```
+修改配置后,重新加载 nginx 配置
+
+```shell script
+sudo nginx -s reload
+```
+
+注意 nginx 中,location 配置块中使用 root 和 alias 区别
+- root 的处理结果是:root 路径+location 路径.
+- alias 的处理结果是:使用 alias 路径替换 location 路径.
+- alias 是一个目录别名的定义,root 则是最上层目录的定义
+
+## 5 Scriptis 使用步骤
+必须先通过 Linkis 管理台登陆页面登陆成功后,再访问scriptis 页面
+
+### 5.1 正常登录 Linkis 管理台
+
+```shell script
+#http://10.10.10.10:8080/#/
+http://nginxIp:port/#/
+```
+因访问 scriptis 需要进行登录验证,所以需要先进行登录,获取并缓存 cookie。
+
+### 5.2 登录成功后 访问 Scriptis 页面
+
+```shell script
+#http://10.10.10.10:8080/scriptis/#/home
+http://nginxIp:port/scriptis/#/home
+```
+`nginxIp`:Linkis 管理台所部署的 nginx 服务器 ip,`port`:nginx 配置启动的端口号,`scriptis`为请求 scriptis 项目静态文件 nginx 配置的 location 地址(可自定义设置)
+
+### 5.3 使用 Scriptis
+
+以新建一个 sql 查询任务为例。
+
+
+step1 新建脚本 选择脚本类型为 sql 类型
+
+![效果图 ](/Images-zh/deployment/scriptis/new_script.png)
+
+step2 输入要查询的语句
+
+![效果图 ](/Images-zh/deployment/scriptis/test_statement.png)
+
+step3 运行
+
+![效果图 ](/Images-zh/deployment/scriptis/running_results.png)
+
+
+shep4 查看结果
+
+![效果图 ](/Images-zh/deployment/scriptis/design_sketch.png)
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/involve-knife4j.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/involve-knife4j.md
new file mode 100644
index 00000000000..f0e75a1e03f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/involve-knife4j.md
@@ -0,0 +1,63 @@
+---
+title: 集成 Knife4j
+sidebar_position: 5.2
+---
+
+## 1.knife4j介绍
+knife4j是为Java MVC框架集成Swagger生成Api文档的增强解决方案,前身是swagger-bootstrap-ui,取名knife4j是希望它能像一把匕首一样小巧,轻量,并且功能强悍!其底层是对Springfox的封装,使用方式也和Springfox一致,只是对接口文档UI进行了优化
+**核心功能:**
+
+- 文档说明:根据Swagger的规范说明,详细列出接口文档的说明,包括接口地址、类型、请求示例、请求参数、响应示例、响应参数、响应码等信息,对该接口的使用情况一目了然。
+- 在线调试:提供在线接口联调的强大功能,自动解析当前接口参数,同时包含表单验证,调用参数可返回接口响应内容、headers、响应时间、响应状态码等信息,帮助开发者在线调试。
+## 2.Linkis集成knif4j
+### 2.1 测试模式下启动knif4j
+修改application-linkis.yml文件设置knife4j.production=false
+```shell
+knife4j:
+ enable: true
+ production: false
+```
+修改 linkis.properties文件打开测试模式
+```shell
+wds.linkis.test.mode=true
+wds.linkis.test.user=hadoop
+```
+重启所有服务后,可以通过http://ip:port/api/rest_j/v1/doc.html 访问knife4j页面
+```shell
+http://ip:port/api/rest_j/v1/doc.html
+```
+### 2.2 非测试模式下启动knif4j
+修改application-linkis.yml文件设置knife4j.production=false
+```shell
+knife4j:
+ enable: true
+ production: false
+```
+修改 linkis.properties文件添加wds.linkis.server.user.restful.uri.pass.auth
+```shell
+wds.linkis.server.user.restful.uri.pass.auth=/api/rest_j/v1/doc.html,/api/rest_j/v1/swagger-resources,/api/rest_j/v1/webjars,/api/rest_j/v1/v2/api-docs
+```
+重启所有服务后,可以通过http://ip:port/api/rest_j/v1/doc.html 访问knife4j页面
+```shell
+http://ip:port/api/rest_j/v1/doc.html
+```
+由于knife4j调试各接口时,需要进行身份认证,需手工在浏览器添加如下cookie信息
+```shell
+#用户登录ticket-id
+bdp-user-ticket-id=
+#工作空间ID
+workspaceId=
+#内部请求开关
+dataworkcloud_inner_request=true
+```
+以Chrome浏览器为例
+![](/Images-zh/deployment/knife4j/Knife4j_addcookie.png)
+## 3.进入Knife4j页面
+通过http://ip:port/api/rest_j/v1/doc.html 访问knife4j页面
+![](/Images-zh/deployment/knife4j/Knife4j_home.png)
+点击接口名称可展示详细的接口文档
+![](/Images-zh/deployment/knife4j/Knife4j_interface.png)
+点击“调试”并录入参数可对接口进行调试
+![](/Images-zh/deployment/knife4j/Knife4j_debug.png)
+
+详细使用指南可浏览knife4j官网查看:[https://doc.xiaominfo.com/knife4j/](https://doc.xiaominfo.com/knife4j/)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/involve-prometheus.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/involve-prometheus.md
new file mode 100644
index 00000000000..45093aa6e06
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/involve-prometheus.md
@@ -0,0 +1,346 @@
+---
+title: 集成 Prometheus
+sidebar_position: 5.1
+---
+这篇文章描述了如何让Prometheus监控所有正在运行的Linkis服务。
+
+## 1. Prometheus介绍
+
+### 1.1 Prometheus是什么
+
+
+Prometheus 是一个云原生计算基金会项目,是一个系统和服务监控系统。它以给定的时间间隔从配置的目标收集指标,评估规则表达式,显示结果,并在观察到指定条件时触发警报。
+
+在微服务上下文中,它提供了服务发现功能,可以从服务注册中心动态查找目标,如 Eureka、Consul 等,并通过 http 协议从 API 端点拉取指标。
+
+### 1.2 Prometheus架构
+
+下图说明了 Prometheus 的架构及其一些生态系统组件:
+
+![](https://prometheus.io/assets/architecture.png)
+
+Prometheus可以直接抓取指标,或通过push gateway间接地接收短作业的指标。它将所有抓取的样本存储在本地,并在这些数据上运行规则,以从现有数据聚合和记录新的时间序列,或生成警报。可以使用Grafana或其他API消费者对收集的数据进行可视化。
+
+![](/Images/deployment/monitoring/prometheus_architecture.jpg)
+
+在 Linkis中,我们将使用 Prometheus 中的 Eureka (Service Discover)SD 来使用 Eureka REST API 来查询抓取目标。 Prometheus 将定期检查 REST 端点并为每个应用程序实例创建一个抓取目标。
+
+## 2. 如何启用 Prometheus
+
+### 2.1 安装 Linkis时 启用 Prometheus
+
+>安装脚本中,可以通过开关进行开启
+
+修改安装脚本linkis-env.sh中的`PROMETHEUS_ENABLE`。
+
+```bash
+export PROMETHEUS_ENABLE=true
+```
+
+运行 `install.sh`安装linkis后, `prometheus`的相关配置会出现在下列文件中:
+
+```yaml
+## application-linkis.yml ##
+
+eureka:
+ instance:
+ metadata-map:
+ prometheus.path: ${prometheus.path:${prometheus.endpoint}}
+...
+management:
+ endpoints:
+ web:
+ exposure:
+ include: refresh,info,health,metrics,prometheus
+````
+
+```yaml
+## application-eureka.yml ##
+
+eureka:
+ instance:
+ metadata-map:
+ prometheus.path: ${prometheus.path:/actuator/prometheus}
+...
+management:
+ endpoints:
+ web:
+ exposure:
+ include: refresh,info,health,metrics,prometheus
+````
+
+```yaml
+## linkis.properties ##
+...
+wds.linkis.prometheus.enable=true
+wds.linkis.server.user.restful.uri.pass.auth=/api/rest_j/v1/actuator/prometheus,
+...
+```
+
+如果在引擎内部,如 spark、flink 或 hive,都需要手动添加相同的配置。
+```yaml
+## linkis-engineconn.properties ##
+...
+wds.linkis.prometheus.enable=true
+wds.linkis.server.user.restful.uri.pass.auth=/api/rest_j/v1/actuator/prometheus,
+...
+```
+### 2.2 已经安装后 启用 Prometheus
+
+修改`${LINKIS_HOME}/conf/application-linkis.yml`
+endpoints配置修改 增加`prometheus`
+```yaml
+## application-linkis.yml ##
+management:
+ endpoints:
+ web:
+ exposure:
+ #增加 prometheus
+ include: refresh,info,health,metrics,prometheus
+```
+
+修改`${LINKIS_HOME}/conf/application-eureka.yml`,endpoints配置修改增加`prometheus`
+
+```yaml
+## application-eureka.yml ##
+management:
+ endpoints:
+ web:
+ exposure:
+ #增加 prometheus
+ include: refresh,info,health,metrics,prometheus
+````
+
+修改`${LINKIS_HOME}/conf/linkis.properties`,去掉`prometheus.enable`前的注释
+
+```yaml
+## linkis.properties ##
+...
+wds.linkis.prometheus.enable=true
+...
+```
+
+### 2.3 启动Linkis
+
+```bash
+$ bash linkis-start-all.sh
+````
+
+Linkis启动后,各个微服务的prometheus端点是可以直接被访问的,例如http://linkishost:9103/api/rest_j/v1/actuator/prometheus
+:::caution 注意
+gateway/eureka 服务prometheus端点是没有`api/rest_j/v1`前缀的 http://linkishost:9001/actuator/prometheus
+:::
+
+
+## 3. 部署 Prometheus,Alertmanager和 Grafana 示例
+
+:::caution 注意
+gateway/eureka 服务prometheus端点是没有`api/rest_j/v1`前缀的 http://linkishost:9001/actuator/prometheus
+:::
+
+通常来说,云原生应用程序的监控设置将部署在具有服务发现和高可用性的 Kubernetes 上(例如,使用像 Prometheus Operator 这样的 Kubernetes Operator)。
+为了快速展示监控仪表盘,和试验不同类型的图表(histogram/ gauge),你需要一个本地简易的构建。
+这个部分将会解释如何在本地通过 Docker Compose搭建Prometheus/Alert Manager和Grafana这一监控套件。
+
+首先,让我们定义该技术栈的通用组件,如下所示:
+
+- Alert Manager容器对外通过端口9093暴露UI,并从alertmanager.conf读取配置;
+- Prometheus容器对外通过端口9090暴露UI,从prometheus.yml读取配置文件,从alert_rules.yml中读取报警规则;
+- Grafana容器对外通过端口3000暴露UI, 指标数据源定义在grafana_datasources.yml中,配置文件通过grafana_config.ini定义;
+- 以下的docker-compose.yml文件总结了上述组件的配置:
+
+````yaml
+## docker-compose.yml ##
+version: "3"
+networks:
+ default:
+ external: true
+ name: my-network
+services:
+ prometheus:
+ image: prom/prometheus:latest
+ container_name: prometheus
+ volumes:
+ - ./config/prometheus.yml:/etc/prometheus/prometheus.yml
+ - ./config/alertrule.yml:/etc/prometheus/alertrule.yml
+ - ./prometheus/prometheus_data:/prometheus
+ command:
+ - '--config.file=/etc/prometheus/prometheus.yml'
+ ports:
+ - "9090:9090"
+
+ alertmanager:
+ image: prom/alertmanager:latest
+ container_name: alertmanager
+ volumes:
+ - ./config/alertmanager.yml:/etc/alertmanager/alertmanager.yml
+ ports:
+ - "9093:9093"
+
+ grafana:
+ image: grafana/grafana:latest
+ container_name: grafana
+ environment:
+ - GF_SECURITY_ADMIN_PASSWORD=123456
+ - GF_USERS_ALLOW_SIGN_UP=false
+ volumes:
+ - ./grafana/provisioning/dashboards:/etc/grafana/provisioning/dashboards
+ - ./grafana/provisioning/datasources:/etc/grafana/provisioning/datasources
+ - ./grafana/grafana_data:/var/lib/grafana
+ ports:
+ - "3000:3000"
+````
+
+然后,为了根据 Prometheus 中的指标定义一些警报,您可以将它们分组到一个 alert_rules.yml 中,这样您就可以在生产实例中配置它们之前验证这些警报是否在本地设置中正确触发。例如,以下配置转换了用于监控 Linkis 服务的常用指标。
+
+- a. Down instance
+- b. High Cpu for each JVM instance (>80%)
+- c. High Heap memory for each JVM instance (>80%)
+- d. High NonHeap memory for each JVM instance (>80%)
+- e. High Waiting thread for each JVM instance (100)
+
+```yaml
+## alertrule.yml ##
+groups:
+- name: LinkisAlert
+ rules:
+ - alert: LinkisNodeDown
+ expr: last_over_time(up{job="linkis", application=~"LINKISI.*", application!="LINKIS-CG-ENGINECONN"}[1m])== 0
+ for: 15s
+ labels:
+ severity: critical
+ service: Linkis
+ instance: "{{ $labels.instance }}"
+ annotations:
+ summary: "instance: {{ $labels.instance }} down"
+ description: "Linkis instance(s) is/are down in last 1m"
+ value: "{{ $value }}"
+
+ - alert: LinkisNodeCpuHigh
+ expr: system_cpu_usage{job="linkis", application=~"LINKIS.*"} >= 0.8
+ for: 1m
+ labels:
+ severity: warning
+ service: Linkis
+ instance: "{{ $labels.instance }}"
+ annotations:
+ summary: "instance: {{ $labels.instance }} cpu overload"
+ description: "CPU usage is over 80% for over 1min"
+ value: "{{ $value }}"
+
+ - alert: LinkisNodeHeapMemoryHigh
+ expr: sum(jvm_memory_used_bytes{job="linkis", application=~"LINKIS.*", area="heap"}) by(instance) *100/sum(jvm_memory_max_bytes{job="linkis", application=~"LINKIS.*", area="heap"}) by(instance) >= 50
+ for: 1m
+ labels:
+ severity: warning
+ service: Linkis
+ instance: "{{ $labels.instance }}"
+ annotations:
+ summary: "instance: {{ $labels.instance }} memory(heap) overload"
+ description: "Memory usage(heap) is over 80% for over 1min"
+ value: "{{ $value }}"
+
+ - alert: LinkisNodeNonHeapMemoryHigh
+ expr: sum(jvm_memory_used_bytes{job="linkis", application=~"LINKIS.*", area="nonheap"}) by(instance) *100/sum(jvm_memory_max_bytes{job="linkis", application=~"LINKIS.*", area="nonheap"}) by(instance) >= 60
+ for: 1m
+ labels:
+ severity: warning
+ service: Linkis
+ instance: "{{ $labels.instance }}"
+ annotations:
+ summary: "instance: {{ $labels.instance }} memory(nonheap) overload"
+ description: "Memory usage(nonheap) is over 80% for over 1min"
+ value: "{{ $value }}"
+
+ - alert: LinkisWaitingThreadHigh
+ expr: jvm_threads_states_threads{job="linkis", application=~"LINKIS.*", state="waiting"} >= 100
+ for: 1m
+ labels:
+ severity: warning
+ service: Linkis
+ instance: "{{ $labels.instance }}"
+ annotations:
+ summary: "instance: {{ $labels.instance }} waiting threads is high"
+ description: "waiting threads is over 100 for over 1min"
+ value: "{{ $value }}"
+```
+
+**请注意**: 由于服务实例一旦关闭,它就不会成为 Prometheus Eureka SD 的目标之一,并且 up 指标在短时间内不会返回任何数据。因此,我们将收集最后一分钟是否 up=0 以确定服务是否处于活动状态。
+
+第三点, 最重要的是在 prometheus.yml 文件中定义 Prometheus 配置。这将定义:
+
+- 全局设定,例如指标抓取时间间隔,和规则扫描间隔;
+- AlertManager的连接信息,告警规则定义路径;
+- 应用指标端口的连接信息。
+
+这是 Linkis 的示例配置文件:
+````yaml
+## prometheus.yml ##
+# my global config
+global:
+ scrape_interval: 30s # By default, scrape targets every 15 seconds.
+ evaluation_interval: 30s # By default, scrape targets every 15 seconds.
+alerting:
+ alertmanagers:
+ - static_configs:
+ - targets: ['alertmanager:9093']
+# Load and evaluate rules in this file every 'evaluation_interval' seconds.
+rule_files:
+ - "alertrule.yml"
+
+# A scrape configuration containing exactly one endpoint to scrape:
+# Here it's Prometheus itself.
+scrape_configs:
+ - job_name: 'prometheus'
+ static_configs:
+ - targets: ['localhost:9090']
+ - job_name: linkis
+ eureka_sd_configs:
+ # the endpoint of your eureka instance
+ - server: {{linkis-host}}:20303/eureka
+ relabel_configs:
+ - source_labels: [__meta_eureka_app_name]
+ target_label: application
+ - source_labels: [__meta_eureka_app_instance_metadata_prometheus_path]
+ action: replace
+ target_label: __metrics_path__
+ regex: (.+)
+````
+第四点,下面的配置定义了警报将如何发送到外部webhook。
+```yaml
+## alertmanager.yml ##
+global:
+ resolve_timeout: 5m
+
+route:
+ receiver: 'webhook'
+ group_by: ['alertname']
+
+ # How long to wait to buffer alerts of the same group before sending a notification initially.
+ group_wait: 1m
+ # How long to wait before sending an alert that has been added to a group for which there has already been a notification.
+ group_interval: 5m
+ # How long to wait before re-sending a given alert that has already been sent in a notification.
+ repeat_interval: 12h
+
+receivers:
+- name: 'webhook'
+ webhook_configs:
+ - send_resolved: true
+ url: {{your-webhook-url}}
+
+````
+
+最后,在定义完所有配置文件以及 docker compose 文件后,我们可以使用 docker-compose up启动监控套件
+
+## 4. 结果展示
+在 Prometheus 页面上,预计会看到所有 Linkis 服务实例,如下所示:
+![](/Images/deployment/monitoring/prometheus_screenshot.jpg)
+
+当 Grafana 可访问的时候,您需要在 Grafana 中导入 prometheus 作为数据源,并导入 id 为 11378 的仪表板模板,该模板通常用于 springboot 服务(2.1+)。然后您可以在那里查看 Linkis 的一个实时仪表板。
+
+然后您可以在那里查看 Linkis 的实时仪表板。
+
+![](/Images/deployment/monitoring/grafana_screenshot.jpg)
+
+您还可以尝试将 Prometheus alter manager 与您自己的 webhook 集成,您可以在其中查看是否触发了告警消息。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/involve-skywalking.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/involve-skywalking.md
new file mode 100644
index 00000000000..50000b0fa79
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/involve-skywalking.md
@@ -0,0 +1,152 @@
+---
+title: 集成 SkyWalking
+sidebar_position: 5.0
+---
+这篇文章介绍一下如何在启动 Linkis 服务的时候开启 SkyWalking,以方便后续做分布式 trace 和 troubleshooting。
+
+## 1. SkyWalking 介绍
+
+### 1.1 SkyWalking 是什么
+
+SkyWalking 是开源的可视化平台,可以从多种数据源采集数据,并提供分析、聚合以及可视化等功能。通过 SkyWalking,我们可以对分布式系统的拓扑结构,数据交互有一个更加清晰的视图。
+
+
+
+### 1.2 SkyWalking 架构
+
+下图是 SkyWalking 的整体架构图。
+
+![](/Images-zh/deployment/skywalking/SkyWalking_Architecture.png)
+
+从逻辑上可以划分成 4 个部分:
+* **Probe**:可以理解为数据采集 agent,主要负责数据采集和格式化。
+* **Platform Backend**:SkyWalking 的后端服务,支持数据聚合、分析以及流式处理等。
+* **Storage**:负责数据存储,以 plugin 的方式支持多种存储引擎,比如 ElasticSearch, H2, MySQL, TiDB, InfluxDB 等。
+* **UI**: 数据可视化。
+
+在 Linkis 中使用 SkyWalking,需要用户已经存在 Backend 服务以及对应的 Storage。Linkis 服务启动的时候集成 Probe 即可。Probe 集成主要有三种方式:
+* **Language based native agent**:这些 agent 和目标服务进程运行在相同的用户空间,从外部来看,agent 和目标服务的代码是一样的。一个典型的例子是 Java agent,在运行 Java 应用的时候我们可以通过 `-javaagent` 来指定 agent。
+* **Service Mesh probes**:这种 Probe 通过 sidecar 或者 proxy 收集数据。
+* **3rd-party intrument library**:简单来说就是第三方的数据,比如 zipkin。
+
+我们在 Linkis 集成 SkyWalking 的时候采用第一种方式,也就是 java agent 的方式。下面我们为大家演示一下如何在 Linkis 服务中开启 SkyWalking。
+
+## 2. 部署 SkyWalking 后端
+
+SkyWalking 后端是开启 SkyWalk 的前置条件,下面先简单演示下如何安装 SkyWalking 的后端。
+
+首先从 SkyWalking 的 [Downloads](https://skywalking.apache.org/downloads/) 页面下载 SkyWalking APM。
+
+![](/Images-zh/deployment/skywalking/SkyWalking_APM_Download.png)
+
+下载完,直接解压得到如下的目录结构。
+
+```bash
+$ ls
+bin config config-examples LICENSE licenses logs NOTICE oap-libs README.txt tools webapp
+```
+
+后端默认使用 H2 内存数据库作为后端存储,不需要修改配置。按如下方式启动。
+
+启动 Backend
+```bash
+$ sh bin/startup.sh
+```
+
+启动 WebApp
+```bash
+$ sh bin/webappService.sh
+```
+
+UI 默认启动在 8080 端口,也可以通过修改 webapp 目录下的 webapp.yml 文件修改监听端口。
+
+```yaml
+server:
+ port: 8080
+
+spring:
+ cloud:
+ gateway:
+ routes:
+ - id: oap-route
+ uri: lb://oap-service
+ predicates:
+ - Path=/graphql/**
+ discovery:
+ client:
+ simple:
+ instances:
+ oap-service:
+ - uri: http://127.0.0.1:12800
+ # - uri: http://:
+ # - uri: http://:
+
+ mvc:
+ throw-exception-if-no-handler-found: true
+
+ web:
+ resources:
+ add-mappings: true
+
+management:
+ server:
+ base-path: /manage
+```
+
+## 3. Linkis 服务启动开启 SkyWalking
+
+这里假定大家对 Linkis 的服务部署已经比较清晰,如果还不清晰,可以异步:
+
+在 Linkis 中开启 SkyWalking 首先需要下载 SkyWalking 的 Java agent,我们可以在 [Downloads](https://skywalking.apache.org/downloads/) 页面进行下载。
+
+![](/Images-zh/deployment/skywalking/SkyWalking_Agent_Download.png)
+
+下载之后解压,内部的文件结构如下:
+```bash
+tree skywalking-agent
+$ skywalking-agent
+├── LICENSE
+├── NOTICE
+├── activations
+│ ├── apm-toolkit-kafka-activation-8.8.0.jar
+│ ├── ...
+├── bootstrap-plugins
+│ ├── apm-jdk-http-plugin-8.8.0.jar
+│ └── apm-jdk-threading-plugin-8.8.0.jar
+├── config
+│ └── agent.config
+├── licenses
+│ └── LICENSE-asm.txt
+├── logs
+├── optional-plugins
+│ ├── apm-customize-enhance-plugin-8.8.0.jar
+│ ├── ...
+├── optional-reporter-plugins
+│ ├── kafka-reporter-plugin-8.8.0.jar
+│ ├── ...
+├── plugins
+│ ├── apm-activemq-5.x-plugin-8.8.0.jar
+│ ├── ...
+└── skywalking-agent.jar
+```
+
+修改 Linkis 的 deploy-config/linkis-env.sh 中的配置项 `SKYWALKING_AGENT_PATH`。将其设置为 `skywalking-agent.jar` 的路径。
+```bash
+SKYWALKING_AGENT_PATH=/path/to/skywalking-agent.jar
+```
+
+然后启动 Linkis 即可。
+```bash
+$ sh linkis-start-all.sh
+```
+
+## 4. 结果展示
+Linkis 的 UI 端口默认启动在 8080 端口,Linkis 开启 SkyWalking 之后打开 UI 如果能看到如下的图就表示成功了。
+如果看不到展示效果,可能是浏览器兼容性问题,尝试切换浏览器试试。
+
+![](/Images-zh/deployment/skywalking/SkyWalking_UI_Dashboard.png)
+
+![](/Images-zh/deployment/skywalking/SkyWalking_UI_Dashboard2.png)
+
+![](/Images-zh/deployment/skywalking/SkyWalking_Topology.png)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/spark-lineage.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/spark-lineage.md
new file mode 100644
index 00000000000..6e95fb0d6cf
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/spark-lineage.md
@@ -0,0 +1,372 @@
+---
+title: 集成 Spark血缘
+sidebar_position: 1
+---
+
+本文主要介绍在 `Linkis` 中, `Spark` 引擎血缘采集方案。
+
+
+## 1. 介绍
+
+`spline-spark-agent`是一个用于在Spark应用程序中启用血缘跟踪(Lineage Tracking)的组件。它是Spline项目的一部分,旨在对Spark作业进行实时的血缘数据收集
+
+github地址
+```
+https://github.com/AbsaOSS/spline-spark-agent
+```
+
+## 2. 下载`spline-spark-agent`所需jar包
+
+```shell
+cd $SPARK_HOME/jars
+
+wget https://repo1.maven.org/maven2/za/co/absa/spline/agent/spark/spark-3.2-spline-agent-bundle_2.12/2.0.0/spark-3.2-spline-agent-bundle_2.12-2.0.0.jar
+```
+下载完成后 `$SPARK_HOME/jars` 会出现 `spark-3.2-spline-agent-bundle_2.12-2.0.0.jar`
+
+## 3. 将spark血缘采集至日志
+
+### 3.1 修改`spark-defaults.conf`
+
+```shell
+vim $SPARK_HOME/conf/spark-defaults.conf
+
+增加如下配置
+spark.sql.queryExecutionListeners=za.co.absa.spline.harvester.listener.SplineQueryExecutionListener
+spark.spline.lineageDispatcher=log
+spark.spline.lineageDispatcher.log.level=INFO
+spark.spline.lineageDispatcher.log.className=za.co.absa.spline.harvester.dispatcher.LoggingLineageDispatcher
+```
+
+### 3.2 数据准备
+
+```shell
+创建输入文件并上传至hdfs
+
+vim read.json
+
+{"name":"linkis","age":"5"}
+
+hadoop fs -put read.json /tmp
+````
+
+```shell
+创建输出目录
+hadoop fs -mkdir /tmp/jsonWrite
+````
+
+### 3.3 提交任务
+```shell
+sh ./bin/linkis-cli -engineType spark-3.2.1 -codeType sql -code \
+"CREATE TEMPORARY VIEW jsonReadTable
+USING org.apache.spark.sql.json
+OPTIONS (
+ path '/tmp/read.json'
+);
+INSERT OVERWRITE DIRECTORY '/tmp/jsonWrite' SELECT * FROM jsonReadTable;" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+### 3.4 查看日志
+```shell
+cat /appcom/tmp/hadoop/20230829/spark/117ca887-f9d6-4923-8ca1-cef7155ee0e7/logs/stdout
+```
+
+输出结果如下:
+![spark-lineage-log](../images/spark-lineage-log.png)
+
+详细信息如下:
+```json
+{
+ "id":"a5b273b3-a87f-5a30-8ced-c8eeff2d1458",
+ "name":"Linkis-EngineConn-Spark_LINKISCLI",
+ "operations":{
+ "write":{
+ "outputSource":"/tmp/jsonWrite",
+ "append":false,
+ "id":"op-0",
+ "name":"InsertIntoHiveDirCommand",
+ "childIds":[
+ "op-1"
+ ],
+ "extra":{
+ "destinationType":"hive"
+ }
+ },
+ "reads":[
+ {
+ "inputSources":[
+ "hdfs://linkishdfs/tmp/read.json"
+ ],
+ "id":"op-4",
+ "name":"LogicalRelation",
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "path":"/tmp/read.json"
+ },
+ "extra":{
+ "sourceType":"json"
+ }
+ }
+ ],
+ "other":[
+ {
+ "id":"op-3",
+ "name":"View",
+ "childIds":[
+ "op-4"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "desc":"CatalogTable(\nTable: jsonReadTable\nCreated Time: Tue Aug 29 11:52:10 CST 2023\nLast Access: UNKNOWN\nCreated By: Spark \nType: VIEW\nTable Properties: []\nSchema: root\n |-- age: string (nullable = true)\n |-- name: string (nullable = true)\n)",
+ "isTempView":true
+ }
+ },
+ {
+ "id":"op-2",
+ "name":"SubqueryAlias",
+ "childIds":[
+ "op-3"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "identifier":"jsonreadtable"
+ }
+ },
+ {
+ "id":"op-1",
+ "name":"Project",
+ "childIds":[
+ "op-2"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "projectList":[
+ {
+ "__attrId":"attr-0"
+ },
+ {
+ "__attrId":"attr-1"
+ }
+ ]
+ }
+ }
+ ]
+ },
+ "attributes":[
+ {
+ "id":"attr-0",
+ "dataType":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"age"
+ },
+ {
+ "id":"attr-1",
+ "dataType":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"name"
+ }
+ ],
+ "expressions":{
+
+ },
+ "systemInfo":{
+ "name":"spark",
+ "version":"3.2.1"
+ },
+ "agentInfo":{
+ "name":"spline",
+ "version":"2.0.0"
+ },
+ "extraInfo":{
+ "appName":"Linkis-EngineConn-Spark_LINKISCLI",
+ "dataTypes":[
+ {
+ "id":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"string",
+ "nullable":true,
+ "_typeHint":"dt.Simple"
+ }
+ ]
+ }
+}
+```
+
+## 4. 将spark血缘采集至kafka
+
+### 4.1 修改`spark-defaults.conf`
+
+```shell
+vim $SPARK_HOME/conf/spark-defaults.conf
+
+增加如下配置
+spark.sql.queryExecutionListeners=za.co.absa.spline.harvester.listener.SplineQueryExecutionListener
+spark.spline.lineageDispatcher=kafka
+spark.spline.lineageDispatcher.kafka.topic=linkis_spark_lineage_test
+spark.spline.lineageDispatcher.kafka.producer.bootstrap.servers=localhost:9092
+```
+
+### 4.2 提交任务
+```shell
+sh ./bin/linkis-cli -engineType spark-3.2.1 -codeType sql -code \
+"CREATE TEMPORARY VIEW jsonReadTable
+USING org.apache.spark.sql.json
+OPTIONS (
+ path '/tmp/read.json'
+);
+INSERT OVERWRITE DIRECTORY '/tmp/jsonWrite' SELECT * FROM jsonReadTable;" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+### 4.3 查看topic
+```shell
+kafka/bin/kafka-console-consumer.sh --topic linkis_spark_lineage_test --from-beginning --bootstrap-server localhost:9092
+```
+
+输出结果如下:
+![spark-lineage-kafka](../images/spark-lineage-kafka.png)
+
+
+详细信息如下:
+```json
+{
+ "id":"3a0e2b8e-11dc-5bd1-9bbc-cfba2fa469e9",
+ "name":"Linkis-EngineConn-Spark_LINKISCLI",
+ "operations":{
+ "write":{
+ "outputSource":"/tmp/jsonWrite",
+ "append":false,
+ "id":"op-0",
+ "name":"InsertIntoHiveDirCommand",
+ "childIds":[
+ "op-1"
+ ],
+ "extra":{
+ "destinationType":"hive"
+ }
+ },
+ "reads":[
+ {
+ "inputSources":[
+ "hdfs://linkishdfs/tmp/read.json"
+ ],
+ "id":"op-4",
+ "name":"LogicalRelation",
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "path":"/tmp/read.json"
+ },
+ "extra":{
+ "sourceType":"json"
+ }
+ }
+ ],
+ "other":[
+ {
+ "id":"op-3",
+ "name":"View",
+ "childIds":[
+ "op-4"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "desc":"CatalogTable(\nTable: jsonReadTable\nCreated Time: Tue Aug 29 14:48:06 CST 2023\nLast Access: UNKNOWN\nCreated By: Spark \nType: VIEW\nTable Properties: []\nSchema: root\n |-- age: string (nullable = true)\n |-- name: string (nullable = true)\n)",
+ "isTempView":true
+ }
+ },
+ {
+ "id":"op-2",
+ "name":"SubqueryAlias",
+ "childIds":[
+ "op-3"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "identifier":"jsonreadtable"
+ }
+ },
+ {
+ "id":"op-1",
+ "name":"Project",
+ "childIds":[
+ "op-2"
+ ],
+ "output":[
+ "attr-0",
+ "attr-1"
+ ],
+ "params":{
+ "projectList":[
+ {
+ "__attrId":"attr-0"
+ },
+ {
+ "__attrId":"attr-1"
+ }
+ ]
+ }
+ }
+ ]
+ },
+ "attributes":[
+ {
+ "id":"attr-0",
+ "dataType":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"age"
+ },
+ {
+ "id":"attr-1",
+ "dataType":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"name"
+ }
+ ],
+ "expressions":{
+
+ },
+ "systemInfo":{
+ "name":"spark",
+ "version":"3.2.1"
+ },
+ "agentInfo":{
+ "name":"spline",
+ "version":"2.0.0"
+ },
+ "extraInfo":{
+ "appName":"Linkis-EngineConn-Spark_LINKISCLI",
+ "dataTypes":[
+ {
+ "id":"e63adadc-648a-56a0-9424-3289858cf0bb",
+ "name":"string",
+ "nullable":true,
+ "_typeHint":"dt.Simple"
+ }
+ ]
+ }
+}
+```
+
+## 5. 更多方式
+
+```text
+`spline-spark-agent`还支持更多的采集方式,比如:Http、Console,请参考官方文档
+https://github.com/AbsaOSS/spline-spark-agent/#configuration
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/sso-with-redis.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/sso-with-redis.md
new file mode 100644
index 00000000000..aaf9548eb2b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/integrated/sso-with-redis.md
@@ -0,0 +1,47 @@
+---
+title: 网关服务支持多活
+sidebar_position: 8
+---
+## 1.背景
+因为原有的登陆 session 未支持分布式存储,对于同一个用户的所有请求,需要 nginx 转发请求到同一个 gateway 实例上,才能正常处理请求。
+常用的解决方式是通过在入口 nginx 上通过配置 ip hash 负载均衡的方式来支持。
+但是ip hash 方式 如果存在服务器的扩容与缩容时,所有客户端ip的 hash 值都需要重新计算,会导致会话丢失,
+其次容易因为节点分部不均匀⽽造成数据倾斜问题。为了优化 ip hash 方式存在的问题,对登陆态的 session 实现共享存储
+
+
+## 2.实现方案
+因为会话信息主要是通过 ticketId 来标识,所有对外入口为 gateway,所以只需要对 gateway 模块进行改造。
+对于底层的共享存储,选择主流的内存数据库 redis。对于是否启动 redis 会话存储,支持通过配置文件控制。
+关键代码改动为 `org.apache.linkis.server.security.SSOUtils` 的 `userTicketIdToLastAccessTime`。
+
+请求流程:
+
+`用户请求 -> nginx -> linkis-gateway -> linkis 后端服务`
+
+
+## 3.使用方式
+
+需要可用的 reids 环境,支持单机版redis和redis 哨兵模式。
+
+安装部署Linkis 后,修改配置文件 `${LINKIS_HOME}/conf/linkis.properties`
+```shell script
+#开启redis cache配置
+linkis.session.redis.cache.enabled=true
+
+
+#单机版
+linkis.session.redis.host=127.0.0.1
+linkis.session.redis.port=6379
+linkis.session.redis.password=test123
+
+# 哨兵模式
+linkis.session.redis.sentinel.master=sentinel-master-name
+linkis.session.redis.sentinel.nodes=127.0.1.1:6381,127.0.2.1:6381,127.0.3.1:6381
+linkis.session.redis.password=test123
+
+```
+
+正常启用 gateway 即可,启动 redis 后,对于多个 gateway 示例,在 nginx 侧配置时,可以使用 nginx 默认负载均衡模式。
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/version-adaptation.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/version-adaptation.md
new file mode 100644
index 00000000000..a496e5c5119
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/deployment/version-adaptation.md
@@ -0,0 +1,510 @@
+---
+title: 版本适配
+sidebar_position: 8
+---
+
+# 版本适配
+
+## 1. 功能说明
+
+针对Apache,CDH,HDP等版本适配需要手动修改的地方进行说明
+
+## 2. 编译指令
+
+进入到项目的根目录下,依次执行如下指令
+
+```text
+mvn -N install
+mvn clean install -Dmaven.test.skip=true
+```
+
+## 3. SQL脚本切换
+
+linkis-dist -> package -> db 下的 linkis-dml.sql 脚本
+
+将对应的引擎版本切换为自己需要的版本,如果你使用的版本和官方一致的话,则无需修改此步
+
+比如:
+
+1. spark是3.0.0的话,则此处是 SET @SPARK_LABEL="spark-3.0.0";
+2. hive是2.1.1-cdh6.3.2的话,需先调整2.1.1_cdh6.3.2(构建时),则此处是 SET @HIVE_LABEL="hive-2.1.1_cdh6.3.2";
+
+```sql
+-- 变量:
+SET @SPARK_LABEL="spark-2.4.3";
+SET @HIVE_LABEL="hive-2.3.3";
+SET @PYTHON_LABEL="python-python2";
+SET @PIPELINE_LABEL="pipeline-1";
+SET @JDBC_LABEL="jdbc-4";
+SET @PRESTO_LABEL="presto-0.234";
+SET @IO_FILE_LABEL="io_file-1.0";
+SET @OPENLOOKENG_LABEL="openlookeng-1.5.0";
+```
+
+## 4. Linkis官方版本
+
+| 引擎 | 版本 |
+| ------ | ------ |
+| hadoop | 2.7.2 |
+| hive | 2.3.3 |
+| spark | 2.4.3 |
+| flink | 1.12.2 |
+
+## 5. Apache版本适配
+
+### 5.1 Apache3.1.x版本
+
+| 引擎 | 版本 |
+| ------ | ------ |
+| hadoop | 3.1.1 |
+| hive | 3.1.2 |
+| spark | 3.0.1 |
+| flink | 1.13.2 |
+
+#### 5.1.1 linkis的pom文件
+
+Linkis版本小于`1.3.2`时
+```java
+3.1.1
+2.12.10
+2.12
+
+
+
+ org.apache.hadoop
+ hadoop-hdfs-client
+ ${hadoop.version}
+
+```
+
+当Linkis版本大于等于`1.3.2`时, 只需要设置 `scala.version` and `scala.binary.version`
+```java
+2.12.10
+2.12
+```
+因为我们可以直接使用`hadoop-3.3` or `hadoop-2.7` profile来编译
+Profile `hadoop-3.3` 可以用于任意hadoop3.x, 默认hadoop3.x版本是3.3.1,
+Profile `hadoop-2.7` 可以用于任意hadoop2.x, 默认hadoop2.x版本是2.7.2,
+想要用其他版本可以编译时指定 -Dhadoop.version=xxx
+```text
+mvn -N install
+mvn clean install -Phadoop-3.3 -Dmaven.test.skip=true
+mvn clean install -Phadoop-3.3 -Dhadoop.version=3.1.1 -Dmaven.test.skip=true
+```
+
+#### 5.1.2 linkis-hadoop-common的pom文件
+
+Linkis版本小于`1.3.2`时
+```java
+
+
+ org.apache.hadoop
+ hadoop-hdfs-client
+ ${hadoop.version}
+
+```
+
+当Linkis版本大于等于`1.3.2`时,`linkis-hadoop-common`模块不需要变更
+
+#### 5.1.3 linkis-engineplugin-hive的pom文件
+
+```java
+3.1.2
+```
+
+#### 5.1.4 linkis-engineplugin-spark的pom文件
+
+Linkis版本小于`1.3.2`时
+```java
+3.0.1
+```
+
+当Linkis版本大于等于`1.3.2`时
+```text
+我们可以直接编译spark-3.2 profile, 如果我们同时使用hadoop3, 那么我们还需要指定hadoop-3.3 profile.
+默认 spark3.x 版本时3.2.1. 如果我们使用spark-3.2 profile编译, scala版本默认是2.12.15,因此我们不需要在项目根目录设置scala版本了(5.1.1提到当)
+如果Linkis使用hadoop3编译,同时spark仍旧是2.x版本的话,由于spark兼容性问题需要激活profile `spark-2.4-hadoop-3.3`
+```
+```text
+mvn -N install
+mvn clean install -Pspark-3.2 -Phadoop-3.3 -Dmaven.test.skip=true
+mvn clean install -Pspark-2.4-hadoop-3.3 -Phadoop-3.3 -Dmaven.test.skip=true
+```
+
+#### 5.1.5 flink-engineconn-flink的pom文件
+
+```java
+1.13.2
+```
+
+:::caution 临时方案
+
+注意以下复制类操作均在flink中
+
+由于flink1.12.2到1.13.2版本,有部分类进行调整,所以需要进行flink的编译和调整,编译flink选择scala的版本为2.12版本(scala版本根据自己的实际使用版本来)
+
+flink编译参考指令: mvn clean install -DskipTests -P scala-2.12 -Dfast -T 4 -Dmaven.compile.fock=true
+
+:::
+
+```text
+-- 注意,下列的类是从flink的1.12.2版本给copy到flink的1.13.2版本来
+org.apache.flink.table.client.config.entries.DeploymentEntry
+org.apache.flink.table.client.config.entries.ExecutionEntry
+org.apache.flink.table.client.gateway.local.CollectBatchTableSink
+org.apache.flink.table.client.gateway.local.CollectStreamTableSink
+```
+
+#### 5.1.6 linkis-label-common调整
+
+org.apache.linkis.manager.label.conf.LabelCommonConfig 文件调整
+
+```java
+ public static final CommonVars SPARK_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.spark.engine.version", "3.0.1");
+
+ public static final CommonVars HIVE_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.hive.engine.version", "3.1.2");
+```
+
+#### 5.1.7 linkis-computation-governance-common调整
+
+org.apache.linkis.governance.common.conf.GovernanceCommonConf 文件调整
+
+```java
+ val SPARK_ENGINE_VERSION = CommonVars("wds.linkis.spark.engine.version", "3.0.1")
+
+ val HIVE_ENGINE_VERSION = CommonVars("wds.linkis.hive.engine.version", "3.1.2")
+```
+
+## 6. HDP版本适配
+
+### 6.1 HDP3.0.1版本
+
+| 引擎 | 版本 |
+| -------------- | ------ |
+| hadoop | 3.1.1 |
+| hive | 3.1.0 |
+| spark | 2.3.2 |
+| json4s.version | 3.2.11 |
+
+#### 6.1.1 linkis的pom文件
+
+Linkis版本小于`1.3.2`时
+```java
+3.1.1
+3.2.11
+
+
+
+ org.apache.hadoop
+ hadoop-hdfs-client
+ ${hadoop.version}
+
+```
+
+当Linkis版本大于等于`1.3.2`时, 只需要设置 `json4s.version`
+```java
+3.2.11
+```
+因为我们可以直接使用`hadoop-3.3` or `hadoop-2.7` profile来编译
+Profile `hadoop-3.3` 可以用于任意hadoop3.x, 默认hadoop3.x版本是3.3.1,
+Profile `hadoop-2.7` 可以用于任意hadoop2.x, 默认hadoop2.x版本是2.7.2,
+想要用其他版本可以编译时指定 -Dhadoop.version=xxx
+```text
+mvn -N install
+mvn clean install -Phadoop-3.3 -Dmaven.test.skip=true
+mvn clean install -Phadoop-3.3 -Dhadoop.version=3.1.1 -Dmaven.test.skip=true
+```
+
+#### 6.1.2 linkis-engineplugin-hive的pom文件
+
+```java
+3.1.0
+```
+
+#### 6.1.3 linkis-engineplugin-spark的pom文件
+
+Linkis版本小于`1.3.2`时
+```java
+2.3.2
+```
+
+当Linkis版本大于等于`1.3.2`时
+```text
+我们可以直接编译spark-3.2 profile, 如果我们同时使用hadoop3, 那么我们还需要指定hadoop-3.3 profile.
+默认 spark3.x 版本时3.2.1. 如果我们使用spark-3.2 profile编译, scala版本默认是2.12.15,因此我们不需要在项目根目录设置scala版本了(5.1.1提到当)
+如果Linkis使用hadoop3编译,同时spark仍旧是2.x版本的话,由于spark兼容性问题需要激活profile `spark-2.4-hadoop-3.3`
+```
+```text
+mvn -N install
+mvn clean install -Pspark-3.2 -Phadoop-3.3 -Dmaven.test.skip=true
+mvn clean install -Pspark-2.4-hadoop-3.3 -Phadoop-3.3 -Dmaven.test.skip=true
+```
+
+#### 6.1.4 linkis-label-common调整
+
+org.apache.linkis.manager.label.conf.LabelCommonConfig 文件调整
+
+```java
+ public static final CommonVars SPARK_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.spark.engine.version", "2.3.2");
+
+ public static final CommonVars HIVE_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.hive.engine.version", "3.1.0");
+```
+
+#### 6.1.5 linkis-computation-governance-common调整
+
+org.apache.linkis.governance.common.conf.GovernanceCommonConf 文件调整
+
+```java
+ val SPARK_ENGINE_VERSION = CommonVars("wds.linkis.spark.engine.version", "2.3.2")
+
+ val HIVE_ENGINE_VERSION = CommonVars("wds.linkis.hive.engine.version", "3.1.0")
+```
+
+## 7 CDH版本适配
+
+### 7.1 maven配置地址
+
+#### 7.1.1 setting文件
+
+```xml
+
+
+
+ nexus-aliyun
+ *,!cloudera
+ Nexus aliyun
+ http://maven.aliyun.com/nexus/content/groups/public
+
+
+ aliyunmaven
+ *,!cloudera
+ 阿里云公共仓库
+ https://maven.aliyun.com/repository/public
+
+
+ aliyunmaven
+ *,!cloudera
+ spring-plugin
+ https://maven.aliyun.com/repository/spring-plugin
+
+
+ maven-default-http-blocker
+ external:http:*
+ Pseudo repository to mirror external repositories initially using HTTP.
+ http://0.0.0.0/
+ true
+
+
+```
+
+#### 7.1.2 linkis的pom文件
+
+```xml
+
+
+ cloudera
+ https://repository.cloudera.com/artifactory/cloudera-repos/
+
+ true
+
+
+
+
+ aliyun
+ http://maven.aliyun.com/nexus/content/groups/public/
+
+ true
+
+
+
+```
+
+### 7.2 CDH5.12.1版本
+
+| 引擎 | 版本 |
+| --------- | --------------- |
+| hadoop | 2.6.0-cdh5.12.1 |
+| zookeeper | 3.4.5-cdh5.12.1 |
+| hive | 1.1.0-cdh5.12.1 |
+| spark | 2.3.4 |
+| flink | 1.12.4 |
+| python | python3 |
+
+#### 7.2.1 linkis的pom文件
+
+```xml
+2.6.0-cdh5.12.1
+3.4.5-cdh5.12.1
+2.11.8
+```
+
+#### 7.2.2 linkis-engineplugin-hive的pom文件
+
+```xml
+-- 修改
+1.1.0-cdh5.12.1
+-- 添加
+1.1.0_cdh5.12.1
+```
+
+- 修改 assembly 下的 distribution.xml 文件
+
+```xml
+/dist/v${package.hive.version}/lib
+dist/v${package.hive.version}/conf
+plugin/${package.hive.version}
+```
+
+- 修改CustomerDelimitedJSONSerDe文件
+
+ ```
+ /* hive版本过低,需注释
+ case INTERVAL_YEAR_MONTH:
+ {
+ wc = ((HiveIntervalYearMonthObjectInspector) oi).getPrimitiveWritableObject(o);
+ binaryData = Base64.encodeBase64(String.valueOf(wc).getBytes());
+ break;
+ }
+ case INTERVAL_DAY_TIME:
+ {
+ wc = ((HiveIntervalDayTimeObjectInspector) oi).getPrimitiveWritableObject(o);
+ binaryData = Base64.encodeBase64(String.valueOf(wc).getBytes());
+ break;
+ }
+ */
+ ```
+
+#### 7.2.3 linkis-engineplugin-flink的pom文件
+
+```xml
+1.12.4
+```
+
+#### 7.2.4 linkis-engineplugin-spark的pom文件
+
+```xml
+2.3.4
+```
+
+#### 7.2.5 linkis-engineplugin-python的pom文件
+
+```xml
+python3
+```
+
+#### 7.2.6 linkis-label-common调整
+
+org.apache.linkis.manager.label.conf.LabelCommonConfig 文件调整
+
+```java
+ public static final CommonVars SPARK_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.spark.engine.version", "2.3.4");
+
+ public static final CommonVars HIVE_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.hive.engine.version", "1.1.0");
+
+ CommonVars.apply("wds.linkis.python.engine.version", "python3")
+```
+
+#### 7.2.7 linkis-computation-governance-common调整
+
+org.apache.linkis.governance.common.conf.GovernanceCommonConf 文件调整
+
+```java
+ val SPARK_ENGINE_VERSION = CommonVars("wds.linkis.spark.engine.version", "2.3.4")
+
+ val HIVE_ENGINE_VERSION = CommonVars("wds.linkis.hive.engine.version", "1.1.0")
+
+ val PYTHON_ENGINE_VERSION = CommonVars("wds.linkis.python.engine.version", "python3")
+```
+
+### 7.3 CDH6.3.2
+
+| 引擎 | 版本 |
+| ------ | -------------- |
+| hadoop | 3.0.0-cdh6.3.2 |
+| hive | 2.1.1-cdh6.3.2 |
+| spark | 3.0.0 |
+
+#### 7.3.1 linkis的pom文件
+
+```xml
+3.0.0-cdh6.3.2
+2.12.10
+```
+
+#### 7.3.2 linkis-hadoop-common
+
+```xml
+
+
+ org.apache.hadoop
+ hadoop-hdfs-client
+
+```
+
+#### 7.3.3 linkis-engineplugin-hive的pom文件
+
+```xml
+-- 修改
+2.1.1-cdh6.3.2
+-- 添加
+2.1.1_cdh6.3.2
+```
+
+修改 assembly 下的 distribution.xml 文件
+
+```xml
+/dist/v${package.hive.version}/lib
+dist/v${package.hive.version}/conf
+plugin/${package.hive.version}
+```
+
+#### 7.3.4 linkis-engineplugin-spark的pom文件
+
+```xml
+3.0.0
+```
+
+#### 7.3.5 linkis-label-common调整
+
+org.apache.linkis.manager.label.conf.LabelCommonConfig 文件调整
+
+```java
+ public static final CommonVars SPARK_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.spark.engine.version", "3.0.0");
+
+ public static final CommonVars HIVE_ENGINE_VERSION =
+ CommonVars.apply("wds.linkis.hive.engine.version", "2.1.1_cdh6.3.2");
+```
+
+#### 7.3.6 linkis-computation-governance-common调整
+
+org.apache.linkis.governance.common.conf.GovernanceCommonConf 文件调整
+
+```java
+ val SPARK_ENGINE_VERSION = CommonVars("wds.linkis.spark.engine.version", "3.0.0")
+
+ val HIVE_ENGINE_VERSION = CommonVars("wds.linkis.hive.engine.version", "2.1.1_cdh6.3.2")
+```
+
+## 8 编译技巧
+
+- 如果遇到类缺少或者类中方法缺少的情况下,找到对应引用这个包依赖,如何尝试切换到有对应包或者类的版本中来
+- 引擎版本如果需要使用到-的话,使用_来进行替换,并且加上来指定替换后的版本,同时在对应的引擎distribution文件中使用${package.引擎名字.version}来替换原有的
+- 如果有时候使用阿里云镜像出现下载guava的jar出现403的问题的话,可以切换到华为,腾讯等镜像仓库
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/_category_.json
new file mode 100644
index 00000000000..a857e622c21
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "开发指南",
+ "position": 8
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/build-console.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/build-console.md
new file mode 100644
index 00000000000..6fa4f38643e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/build-console.md
@@ -0,0 +1,79 @@
+---
+title: 管理台编译
+sidebar_position: 4.0
+---
+
+## 1. 前置准备
+
+## 1.1 安装Node.js
+
+>该步骤仅第一次使用时需要执行,如果已有node环境,可跳过
+
+将Node.js下载到本地,安装即可。下载地址:[http://nodejs.cn/download/](http://nodejs.cn/download/) (建议使用node v16版本)
+
+## 1.2 源码获取
+
+- 方式1:从[github仓库](https://github.com/apache/linkis) https://github.com/apache/linkis 获取项目的源代码。
+- 方式2:从[linkis的官方下载页面](https://linkis.apache.org/download/main) https://linkis.apache.org/download/main 下载所需版本的源码包。
+
+
+## 2. 编译
+
+## 2.1 安装npm依赖
+
+在终端命令行中执行以下指令:
+```
+#进入项目WEB根目录
+$ cd linkis/linkis-web
+#安装项目所需依赖
+$ npm install
+```
+**该步骤仅第一次使用时需要执行。**
+
+
+## 2.2. 打包项目
+
+在终端命令行执行以下指令对项目进行打包,生成压缩后的部署安装包。
+检查`linkis-web/package.json`,`linkis-web/.env`文件,检查前端管理台版本号是否正确。
+```
+$ npm run build
+```
+上述命令执行成功后,会生成前端管理台安装包 `apache-linkis-${version}-web-bin.tar.gz`,可以直接将该文件夹放进您的静态服务器中,或者参考[安装文档](../deployment/deploy-console.md),使用脚本进行部署安装。
+
+## 3 . 注意事项
+### 3.1 Windows下npm install 步骤报错
+```shell
+Error: Can't find Python executable "python", you can set the PYTHON env variable
+安装windows-build-tools (管理员权限)
+$ npm install --global --production windows-build-tools
+安装node-gyp
+$ npm install --global node-gyp
+
+2.如果编译失败 请按如下步骤清理后重新执行
+#进入项目工作目录,删除 node_modules
+$ rm -rf node_modules
+#删除 package-lock.json
+$ rm -rf package-lock.json
+#清除 npm 缓存
+$ npm cache clear --force
+#重新下载依赖
+$ npm install
+
+```
+### 3.2 如果出现兼容问题,建议重新安装node
+[node下载地址](https://nodejs.org/zh-cn/download/)
+```shell
+1.查看node版本(推荐使用node v16版本)
+$ node -v
+2.下载node v16版本并且重新安装node
+```
+
+### 3.3 npm install下载前端依赖无法成功
+如果遇到该情况,可以使用国内的淘宝npm镜像:
+```
+npm install -g cnpm --registry=https://registry.npm.taobao.org
+```
+接着,通过执行以下指令代替npm install指令
+```
+cnpm install
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/build-docker.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/build-docker.md
new file mode 100644
index 00000000000..17c01e84f5b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/build-docker.md
@@ -0,0 +1,136 @@
+---
+title: Docker 编译
+sidebar_position: 5.0
+---
+
+## Linkis 镜像组成
+
+从1.3.0版本起,Linkis引入了一些 Docker 镜像,项目所有镜像的 Dockerfile 文件都在`linkis-dist/docker`目录下。
+
+目前由如下几个镜像组成:
+
+### linkis-base
+
+ - __Dockerfile__:
+ - 文件名: linkis.Dockerfile
+ - 参数, 可以通过 `docker build` 命令的 `--build-arg` 参数来重载:
+ * JDK_VERSION: JDK 版本,默认为 1.8.0-openjdk
+ * JDK_BUILD_REVISION: JDK 发布版本, 默认为 1.8.0.332.b09-1.el7_9
+ - __说明__: Linkis服务基础镜像,主要用于预安装 Linkis 系统需要的外部库,初始化系统环境和目录。本镜像不需要经常更新,利用 docker 的镜像缓存机制,可以加速 Linkis 镜像的制作。
+
+### linkis
+ - __Dockerfile__:
+ - 文件名: linkis.Dockerfile
+ - 参数:
+ * LINKIS_VERSION: Linkis 版本号,默认为 0.0.0
+ * LINKIS_SYSTEM_USER: 系统用户,默认为 hadoop
+ * LINKIS_SYSTEM_UID: 系统用户UID, 默认为 9001
+ * LINKIS_HOME: Linkis 主目录,默认为 /opt/linkis , 系统的二进制包和各类脚本会部署到这里
+ * LINKIS_CONF_DIR: Linkis 配置文件目录,默认为 /etc/linkis-conf
+ * LINKIS_LOG_DIR: Linkis 日志目录,默认为 /var/logs/linkis
+ - __说明__: Linkis服务镜像,镜像中包含了 Apache Linkis 的所有组件的二进制包和各类脚本。
+
+### linkis-web
+ - __Dockerfile__:
+ - 文件名: linkis.Dockerfile
+ - 参数:
+ * LINKIS_VERSION: Linkis 版本号,默认为 0.0.0
+ * LINKIS_HOME: Linkis 主目录,默认为 /opt/linkis , Web 相关的包会被放置在 ${LINKIS_HOME}-web 下
+ - __说明__: Linkis Web 控制台镜像,镜像中包含了 Apache Linkis Web 控制台的的二进制包和各类脚本,本镜像使用 nginx 作为 Web 服务器。
+
+### linkis-ldh
+ - __Dockerfile__:
+ - 文件名: ldh.Dockerfile
+ - 参数:
+ * JDK_VERSION: JDK 版本,默认为 1.8.0-openjdk
+ * JDK_BUILD_REVISION: JDK 发布版本, 默认为 1.8.0.332.b09-1.el7_9
+ * LINKIS_VERSION: Linkis 版本号,默认为 0.0.0
+ * MYSQL_JDBC_VERSION: MySQL JDBC 版本,默认为 8.0.28
+ * HADOOP_VERSION: Apache Hadoop 组件版本,默认为 2.7.2
+ * HIVE_VERSION: Apache Hive 组件版本,默认为 2.3.3
+ * SPARK_VERSION: Apache Spark 组件版本,默认为 2.4.3
+ * SPARK_HADOOP_VERSION: 预编译的 Apache Spark 发布包 Hadoop 版本后缀,默认为 2.7,该值不能任意设置,需要和 Apache Spark 官方发布版本保持一致,否则无法自动下载相关组件
+ * FLINK_VERSION: Apache Flink 组件版本,默认为 1.12.2
+ * ZOOKEEPER_VERSION: Apache Zookeeper 组件版本,默认为 3.5.9
+ - __说明__: LDH 是一个面向测试用途的镜像,LDH 镜像提供了一套完整的、伪分布式模式的 Apache Hadoop 运行环境,包含了 HDFS, YARN, HIVE, Spark, Flink 和 Zookeeper, 可以很方便的在开发环境中拉起一个全真的 Hadoop 环境用来测试 Linkis 的功能。LDH 镜像的 ENTRYPOINT 为 `linkis-dist/docker/scripts/entry-point-ldh.sh`,一些初始化操作,如 HDFS 的 format 操作都是在这个脚本中完成的。
+
+### 集成 MySQL JDBC
+
+由于MySQL的许可协议限制,官方发布的 Linkis 镜像没有集成 MySQL JDBC 驱动,用户在使用 Linkis 容器前需要自行将 MySQL JDBC 驱动放置到容器中。为了简化这个过程,我们提供了一个 Dockerfile:
+
+- 文件名: linkis-with-mysql-jdbc.Dockerfile
+- 参数:
+ * LINKIS_IMAGE: Linkis 镜像名,基于这个镜像来制作包含 MySQL JDBC 驱动的自定义镜像, 默认为 `linkis:dev`
+ * LINKIS_HOME: Linkis 主目录,默认为 /opt/linkis
+ * MYSQL_JDBC_VERSION: MySQL JDBC 版本,默认为 8.0.28
+
+## Linkis 镜像制作
+
+> 因为镜像制作过程中使用了一些 Bash 脚本,目前仅支持在 Linux/MaxOS 下完成 Linkis 镜像打包的工作。
+
+### 使用 Maven 构建镜像
+
+Linkis 镜像制作过程都已经集成到项目的 Maven Profile 中,可以通过 Maven 命令实现 Liniks 镜像的制作。
+
+1. 构建 `linkis` 镜像
+
+ ``` shell
+ # 构建不包含 MySQL JDBC 的 Linkis 镜像
+ $> ./mvnw clean install -Pdocker -Dmaven.javadoc.skip=true -Dmaven.test.skip=true
+ # 构建包含 MySQL JDBC 的 Linkis 镜像
+ $> ./mvnw clean install -Pdocker -Dmaven.javadoc.skip=true -Dmaven.test.skip=true -Dlinkis.build.with.jdbc=true
+ ```
+ 需要注意:
+ * `linkis-base` 镜像会在 `linkis` 镜像第一次构建时被构建,后续如果 Dockerfile 没有被修改,将不会被重复构建;
+ * 受制于 Maven POM 文件的语法,`linkis.build.with.jdbc` 是一个伪布尔参数,实际上`-Dlinkis.build.with.jdbc=false`和`-Dlinkis.build.with.jdbc=true`是一样的,如希望表达`-Dlinkis.build.with.jdbc=false`,请直接将这个参数去掉。其他参数类似。
+
+2. 构建 `linkis-web` 镜像
+
+ ``` shell
+ $> ./mvnw clean install -Pdocker -Dmaven.javadoc.skip=true -Dmaven.test.skip=true -Dlinkis.build.web=true
+ ```
+
+3. 构建 `linkis-ldh` 镜像
+
+ ``` shell
+ $> ./mvnw clean install -Pdocker -Dmaven.javadoc.skip=true -Dmaven.test.skip=true -Dlinkis.build.ldh=true
+ ```
+
+ 需要注意:
+ * 在制作本镜像的过程中,我们从 [Apache Archives](https://archive.apache.org/dist/) 这个官方站点下载每个hadoop组件的预建二进制发行版。但是,受制于国内的网络环境,这种方式可能会非常缓慢。如果你有更快的站点,你可以手动从这些站点下载相应的包,并将其移动到如下这个目录`${HOME}/.linkis-build-cache` 来解决这个问题。
+
+上述参数都可以组合使用,如希望一次性构建所有镜像,可以使用如下命令:
+
+``` shell
+$> ./mvnw clean install -Pdocker -Dmaven.javadoc.skip=true -Dmaven.test.skip=true -Dlinkis.build.web=true -Dlinkis.build.ldh=true
+```
+
+### 使用 docker build 命令构建镜像
+
+使用 Maven 命令构建镜像固然方便,但是构建过程中引入了不少重复的编译过程,整个过程比较漫长。如果仅调整镜像内部结构,如目录结构,初始化命令等,可以在第一次使用 Maven 命令构建镜像后,直接使用`docker build` 命令来快速构建镜像进行测试。
+
+使用 `docker build` 命令构建 linkis-ldh 镜像示例如下:
+
+``` shell
+$> docker build -t linkis-ldh:dev --target linkis-ldh -f linkis-dist/docker/ldh.Dockerfile linkis-dist/target
+
+[+] Building 0.2s (19/19) FINISHED
+ => [internal] load build definition from ldh.Dockerfile 0.0s
+ => => transferring dockerfile: 41B 0.0s
+ => [internal] load .dockerignore 0.0s
+ => => transferring context: 2B 0.0s
+ => [internal] load metadata for docker.io/library/centos:7 0.0s
+ => [ 1/14] FROM docker.io/library/centos:7 0.0s
+ => [internal] load build context 0.0s
+ => => transferring context: 1.93kB 0.0s
+ => CACHED [ 2/14] RUN useradd -r -s ... 0.0s
+ => CACHED [ 3/14] RUN yum install -y ... 0.0s
+ ...
+ => CACHED [14/14] RUN chmod +x /usr/bin/start-all.sh 0.0s
+ => exporting to image 0.0s
+ => => exporting layers 0.0s
+ => => writing image sha256:aa3bde0a31bf704413fb75673fc2894b03a0840473d8fe15e2d7f7dd22f1f854 0.0s
+ => => naming to docker.io/library/linkis-ldh:dev
+```
+
+其他镜像的构建命令请参考 `linkis-dist/pom.xml` 中相关的 profile.
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/build.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/build.md
new file mode 100644
index 00000000000..aba12c6c0e1
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/build.md
@@ -0,0 +1,213 @@
+---
+title: 后端编译
+sidebar_position: 3.0
+---
+
+## 1. 前置准备
+
+## 1.1 环境要求
+
+__编译环境要求:__ 必须 **JDK8** 以上,**Oracle/Sun** 和 **OpenJDK**都支持。
+
+
+### 1.2 源码获取
+
+- 方式1:从[github仓库](https://github.com/apache/linkis) https://github.com/apache/linkis 获取项目的源代码。
+- 方式2:从[linkis的官方下载页面](https://linkis.apache.org/download/main) https://linkis.apache.org/download/main 下载所需版本的源码包。
+
+**请注意**:官方推荐使用 Hadoop-2.7.2、Hive-1.2.1、Spark-2.4.3 和 Scala-2.11.12 对 Linkis 进行编译。
+
+如果您想使用 Hadoop、Hive、Spark 的其他版本对 Linkis 进行编译,请参考:[如何修改Linkis的依赖的Hadoop、Hive、Spark版本](#4-如何修改linkis的依赖的hadoophivespark版本)
+
+### 1.2 修改依赖配置
+:::caution 注意
+因为mysql-connector-java驱动是GPL2.0协议,不满足Apache开源协议关于license的政策,因此从1.0.3版本开始,对mysql-connector-java的依赖项作用域scope默认是test,若自行编译,可以修改顶级pom.xml的mysql-connector-java依赖的scope作用域(注释掉即可)
+:::
+```xml
+
+ mysql
+ mysql-connector-java
+ ${mysql.connector.version}
+
+
+```
+
+## 2. 全量编译 Linkis
+
+### step1 首次编译(非首次可跳过此步)
+
+**如果您是本地第一次编译使用,必须在 Linkis 源码工程的根目录先执行以下命令**:
+```bash
+ cd linkis-x.x.x
+ mvn -N install
+```
+
+### step2 执行编译
+在 Linkis 源码包根目录执行以下命令:
+
+```bash
+ cd linkis-x.x.x
+ mvn clean install
+
+```
+
+### step3 获取安装包
+编译后的完整安装包,在工程的linkis-dist->target目录下:
+
+```bash
+ #详细路径如下
+ linkis-x.x.x/linkis-dist/target/apache-linkis-x.x.x-bin.tar.gz
+```
+
+## 3 常见问题
+
+### 3.1 如何编译单个模块
+> 有些场景可能只需要针对某个模块进行编译,可参考如下流程
+
+:::caution 注意
+如有没有执行过全量编译,先要进行一次全量编译
+:::
+
+#### step1 进入到对应模块进行编译
+进入到对应模块进行编译,比如想重新编译 Entrance,命令如下:
+
+```bash
+ cd linkis-x.x.x/linkis-computation-governance/linkis-entrance
+ mvn clean install
+```
+
+#### step2 获取安装包
+获取安装包,在对应模块的->target目录下会有编译好的包:
+
+```
+ ls linkis-x.x.x/linkis-computation-governance/linkis-entrance/target/linkis-entrance.x.x.x.jar
+```
+
+### 3.2 如何编译某个引擎
+
+>有些场景可能只需要针对某个引擎进行编译,可参考如下流程
+
+:::caution 注意
+如有没有执行过全量编译,先要进行一次全量编译
+:::
+
+这里以编译Spark 引擎为例:
+
+#### step1 进入到对应模块进行编译
+进入到 Spark 引擎所在的目录进行编译打包,命令如下:
+
+```bash
+ cd linkis-x.x.x/linkis-engineconn-plugins/spark
+ mvn clean install
+```
+#### step2 获取引擎的物料包
+在对应模块的target目录下:
+
+```
+ #spark文件下就是编译好的引擎物料
+ linkis-x.x.x/linkis-engineconn-plugins/spark/target/out/spark
+```
+如何单独安装 Spark 引擎?请参考 [Linkis 引擎插件安装文档](../deployment/install-engineconn)
+
+
+### 3.2 如何将非默认引擎打包至安装部署包中
+
+> 默认打包配置中`linkis-dist/src/main/assembly/distribution.xml`,只会将`spark/hive/python/shell`打包到安装包中,如果需要添加其它引擎,可参考此步骤
+
+以jdbc引擎为例
+
+step1 修改`linkis-dist/src/main/assembly/distribution.xml` 添加jdbc引擎
+```shell script
+
+
+
+ ../../linkis-engineconn-plugins/jdbc/target/out/
+
+ lib/linkis-engineconn-plugins/
+
+ **/*
+
+
+```
+step2 如果已经全量编译,可以直接重新编译`linkis-dist`模块,如果没有,这执行全量编译
+
+### 3.3 如何在全量编译时跳过指定引擎
+可使用mvn指令中的`-pl`选项,详情可参考如下
+```
+-pl,--projects Comma-delimited list of specified
+ reactor projects to build instead
+ of all projects. A project can be
+ specified by [groupId]:artifactId
+ or by its relative path.
+```
+通过`!`实现反选,从而排除指定的引擎,缩短全量编译所需时间,以flink、sqoop和hive为例,跳过这些引擎进行编译:
+```
+mvn clean install -Dmaven.test.skip=true \
+-pl '!linkis-engineconn-plugins/flink,!linkis-engineconn-plugins/sqoop,!linkis-engineconn-plugins/hive'
+```
+
+## 4. 如何修改Linkis的依赖的Hadoop、Hive、Spark版本
+
+请注意:Hadoop 作为大数据基础服务,Linkis 必须依赖 Hadoop 进行编译;
+而 Spark、Hive等计算存储引擎则不然,如果您不想使用某个引擎,可以无需设置该引擎的版本,无需编译该引擎插件。
+
+具体而言,修改 Hadoop 的版本与 Spark、Hive 等计算引擎的方式不同,下面详细介绍:
+
+### 4.1 如何修改 Linkis 依赖的 Hadoop 版本
+
+进入 Linkis 源码包根目录,手动修改 pom.xml 文件的 Hadoop 版本信息,具体如下:
+
+```bash
+ cd linkis-x.x.x
+ vim pom.xml
+```
+
+```xml
+
+
+ 2.7.2 在这里修改Hadoop版本号 <-->
+ 2.11.12
+ 1.8
+
+
+```
+:::caution 注意
+**请注意:如果你的hadoop版本是hadoop3,需要修改linkis-hadoop-common的pom文件**
+:::
+
+因为在hadoop2.8以下的时候,hdfs相关的class是在hadoop-hdfs模块中的,但是在hadoop 3.X中将对应的class移动到了模块hadoop-hdfs-client当中,您需要修改下这个文件:
+
+pom:Linkis/linkis-commons/linkis-hadoop-common/pom.xml
+修改依赖hadoop-hdfs为hadoop-hdfs-client:
+```
+
+ org.apache.hadoop
+ hadoop-hdfs
+ ${hadoop.version}
+
+ 将hadoop-hdfs修改为:
+
+ org.apache.hadoop
+ hadoop-hdfs-client
+ ${hadoop.version}
+
+```
+
+### 4.2 如何修改 Linkis 依赖的 Spark、Hive 版本
+
+这里以修改 Spark 的版本为例进行介绍。进入 Spark 引擎所在的目录,手动修改 pom.xml 文件的 Spark 版本信息,具体如下:
+
+```bash
+ cd linkis-x.x.x/linkis-engineconn-plugins/spark
+ vim pom.xml
+```
+
+```xml
+
+ 2.4.3 在这里修改Spark版本号 <-->
+
+```
+
+修改其他引擎的版本与修改 Spark 版本类似,先进入相关引擎所在的目录,手动修改 pom.xml 文件的引擎版本信息即可。
+
+然后请参考 [编译某个引擎](#32-如何编译某个引擎)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/config.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/config.md
new file mode 100644
index 00000000000..a0b86b0d18a
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/config.md
@@ -0,0 +1,131 @@
+---
+title: 配置参数介绍
+sidebar_position: 11.0
+---
+
+## 1. 参数分类
+
+Linkis参数主要分为以下三个部分:
+- Linkis 服务端参数,主要包含Linkis本身的参数和Spring的参数
+- Linkis SDK、Restful等客户端端调用提交的参数
+- Linkis 管理台参数
+
+
+## 2. Linkis 服务端参数
+
+1. Linkis本身的参数
+linkis本身的参数支持在配置文件里面进行设置,也支持通过环境变量和系统属性进行设置,推荐使用配置文件进行设置。
+Linkis配置文件格式如下所示:
+```shell
+├── conf 配置目录
+│ ├── application-eureka.yml
+│ ├── application-linkis.yml
+│ ├── linkis-cg-engineconnmanager-io.properties
+│ ├── linkis-cg-engineconnmanager.properties
+│ ├── linkis-cg-engineplugin.properties
+│ ├── linkis-cg-entrance.properties
+│ ├── linkis-cg-linkismanager.properties
+│ ├── linkis.properties ──linkis global properties
+│ ├── linkis-ps-bml.properties
+│ ├── linkis-ps-cs.properties
+│ ├── linkis-ps-datasource.properties
+│ ├── linkis-ps-publicservice.properties
+│ ├── log4j2.xml
+```
+每个服务会加载两个属性配置文件,一个为公用的主配置文件linkis.properties,以及服务配置文件linkis-serviceName.properties。设置的优先级为服务配置文件高于主配置文件
+建议通用的参数放置在主配置文件,个性化配置文件放在服务配置文件
+
+2. Spring 参数
+Linkis服务是基于SpringBoot应用的,Spring相关的参数支持在application-linkis.yml进行设置,也支持在linkis配置文件里面进行配置。在linkis配置文件里面配置需要加上spring.的前缀。如下:
+
+```shell
+# spring port default
+server.port=9102
+# in linkis conf need spring prefix
+spring.server.port=9102
+
+```
+
+## 3. Linkis 客户端参数
+Linkis客户端参数主要是指任务提交时的参数,主要在提交接口里面进行指定的参数。
+1.restful 如何设置参数:
+
+```shell
+{
+ "executionContent": {"code": "show tables", "runType": "sql"},
+ "params": { // 提交参数
+ "variable":{ //代码中需要的自定义变量
+ "k1":"v1"
+ },
+ "configuration":{
+ "special":{ //特殊配置参数 如日志路径,结果集路径等
+ "k2":"v2"
+ },
+ "runtime":{ //运行时参数,执行配置参数,如JDBC引擎的的数据库连接参数,presto引擎的数据源参数
+ "k3":"v3"
+ },
+ "startup":{ //启动参数,如启动EC的内存参数,spark引擎参数、hive引擎参数等
+ "k4":"v4" 如:spark.executor.memory:5G 设置Spark的执行器内存,底层Spark、hive等引擎参数keyName是和原生参数一致的
+ }
+ }
+ },
+ "labels": { //标签参数,支持设置引擎版本、用户和提应用
+ "engineType": "spark-2.4.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+2.SDK如何设置参数:
+
+```java
+JobSubmitAction jobSubmitAction = JobSubmitAction.builder()
+ .addExecuteCode(code)
+ .setStartupParams(startupMap) //启动参数,如启动EC的内存参数,spark引擎参数、hive引擎参数等, 如:spark.executor.memory:5G 设置Spark的执行器内存,底层Spark、hive等引擎参数keyName是和原生参数一致的
+ .setRuntimeParams(runTimeMap) //引擎,执行配置参数,如JDBC引擎的的数据库连接参数,presto引擎的数据源参数
+ .setVariableMap(varMap) //代码中需要的自定义变量
+ .setLabels(labels) //标签参数,支持设置引擎版本、用户和提应用等
+ .setUser(user) //submit user
+ .addExecuteUser(user) // execute user
+ .build();
+```
+3.linkis-cli如何设置参数
+
+```shell
+linkis-cli -runtieMap key1=value -runtieMap key2=value
+ -labelMap key1=value
+ -varMap key1=value
+ -startUpMap key1=value
+
+```
+注意: 客户端参数提交时,只有引擎相关参数和标签参数,以及Yarn队列设置可以生效,其他Linkis服务端参数和资源限制参数,如任务和引擎并发参数wds.linkis.rm.instances不支持任务设置
+
+4.常用标签参数:
+
+```shell
+ Map labels = new HashMap();
+ labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "spark-2.4.3"); // 指定引擎类型和版本
+ labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, user + "-IDE");// 指定运行的用户和您的APPName
+ labels.put(LabelKeyConstant.CODE_TYPE_KEY, "sql"); // 指定运行的脚本类型:spark支持:sql、scala、py;Hive:hql;shell:sh;python:python;presto:psql
+ labels.put(LabelKeyConstant.JOB_RUNNING_TIMEOUT_KEY, "10000");//job运行10s没完成自动发起Kill,单位为s
+ labels.put(LabelKeyConstant.JOB_QUEUING_TIMEOUT_KEY, "10000");//job排队超过10s没完成自动发起Kill,单位为s
+ labels.put(LabelKeyConstant.RETRY_TIMEOUT_KEY, "10000");//job因为资源等原因失败重试的等待时间,单位为ms,如因为队列资源不足的失败,会默认按间隔发起10次重试
+ labels.put(LabelKeyConstant.TENANT_KEY,"hduser02");//租户标签,任务如果指定了租户参数则任务会被路由到单独的ECM机器
+ labels.put(LabelKeyConstant.EXECUTE_ONCE_KEY,"");//执行一次标签,该参数不建议设置,设置后引擎不会复用任务运行完就会结束引擎,只有某个任务参数有特殊化的可以进行设置
+```
+
+## 4. Linkis 管理台参数
+Linkis管理台参数时方便用户指定资源限制参数和默认的任务参数提供的Web界面,如下:
+全局配置参数:
+![](/Images/development/linkis_global_conf.png)
+主要包含了全局队列参数[wds.linkis.rm.yarnqueue],任务默认采用的Yarn队列,支持在客户端StartUPMap里面另外进行指定
+资源限制参数,这些参数不支持任务设置,支持管理台进行调整。
+```shell
+队列CPU使用上限[wds.linkis.rm.yarnqueue.cores.max],现阶段只支持限制Spark类型任务总队列资源的使用
+队列内存使用上限[wds.linkis.rm.yarnqueue.memory.max]
+全局各个引擎内存使用上限[wds.linkis.rm.client.memory.max] 该参数不是指总共只能使用的内存,而是指定某个Creator特定引擎总的内存使用,如限制IDE-SPARK任务只能使用10G内存
+全局各个引擎核心个数上限[wds.linkis.rm.client.core.max]该参数不是指总共只能使用的CPU,而是指定某个Creator特定引擎总的内存使用,如限制IDE-SPARK任务只能使用10Cores
+全局各个引擎最大并发数[wds.linkis.rm.instance],该参数有两层含义,一个是限制某个Creator特定引擎总共能启动多少个,以及限制某个Creator特定引擎任务同时能运行的任务数
+```
+引擎配置参数:
+![](/Images/development/linkis_creator_ec_conf.png)
+主要指定引擎的启动参数和运行时参数,这些参数支持在客户端进行设置,建议使用客户端进行个性化提交设置,页面只设置默认值
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/debug-with-helm-charts.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/debug-with-helm-charts.md
new file mode 100644
index 00000000000..349662b6d53
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/debug-with-helm-charts.md
@@ -0,0 +1,500 @@
+---
+title: 容器化开发调试
+sidebar_position: 7.0
+---
+
+## 前言
+
+本文介绍如何使用 Kubernetes 技术来简化 Linkis 项目的开发调试工作。在没有引入 Kubernetes 工具前,调试 Linkis 是一个非常繁琐和复杂的工作,有时候可能需要搭建 Linkis 依赖的 Hadoop 环境。为了改善这个问题,本文使用了另一种方法,利用 Kubernetes 技术在开发机上创建一个 Hadoop 集群并拉起所有 Linkis 服务,这是个分布式的环境,并且可以随时拉起和销毁,开发者通过 JVM 远程调试功能连接这些服务并进行单步调试. 这里我们用到了如下几个技术:
+
+* Docker: 一种容器化技术,用于支创建和使用 Linux 容器;
+* Kubernetes: 一种可自动部署和管理 Linux 容器的开源平台,Kubernetes 还整合了网络、存储、安全性、遥测和其他服务,提供了全面的基于容器的基础设施;
+* KinD: 一个使用Docker容器作为 "Kubernetes节点" 来运行本地 Kubernetes 集群的工具;
+* Helm: Kubernetes 上一个开源的包管理工具, 通过 Helm 命令行工具和安装包(Chart)来管理 Kubernetes 上的用户资源;
+
+## 依赖工具介绍
+
+### 版本要求
+
+* [Docker](https://docs.docker.com/get-docker/), 最低版本 v20.10.8+
+* [Kubernetes](https://kubernetes.io/docs/setup/), 最低版本 v1.21.0+
+* [Helm](https://helm.sh/docs/intro/install/), 最低版本 v3.0.0+.
+* [KinD](https://kind.sigs.k8s.io/docs/user/quick-start/), 最低版本 v0.11.0+.
+
+### Helm Charts 介绍
+
+Helm 是 Kubernetes 上一个开源的包管理工具,Helm 最初的目标是为用户提供一种更好的方式来管理在 Kubernetes 上创建的所有 Kubernetes YAML 文件。Helm 使用 Charts 这个方式来解决上述问题,Chart 是一组文本文件,使用 Helm 模版语言编写,用来描述一个或者多个 Kubernetes 资源文件,Chart 直接依赖或者引用其他 Chart. 在使用 Charts 时,用户需要提供一个 变量文件,Helm 使用这个变量文件中定义的变量来渲染相应的 Chart, 生产 Kubernetes YAML 文件, 然后调用 Kubernetes api 提交到 Kubernetes 上。每一个发布到 Kubernetes 的 Charts 被称为 Release,一个 Chart 通常可以被多次安装到同一个集群中,而每次安装时,都会创建一个新的 Release。
+
+Helm 的安装方式比较简单,请参考官方文档进行安装: [Installing Helm](https://helm.sh/docs/intro/install/)
+
+### KinD 介绍
+
+在本地创建一个 Kubernetes 测试环境是一个非常普遍的需求,Kubernetes 社区提供了多种解决方案,如 MiniKube 或 MicroK8s 等,KinD 是一个相对较新的工具,KinD 是 Kubernetes IN Docker 的缩写,顾名思义,它使用 Docker 托管节点来创建一个面向测试的 Kubernetes 集群。
+
+KinD 系统架构
+
+![](/Images/development/kind-arc.png)
+
+部署 KinD 也非常简单,请参考官方部署文档: [KinD Installation](https://kind.sigs.k8s.io/docs/user/quick-start/#installation), 部署 KinD 前请先安装 Docker .
+
+> ⚠️注意:
+> KinD 是面向测试的用途的工具,不能用于生产部署。同时,KinD 利用 Docker 带来的便利的同时,也引入了一些限制, 比如,开发机重启后,KinD 集群无法继续使用,需要重新创建(因为 KinD 在创建 Node 容器后会进行一系列的初始化工作,这些工作在机器重启后无法自动回复)。
+
+## Linkis 容器化组件
+
+### Linkis 镜像
+
+Linkis 提供了多个镜像,所有镜像的 Dockerfile 和相关脚本都在 `linkis-dist/docker` 目录下。 可以通过 Maven 命令和 `docker build` 命令来制作相应的镜像。Linkis 镜像主要包括如下几个:
+
+* `linkis`: Linkis 服务镜像,镜像中包含了 Apache Linkis 的所有组件的二进制包和各类脚本。
+* `linkis-web`: Linkis Web 控制台镜像,镜像中包含了 Apache Linkis Web 控制台的的二进制包和各类脚本,本镜像使用 nginx 作为 Web 服务器。
+* `linkis-ldh`: LDH 是一个面向测试用途的镜像,LDH 镜像提供了一套完整的、伪分布式模式的 Apache Hadoop 运行环境,包含了 HDFS, YARN, HIVE, Spark, Flink 和 Zookeeper, 可以很方便的在开发环境中拉起一个全真的 Hadoop 环境用来测试 Linkis 的功能。
+
+具体请参考: [Linkis Docker 镜像打包](https://linkis.apache.org/zh-CN/docs/latest/development/linkis_docker_build_instrument).
+
+### Linkis Helm Chart
+
+Linkis Helm Chart 是遵循 Helm Chart 规范开发的 Helm 安装包,在 `linkis-dist/helm` 目录下. 模块目录结构如下:
+
+``` shell
+linkis-dist/helm
+├── charts # Charts 目录, 目前仅包含 Linkis Helm Chart
+│ └── linkis # Linkis Helm Chart 目录
+│ ├── Chart.yaml # - Chart 元数据
+│ ├── templates # - Chart 模版文件,包含了所有 linkis 组件的 Kubernetes YAML 模版
+│ │ ├── NOTES.txt # - Chart 提示信息
+│ │ ├── _helpers.tpl # - Chart 变量辅助模版
+│ │ ├── configmap-init-sql.yaml # - 数据库初始化 SQL 脚本模版
+│ │ ├── configmap-linkis-config.yaml # - Linkis 服务配置文件模版
+│ │ ├── configmap-linkis-web-config.yaml # - Linkis Web 控制台配置文件模版
+│ │ ├── jobs.yaml # - Kubernetes Job 模版,目前仅包括一个数据库初始化作业, 数据库初始化 SQL 脚本会在这个
+| | | # 作业中被执行
+│ │ ├── linkis-cg-engineconnmanager.yaml # - Linkis EngineConnManager 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-cg-engineplugin.yaml # - Linkis EngineConn 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-cg-entrance.yaml # - Linkis Entrance 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-cg-linkismanager.yaml # - Linkis Manager 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-mg-eureka.yaml # - Linkis Eureka 部署模版,是一个 Kubernetes Statefulset 类型的工作负载
+│ │ ├── linkis-mg-gateway.yaml # - Linkis Gateway 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-ps-publicservice.yaml # - Linkis PublicService 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ ├── linkis-web.yaml # - Linkis Web Console 部署模版,是一个 Kubernetes Deployment 类型的工作负载
+│ │ └── serviceaccount.yaml # - Linkis 相关的 Kubernetes Service Account 模版
+│ └── values.yaml # - Linkis Helm Chart 变量文件,默认提供了 Linkis Local 模式相关的变量
+├── scripts # 一些用于简化开发调试的工具脚本
+│ ├── common.sh # - 公共脚本,定义了一些公共方法和变量
+│ ├── create-kind-cluster.sh # - 创建 KinD 集群
+│ ├── install-charts-with-ldh.sh # - 在 KinD 集群上部署 Linkis 服务,使用 On-LDH 的部署方式, 调用 install-linkis.sh 实现
+│ ├── install-charts.sh # - 在 KinD 集群上部署 Linkis 服务,使用 Local 的部署方式, 调用 install-linkis.sh 实现
+│ ├── install-ldh.sh # - 在 KinD 集群上部署 LDH 部署
+│ ├── install-linkis.sh # - 在 KinD 集群上部署 Linkis 服务,可以为 Local 或者 On-LDH 的模式
+│ ├── install-mysql.sh # - 在 KinD 集群上部署一个 MySQL 实例
+│ ├── login-pod.sh # - 登入一个 Pod,打开 Bash 进行交互
+│ ├── remote-debug-proxy.sh # - 开启 JVM 远程调试代理,开启后,可以在 IDE 上连接相应的端口进行调试
+│ └── resources # - 一些资源文件
+│ ├── kind-cluster.yaml # - KinD 集群配置,默认为单个 Node
+│ ├── ldh # - LDH 相关资源文件
+│ │ ├── configmaps # - LDH 各个组件的配置文件
+│ │ │ ├── configmap-flink.yaml # - Flink 配置文件
+│ │ │ ├── configmap-hadoop.yaml # - Hdfs & Yarn 配置文件
+│ │ │ ├── configmap-hive.yaml # - Hive 配置文件
+│ │ │ ├── configmap-spark.yaml # - Spark 配置文件
+│ │ │ └── configmap-zookeeper.yaml # - Zookeeper 配置文件
+│ │ └── ldh.yaml # - LDH Kubernetes YAML, 用于在 KinD 上部署 LDH 实例
+│ └── mysql.yaml # - MySQL Kubernetes YAML, 用于在 KinD 上部署 MySQL 实例
+
+```
+
+本项目提供了一组工具脚本,用于快速创建一个用于开发测试的 Linkis 环境。在生产部署中,需要根据集群的实际情况,修改 `values.yaml` 文件,再使用 Helm CLI 进行部署。使用 Helm CLI 进行部署时,通常有如下两种比较常见的做法:
+1. 使用 `helm install` 命令直接部署。适用于非定制化的部署方式;
+2. 使用 `helm template` 命令选生成 Kubernetes YAML 文件,然后手动修改这些文件,添加自定义配置,然后使用`kubectl apply`命令进行部署。适用于需要定制 Linkis Helm Charts 不支持的 Kubernetes 特性的高阶用户, 如需要使用特定的 StorageClass 或者 PV 等;
+
+### LDH
+
+LDH 是一个面向测试用途的 Hadoop 集群镜像,它提供了一个伪分布式的 hadoop 集群,方便快速测试 On Hadoop 的部署模式。
+这个镜像包含以下多个 hadoop 组件,LDH 中引擎的默认模式是 on-yarn 的。
+* Hadoop 2.7.2 , 包括 HDFS 和 YARN
+* Hive 2.3.3
+* Spark 2.4.3
+* Flink 1.12.2
+* ZooKeeper 3.5.9
+
+LDH 启动时会进行一些初始化操作,比如 format hdfs, 在 HDFS 上创建初始化目录等,这些操作定义在`linkis-dist/docker/scripts/entry-point-ldh.sh`这个文件中,添加、修改、删除一些初始化操作需要重新制作 LDH 镜像才能生效。
+
+另外,LDH 中的 Hive 组件依赖外部的 MySQL 实例,需要先部署 MySQL 实例才能使用 LDH 中的 Hive 组件。
+
+```shell
+# 创建 KinD 集群,并部署 Linkis 和 LDH 实例
+$> sh ./scripts/create-kind-cluster.sh \
+ && sh ./scripts/install-mysql.sh \
+ && sh ./scripts/install-ldh.sh
+
+# 快速体验 LDH
+$> kubectl exec -it -n ldh $(kubectl get pod -n ldh -o jsonpath='{.items[0].metadata.name}') -- bash
+
+[root@ldh-96bdc757c-dnkbs /]# hdfs dfs -ls /
+Found 4 items
+drwxrwxrwx - root supergroup 0 2022-07-31 02:48 /completed-jobs
+drwxrwxrwx - root supergroup 0 2022-07-31 02:48 /spark2-history
+drwxrwxrwx - root supergroup 0 2022-07-31 02:49 /tmp
+drwxrwxrwx - root supergroup 0 2022-07-31 02:48 /user
+
+[root@ldh-96bdc757c-dnkbs /]# beeline -u jdbc:hive2://ldh.ldh.svc.cluster.local:10000/ -n hadoop
+Connecting to jdbc:hive2://ldh.ldh.svc.cluster.local:10000/
+Connected to: Apache Hive (version 2.3.3)
+Driver: Hive JDBC (version 2.3.3)
+Transaction isolation: TRANSACTION_REPEATABLE_READ
+Beeline version 2.3.3 by Apache Hive
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> create database demo;
+No rows affected (1.306 seconds)
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> use demo;
+No rows affected (0.046 seconds)
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> create table t1 (id int, data string);
+No rows affected (0.709 seconds)
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> insert into t1 values(1, 'linikis demo');
+WARNING: Hive-on-MR is deprecated in Hive 2 and may not be available in the future versions. Consider using a different execution engine (i.e. spark, tez) or using Hive 1.X releases.
+No rows affected (5.491 seconds)
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> select * from t1;
++--------+---------------+
+| t1.id | t1.data |
++--------+---------------+
+| 1 | linikis demo |
++--------+---------------+
+1 row selected (0.39 seconds)
+0: jdbc:hive2://ldh.ldh.svc.cluster.local:100> !q
+
+[root@ldh-96bdc757c-dnkbs /]# spark-sql
+22/07/31 02:53:18 INFO hive.metastore: Trying to connect to metastore with URI thrift://ldh.ldh.svc.cluster.local:9083
+22/07/31 02:53:18 INFO hive.metastore: Connected to metastore.
+...
+22/07/31 02:53:19 INFO spark.SparkContext: Running Spark version 2.4.3
+22/07/31 02:53:19 INFO spark.SparkContext: Submitted application: SparkSQL::10.244.0.6
+...
+22/07/31 02:53:27 INFO yarn.Client: Submitting application application_1659235712576_0001 to ResourceManager
+22/07/31 02:53:27 INFO impl.YarnClientImpl: Submitted application application_1659235712576_0001
+22/07/31 02:53:27 INFO cluster.SchedulerExtensionServices: Starting Yarn extension services with app application_1659235712576_0001 and attemptId None
+22/07/31 02:53:28 INFO yarn.Client: Application report for application_1659235712576_0001 (state: ACCEPTED)
+...
+22/07/31 02:53:36 INFO yarn.Client: Application report for application_1659235712576_0001 (state: RUNNING)
+...
+Spark master: yarn, Application Id: application_1659235712576_0001
+22/07/31 02:53:46 INFO thriftserver.SparkSQLCLIDriver: Spark master: yarn, Application Id: application_1659235712576_0001
+spark-sql> use demo;
+Time taken: 0.074 seconds
+22/07/31 02:58:02 INFO thriftserver.SparkSQLCLIDriver: Time taken: 0.074 seconds
+spark-sql> select * from t1;
+...
+1 linikis demo
+2 linkis demo spark sql
+Time taken: 3.352 seconds, Fetched 2 row(s)
+spark-sql> quit;
+
+[root@ldh-96bdc757c-dnkbs /]# zkCli.sh
+Connecting to localhost:2181
+Welcome to ZooKeeper!
+JLine support is enabled
+WATCHER::
+
+WatchedEvent state:SyncConnected type:None path:null
+
+[zk: localhost:2181(CONNECTED) 0] get -s /zookeeper/quota
+
+cZxid = 0x0
+ctime = Thu Jan 01 00:00:00 UTC 1970
+mZxid = 0x0
+mtime = Thu Jan 01 00:00:00 UTC 1970
+pZxid = 0x0
+cversion = 0
+dataVersion = 0
+aclVersion = 0
+ephemeralOwner = 0x0
+dataLength = 0
+numChildren = 0
+[zk: localhost:2181(CONNECTED) 1] quit
+
+# 以 per-job cluster 模式启动 Flink 作业
+[root@ldh-96bdc757c-dnkbs /]# HADOOP_CLASSPATH=`hadoop classpath` flink run -t yarn-per-job /opt/ldh/current/flink/examples/streaming/TopSpeedWindowing.jar
+# 以 session 模式启动 Flink 作业,
+# Flink session 在 LDH Pod 启动时会被启动了一个.
+[root@ldh-96bdc757c-dnkbs /]# flink run /opt/ldh/current/flink/examples/streaming/TopSpeedWindowing.jar
+Executing TopSpeedWindowing example with default input data set.
+Use --input to specify file input.
+Printing result to stdout. Use --output to specify output path.
+...
+```
+
+### KinD 集群
+
+Linkis 项目默认使用的 KinD 集群描述文件是`linkis-dist/helm/scripts/resources/kind-cluster.yaml`, 默认会创建一个包含一个节点的 KinD 集群。打开文件中注释的内容可以添加多个节点。
+
+> ⚠️注意,KinD 集群仅用于测试用途。
+
+``` yaml
+# linkis-dist/helm/scripts/resources/kind-cluster.yaml
+kind: Cluster
+apiVersion: kind.x-k8s.io/v1alpha4
+nodes:
+ - role: control-plane
+ extraMounts:
+ - hostPath: ${KIND_CLUSTER_HOST_PATH} # 指向开发机上的一个目录。这个目录会被映射到 Kind Node 容器中的 `/data` 目录,
+ # Linkis Helm Charts 默认会使用这个目录作为数据目录挂载到各个 Linkis 组件的
+ # Pod 中。当 Linkis 使用 Local 模式进行部署时,所有组件实际上使用了开发机上的
+ # 同一个目录,就和在同一台机器上一样,从而模拟了 Local 模式的行为。当使用
+ # On-Hadoop 模式进行部署时,这个目录不会被使用。
+ containerPath: /data
+# - role: worker # 打开注释可以添加2个 KinD 节点。添加 KinD 节点会增加加载 Docker 镜像到 KinD
+# # 集群的时间,所以默认不打开。
+# extraMounts:
+# - hostPath: ${KIND_CLUSTER_HOST_PATH}
+# containerPath: /data
+# - role: worker
+# extraMounts:
+# - hostPath: ${KIND_CLUSTER_HOST_PATH}
+# containerPath: /data
+
+```
+
+## 使用 Linkis 容器化组件开发调试
+
+下面介绍使用 Linkis 容器化组件开发调试的步骤(目前仅支持 Linux 和 MacOS)。在进行本步骤前请确认如下事项:
+1. 开发机上是否已经安装了 Docker 引擎
+2. 开发机上是否已经安装了 Helm
+3. 开发机上是否已经安装了 KinD
+4. 是否已经按照 [Linkis Docker 镜像打包](https://linkis.apache.org/zh-CN/docs/latest/development/linkis_docker_build_instrument) 所述的方式制作了 Linkis 镜像
+
+### 创建调试环境
+
+本步骤会创建一个 KinD 集群,并在其上部署 MySQL、 Linkis 和 LDH 实例。
+
+``` shell
+$> cd linkis-dist/helm
+$> sh ./scripts/create-kind-cluster.sh \
+> && sh ./scripts/install-mysql.sh \
+> && sh ./scripts/install-ldh.sh \
+> && sh ./scripts/install-charts-with-ldh.sh
+
+# Creating KinD cluster ...
+- kind cluster config: /var/folders/9d/bb6ggdm177j25q40yf5d50dm0000gn/T/kind-XXXXX.Fc2dFJbG/kind-cluster.yaml
+...
+kind: Cluster
+apiVersion: kind.x-k8s.io/v1alpha4
+nodes:
+ - role: control-plane
+ extraMounts:
+ - hostPath: /var/folders/9d/bb6ggdm177j25q40yf5d50dm0000gn/T/kind-XXXXX.Fc2dFJbG/data
+ containerPath: /data
+...
+Creating cluster "test-helm" ...
+ ✓ Ensuring node image (kindest/node:v1.21.1) 🖼
+ ✓ Preparing nodes 📦
+ ✓ Writing configuration 📜
+ ✓ Starting control-plane 🕹️
+ ✓ Installing CNI 🔌
+ ✓ Installing StorageClass 💾
+Set kubectl context to "kind-test-helm"
+You can now use your cluster with:
+
+kubectl cluster-info --context kind-test-helm
+
+Have a nice day! 👋
+# Loading MySQL image ...
+Image: "mysql:5.7" with ID "sha256:3147495b3a5ce957dee2319099a8808c1418e0b0a2c82c9b2396c5fb4b688509" not yet present on node "test-helm-control-plane", loading...
+# Deploying MySQL ...
+namespace/mysql created
+service/mysql created
+deployment.apps/mysql created
+# LDH version: dev
+# Loading LDH image ...
+Image: "linkis-ldh:dev" with ID "sha256:aa3bde0a31bf704413fb75673fc2894b03a0840473d8fe15e2d7f7dd22f1f854" not yet present on node "test-helm-control-plane", loading...
+# Deploying LDH ...
+namespace/ldh created
+configmap/flink-conf created
+configmap/hadoop-conf created
+configmap/hive-conf created
+configmap/spark-conf created
+configmap/zookeeper-conf created
+service/ldh created
+deployment.apps/ldh created
+# Loading Linkis image ...
+Image: "linkis:dev" with ID "sha256:0dfa7882c4216305a80cf57efa8cfb483d006bae5ba931288ffb8025e1db4e58" not yet present on node "test-helm-control-plane", loading...
+Image: "linkis-web:dev" with ID "sha256:1dbe0e9319761dbe0e93197665d38077cb2432b8b755dee834928694875c8a22" not yet present on node "test-helm-control-plane", loading...
+# Installing linkis, image tag=dev,local mode=false ...
+NAME: linkis-demo
+NAMESPACE: linkis
+STATUS: deployed
+REVISION: 1
+TEST SUITE: None
+NOTES:
+...
+
+---
+Welcome to Apache Linkis (v1.3.0)!
+
+.___ .___ .______ .____/\ .___ .________
+| | : __|: \ : / \: __|| ___/
+| | | : || ||. ___/| : ||___ \
+| |/\ | || | || \ | || /
+| / \| ||___| || \| ||__:___/
+|______/|___| |___||___\ /|___| : v1.3.0
+ \/
+
+Linkis builds a layer of computation middleware between upper applications and underlying engines.
+Please visit https://linkis.apache.org/ for details.
+
+Enjoy!
+configmap/flink-conf created
+configmap/hadoop-conf created
+configmap/hive-conf created
+configmap/spark-conf created
+configmap/zookeeper-conf created
+
+$> kubectl get pods -n ldh -o wide
+NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
+ldh-6648554447-ml2bn 1/1 Running 0 6m25s 10.244.0.6 test-helm-control-plane
+
+$> kubectl get pods -n linkis -o wide
+NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
+init-db-bcp85 0/1 Completed 0 4m52s 10.244.0.14 test-helm-control-plane
+linkis-demo-cg-engineconnmanager-659bf85689-ddvhw 1/1 Running 1 4m52s 10.244.0.7 test-helm-control-plane
+linkis-demo-cg-engineplugin-98bd6945-tsgjl 1/1 Running 1 4m52s 10.244.0.10 test-helm-control-plane
+linkis-demo-cg-entrance-858f74c868-xrd82 1/1 Running 0 4m52s 10.244.0.12 test-helm-control-plane
+linkis-demo-cg-linkismanager-6f96f69b8b-ns6st 1/1 Running 0 4m52s 10.244.0.11 test-helm-control-plane
+linkis-demo-mg-eureka-0 1/1 Running 0 4m52s 10.244.0.13 test-helm-control-plane
+linkis-demo-mg-gateway-68ddb8c547-xgvhn 1/1 Running 0 4m52s 10.244.0.15 test-helm-control-plane
+linkis-demo-ps-publicservice-6bbf99fcd7-sc922 1/1 Running 0 4m52s 10.244.0.8 test-helm-control-plane
+linkis-demo-web-554bd7659f-nmdjl 1/1 Running 0 4m52s 10.244.0.9 test-helm-control-plane
+
+```
+
+### 调试组件
+
+#### 打开端口转发
+
+每个组件在容器内的 JVM 远程调试端口均为 5005, 这些端口会被映射到宿主机上的不同端口,具体如下:
+* mg-eureka: 5001
+* mg-gateway: 5002
+* ps-publicservice: 5004
+* cg-linkismanager: 5007
+* cg-entrance: 5008
+* cg-engineconnmanager: 5009
+* cg-engineplugin: 5010
+
+另外,Web Console 会被映射到宿主机上的 8087 端口,可以在浏览器上输入`http://localhost:8087`进行访问.
+
+``` shell
+$> ./scripts/remote-debug-proxy.sh start
+- starting port-forwad for [web] with mapping [local->8087:8087->pod] ...
+- starting port-forwad for [mg-eureka] with mapping [local->5001:5005->pod] ...
+- starting port-forwad for [mg-gateway] with mapping [local->5002:5005->pod] ...
+- starting port-forwad for [ps-publicservice] with mapping [local->5004:5005->pod] ...
+- starting port-forwad for [cg-linkismanager] with mapping [local->5007:5005->pod] ...
+- starting port-forwad for [cg-entrance] with mapping [local->5008:5005->pod] ...
+- starting port-forwad for [cg-engineconnmanager] with mapping [local->5009:5005->pod] ...
+- starting port-forwad for [cg-engineplugin] with mapping [local->5010:5005->pod] ..
+
+$> ./scripts/remote-debug-proxy.sh list
+user 10972 0.0 0.1 5052548 31244 s001 S 12:57AM 0:00.10 kubectl port-forward -n linkis pod/linkis-demo-cg-engineplugin-98bd6945-tsgjl 5010:5005 --address=0.0.0.0
+user 10970 0.0 0.1 5053060 30988 s001 S 12:57AM 0:00.12 kubectl port-forward -n linkis pod/linkis-demo-cg-engineconnmanager-659bf85689-ddvhw 5009:5005 --address=0.0.0.0
+user 10968 0.0 0.1 5054084 30428 s001 S 12:57AM 0:00.10 kubectl port-forward -n linkis pod/linkis-demo-cg-entrance-858f74c868-xrd82 5008:5005 --address=0.0.0.0
+user 10966 0.0 0.1 5053316 30620 s001 S 12:57AM 0:00.11 kubectl port-forward -n linkis pod/linkis-demo-cg-linkismanager-6f96f69b8b-ns6st 5007:5005 --address=0.0.0.0
+user 10964 0.0 0.1 5064092 31152 s001 S 12:57AM 0:00.10 kubectl port-forward -n linkis pod/linkis-demo-ps-publicservice-6bbf99fcd7-sc922 5004:5005 --address=0.0.0.0
+user 10962 0.0 0.1 5051012 31244 s001 S 12:57AM 0:00.12 kubectl port-forward -n linkis pod/linkis-demo-mg-gateway-68ddb8c547-xgvhn 5002:5005 --address=0.0.0.0
+user 10960 0.0 0.1 5053060 31312 s001 S 12:57AM 0:00.13 kubectl port-forward -n linkis pod/linkis-demo-mg-eureka-0 5001:5005 --address=0.0.0.0
+
+...
+
+# 在调试完成后,可以使用如下命令停止端口转发
+$> ./scripts/remote-debug-proxy.sh stop
+- stopping port-forward for [web] with mapping [local->8087:8087->pod] ...
+- stopping port-forward for [mg-eureka] with mapping [local->5001:5005->pod] ...
+- stopping port-forward for [mg-gateway] with mapping [local->5002:5005->pod] ...
+- stopping port-forward for [ps-publicservice] with mapping [local->5004:5005->pod] ...
+- stopping port-forward for [cg-linkismanager] with mapping [local->5007:5005->pod] ...
+- stopping port-forward for [cg-entrance] with mapping [local->5008:5005->pod] ...
+- stopping port-forward for [cg-engineconnmanager] with mapping [local->5009:5005->pod] ...
+- stopping port-forward for [cg-engineplugin] with mapping [local->5010:5005->pod] ...
+```
+
+#### 配置 IDE 进行远程调试
+
+在 IDE 上进行如下配置,开启远程调试:
+
+![](/Images/development/kube-jvm-remote-debug.png)
+
+开启远程调试
+![](/Images/development/kube-jvm-remote-debug-start.png)
+
+设置断点,提交一个作业,进行调试
+
+``` shell
+$> ./scripts/login-pod.sh mg-gateway
+
+- login [mg-gateway]'s bash ...
+bash-4.2$ ./bin/./linkis-cli -engineType shell-1 -codeType shell -code "echo \"hello\" " -submitUser hadoop -proxyUser hadoop
+=====Java Start Command=====
+exec /etc/alternatives/jre/bin/java -server -Xms32m -Xmx2048m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/linkis/logs/linkis-cli -XX:ErrorFile=/opt/linkis/logs/linkis-cli/ps_err_pid%p.log -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFraction=80 -XX:+DisableExplicitGC -classpath /opt/linkis/conf/linkis-cli:/opt/linkis/lib/linkis-computation-governance/linkis-client/linkis-cli/*:/opt/linkis/lib/linkis-commons/public-module/*: -Dconf.root=/etc/linkis-conf -Dconf.file=linkis-cli.properties -Dlog.path=/opt/linkis/logs/linkis-cli -Dlog.file=linkis-client..log.20220925171540947077800 org.apache.linkis.cli.application.LinkisClientApplication '-engineType shell-1 -codeType shell -code echo "hello" -submitUser hadoop -proxyUser hadoop'
+...
+```
+![](/Images/development/kube-jvm-remote-debug-breakpoint.png)
+
+
+### 清理环境
+
+调试完成后,可以使用如下命令清理整个环境:
+
+``` shell
+$> kind delete clusters test-helm
+Deleted clusters: ["test-helm"]
+```
+
+### 其他常用操作
+
+#### 查看组件日志
+
+``` bash
+$> kubectl logs -n linkis linkis-demo-cg-engineconnmanager-659bf85689-ddvhw -f
+
++ RUN_IN_FOREGROUND=true
++ /opt/linkis/sbin/linkis-daemon.sh start cg-engineconnmanager
+Start to check whether the cg-engineconnmanager is running
+Start server, startup script: /opt/linkis/sbin/ext/linkis-cg-engineconnmanager
+=====Java Start Command=====
+java -DserviceName=linkis-cg-engineconnmanager -Xmx512M -XX:+UseG1GC -Xloggc:/var/logs/linkis/linkis-cg-engineconnmanager-gc.log -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -cp /etc/linkis-conf:/opt/linkis/lib/linkis-commons/public-module/*:/opt/linkis/lib/linkis-computation-governance/linkis-cg-engineconnmanager/* org.apache.linkis.ecm.server.LinkisECMApplication --eureka.instance.prefer-ip-address=true --eureka.instance.instance-id=${spring.cloud.client.ip-address}:${spring.application.name}:${server.port} 2>&1
+OpenJDK 64-Bit Server VM warning: If the number of processors is expected to increase from one, then you should configure the number of parallel GC threads appropriately using -XX:ParallelGCThreads=N
+Listening for transport dt_socket at address: 5005
+16:32:41.101 [main] INFO org.apache.linkis.common.conf.BDPConfiguration$ - ******************* Notice: The Linkis configuration file is linkis.properties ! *******************
+16:32:41.130 [main] INFO org.apache.linkis.common.conf.BDPConfiguration$ - *********************** Notice: The Linkis serverConf file is linkis-cg-engineconnmanager.properties ! ******************
+16:32:41.222 [main] INFO org.apache.linkis.LinkisBaseServerApp - Ready to start linkis-cg-engineconnmanager with args: --eureka.instance.prefer-ip-address=true
+--eureka.instance.instance-id=${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}
+...
+```
+
+#### 进入组件 Pod 内
+使用`./scripts/login-pod.sh <组件名>`可以进入组件的 Pod 打开一个 Bash 实例进行交互式操作,其中组件名可以为:
+* cg-engineconnmanager
+* cg-engineplugin
+* cg-entrance
+* cg-linkismanager
+* mg-eureka
+* mg-gateway
+* ps-publicservice
+* web
+
+``` bash
+$> ./scripts/login-pod.sh cg-engineconnmanager
+- login [cg-engineconnmanager]'s bash ...
+bash-4.2$ pwd
+/opt/linkis
+bash-4.2$ env |grep LINKIS
+LINKIS_DEMO_PS_PUBLICSERVICE_SERVICE_HOST=127.0.0.1
+LINKIS_DEMO_CG_LINKISMANAGER_PORT_9101_TCP_PROTO=tcp
+LINKIS_DEMO_WEB_PORT_8087_TCP_PORT=8087
+...
+LINKIS_CLIENT_CONF_DIR=/etc/linkis-conf
+bash-4.2$ ps aux |grep linkis
+hadoop 1 0.0 0.0 11708 2664 ? Ss 16:32 0:00 /bin/bash /opt/linkis/sbin/linkis-daemon.sh start cg-engineconnmanager
+hadoop 10 0.0 0.0 11708 2624 ? S 16:32 0:00 sh /opt/linkis/sbin/ext/linkis-cg-engineconnmanager
+hadoop 11 0.0 0.0 11712 2536 ? S 16:32 0:00 sh /opt/linkis/sbin/ext/linkis-common-start
+hadoop 12 4.0 3.2 4146404 400084 ? Sl 16:32 0:35 java -DserviceName=linkis-cg-engineconnmanager -Xmx512M -XX:+UseG1GC -Xloggc:/var/logs/linkis/linkis-cg-engineconnmanager-gc.log -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -cp /etc/linkis-conf:/opt/linkis/lib/linkis-commons/public-module/*:/opt/linkis/lib/linkis-computation-governance/linkis-cg-engineconnmanager/* org.apache.linkis.ecm.server.LinkisECMApplication --eureka.instance.prefer-ip-address=true --eureka.instance.instance-id=${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}
+bash-4.2$ exit
+exit
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/debug.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/debug.md
new file mode 100644
index 00000000000..63a527a3c6f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/debug.md
@@ -0,0 +1,481 @@
+---
+title: 调试 Debug 指引
+sidebar_position: 6.0
+---
+
+> 导语:本文详细记录了如何在IDEA中配置和启动Linkis的各个微服务,并实现JDBC、Python、Shell等脚本的提交和执行。在Mac OS上,Linkis的各个微服务都支持本地调试。
+> 但在Windows OS上,linkis-cg-engineconnmanager服务暂不支持在本地进行调试,可参考下文第4小节的远程调试文档进行调试。
+
+linkis 1.0.3版本前,还未进入apache孵化,组织还是归属webank,主类的包名为`com.webank.wedatasphere.linkis`,调试时,注意区分。
+
+## 1. 代码调试环境
+
+- jdk1.8
+- maven3.5+
+
+## 2. 准备代码并编译
+
+```shell
+git clone git@github.com:apache/linkis.git
+cd linkis
+git checkout dev-1.2.0
+```
+
+克隆Linkis的源码到本地,并用IDEA打开,首次打开项目会从maven仓库中下载Linkis项目编译所需的依赖jar包。当依赖jar包加载完毕之后,运行如下编译打包命令。
+
+```shell
+##如果对应版本已经发布,则可以跳过该步骤。发布的版本相关依赖已经deploy到maven中央仓库
+mvn -N install
+mvn clean install -DskipTests
+```
+
+编译命令运行成功之后,在目录linkis/linkis-dist/target/下可找到编译好的安装包:apache-linkis-版本号-bin.tar.gz
+
+## 3. 配置并启动服务
+
+### 3.1 add mysql-connector-java到classpath中
+
+服务启动过程中如果遇到mysql驱动类找不到的情况,可以把mysql-connector-java-版本号.jar添加到对应服务模块的classpath下。
+
+目前依赖mysql的服务有和对应的pom.xml路径如下:
+
+- linkis-mg-gateway:linkis-spring-cloud-services/linkis-service-gateway/linkis-gateway-server-support/pom.xml
+- linkis-ps-publicservice:linkis-public-enhancements/pom.xml
+- linkis-cg-linkismanage:linkis-computation-governance/linkis-manager/linkis-application-manager/pom.xml
+- linkis-cg-engineplugin: linkis-computation-governance/linkis-engineconn/linkis-engineconn-plugin-server/pom.xml
+
+增加到依赖的方式如下,修改对应服务的pom.xml文件讲mysql依赖加入进去,
+```xml
+
+ mysql
+ mysql-connector-java
+ ${mysql.connector.version}
+
+```
+同时需要留意 根pom.xml的``中是否将mysql-connector-java依赖的scope设置为test,如是,本地调试时需要注释掉
+
+### 3.2 调整log4j2.xml配置
+
+在Linkis源码文件夹下,子目录linkis-dist/package/conf中,是Linkis的一些默认配置文件,首先对log4j2.xml文件进行编辑,在其中增加日志输出到控制台的配置。
+
+![log4j2.xml](/Images/development/debug/log4j.png)
+
+这里只贴出来需要新增的配置内容。
+
+```xml
+
+
+
+
+
+
+
+
+
+
+
+
+
+```
+__注意:__ linkis.properties需要修改对应的jdbc的参数
+
+### 3.3 启动eureka服务
+
+Linkis的服务依赖Eureka作为注册中心,所以我们需要首先启动Eureka服务,Eureka服务可以在本地启动,也可以使用远程启动的服务。保证各个服务都能访问到Eureka的IP和端口之后,就可以开始着手启动其他微服务了。
+
+在Linkis内部是通过-DserviceName参数设置应用名以及使用配置文件,所以-DserviceName是必须要指定的VM启动参数。
+
+可以通过 “-Xbootclasspath/a:配置文件路径”命令,将配置文件追加到引导程序类的路径末尾,即将依赖的配置文件加到classpath中。
+
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+
+![eureka](/Images/development/debug/eureka.png)
+
+参数解释:
+
+```shell
+[service name]
+linkis-mg-eureka
+
+[Use classpath of module]
+linkis-eureka
+
+[Main Class]
+org.apache.linkis.eureka.SpringCloudEurekaApplication
+
+[VM Opitons]
+-DserviceName=linkis-mg-eureka -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf
+
+[Program arguments]
+--spring.profiles.active=eureka --eureka.instance.preferIpAddress=true
+```
+
+注意调试配置中涉及到的本地路径,需要要修改成自己设置的路径;
+在Windows中路径书写规则是:D:\{YourPathPrefix}\linkis\linkis-dist\package\conf
+(针对以下微服务同样适用)
+
+如果不想默认的20303端口可以修改端口配置:
+
+```shell
+文件路径:conf/application-eureka.yml
+修改端口:
+server:
+ port: 8080 ##启动的端口
+```
+
+上述设置完成之后,直接运行此Application,成功启动后可以通过http://localhost:20303/ 查看eureka服务列表。
+
+![eureka-web](/Images/development/debug/eureka-web.png)
+
+### 3.4 启动linkis-mg-gateway
+
+linkis-mg-gateway是Linkis的服务网关,所有的请求都会经由gateway来转发到对应的服务上。
+启动服务器前,首先需要编辑conf/linkis-mg-gateway.properties配置文件,增加管理员用户名和密码,用户名需要与你当前登录的mac用户名保持一致。
+
+```properties
+wds.linkis.admin.user=leojie
+wds.linkis.admin.password=123456
+```
+
+设置 linkis-mg-gateway的启动Application
+
+![gateway-app](/Images/development/debug/gateway.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-mg-gateway
+
+[Use classpath of module]
+linkis-gateway-server-support
+
+[VM Opitons]
+-DserviceName=linkis-mg-gateway -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf
+
+[main Class]
+org.apache.linkis.gateway.springcloud.LinkisGatewayApplication
+```
+
+上述设置完成之后,可直接运行此Application。
+
+### 3.5 启动linkis-ps-publicservice
+
+publicservice是Linkis的公共增强服务,为其他微服务模块提供统一配置管理、上下文服务、物料库、数据源管理、微服务管理和历史任务查询等功能的模块。
+
+设置linkis-ps-publicservice的启动Application
+
+![publicservice-app](/Images/development/debug/publicservice.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-ps-publicservice
+
+[Module Name]
+linkis-public-enhancements
+
+[VM Opitons]
+-DserviceName=linkis-ps-publicservice -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf
+
+[main Class]
+org.apache.linkis.filesystem.LinkisPublicServiceApp
+
+[Add provided scope to classpath]
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+```
+
+直接启动publicservice时,可能会遇到如下报错:
+
+![publicservice-debug-error](/Images/development/debug/publicservice-debug-error.png)
+
+需要把公共依赖的模块加到linkis-public-enhancements模块的classpath下,修改pes的pom增加以下依赖:
+linkis-public-enhancements/pom.xml
+```xml
+
+ org.apache.linkis
+ linkis-dist
+ ${project.version}
+
+
+
+ mysql
+ mysql-connector-java
+ ${mysql.connector.version}
+
+
+```
+
+做完上述配置后重新启动publicservice的Application
+
+### 3.6 启动linkis-cg-linkismanager
+
+![cg-linkismanager-APP](/Images/development/debug/cg-linkismanager-APP.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-cg-linkismanager
+
+[Use classpath of module]
+linkis-application-manager
+
+[VM Opitons]
+-DserviceName=linkis-cg-linkismanager -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf
+
+[main Class]
+org.apache.linkis.manager.am.LinkisManagerApplication
+
+[Add provided scope to classpath]
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+```
+
+### 3.7 启动linkis-cg-entrance
+
+![cg-entrance-APP](/Images/development/debug/cg-entrance-APP.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-cg-entrance
+
+[Use classpath of module]
+linkis-entrance
+
+[VM Opitons]
+-DserviceName=linkis-cg-entrance -Xbootclasspath/a:D:\yourDir\linkis\linkis-dist\package\conf
+
+[main Class]
+org.apache.linkis.entrance.LinkisEntranceApplication
+
+[Add provided scope to classpath]
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+```
+
+### 3.8 启动linkis-cg-engineconnmanager
+
+![engineconnmanager-app](/Images/development/debug/engineconnmanager-app.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-cg-engineconnmanager
+
+[Use classpath of module]
+linkis-engineconn-manager-server
+
+[VM Opitons]
+-DserviceName=linkis-cg-engineconnmanager -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf -DJAVA_HOME=/Library/Java/JavaVirtualMachines/zulu-8.jdk/Contents/Home/
+
+[main Class]
+org.apache.linkis.ecm.server.LinkisECMApplication
+
+[Add provided scope to classpath]
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+```
+
+-DJAVA_HOME是为了指定ecm启动引擎时所使用的java命令所在的路径,如果你默认JAVA环境变量中的版本满足需要,此配置可以不加
+
+针对linkis-cg-engineconnmanager模块调试暂只支持Mac OS 和 Linux系统
+
+
+
+
+### 3.9 关键配置修改
+
+以上操作只是完成了对Linkis各个微服务启动Application的配置,除此之外,Linkis服务启动时所加载的配置文件中,有些关键配置也需要做针对性地修改,否则启动服务或脚本执行的过程中会遇到一些报错。关键配置的修改归纳如下:
+
+#### 3.9.1 conf/linkis.properties
+
+```properties
+# linkis底层数据库连接参数配置
+wds.linkis.server.mybatis.datasource.url=jdbc:mysql://yourip:3306/linkis?characterEncoding=UTF-8
+wds.linkis.server.mybatis.datasource.username=your username
+wds.linkis.server.mybatis.datasource.password=your password
+
+# 设置bml物料存储路径不为hdfs
+wds.linkis.bml.is.hdfs=false
+wds.linkis.bml.local.prefix=/Users/leojie/software/linkis/data/bml
+
+wds.linkis.home=/Users/leojie/software/linkis
+
+# 设置管理员用户名,你的本机用户名
+wds.linkis.governance.station.admin=leojie
+
+# 设置ip地址优先
+linkis.discovery.prefer-ip-address=true
+
+# 设置ec调试启用
+wds.linkis.engineconn.debug.enable=true
+```
+
+在配置linkis底层数据库连接参数之前,请创建linkis数据库,并运行linkis-dist/package/db/linkis_ddl.sql和linkis-dist/package/db/linkis_dml.sql来初始化所有表和数据。
+
+其中wds.linkis.home={YourPathPrefix}/linkis的目录结构如下,里面只放置了lib目录和conf目录。引擎进程启动时会把wds.linkis.home中的conf和lib路径,加到classpath下,如果wds.linkis.home不指定,可能会遇到目录找不到的异常。
+
+![linkis-home](/Images/development/debug/linkis-home.png)
+
+#### 3.9.2 conf/linkis-cg-entrance.properties
+
+```properties
+# entrance服务执行任务的日志目录
+wds.linkis.entrance.config.log.path=file:///{YourPathPrefix}/linkis/data/entranceConfigLog
+
+# 结果集保存目录,本机用户需要读写权限
+wds.linkis.resultSet.store.path=file:///{YourPathPrefix}/linkis/data/resultSetDir
+```
+
+#### 3.9.3 conf/linkis-cg-engineconnmanager.properties
+
+```properties
+wds.linkis.engineconn.root.dir={YourPathPrefix}/linkis/data/engineconnRootDir
+```
+
+不修改可能会遇到路径不存在异常。
+
+#### 3.9.4 conf/linkis-cg-engineplugin.properties
+
+```properties
+wds.linkis.engineconn.home={YourPathPrefix}/linkis/linkis-engineconn-plugins/shell/target/out
+
+wds.linkis.engineconn.plugin.loader.store.path={YourPathPrefix}/linkis/linkis-engineconn-plugins/shell/target/out
+```
+
+这里两个配置主要为了指定引擎存储的根目录,指定为target/out的主要目的是,引擎相关代码或配置改动后可以直接重启engineplugin服务后生效。
+
+### 3.10 为当前用户设置sudo免密
+
+引擎拉起时需要使用sudo来执行启动引擎进程的shell命令,mac上当前用户使用sudo时一般都需要输入密码,因此,需要为当前用户设置sudo免密,设置方法如下:
+
+```shell
+sudo chmod u-w /etc/sudoers
+sudo visudo
+将#%admin ALL=(ALL) AL替换为 %admin ALL=(ALL) NOPASSWD: ALL
+保存文件退出
+```
+
+### 3.11 服务测试
+
+保证上述服务都是成功启动状态,然后在postman中测试提交运行shell脚本作业。
+
+首先访问登录接口来生成Cookie:
+
+![login](/Images/development/debug/login.png)
+
+然后提交执行shell代码
+
+POST: http://127.0.0.1:9001/api/rest_j/v1/entrance/submit
+
+body参数:
+
+```json
+{
+ "executionContent": {
+ "code": "echo 'hello'",
+ "runType": "shell"
+ },
+ "params": {
+ "variable": {
+ "testvar": "hello"
+ },
+ "configuration": {
+ "runtime": {},
+ "startup": {}
+ }
+ },
+ "source": {
+ "scriptPath": "file:///tmp/hadoop/test.sql"
+ },
+ "labels": {
+ "engineType": "shell-1",
+ "userCreator": "leojie-IDE"
+ }
+}
+```
+
+执行结果:
+
+```json
+{
+ "method": "/api/entrance/submit",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "taskID": 1,
+ "execID": "exec_id018017linkis-cg-entrance127.0.0.1:9104IDE_leojie_shell_0"
+ }
+}
+```
+
+最后检查任务运行状态和获取运行结果集:
+
+GET http://127.0.0.1:9001/api/rest_j/v1/entrance/exec_id018017linkis-cg-entrance127.0.0.1:9104IDE_leojie_shell_0/progress
+
+```json
+{
+ "method": "/api/entrance/exec_id018017linkis-cg-entrance127.0.0.1:9104IDE_leojie_shell_0/progress",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "progress": 1,
+ "progressInfo": [],
+ "execID": "exec_id018017linkis-cg-entrance127.0.0.1:9104IDE_leojie_shell_0"
+ }
+}
+```
+
+GET http://127.0.0.1:9001/api/rest_j/v1/jobhistory/1/get
+
+GET http://127.0.0.1:9001/api/rest_j/v1/filesystem/openFile?path=file:///Users/leojie/software/linkis/data/resultSetDir/leojie/linkis/2022-07-16/214859/IDE/1/1_0.dolphin
+
+```json
+{
+ "method": "/api/filesystem/openFile",
+ "status": 0,
+ "message": "OK",
+ "data": {
+ "metadata": "NULL",
+ "totalPage": 0,
+ "totalLine": 1,
+ "page": 1,
+ "type": "1",
+ "fileContent": [
+ [
+ "hello"
+ ]
+ ]
+ }
+}
+```
+
+## 4. 远程调试服务指引
+
+根据需要调试的代码位置,确定其所属的服务,使用启动脚本`linkis-daemon.sh`,启动时针对该服务设置远程调试端口。
+
+### 4.1 确认要调试的包所在的服务
+
+根据需要调试的代码位置,确定其所属的服务(如果不确定服务名称,在 ${LINKIS_HOME}/sbin/linkis-start-all.sh 内查询)
+
+### 4.2 重启需要调试的服务
+
+进入{LINKIS_HOME}/sbin目录,在启动命令中添加debug参数,指定远程调试端口。
+
+```shell
+sh linkis-daemon.sh restart ps-publicservice debug-5005
+```
+观察输出的启动命令,是否包含`-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005`,包含则说明添加远程调试端口成功。
+
+### 4.3 编译器配置远程调试
+
+如下图所示打开窗口并配置远程调试的端口,服务,以及模块
+![c-debug](images/c-debug.png)
+
+### 4.4 开始调试
+
+点击调试按钮,出现如下信息代表可以开始调试
+![debug](images/debug.png)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/_category_.json
new file mode 100644
index 00000000000..b78c0cb3dae
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "开发规范",
+ "position": 12
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/api.md
new file mode 100644
index 00000000000..dcb2ddd9876
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/api.md
@@ -0,0 +1,77 @@
+---
+title: 接口规范
+sidebar_position: 4
+---
+
+> Contributor为Linkis贡献新的Restful接口时,需遵循如下接口规范进行接口开发。
+
+## 1. HTTP or WebSocket ?
+
+Linkis目前提供了两种接口方式:HTTP和WebSocket。
+
+WebSocket相比于HTTP的优势:
+
+- 对服务器产生的压力更小
+- 信息推送更加及时
+- 交互性更加友好
+
+相应的,WebSocket也有如下的劣势:
+
+- WebSocket在使用时可能出现断开连接的情况
+- 对前端的技术要求更高
+- 一般要求前端有降级处理机制
+
+**如非必要,我们通常强烈建议Contributor尽量少用WebSocket的方式提供接口;**
+
+**如您觉得使用WebSocket很有必要,且愿意将开发的功能贡献给Linkis,建议您在开发前与我们取得沟通,多谢!**
+
+## 2. URL规范
+
+```
+/api/rest_j/v1/{applicationName}/.+
+/api/rest_s/v1/{applicationName}/.+
+```
+
+**约定**:
+
+ - rest_j表示接口符合Jersey规范
+ - rest_s表示接口符合springMVC Rest规范
+ - v1为服务的版本号,**版本号会随着Linkis版本进行升级**
+ - {applicationName}为微服务名
+
+## 3. 接口请求格式
+
+```json
+{
+ "method":"/api/rest_j/v1/entrance/execute",
+ "data":{},
+ "websocketTag":"37fcbd8b762d465a0c870684a0261c6e" // WebSocket请求的必需参数,HTTP请求可忽略
+}
+```
+
+**约定**:
+
+ - method:请求的Restful API URL。
+ - data:请求的具体数据。
+ - websocketTag:某一次WebSocket请求的唯一标识,后台也会带回该参数用于给前端进行识别。
+
+## 4. 接口返回格式
+
+```json
+{"method":"/api/rest_j/v1/project/create","status":0, "message":"创建成功!","data":{}}
+```
+
+**约定**:
+
+ - method:返回请求的Restful API URL,主要是websocket模式需要使用。
+ - status:返回状态信息,其中:-1表示没有登录,0表示成功,1表示错误,2表示验证失败,3表示没该接口的访问权限。
+ - data:返回具体的数据。
+ - message:返回请求的提示信息。如果status非0时,message返回的是错误信息,其中data有可能存在stack字段,返回具体的堆栈信息。
+
+另:根据status的不同,HTTP请求的状态码也不一样,一般情况下:
+
+ - 当status为0时,HTTP的状态码为200
+ - 当status为-1时,HTTP的状态码为401
+ - 当status为1时,HTTP的状态码为400
+ - 当status为2时,HTTP的状态码为412
+ - 当status为3时,HTTP的状态码为403
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/commit-message.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/commit-message.md
new file mode 100644
index 00000000000..b03e914fcd6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/commit-message.md
@@ -0,0 +1,95 @@
+---
+title: Commit Message 须知
+sidebar_position: 2
+---
+> 本文引用自 https://dolphinscheduler.apache.org/zh-cn/docs/dev/user_doc/contribute/join/commit-message.html
+
+### 1.前言
+ 一个好的 commit message 是能够帮助其他的开发者(或者未来的开发者)快速理解相关变更的上下文,同时也可以帮助项目管理人员确定该提交是否适合包含在发行版中。但当我们在查看了很多开源项目的 commit log 后,发现一个有趣的问题,一部分开发者,代码质量很不错,但是 commit message 记录却比较混乱,当其他贡献者或者学习者在查看代码的时候,并不能通过 commit log 很直观的了解
+该提交前后变更的目的,正如 Peter Hutterer 所言:Re-establishing the context of a piece of code is wasteful. We can’t avoid it completely, so our efforts should go to reducing it as much as possible. Commit messages can do exactly that and as a result, a commit message shows whether a developer is a good collaborator. 因此,DolphinScheduler 结合其他社区以及 Apache 官方文档制定了该规约。
+
+### 2.Commit Message RIP
+
+#### 2.1 明确修改内容
+
+commit message 应该明确说明该提交解决了哪些问题(bug 修复、功能增强等),以便于用户开发者更好的跟踪问题,明确版本迭代过程中的优化情况。
+
+#### 2.2 关联相应的Pull Request 或者Issue
+
+当我们的改动较大的时候,commit message 最好能够关联 GitHub 上的相关 Issue 或者 Pull Request,这样,我们的开发者在查阅代码的时候能够通过关联信息较为迅速的了解改代码提交的上下文情景,如果当前 commit 针对某个 issue,那么可以在 Footer 部分关闭这个 issue。
+
+#### 2.3 统一的格式
+
+格式化后的 CommitMessage 能够帮助我们提供更多的历史信息,方便快速浏览,同时也可以直接从 commit 生成 Change Log。
+
+Commit message 应该包括三个部分:Header,Body 和 Footer。其中,Header 是必需的,Body 和 Footer 可以省略。
+
+##### header
+Header 部分只有一行,包括三个字段:type(必需)、scope(可选)和 subject(必需)。
+
+[DS-ISSUE编号][type] subject
+
+(1) type 用于说明 commit 的类别,只允许使用下面7个标识。
+
+* feat:新功能(feature)
+* fix:修补bug
+* docs:文档(documentation)
+* style: 格式(不影响代码运行的变动)
+* refactor:重构(即不是新增功能,也不是修改bug的代码变动)
+* test:增加测试
+* chore:构建过程或辅助工具的变动
+
+如果 type 为 feat 和 fix,则该 commit 将肯定出现在 Change log 之中。其他情况(docs、chore、style、refactor、test)建议不放入。
+
+(2)scope
+
+scope 用于说明 commit 影响的范围,比如 server、remote 等,如果没有更合适的范围,你可以用 *。
+
+(3) subject
+
+subject 是 commit 目的的简短描述,不超过50个字符。
+
+##### Body
+
+Body 部分是对本次 commit 的详细描述,可以分成多行,换行符将以72个字符换行,避免自动换行影响美观。
+
+Body 部分需要注意以下几点:
+
+* 使用动宾结构,注意使用现在时,比如使用 change 而非 changed 或 changes
+
+* 首字母不要大写
+
+* 语句最后不需要 ‘.’ (句号) 结尾
+
+
+##### Footer
+
+Footer只适用于两种情况
+
+(1) 不兼容变动
+
+如果当前代码与上一个版本不兼容,则 Footer 部分以 BREAKING CHANGE 开头,后面是对变动的描述、以及变动理由和迁移方法。
+
+(2) 关闭 Issue
+
+如果当前 commit 针对某个issue,那么可以在 Footer 部分关闭这个 issue,也可以一次关闭多个 issue 。
+
+##### 举个例子
+[Linkis-001][docs-zh] add commit message
+
+* commit message RIP
+* build some conventions
+* help the commit messages become clean and tidy
+* help developers and release managers better track issues
+and clarify the optimization in the version iteration
+
+This closes #001
+
+### 3.参考文档
+[Dolphinscheduler Commit Message 须知](https://dolphinscheduler.apache.org/zh-cn/docs/dev/user_doc/contribute/join/commit-message.html)
+
+[提交消息格式](https://cwiki.apache.org/confluence/display/GEODE/Commit+Message+Format)
+
+[关于提交消息](http://who-t.blogspot.com/2009/12/on-commit-messages.html)
+
+[RocketMQ 社区操作约定](https://mp.weixin.qq.com/s/LKM4IXAY-7dKhTzGu5-oug)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/concurrent.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/concurrent.md
new file mode 100644
index 00000000000..09221a88a3f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/concurrent.md
@@ -0,0 +1,13 @@
+---
+title: 并发规范
+sidebar_position: 5
+---
+1. 【**强制**】获取单例对象要线程安全。在单例对象里面做操作也要保证线程安全。
+
+2. 【**强制**】线程资源必须通过线程池提供,不允许在应用中自行显式创建线程。
+
+3. SimpleDateFormat 是线程不安全的类,建议使用使用DateUtils工具类。
+
+4. 【**强制**】高并发时,同步调用应该去考量锁的性能损耗。能用无锁数据结构,就不要用锁;能锁区块,就不要锁整个方法体;能用对象锁,就不要用类锁。
+
+5. 【**强制**】ThreadLocal尽量少用,用的时候如果存入的是一个需要close的对象,记得及时close释放掉。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/exception-catch.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/exception-catch.md
new file mode 100644
index 00000000000..7409280f00f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/exception-catch.md
@@ -0,0 +1,87 @@
+---
+title: 异常规范
+sidebar_position: 3
+---
+
+## 1. 异常层次定义
+1. linkis异常继承层次:
+
+LinkisException:异常继承于Exception,存在三个静态属性,是服务在启动时进行赋值的,这三个属性主要为了在进行异常打印时,标明异常来自于哪个微服务
+```
+ static String applicationName;//Microservice AppName
+ static String hostname;//Microservice hostName
+ static int hostPort;//Microservice port
+```
+可继承异常:
+
+|异常类 | 所在服务| 错误描述|
+|:---- |:--- |:--- |
+|LinkisException| common| 顶级父类,继承自Exception,不允许直接继承|
+|LinkisRuntimeException| common| 顶级父类,继承自RuntimeException,不允许直接继承|
+|WarnException| common| 次级父类,继承自LinkisRuntimeException。提示级的异常,必须直接或间接继承该类|
+|ErrorException| common| 次级父类,继承自LinkisException。错误级的异常,必须直接或间接继承该类|
+|FatalException| common| 次级父类,继承自LinkisException。致命级的异常,必须直接或间接继承该类,出现此类异常服务需要在Catch时进行退出。如:ECM在向LM注册失败时需要退出|
+|LinkisRetryException| common| 次级父类,继承自LinkisException。重试级的异常,必须直接或间接继承该类,一般用于Linkis内部,用于捕获该异常进行请求的重试,如:引擎启动的资源不足异常|
+
+2. 模块使用异常须知:
+- 【**强制**】每个模块需要自定义对应模块的异常,自定义的异常都必须继承自LinkisRetryException、WarnException、ErrorException或FatalException之一
+- 【**强制**】自定义的异常必须包含错误码和错误描述,如有必要,也可将发生异常的ip地址和进程端口封装到异常当中
+- 【**强制**】慎用WarnException!WarnException抛出来的异常,如果在Restful和RPC的Receiver端被捕获,不会给前端或sender端抛出执行失败,而是只返回一条警告信息!
+- 【**强制**】WARNException的异常级别为1,ErrorException的异常级别为2,FatalException的异常级别为3,LinkisRetryException的异常级别为4
+
+3. 错误码需按照规范进行定义,错误码规范如下(PS:现有不规范的错误码,您可以提PR进行修复)
+```
+## 错误码定义:整个调用链路的需要有规则
+linkis-commons:10000-11000
+linkis-computattion-governace:11000-12000
+linkis-engineconn-plugins:12000-13000
+linkis-orchestrator:13000-14000
+linkis-public-enghancements:14000-15000
+linkis-spring-cloud-service:15100-15500
+linkis-extensions:15500-16000
+```
+
+## 2. 异常规范
+1. [强制] 禁止直接catch Throwable,这种代码非常危险,因为会把Error也给catch住,像OOM等异常会被直接catch,原本JVM检测到该异常会自动停止进程,但是因为我们catch住了,会导致进程实际已经无法提供服务,但是不会正常退出。
+```scala
+// 对于Scala代码建议使用Utils工具类里面提供的相关tryCatch方法
+ def tryCatch[T](tryOp: => T)(catchOp: Throwable => T): T = {
+ try tryOp catch {
+ case t: ControlThrowable => throw t
+ case fatal: FatalException =>
+ error("Fatal error, system exit...", fatal)
+ System.exit(fatal.getErrCode)
+ null.asInstanceOf[T]
+ case e: VirtualMachineError =>
+ error("Fatal error, system exit...", e)
+ System.exit(-1)
+ throw e
+ case er: Error =>
+ error("Throw error", er)
+ throw er
+ case t => catchOp(t)
+ }
+ }
+```
+2. [强制] 捕获异常后,如果需要创建新的异常,一定要将cause进行传递对新加的异常进行initCause,防止丢失根因
+```
+// 新生成的异常,需要继承cacuse
+public StorageErrorException(int errCode, String desc, Throwable t){
+ super(errCode, desc);
+ initCause(t);
+}
+```
+
+3. 【**强制**】每个小模块的异常,都应该定义一个专门的exception类,方便后续给用户生成错误码,不允许抛出任何RuntimeException和直接抛Exception。
+
+4. 【推荐】尽量不要对大段代码进行try-catch,这是不负责任的表现。catch时请分清稳定代码和非稳定代码,稳定代码指的是无论如何不会出错的代码。对于非稳定代码的catch尽可能进行区分异常类型,再做对应的异常处理。
+
+5. 【**强制**】捕获异常是为了处理它,不要捕获了却什么都不处理而抛弃之,如果不想处理它,请将该异常抛给它的调用者。注意:什么情况下,都不要用e.printStackTrace()!最外层的业务使用者,必须处理异常,将其转化为用户可以理解的内容。
+
+finally块必须对资源对象、流对象进行关闭,有异常也要做try-catch。
+
+6. 【**强制**】预防NullPointerException。方法的返回值可以为null,不强制返回空集合,或者空对象等,但是必须添加注释充分说明什么情况下会返回 null 值。RPC、SpringCloud Feign调用,一律要求进行非空判断。
+
+7. 【**强制**】不要在finally中使用Return和抛出异常
+
+8. 【**强制**】如果异常已经抛出,禁止打印异常的堆栈日志,会导致日志冗余
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/how-to-write-unit-test-code.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/how-to-write-unit-test-code.md
new file mode 100644
index 00000000000..af8faa8bd56
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/how-to-write-unit-test-code.md
@@ -0,0 +1,365 @@
+---
+title: 如何编写单元测试代码
+sidebar_position: 10
+---
+## 1.框架选型
+Junit5+Mockito+jacoco+h2本地数据库
+Idea增强插件
+- JUnitGenerator V2.0 用于生成测试用例的标准模块
+- GenerateAllSet 用于快速new创建对象,并设置默认值
+- MybatisX dao与mapper的关联映射 方便查看
+
+### 1.1 配置IDEA的Junit的模板
+```properties
+########################################################################################
+##
+## Available variables:
+## $entryList.methodList - List of method composites
+## $entryList.privateMethodList - List of private method composites
+## $entryList.fieldList - ArrayList of class scope field names
+## $entryList.className - class name
+## $entryList.packageName - package name
+## $today - Todays date in MM/dd/yyyy format
+##
+## MethodComposite variables:
+## $method.name - Method Name
+## $method.signature - Full method signature in String form
+## $method.reflectionCode - list of strings representing commented out reflection code to access method (Private Methods)
+## $method.paramNames - List of Strings representing the method's parameters' names
+## $method.paramClasses - List of Strings representing the method's parameters' classes
+##
+## You can configure the output class name using "testClass" variable below.
+## Here are some examples:
+## Test${entry.ClassName} - will produce TestSomeClass
+## ${entry.className}Test - will produce SomeClassTest
+##
+########################################################################################
+##
+## 首字母大写
+#macro (cap $strIn)$strIn.valueOf($strIn.charAt(0)).toUpperCase()$strIn.substring(1)#end
+## 首字母小写 自定义down
+#macro (down $strIn)$strIn.valueOf($strIn.charAt(0)).toLowerCase()$strIn.substring(1)#end
+## Iterate through the list and generate testcase for every entry.
+#foreach ($entry in $entryList)
+#set( $testClass="${entry.className}Test")
+##
+
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package $entry.packageName;
+
+import org.junit.jupiter.api.AfterEach;
+import org.junit.jupiter.api.BeforeEach;
+import org.junit.jupiter.api.DisplayName;
+import org.junit.jupiter.api.Test;
+import org.springframework.beans.factory.annotation.Autowired;
+
+/**
+ * ${entry.className} Tester
+*/
+public class $testClass {
+
+ @Autowired
+ private ${entry.className} #down(${entry.className});
+
+ @BeforeEach
+ @DisplayName("Each unit test method is executed once before execution")
+ public void before() throws Exception {
+ }
+
+ @AfterEach
+ @DisplayName("Each unit test method is executed once before execution")
+ public void after() throws Exception {
+ }
+
+#foreach($method in $entry.methodList)
+
+ @Test
+ @DisplayName("Method description: ...")
+ public void test#cap(${method.name})() throws Exception {
+ //TODO: Test goes here...
+ }
+
+#end
+
+#foreach($method in $entry.privateMethodList)
+
+ @Test
+ @DisplayName("Method description: ...")
+ public void test#cap(${method.name})() throws Exception {
+ //TODO: Test goes here...
+ #foreach($string in $method.reflectionCode)
+ $string
+ #end
+ }
+
+#end
+}
+#end
+
+```
+![test-0](../images/test-0.png)
+
+1.配置配置测试类生成路径
+原配置:${SOURCEPATH}/test/${PACKAGE}/${FILENAME}
+修改后配置:${SOURCEPATH}/../../test/java/${PACKAGE}/${FILENAME}
+如图:
+![test-1](../images/test-1.png)
+2.选择类——>右键——>Generate——>Junit Test,生成测试类
+![test-2](../images/test-2.png)
+
+## 2.单元测试准则
+### 2.1 目录以及命名准则
+
+- 1.单元测试代码目录
+ 必须写在如下工程目录:src/test/java,不允许写在业务代码目录下。
+ 说明:源码编译时会跳过此目录,而单元测试框架默认是扫描此目录,测试的配置文件必须放在:src/test/resources文件下
+
+- 2.测试类所在的包名应该和被测试类所在的包名保持一致
+ 示例:
+ 业务类 src/main/java/org/apache/linkis/jobhistory/dao/JobDetailMapper.java
+ 对应的测试类 src/test/java/org/apache/linkis/jobhistory/dao/JobDetailMapperTest.java
+
+- 3.测试类的命名定义规范:使用Test作为类名的后缀
+ 测试类的命名如下:
+ 被测试的业务+Test、被测试的接口+Test、被测试的类+Test
+
+- 4.测试用例的命名定义规范:使用test作为方法名的前缀
+ 测试用例的命名规则是:test+方法名。避免使用test1、test2没有含义的名称,其次需要有必要的函数方法注释。
+
+
+### 2.2 编写准则
+- 1.单元测试中不准使用 System.out 来进行人肉验证,或则if判断来验证(可以使用log进行关键日志输出),必须使用断言 assert 来验证。
+
+- 2.保持单元测试的独立性。为了保证单元测试稳定可靠且便于维护,单元测试用例之间决不能互相调用,也不能依赖执行的先后次序。
+ 反例:method2 需要依赖 method1 的执行,将执行结果作为 method2 的输入
+
+- 3.单元测试必须可以重复执行的,不能受到外界环境的影响。
+ 说明:单元测试通常会被放到持续集成中,每次有代码 check in 时单元测试都会被执行。如果单测对外部环境(网络、服务、中间件等)有依赖,容易导致持续集成机制的不可用。
+ 正例:为了不受外界环境影响,要求设计代码时就把被测类的相关依赖改成注入,在测试时用 spring 这样的依赖注入框架注入一个本地(内存)实现或者 Mock 实现。
+
+- 4.增量代码确保单元测试通过。
+ 说明:新增代码必须补充单元测试,如果新增代码影响了原有单元测试,请修正
+
+- 5.对于单元测试,要保证测试粒度足够小,有助于精确定位问题。单测粒度一般都是方法级别(工具类或则枚举类等极少场景可以是类级别)。
+ 说明:只有测试粒度小才能在出错时尽快定位到出错位置。单测不负责检查跨类或者跨系统的交互逻辑,那是集成测试的领域。
+
+
+## 3.断言的使用
+所有的测试用例的结果验证都必须使用断言模式
+优先使用Junit5的Assertions断言,极少数场景允许使用AssertJ的断言
+
+### 3.1 Junit5常规断言
+
+| 方法 | 说明 | 备注 |
+|--------|-------------|-------------|
+|assertEquals | 判断两个对象或两个原始类型是否相等| |
+|assertNotEquals| 判断两个对象或两个原始类型是否不相等| |
+|assertTrue| 判断给定的布尔值是否为 true| |
+|assertFalse| 判断给定的布尔值是否为 false | |
+|assertNull| 判断给定的对象引用是否为 null| |
+|assertNotNull| 判断给定的对象引用是否不为 null | |
+|assertAll| 将多个判断逻辑放在一起处理,只要有一个报错就会导致整体测试不通过 | |
+### 3.2 Junit5组合断言和异常断言
+**组合断言**
+assertAll方法可以将多个判断逻辑放在一起处理,只要有一个报错就会导致整体测试不通过:
+```java
+ @Test
+ @DisplayName("assert all")
+ public void all() {
+ //将多个判断放在一起执行,只有全部通过才算通过
+ assertAll("Math",
+ () -> assertEquals(2, 1 + 1),
+ () -> assertTrue(1 > 0)
+ );
+ }
+```
+**异常断言 **
+Assertions.assertThrows方法,用来测试Executable实例执行execute方法时是否抛出指定类型的异常;
+如果execute方法执行时不抛出异常,或者抛出的异常与期望类型不一致,都会导致测试失败;
+示例:
+```java
+ @Test
+ @DisplayName("异常的断言")
+ void exceptionTesting() {
+ // 其execute方法执行时,如果抛出了异常,并且异常的类型是assertThrows的第一个参数(这里是ArithmeticException.class),
+ // 返回值是异常的实例
+ Exception exception = assertThrows(ArithmeticException.class, () -> Math.floorDiv(1,0));
+ log.info("assertThrows通过后,返回的异常实例:{}", exception.getMessage());
+ }
+```
+### 3.3 断言使用准则
+**对象实例是否相等断言**
+1.是否是同一个对象实例
+ ```html
+ 使用Junitd的Assertions.assertEquals
+ Assertions.assertEquals(expectedJobDetail, actualJobDetail)
+ ```
+
+
+ 不是同一个实例,但是比较实例的属性值是否完全相等
+ AssertJ
+ ```html
+ 常用场景 数据库更新操作前/后的对象比较
+ 使用AssertJ的assertThat断言usingRecursiveComparison模式
+ Assertions.assertThat(actualObject).usingRecursiveComparison().isEqualTo(expectedObject);
+ ```
+
+
+2.list等集合结果的断言
+ 结果集集合的大小需要断言
+ 范围或则具体大size
+
+ 结果集集合中的每个对象需要断言,推荐结合stream模式的Predicate进行使用
+ 示例:
+ ```java
+ ArrayList jobRespProtocolArrayList=service.batchChange(jobDetailReqBatchUpdate);
+ //list配和stream的predicate进行断言判断
+ Predicate statusPrecate = e -> e.getStatus()==0;
+ assertEquals(2, jobRespProtocolArrayList.size());
+ assertTrue(jobRespProtocolArrayList.stream().anyMatch(statusPrecate));
+ ```
+
+## 4.Mock模拟返回数据
+
+有时我们单测一些api或者service模块,其中的service或者dao对于一些方法的返回值默认是null,但是逻辑里面有对这个返回null的对象进行判断或者二次取值的话,就是引发一些异常
+
+示例:
+
+```java
+ PageInfo pageInfo =
+ udfService.getManagerPages(udfName, udfTypes, userName, curPage, pageSize);
+ message = Message.ok();
+ // 这里的pageInfo是null,后续的get方法就会出现异常
+ message.data("infoList", pageInfo.getList());
+ message.data("totalPage", pageInfo.getPages());
+ message.data("total", pageInfo.getTotal());
+```
+
+mock模拟数据示例:
+
+```java
+ PageInfo pageInfo = new PageInfo<>();
+ pageInfo.setList(new ArrayList<>());
+ pageInfo.setPages(10);
+ pageInfo.setTotal(100);
+ // 对 udfService.getManagerPages 方法进行任意传递参数,模拟返回pageInfo对象
+ // 有了这个模拟数据,上面示例在执行get方法的时候,就不会有异常
+ Mockito.when(
+ udfService.getManagerPages(
+ Mockito.anyString(),
+ Mockito.anyCollection(),
+ Mockito.anyString(),
+ Mockito.anyInt(),
+ Mockito.anyInt()))
+ .thenReturn(pageInfo);
+```
+
+## 5.单元测试的编写
+
+### 5.1 类的划分
+
+按类的大功能可以大体分类
+- Controller 提供http服务的controller 配合mockmvc做单元测试
+- Service 业务逻辑代码的service层
+- Dao 与数据库操作的Dao层
+- util工具功能类 常用的功能工具
+- exception类 自定义的异常类
+- enum类 枚举类
+- entity类 用于DB交互以及方法处理的参数VO对象等实体类(若除了正常的get set外还有其他自定义函数的需要进行单元测试)
+
+### 5.2 Controller类的单元测试
+使用Mockmvc
+主要验证 接口请求RequestMethod方式,基本参数,以及返回结果预期。
+主要场景:带上非必要参数和不带非必要参数的场景 异常
+
+```java
+ @Test
+ public void testList() throws Exception {
+ //带上非必要参数
+ MultiValueMap paramsMap = new LinkedMultiValueMap<>();
+ paramsMap.add("startDate", String.valueOf(System.currentTimeMillis()));
+ MvcResult mvcResult = mockMvc.perform(get("/jobhistory/list")
+ .params(paramsMap))
+ .andExpect(status().isOk())
+ .andExpect(content().contentType(MediaType.APPLICATION_JSON))
+ .andReturn();
+
+ Message res = JsonUtils.jackson().readValue(mvcResult.getResponse().getContentAsString(), Message.class);
+ assertEquals(res.getStatus(), MessageStatus.SUCCESS());
+ logger.info(mvcResult.getResponse().getContentAsString());
+
+ //不带非必要参数
+ mvcResult = mockMvc.perform(get("/jobhistory/list"))
+ .andExpect(status().isOk())
+ .andExpect(content().contentType(MediaType.APPLICATION_JSON))
+ .andReturn();
+
+ res = JsonUtils.jackson().readValue(mvcResult.getResponse().getContentAsString(), Message.class);
+ assertEquals(res.getStatus(), MessageStatus.SUCCESS());
+
+ logger.info(mvcResult.getResponse().getContentAsString());
+ }
+
+```
+### 5.3 Server 类的单元测试
+ //todo
+### 5.4 Dao 类的单元测试
+使用H2数据库,配置文件中application.properties中需要配置H2数据库的基本信息,以及mybatis的相关路径信息
+
+```properties
+#h2数据库配置
+spring.datasource.driver-class-name=org.h2.Driver
+#连接数据库
+spring.datasource.url=jdbc:h2:mem:test;MODE=MySQL;DB_CLOSE_DELAY=-1;DATABASE_TO_LOWER=true
+#初始化数据库表的脚本
+spring.datasource.schema=classpath:create.sql
+#初始化数据库表中的数据的脚本
+spring.datasource.data=classpath:data.sql
+spring.datasource.username=sa
+spring.datasource.password=
+spring.datasource.hikari.connection-test-query=select 1
+spring.datasource.hikari.minimum-idle=5
+spring.datasource.hikari.auto-commit=true
+spring.datasource.hikari.validation-timeout=3000
+spring.datasource.hikari.pool-name=linkis-test
+spring.datasource.hikari.maximum-pool-size=50
+spring.datasource.hikari.connection-timeout=30000
+spring.datasource.hikari.idle-timeout=600000
+spring.datasource.hikari.leak-detection-threshold=0
+spring.datasource.hikari.initialization-fail-timeout=1
+
+#配置mybatis-plus的mapper信息 因为使用的是mybatis-plus,使用mybatis-plus浅醉
+mybatis-plus.mapper-locations=classpath:org/apache/linkis/jobhistory/dao/impl/JobDetailMapper.xml,classpath:org/apache/linkis/jobhistory/dao/impl/JobHistoryMapper.xml
+mybatis-plus.type-aliases-package=org.apache.linkis.jobhistory.entity
+mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
+```
+
+编写规范
+1. 使用@Transactional以及@Rollback 实现数据回滚,避免数据污染
+2. 每一个DaoTest应该有一个创建初始化数据公共方法(或导入数据的方式csv)来准备数据,相关的查询,更新,删除等操作都应该先调用该公共方法进行数据的准备
+3. 创建测试的数据,如果某属性值是自增id,则不应该进行赋值
+4. 创建的测试数据,应尽可能和实际样例数据保持一致
+5. 更新数据测试时,如果字段允许,请带上`modify-原始值`前缀
+
+
+
+
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/license.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/license.md
new file mode 100644
index 00000000000..8d96d44c674
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/license.md
@@ -0,0 +1,166 @@
+---
+title: License 须知
+sidebar_position: 0.1
+---
+
+>注:本文仅适用于Apache项目。
+>本文参考 Dolphinscheduler项目的License须知文档 https://dolphinscheduler.apache.org/zh-cn/community/development/DS-License.html
+
+ASF(Apache基金会)下的开源项目,对于License有着极其严苛的要求,当您为Linkis贡献代码时,就必须按照Apache的规则来,为了避免贡献者在License上浪费过多的时间,
+本文将为您讲解ASF—License以及参与 Linkis 项目开发时如何规避掉License风险。
+
+## 1.License 文件目录说明
+
+licence相关的可以划分为3部分
+- 源码级别 主要需要关注的场景是: 在项目工程源码中,直接引入第三方资源(如 直接使用了某个其他项目的代码JAVA文件,新增了文本、css、js、图片、图标、音视频等文件,以及在第三方基础上做的修改)
+- 项目的安装物料包 主要需要关注的场景是: 依赖的第三方jar包的运行态依赖,pom 配置中 通过dependency依赖引入 即最后编译打包会被打包到发布的安装包中的
+- 管理台的安装物料包 主要需要关注的场景是:前端web编译依赖的第三方npm依赖包 通过linkis-web/package.json 配置引入
+
+
+[Linkis源码](https://github.com/apache/linkis)涉及到license的目录如下
+
+```shell script
+# 最外层目录开始
+
+├── LICENSE //项目源码的LICENSE 一些没有asf header的文件或则引入外部资源需要在这里标明
+├── NOTICE //项目源码的NOTICE 一般不会变动
+├── licenses //项目源码级别引入第三方组件license 说明
+│ └── LICENSE-py4j-0.10.9.5-src.txt
+├── linkis-dist
+│ └── release-docs
+│ ├── LICENSE //编译的安装包中依赖的第三方jar包的license信息汇总
+│ ├── licenses //编译的安装包中依赖的第三方jar包对应的license信息详细
+│ │ ├── LICENSE-log4j-api.txt
+│ │ ├── LICENSE-log4j-core.txt
+│ │ ├── LICENSE-log4j-jul.txt
+│ │ ├── LICENSE-xxxx.txt
+│ └── NOTICE //编译的安装包中依赖的第三方jar包的NOTICE 汇总
+├── linkis-web
+ └── release-docs
+ ├── LICENSE //前端web编译安装包第三方npm依赖的LICENSE信息汇总
+ ├── licenses //前端web编译安装包第三方npm依赖对应的license信息详细
+ │ ├── LICENSE-vuedraggable.txt
+ │ ├── LICENSE-vue-i18n.txt
+ │ ├── LICENSE-vue.txt
+ │ ├── LICENSE-vuescroll.txt
+ │ └── LICENSE-xxxx.txt
+ └── NOTICE //前端web编译安装包第三方npm依赖的NOTICE 汇总
+
+
+```
+
+
+## 2.如何在 Linkis 合法的使用第三方开源软件
+
+当你提交的代码有如下场景时:
+
+- 场景1. 源码中有新增(或移除)使用第三方代码或则静态资源,如源码中直接使用了某个其他项目的代码文件文件,新增了文本、css、js、图片、图标、音视频等文件,以及在第三方基础上做的修改。
+- 场景2. 项目的运行态依赖有新增(或移除)(运行态依赖:即最后编译打包会被打包到发布的安装包中的)
+
+- 场景1中的引入的文件必须是[ASF第三方许可证策](https://apache.org/legal/resolved.html)的A类License
+- 场景2中的引入的依赖必须是[ASF第三方许可证策](https://apache.org/legal/resolved.html)中的A类/B类License,不能是C类License
+
+我们需要知道被我们项目引入的文件或jar依赖的NOTICE/LICENSE,(绝大多数的开源项目都会有NOTICE文件),这些必须在我们的项目中体现,用Apache的话来讲,就是"Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a
+copyright notice that is included in or attached to the work.
+
+### 2.1 示例 场景1
+比如源码中引入了`linkis-engineconn-plugins/python/src/main/py4j/py4j-0.10.7-src.zip`第三方文件
+
+找到py4j-0.10.7-src.zip 对应的版本源码分支,如果对应版本分支无`LICENSE/NOTICE`文件,则选择主分支
+- 项目源码位于:https://github.com/bartdag/py4j/tree/0.10.7/py4j-python
+- LICENSE文件:https://github.com/bartdag/py4j/blob/0.10.7/py4j-python/LICENSE.txt
+- NOTICE文件:无
+
+需要在`linkis/LICENSE`文件中说明`py4j-0.10.7-src.zip`的license信息。
+`py4j-0.10.7-src.zip`对应的详细的license.txt文件放在同级的目录下`linkis-engineconn-plugins/python/src/main/py4j/LICENSE-py4j-0.10.7-src.txt`
+因为https://github.com/bartdag/py4j/tree/0.10.7/py4j-python 没有NOTICE文件,所以`linkis/NOTICE`文件中无需追加。
+
+### 2.2 示例 场景 2
+
+项目编译依赖了`org.apache.ant:ant:1.9.1`,ant-1.9.1.jar会在最后的编译安装包`target/apache-linkis-x.x.x-bin/linkis-package/lib`中
+可以解压ant-1.9.1.jar,从jar包中提取LICENSE/NOTICE文件,如果没有,则需要找到对应的版本源码
+找到py4j-0.10.7-src.zip 对应的版本源码分支,如果对应版本分支没有,则选择主分支
+- 项目源码位于:https://github.com/apache/ant/tree/rel/1.9.1
+- LICENSE文件:https://github.com/apache/ant/blob/rel/1.9.1/LICENSE
+- NOTICE文件:https://github.com/apache/ant/blob/rel/1.9.1/NOTICE
+
+需要在`linkis/LICENSE-binary`文件中说明`ant-1.9.1.jar`的license信息。
+`ant-1.9.1.jar`对应的详细的license.txt文件放在`licenses-binary/LICENSE-ant.txt`
+`ant-1.9.1.jar`对应的详细的notice.txt,追加到 `NOTICE-binary`文件中
+
+关于具体的各个开源协议使用协议,在此不做过多篇幅一一介绍,有兴趣可以自行查询了解。
+
+## 3.license 检测规则
+我们为自己的项目建立license-check脚本,是为了确保我们在使用过程中能够第一时间避免License的问题。
+
+当我们需要添加新的Jar或其他外部资源的时候,我们需要按照以下步骤:
+
+* 在 tool/dependencies/known-dependencies.txt中添加你所需要的jar名称+版本。
+* 在 linkis-web/release-docs/LICENSE(根据实际情况决定)中添加相关的license信息。
+* 在 linkis-web/release-docs/NOTICE(根据实际情况决定)中追加相关的NOTICE文件,此文件请务必和依赖项的代码版本仓库中的NOTICE文件一致。
+
+:::caution 注意
+如果是移除的场景,则对应的上述步骤的反向操作,需要在对应的文件中移除相应的LICENSE/NOTICE内容,总之需要保证这几个文件与实际源码/编译包的数据保持一致
+- tool/dependencies/known-dependencies.txt
+- LICENSE/LICENSE-binary/LICENSE-binary-ui
+- NOTICE/NOTICE-binary/NOTICE-binary-ui
+:::
+
+** check dependency license fail**
+
+编译后 执行tool/dependencies/diff-dependenies.sh 脚本验证
+```
+--- /dev/fd/63 2020-12-03 03:08:57.191579482 +0000
++++ /dev/fd/62 2020-12-03 03:08:57.191579482 +0000
+@@ -1,0 +2 @@
++HikariCP-java6-2.3.13.jar
+@@ -16,0 +18 @@
++c3p0-0.9.5.2.jar
+@@ -149,0 +152 @@
++mchange-commons-java-0.2.11.jar
+Error: Process completed with exit code 1.
+```
+一般来讲,添加一个jar的工作往往不会如此轻易的结束,因为它往往依赖了其它各种各样的jar,这些jar我们同样需要添加相应的license。
+这种情况下,我们会在check里面得到 check dependency license fail的错误信息,如上,我们缺少了HikariCP-java6-2.3.13、c3p0等的license声明,
+按照添加jar的步骤补充即可。
+
+
+## 4.附件
+附件:新jar的邮件格式
+```
+[VOTE][New/Remove Jar] jetcd-core(registry plugin support etcd3 )
+
+
+(说明目的,以及需要添加/移除的 jar 是什么)
+Hi, the registry SPI will provide the implementation of etcd3. Therefore, we need to introduce a new jar (jetcd-core, jetcd-launcher (test)), which complies with the Apache-2.0 License. I checked his related dependencies to make sure it complies with the license of the Apache project.
+
+new or remove jar :
+
+jetcd-core version -x.x.x license apache2.0
+jetcd-launcher (test) version -x.x.x license apache2.0
+
+dependent jar(它依赖了哪些jar,最好附带版本,以及相关采用的license协议):
+grpc-core version -x.x.x license XXX
+grpc-netty version -x.x.x license XXX
+grpc-protobuf version -x.x.x license XXX
+grpc-stub version -x.x.x license XXX
+grpc-grpclb version -x.x.x license XXX
+netty-all version -x.x.x license XXX
+failsafe version -x.x.x license XXX
+
+如果是新增,邮件需要附上如下内容
+相关地址:主要有github地址、license文件地址、notice 文件地址、maven中央仓库地址
+
+github address:https://github.com/etcd-io/jetcd
+license:https://github.com/etcd-io/jetcd/blob/master/LICENSE
+notice:https://github.com/etcd-io/jetcd/blob/master/NOTICE
+
+Maven repository:
+https://mvnrepository.com/artifact/io.etcd/jetcd-core
+https://mvnrepository.com/artifact/io.etcd/jetcd-launcher
+```
+
+## 5.参考文章
+* [COMMUNITY-LED DEVELOPMENT "THE APACHE WAY"](https://apache.org/dev/licensing-howto.html)
+* [ASF 3RD PARTY LICENSE POLICY](https://apache.org/legal/resolved.html)
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/log.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/log.md
new file mode 100644
index 00000000000..ca81c056c35
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/log.md
@@ -0,0 +1,23 @@
+---
+title: 日志规范
+sidebar_position: 2
+---
+1. 【**强制**】日志信息需要使用英文,不能使用中文。可选中英文混打。
+
+1. 【**约定**】Linkis选择slf4j和Log4j2作为日志打印框架,去除了Spring-Cloud包中自带的logback。由于Slf4j会随机选择一个日志框架进行绑定,所以以后在引入新maven包的时候,需要将诸如slf4j-log4j等桥接包exclude掉,不然日志打印会出现问题。但是如果新引入的maven包依赖log4j等包,不要进行exclude,不然代码运行可能会报错
+
+2. 【**配置**】log4j2的配置文件默认为log4j2.xml,需要放置在classpath中。如果需要和springcloud结合,可以在application.yml中加上logging:config:classpath:log4j2-spring.xml(配置文件的位置)
+
+3. 【**强制**】类中不可直接使用日志系统(log4j2、Log4j、Logback)中的API。java采用 LoggerFactory.getLogger(getClass).如果是Scala代码,强制继承Logging trait,Scala打印日志建议加上logger.info 不要直接用info等方法调用,不会打印正确的方法和行数。
+
+4. 【**开发约定**】由于EngineConn是由EngineConnManager通过命令行进行启动的,所以我们在命令行中指定了日志的配置文件的路径,同时也对日志的配置在代码运行中进行了改造,特别是将EngineConn的日志重定向到了系统的standard out中。所以约定EngineConn的日志配置文件在EnginePlugin中定义,名称为log4j2-engineconn.xml(这个是约定名,不能更改)
+
+5. 【**强制**】严格区分日志级别。Fatal级别的日志,在springcloud应用初始化的时候,就应该抛出来,并使用System.out(-1)退出。ERROR级别的异常为开发人员必须关注和处理的异常,不要随便用ERROR级别的。Warn级别是用户操作异常日志和一些方便日后排除BUG的日志。INFO为关键的流程日志。DEBUG为调式日志,尽量少写。
+
+6. 【**强制**】要求:INFO级别的日志,每个小模块都必须有,关键的流程,都至少有INFO级别的日志。守护线程清理资源等必须有WARN级别的日志。
+
+7. 【**强制**】异常信息应该包括两类信息:案发现场信息和异常堆栈信息。如果不处理,那么通过关键字throws往上抛出。 正例:logger.error(各类参数或者对象toString + "_" + e.getMessage(), e);
+
+8. 【**强制**】日志打印时禁止直接用 JSON 工具将对象转换成 String,如果你的类需要在log里面打印,请重写toString方法,不然不知道怎么找问题,只会打印对象名,不会知道具体的对象内容
+
+9. 【**强制**】在日志输出时,字符串变量之间的拼接使用占位符的方式
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/mapper-xml.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/mapper-xml.md
new file mode 100644
index 00000000000..c85afb6fa79
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/mapper-xml.md
@@ -0,0 +1,159 @@
+---
+title: Mapper XML 规范
+sidebar_position: 10
+---
+
+> Contributor为Apache Linkis贡献新的数据表,编写Mapper XML时需遵循如下规范进行开发。
+
+## 1.基本遵循规范
+- 在mapper.xml中namespace等于java接口地址
+- java接口中的方法名和XML中statement的id一致
+- java接口中的方法输入参数类型和XML中statement的parameterType指定的类型一致
+- java接口中的方法返回值类型和XML中statement的resultType指定的类型一致
+- XML中所有mysql关键字统一使用小写
+- 对于过多的查询字段抽象出SQL片段
+- 对于整型返回值类型建议使用Integer,可以区分未赋值和值为0的情况,如确定返回值为数字可使用int。其它数据类型类似。
+- 对于占位符,使用#{name},而不要使用${name}。模糊查询可以使用CONCAT('%',#{sname},'%')
+- 对于sql语句编写,不使用注解方式,统一写在XML文件中
+
+## 2.方法名称规范
+
+|方法名称| 说明| 核心点| 建议|
+|:---- |:--- |:--- |:--- |
+|insert | 新增数据 | 如果是自增主键,应该返回主键ID| |
+|deleteById | 根据主键ID删除数据| sql默认加limit 1,防止多删数据 |此方法不建议有,建议逻辑删除|
+|updateById | 根据主键ID修改数据| sql默认加limit 1,防止多修改数据| |
+|selectById | 根据主键查询数据| 查询一条数据 | |
+|selectByIdForUpdate | 根据主键加锁查询数据| 加锁查询一条数据,事务处理用 | |
+|queryListByParam | 根据输入条件查询数据列表| 多参数查询列表 | |
+|queryCountByParam | 根据输入条件查询总数| 多参数查询数量 | |
+
+## 3.parameterType规范
+java接口中必须包含@Param,XML中可以不包含parameterType
+### 3.1 基本类型
+```java
+// java接口
+User selectUserById(@Param("id") Integer id);
+// XML文件
+
+ select id, name
+ from user
+ where id = #{id}
+
+```
+### 3.2 集合类型
+```java
+// java接口
+List userListByIds(@Param("ids") List ids);
+// XML文件
+
+ select id, name
+ from user
+ where id in
+
+ #{item}
+
+
+```
+### 3.3 Map类型
+```java
+// java接口
+User queryByParams(@Param("map") Map parasms);
+// XML文件
+
+ select id, name
+ from user
+ where id = #{map.id} and name = #{map.name}
+
+```
+### 3.4 实体类型
+```java
+// java接口
+User queryByUser(@Param("user") User user);
+// XML文件
+
+ select id, name
+ from user
+ where id = #{user.id} and name = #{user.name}
+
+```
+### 3.5 多个参数类型
+```java
+// java接口
+User queryByIdAndName(@Param("id") Integer id, @Param("name") String name);
+// XML文件
+
+ select id, name
+ from user
+ where id = #{id} and name = #{name}
+
+```
+## 4.XML文件编写示例
+合理地使用空格和缩进来增强可读性,各类型sql语句示例如下
+```sql
+
+
+ -- 新增语句
+
+ insert into user (id, name)
+ values (1, 'z3');
+
+
+ -- 删除语句
+
+ delete from user
+ where name = #{name}
+ and id = #{id}
+
+
+ -- 修改语句
+
+ update user
+ set name = #{name}
+ where id = #{id}
+
+
+ -- 查询语句
+
+ select id, name
+ from user
+ where name = 'z3'
+
+
+ -- sql片段
+
+ id,
+ name
+
+ -- 引用
+
+
+ -- resultMap
+
+
+
+
+ -- 引用
+
+ do...
+
+
+ -- 条件判断
+
+ name = #{name}
+
+
+ -- 子查询
+
+ select u.id, u.name
+ from user u
+ where u.name in (
+ select t.name
+ from teacher t
+ where t.id = 1
+ and t.name = 'z3'
+ )
+ and u.id = 2
+
+
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/overview.md
new file mode 100644
index 00000000000..ed4cde6e9c7
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/overview.md
@@ -0,0 +1,19 @@
+---
+title: 总览
+sidebar_position: 0
+---
+为了规范 Linkis 的社区开发环境,提高 Linkis 后续版本开发迭代的产出质量,规范 Linkis 的整个开发设计流程,强烈建议各位 Contributor 遵守以下开发规范:
+
+- [License 须知](license.md)
+- [编程规范](programming-specification.md)
+- [日志规范](log.md)
+- [异常规范](exception-catch.md)
+- [接口规范](api.md)
+- [并发规范](concurrent.md)
+- [路径规范](path-usage.md)
+- [测试规范](unit-test.md)
+- [版本和新特性规范](version-feature-specifications.md)
+
+**说明**:Linkis1.0 初始版本的开发规范较为精简,后续会随着 Linkis 的版本迭代不断补充和完善,欢迎各位 Contributor 提出自己的见解和意见。
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/path-usage.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/path-usage.md
new file mode 100644
index 00000000000..b697edcbb84
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/path-usage.md
@@ -0,0 +1,13 @@
+---
+title: 路径规范
+sidebar_position: 6
+---
+
+请注意:Linkis 提供了统一的 Storage模块,所以在使用路径或在配置文件中配置路径时,必须遵守 Linkis 路径规范。
+
+1. 【**强制**】使用文件路径时不管是本地,hdfs,http都必须带有schema信息。其中:
+ - 本地文件 的 Scheme 头为:file:///;
+ - HDFS 的 Scheme 头为:hdfs:///;
+ - http 的 Scheme 头为:http:///。
+
+2. 路径中不应该存在特殊字符,尽量英文,下划线,数字进行组合。
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/programming-specification.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/programming-specification.md
new file mode 100644
index 00000000000..04795eff836
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/programming-specification.md
@@ -0,0 +1,102 @@
+---
+title: 编程规约
+sidebar_position: 1
+---
+## 1. 命名规约
+1. 【**强制**】不要用中文拼音和看不懂的缩写
+2. 基本的Java命名规范可以参考[命名规范](https://alibaba.github.io/Alibaba-Java-Coding-Guidelines/#naming-conventions)
+3. 【约束】在linkis中有scalastyle风格配置文件,如果不符合规范的需要按照scalastyle的风格进行命名
+4. 【**强制**】配置文件命令、启动命名、进程命名、配置的key等也需要遵守命名规范,规范如下:
+
+|分类| 风格| 规范| 例子|
+|:---- |:--- |:--- |:--- |
+|配置文件|小写'-'分隔| linkis-分类层级(ps/cg/mg)-服务名.propertis| linkis-cg-linkismanager.properties|
+|启停脚本|小写'-'分隔| linkis-分类层级-服务名| linkis-cg-linkismanager|
+|模块目录|小写'-'分隔| 模块目录必须在对应的分类层级下面,并以模块名为子目录| linkis-public-enhancements/linkis-bml|
+|进程命名|驼峰命名| 以Linkis开头服务名结尾| LinkisBMLApplication|
+|配置Key命名|小写'.'分隔| linkis+模块名+keyName| linkis.bml.hdfs.prefix|
+
+## 2. 注释规约
+1. 【**强制**】类、类属性、接口方法必须加注释,且注释必须使用 Javadoc 规范,使用`/**内容*/`格式。
+
+示例:
+```java
+/** Wrap the communication between Bml service */
+public class BmlAppServiceImpl implements BmlAppService {
+ /** Bml client */
+ private BmlClient client;
+}
+```
+2. 【**强制**】所有的类都不要添加创建者。Linkis项目已捐献给Apache,无须添加作者信息。
+
+3. 【**强制**】所有的抽象方法(包括接口中的方法)必须要用 Javadoc 注释、除了返回值、参数、 异常说明外,还必须指出该方法做什么事情,实现什么功能。
+
+4. 【**强制**】方法内部单行注释,在被注释语句上方另起一行,使用 // 注释。方法内部多行注释使用 /* */ 注释,注意与代码对齐。
+
+示例:
+```java
+ // Store the reflection relation between parameter variable like 'T' and type like
+ Map typeVariableReflect = new HashMap<>();
+```
+5. 【**强制**】所有的枚举类型字段必须要有注释,说明每个数据项的用途。
+
+示例:
+```java
+/**
+ * 节点监控状态信息
+ * to monitor node status info
+ */
+public enum NodeHealthy {
+
+ /**
+ * 状态正常
+ * healthy status
+ */
+ Healthy,
+
+ /**
+ * EM自己标识自己为UnHealthy 或者manager把他标识为UnHealthy 处理引擎状态不正常,
+ * manager主动要求所有的engine强制退出(engine自杀)
+ * EM identifies itself as UnHealthy or
+ * The manager marks it as abnormal in the status of UnHealthy processing engine.
+ * The manager requests all engines to withdraw forcibly (engine suicide).
+ */
+ UnHealthy,
+
+ /**
+ * 引擎处于告警状态,但是可以接受任务
+ * The engine is in the alarm state, but can accept tasks
+ */
+ WARN,
+
+ /**
+ * 存量可用状态,可以接受任务。当EM状态最近n次心跳没有上报,但是已经启动的Engine还是正常的可以接受任务
+ * The stock is available and can accept tasks. When the EM status is not reported for the last n heartbeats,
+ * the Engine that has been started is still normal and can accept tasks
+ */
+ StockAvailable,
+
+ /**
+ * 存量不可用状态,不可以接受任务。(超过n+1没上报心跳)或者(EM自己判断,但是服务正常的情况),
+ * 但是如果往上面提交任务会出现error失败情况 EM处于StockUnavailable时,
+ * manager主动要求所有的engine非强制退出,manager需要将EM标识为UnHealthy。
+ * 如果StockUnavailable状态如果超过n分钟,则发送IMS告警
+ * The stock is not available. Tasks cannot be accepted
+ */
+ StockUnavailable;
+}
+```
+6. 【推荐】代码修改的同时,注释也要进行相应的修改,尤其是参数、返回值、异常、核心逻辑等的修改。
+7. 【推荐】在类中删除未使用的任何字段、方法、内部类;在方法中删除未使用的任何参数声明与内部变量。
+8. 【参考】谨慎注释掉代码。在上方详细说明,而不是简单地注释掉。如果无用,则删除。代码被注释掉有两种可能性:1)后续会恢复此段代码逻辑。2)永久不用。前者如果没有备注信息,难以知晓注释动机。后者建议直接删掉即可,假如需要查阅历史代码,登录代码仓库即可。
+
+示例:
+```java
+ public static final CommonVars TUNING_CLASS =
+ CommonVars.apply(
+ "wds.linkis.cs.ha.class", "org.apache.linkis.cs.highavailable.DefaultContextHAManager");
+ // 应该删除如下注释代码
+ // public static final CommonVars TUNING_CLASS =
+ // CommonVars.apply("wds.linkis.cs.ha.class","org.apache.linkis.cs.persistence.ProxyMethodA");
+```
+9. 【参考】对于注释的要求:第一、能够准确反映设计思想和代码逻辑;第二、能够描述业务含义,使别的程序员能够迅速了解到代码背后的信息。完全没有注释的大段代码对于阅读者形同天书,注释是给自己看的,即使隔很长时间,也能清晰理解当时的思路;注释也是给继任者看的,使其能够快速接替自己的工作。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/release-notes.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/release-notes.md
new file mode 100644
index 00000000000..f79192ef99c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/release-notes.md
@@ -0,0 +1,42 @@
+---
+title: Release-Notes 编写规范
+sidebar_position: 9
+---
+每次版本发布前,需要由发布经理或则开发者,整理好本次版本的release-notes,来简要地描述了新版本更新中包含的特定更改。
+
+为保持统一和方便编写,制定如下规范:
+- 需要有版本的总结,几句话总结性的描述本版本的核心主要变动点
+- 按变化的功能点 以 新特性/增强点/修复功能/其他 四大类进行分类罗列
+- 包含致谢栏:有参与本此版本贡献的同学,除了issue/pr外,以及任何参与到此次版本讨论/社群答疑/意见建议的同学
+- 每条note的规范:`[服务名缩写-L1 maven module名][Linkis-pr/issues序号] 本次变动简要描述信息,能通过描述信息,大体知道这个功能的变化` `[服务名缩写-L1 maven module名]`作为一个标签,示例如下
+- 同一类别(新特性/增强点/修复功能/其他)下, 服务名相同的放在一起,按pr/issues序号升序排列
+- 需要有对应的英文文档
+
+```
+服务名缩写:此pr的变动,在代码层面上,主要归属的服务对应的服务名缩写
+比如某pr是对JDBC引擎做了bug修复,在代码层面上,它是linkis-cg-engineconn 服务下的JDBC模块
+EG:[EC-Jdbc][[Linkis-1851]](https://github.com/apache/linkis/issues/1851) 修复jdbc引擎,一次任务执行中存在多条sql语句时无法正常执行的问题
+若 L1 maven module 不存在,或则是整个服务级别的调整,下级模块可以不写,比如Entrance
+```
+
+## 常见的notes 标签
+```html
+linkis-mg-eureka Eureka
+linkis-mg-gateway Gataway
+linkis-cg-linkismanager LM
+linkis-cg-engineconnplugin ECP
+linkis-cg-engineconnmanager ECM
+linkis-cg-engineconn EC
+linkis-cg-entrance Entrance
+linkis-ps-publicservice PS
+linkis-ps-cs CS
+linkis-ps-metadatamanager MDM
+linkis-ps-data-source-query DSQ
+
+Web管理台 Web
+安装 Install
+安装-脚本 Install-Scripts
+安装-SQL Install-Sql
+安装-Web Install-Web
+公共模块 Common
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/unit-test.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/unit-test.md
new file mode 100644
index 00000000000..7e486ddcd23
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/unit-test.md
@@ -0,0 +1,12 @@
+---
+title: 测试规约
+sidebar_position: 7
+---
+
+1. 【**强制**】工具类和服务内部接口一定要有测试样例。
+2. 【**强制**】单元测试需要能够自动化(通过 mvn编译即可触发)、独立性(单元测试用例间不可相互调用)、可重复执行(可以多次执行,结果一样)。
+3. 【**强制**】一个测试用例应该只测试一个方法。
+4. 【**强制**】测试用例异常不可以catch,需要向上抛出。
+5. 【**强制**】单元测试代码必须写在如下工程目录:src/test/java or scala,不允许写在其他录下。
+6. 【推荐】单元测试需要考虑边界条件,如日期需要考虑月末和2月。
+7. 【推荐】对于数据库相关的单元测试,要考虑数据回滚。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/version-feature-specifications.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/version-feature-specifications.md
new file mode 100644
index 00000000000..f1f441b5874
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/development-specification/version-feature-specifications.md
@@ -0,0 +1,26 @@
+---
+title: 版本和新特性规范
+sidebar_position: 8
+---
+
+## 1. 新增版本规范
+当您有新的版本需要时,需要遵循以下步骤:
+1. 【强制】新版本一定需要组织PMC成员和开发者进行讨论,需要记录会议纪要发送邮件列表
+2. 【强制】新版本的特性列表范围,需要发起邮件投票.需要3+ PMC成员同意且同意票大于反对票
+3. 【强制】版本投票通过后,需要在GitHub建立对应的版本[Project](https://github.com/apache/linkis/projects)
+4. 【强制】每个特性需要单独发送邮件列表,说明设计原因、设计思路
+5. 【强制】涉及到安装、数据库、配置修改的也需要发送邮件列表
+6. 【推荐】一个特性对应一个issue对应一个PR
+7. 【强制】每个版本需要保证CICD通过、测试案例通过才可以发布版本
+8. 【约束】每个版本需要有对应的Leader,leader需要管理相关的Issue和PR,并拉会讨论、积极回复邮件、确认方案、追踪进度等
+
+
+## 2. 新加特性规范
+当您有新特性的新增时,需要遵循以下步骤:
+1. 【强制】新特性需要发送邮件进行投票,并附上设计原因,设计思路
+2. 【强制】需要在GitHub对应的版本中新添加特性[Project](https://github.com/apache/linkis/projects)
+3. 【强制】涉及到安装、数据库、配置修改的也需要发送邮件列表
+4. 【强制】新的特性一定要新增文档
+5. 【强制】新加特性需要新增对应的单元测试,[单元测试规范](https://linkis.apache.org/community/development-specification/unit_test)
+6. 【推荐】一个特性对应一个issue对应一个PR
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/directory-structure.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/directory-structure.md
new file mode 100644
index 00000000000..1d2bc407415
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/directory-structure.md
@@ -0,0 +1,296 @@
+---
+title: 目录结构
+sidebar_position: 2.0
+---
+
+> Linkis代码层级目录结构,以及安装包目录结构和部署后的目录结构说明,如果想详细了解各个模块,请查看[Linkis的相关架构设计](architecture/overview.md)
+
+## 1. 源码目录结构
+
+```html
+├── docs
+│ ├── configuration //linkis所有模块的配置项文档
+│ ├── errorcode //linkis所有模块的错误码文档
+├── linkis-commons //核心抽象,里面放有所有的公用模块
+│ ├── linkis-common //通用模块,内置很多通用工具类
+│ ├── linkis-hadoop-common
+│ ├── linkis-httpclient //Java SDK顶层接口 对httpclient的进一步封装
+│ ├── linkis-module // linkis的服务顶层公用模块 涉及到服务启动时的参数和服务初始化 统一的Restful处理 登录态校验等
+│ ├── linkis-mybatis //SpringCloud的Mybatis模块
+│ ├── linkis-protocol //服务请求/响应的一些接口和实体类
+│ ├── linkis-rpc //RPC模块,基于Feign实现的复杂双向通信
+│ ├── linkis-scheduler //通用调度模块
+│ ├── linkis-storage //文件操作工具集
+├── linkis-computation-governance //计算治理服务
+│ ├── linkis-client //Java SDK,用户通过Client可直接访问Linkis
+│ ├── linkis-computation-governance-common
+│ ├── linkis-engineconn
+│ ├── linkis-engineconn-manager
+│ ├── linkis-entrance //通用底层entrance模块
+│ ├── linkis-jdbc-driver //可以类似jdbc sdk方式连接使用linkis
+│ ├── linkis-manager
+├── linkis-dist //编译打包最后阶段步骤 整合所有lib包和安装部署脚本配置等
+│ ├── bin
+│ │ ├── checkEnv.sh
+│ │ ├── common.sh
+│ │ └── install.sh //安装脚本
+│ ├── deploy-config
+│ │ ├── db.sh //数据库配置
+│ │ └── linkis-env.sh //linkis 启动相关配置
+│ ├── docker
+│ │ └── scripts
+│ ├── helm
+│ │ ├── charts
+│ │ ├── scripts
+│ │ ├── README_CN.md
+│ │ └── README.md
+│ ├── package
+│ │ ├── bin
+│ │ ├── conf
+│ │ ├── db
+│ │ └── sbin
+│ ├── release-docs
+│ │ ├── licenses
+│ │ ├── LICENSE
+│ │ └── NOTICE
+│ ├── src
+│ └── pom.xml
+├── linkis-engineconn-plugins // 引擎
+│ ├── elasticsearch
+│ ├── flink
+│ ├── hive
+│ ├── io_file
+│ ├── jdbc
+│ ├── openlookeng
+│ ├── pipeline
+│ ├── presto
+│ ├── python
+│ ├── seatunnel
+│ ├── shell
+│ ├── spark
+│ ├── sqoop
+├── linkis-extensions // 扩展功能增强插件模块
+│ ├── linkis-io-file-client // 对linkis-storage的功能扩展
+├── linkis-orchestrator //服务的编排
+│ ├── linkis-code-orchestrator
+│ ├── linkis-computation-orchestrator
+│ ├── linkis-orchestrator-core
+├── linkis-public-enhancements //公共增强服务
+│ ├── linkis-basedata-manager
+│ ├── linkis-bml // 物料库
+│ ├── linkis-configuration
+│ ├── linkis-context-service //统一上下文
+│ ├── linkis-datasource //数据源服务
+│ ├── linkis-error-code
+│ ├── linkis-instance-label
+│ ├── linkis-jobhistory
+│ ├── linkis-ps-common-lock
+│ ├── linkis-script-dev
+│ ├── linkis-udf
+│ ├── linkis-variable
+├── linkis-spring-cloud-services //微服务治理
+│ ├── linkis-service-discovery
+│ ├── linkis-service-gateway //网关Gateway
+├── linkis-web //linkis的管理台代码
+│ ├── release-docs
+│ │ ├── licenses
+│ │ └── LICENSE
+│ ├── src
+│ ├── config.sh
+│ ├── install.sh
+│ ├── package.json
+│ ├── pom.xml
+│ └── vue.config.js
+├── tool
+│ ├── dependencies
+│ │ ├── known-dependencies.txt
+│ │ └── regenerate_konwn_dependencies_txt.sh
+│ ├── code-style-idea.xml
+│ ├── license-header
+│ └── modify_license.sh
+├── CONTRIBUTING_CN.md
+├── CONTRIBUTING.md
+├── linkis-tree.txt
+├── mvnw
+├── mvnw.cmd
+├── pom.xml
+├── README_CN.md
+├── README.md
+└── scalastyle-config.xml
+
+```
+
+## 2. 安装包目录结构
+
+> Linkis安装包解压后的目录结构
+
+下载官方发布的[编译完整包](https://linkis.apache.org/zh-CN/download/main),解压后的目录结构如下:
+```html
+
+├── bin
+│ ├── checkEnv.sh ── 环境变量检测
+│ ├── common.sh ── 部分公共shell函数
+│ └── install.sh ── Linkis安装的主脚本
+├── deploy-config
+│ ├── db.sh //数据库连接配置
+│ └── linkis-env.sh //相关环境配置信息
+├── docker
+├── helm
+├── licenses
+├── linkis-package //微服务相关的启动配置文件,依赖,脚本,linkis-cli等
+│ ├── bin
+│ ├── conf
+│ ├── db
+│ ├── lib
+│ └── sbin
+├── NOTICE
+├── LICENSE
+├── README_CN.md
+└── README.md
+
+```
+
+
+## 3. 部署后的目录结构
+
+安装后`${LINKIS_HOME}`目录结构
+
+```html
+├── bin ── linkis-cli 用于向Linkis提交任务的Shell命令行程序
+│ ├── linkis-cli
+│ ├── linkis-cli-hive
+│ ├── linkis-cli-pre
+│ ├── linkis-cli-spark-sql
+│ ├── linkis-cli-spark-submit
+│ └── linkis-cli-sqoop
+├── conf 配置目录
+│ ├── application-eureka.yml
+│ ├── application-linkis.yml ── 微服务通用yml
+│ ├── linkis-cg-engineconnmanager.properties
+│ ├── linkis-cg-engineplugin.properties
+│ ├── linkis-cg-entrance.properties
+│ ├── linkis-cg-linkismanager.properties
+│ │── linkis-cli
+│ │ ├── linkis-cli.properties
+│ │ └── log4j2.xml
+│ ├── linkis-env.sh ── linkis 环境变量配置
+│ ├── linkis-mg-gateway.properties
+│ ├── linkis.properties ── linkis 服务的全局配合,所有微服务启动都会加载使用
+│ ├── linkis-ps-publicservice.properties
+│ ├── log4j2.xml
+├── db 数据库DML和DDL文件目录
+│ ├── linkis_ddl.sql ── 数据库表定义SQL
+│ ├── linkis_dml.sql ── 数据库表初始化SQL
+│ └── module ── 包含各个微服务的DML和DDL文件
+│ └── upgrade ── 针对每个版本 增量DML/DDL
+├── lib lib目录
+│ ├── linkis-commons ── 公共依赖包 大多服务启动时(linkis-mg-gateway除外) -cp 路径参数 都会加载这个目录
+│ ├── linkis-computation-governance ──计算治理模块的lib目录
+│ ├── linkis-engineconn-plugins ──所有引擎插件的lib目录
+│ ├── linkis-public-enhancements ──公共增强服务的lib目录
+│ └── linkis-spring-cloud-services ──SpringCloud的lib目录
+├── logs 日志目录
+│ ├── linkis-cg-engineconnmanager-gc.log
+│ ├── linkis-cg-engineconnmanager.log
+│ ├── linkis-cg-engineconnmanager.out
+│ ├── linkis-cg-engineplugin-gc.log
+│ ├── linkis-cg-engineplugin.log
+│ ├── linkis-cg-engineplugin.out
+│ ├── linkis-cg-entrance-gc.log
+│ ├── linkis-cg-entrance.log
+│ ├── linkis-cg-entrance.out
+│ ├── linkis-cg-linkismanager-gc.log
+│ ├── linkis-cg-linkismanager.log
+│ ├── linkis-cg-linkismanager.out
+│ ├── linkis-cli
+│ │ ├── linkis-client.hadoop.log.20220409162400037523664
+│ ├── linkis-mg-eureka-gc.log
+│ ├── linkis-mg-eureka.log
+│ ├── linkis-mg-eureka.out
+│ ├── linkis-mg-gateway-gc.log
+│ ├── linkis-mg-gateway.log
+│ ├── linkis-mg-gateway.out
+│ ├── linkis-ps-publicservice-gc.log
+│ ├── linkis-ps-publicservice.log
+│ └── linkis-ps-publicservice.out
+├── pid 所有微服务的进程ID
+│ ├── linkis_cg-engineconnmanager.pid ──引擎管理器微服务
+│ ├── linkis_cg-engineconnplugin.pid ──引擎插件微服务
+│ ├── linkis_cg-entrance.pid ──引擎入口微服务
+│ ├── linkis_cg-linkismanager.pid ──linkis管理器微服务
+│ ├── linkis_mg-eureka.pid ──eureka微服务
+│ ├── linkis_mg-gateway.pid ──gateway微服务
+│ └── linkis_ps-publicservice.pid ──公共微服务
+└── sbin 微服务启停脚本目录
+ ├── ext ──各个微服务的启停脚本目录
+ ├── linkis-daemon.sh ── 快捷启停、重启单个微服务脚本
+ ├── linkis-start-all.sh ── 一键启动全部微服务脚本
+ └── linkis-stop-all.sh ── 一键停止全部微服务脚本
+
+```
+
+### 3.1 配置项修改
+
+在执行完Linkis安装后,所有配置项位于conf目录下,
+如果需要进行配置项修改,修改配置`${LINKIS_HOME}/conf/*properties`文件后,重启对应的服务,
+如:`sh sbin/linkis-daemon.sh start ps-publicservice`。
+如果修改的是公共配置文件`application-eureka.yml/application-linkis.yml/linkis.properties`,需要重启所有服务`sh sbin/linkis-start-all.sh`
+
+
+
+
+### 3.2 微服务启停
+
+所有微服务名称如下:
+ ```
+├── linkis-cg-engineconnmanager 引擎管理服务
+├── linkis-cg-engineplugin 引擎插件管理服务
+├── linkis-cg-entrance 计算治理入口服务
+├── linkis-cg-linkismanager 计算治理管理服务
+├── linkis-mg-eureka 微服务注册中心服务
+├── linkis-mg-gateway Linkis网关服务
+├── linkis-ps-publicservice 公共服务
+ ```
+
+**微服务简称**:
+
+ | 简称 | 英文全称 | 中文全称 |
+ |------|-------------------------|------------|
+ | cg | Computation Governance | 计算治理 |
+ | mg | Microservice Covernance | 微服务治理 |
+ | ps | Public Enhancement Service | 公共增强服务 |
+
+
+
+```
+# 一次性启动所有微服务:
+
+ sh linkis-start-all.sh
+
+# 一次性关停所有微服务
+
+ sh linkis-stop-all.sh
+
+# 启动单个微服务(服务名需要去掉linkis前缀如:mg-eureka)
+
+ sh linkis-daemon.sh start service-name
+
+ 例如: sh linkis-daemon.sh start mg-eureka
+
+# 关闭单个微服务
+
+ sh linkis-daemon.sh stop service-name
+
+ 例如: sh linkis-daemon.sh stop mg-eureka
+
+# 重启单个微服务
+
+ sh linkis-daemon.sh restart service-name
+
+ 例如: sh linkis-daemon.sh restart mg-eureka
+# 查看单个微服务的状态
+
+ sh linkis-daemon.sh status service-name
+
+ 例如: sh linkis-daemon.sh status mg-eureka
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/c-debug.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/c-debug.png
new file mode 100644
index 00000000000..d5edce7fe24
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/c-debug.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/c-port.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/c-port.png
new file mode 100644
index 00000000000..2c0a8cb420f
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/c-port.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/debug.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/debug.png
new file mode 100644
index 00000000000..4c0a9e39e4e
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/debug.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/test-0.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/test-0.png
new file mode 100644
index 00000000000..3ebe85fe283
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/test-0.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/test-1.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/test-1.png
new file mode 100644
index 00000000000..3ebe85fe283
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/test-1.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/test-2.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/test-2.png
new file mode 100644
index 00000000000..95ad650c167
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/images/test-2.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/new-engine-conn.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/new-engine-conn.md
new file mode 100644
index 00000000000..0af601bc4a5
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/new-engine-conn.md
@@ -0,0 +1,477 @@
+---
+title: 如何实现新引擎
+sidebar_position: 8.0
+---
+
+## 1. Linkis新引擎功能代码实现
+
+实现一个新的引擎其实就是实现一个新的EngineConnPlugin(ECP)引擎插件。具体步骤如下:
+
+### 1.1 新建一个maven模块,并引入ECP的maven依赖
+
+![maven依赖](/Images-zh/EngineConnNew/engine_jdbc_dependency.png)
+
+```xml
+
+ org.apache.linkis
+ linkis-engineconn-plugin-core
+ ${linkis.version}
+
+
+```
+
+### 1.2 实现ECP的主要接口
+
+- **EngineConnPlugin:** 启动EngineConn时,先找到对应的EngineConnPlugin类,以此为入口,获取其它核心接口的实现,是必须实现的主要接口。
+
+- **EngineConnFactory:** 实现如何启动一个引擎连接器,和如何启动一个引擎执行器的逻辑,是必须实现的接口。
+ - 实现createEngineConn方法:返回一个EngineConn对象,其中,getEngine返回一个封装了与底层引擎连接信息的对象,同时包含Engine类型信息。
+ - 对于只支持单一计算场景的引擎,继承SingleExecutorEngineConnFactory,实现createExecutor,返回对应的Executor。
+ - 对于支持多计算场景的引擎,需要继承MultiExecutorEngineConnFactory,并为每种计算类型实现一个ExecutorFactory。EngineConnPlugin会通过反射获取所有的ExecutorFactory,根据实际情况返回对应的Executor。
+- **EngineConnResourceFactory:** 用于限定启动一个引擎所需要的资源,引擎启动前,将以此为依 据 向 Linkis Manager 申 请 资 源。非必须,默认可以使用GenericEngineResourceFactory。
+- **EngineLaunchBuilder:** 用于封装EngineConnManager可以解析成启动命令的必要信息。非必须,可以直接继承JavaProcessEngineConnLaunchBuilder。
+
+### 1.3 实现引擎Executor执行器逻辑
+
+Executor为执行器,作为真正的计算场景执行器,是实际的计算逻辑执行单元,也是对引擎各种具体能力的抽象,提供加锁、访问状态、获取日志等多种不同的服务。并根据实际的使用需要,Linkis默认提供以下的派生Executor基类,其类名和主要作用如下:
+
+- **SensibleExecutor:**
+ - Executor存在多种状态,允许Executor切换状态
+ - Executor切换状态后,允许做通知等操作
+- **YarnExecutor:** 指Yarn类型的引擎,能够获取得到applicationId和applicationURL和队列。
+- **ResourceExecutor:** 指引擎具备资源动态变化的能力,配合提供requestExpectedResource方法,用于每次希望更改资源时,先向RM申请新的资源;而resourceUpdate方法,用于每次引擎实际使用资源发生变化时,向RM汇报资源情况。
+- **AccessibleExecutor:** 是一个非常重要的Executor基类。如果用户的Executor继承了该基类,则表示该Engine是可以被访问的。这里需区分SensibleExecutor的state()和 AccessibleExecutor 的 getEngineStatus()方法:state()用于获取引擎状态,getEngineStatus()会获取引擎的状态、负载、并发等基础指标Metric数据。
+- 同时,如果继承了 AccessibleExecutor,会触发Engine 进程实例化多个EngineReceiver方法。EngineReceiver用于处理Entrance、EM和LinkisMaster的RPC请求,使得该引擎变成了一个可被访问的引擎,用户如果有特殊的RPC需求,可以通过实现RPCService接口,进而实现与AccessibleExecutor通信。
+- **ExecutableExecutor:** 是一个常驻型的Executor基类,常驻型的Executor包含:生产中心的Streaming应用、提交给Schedulis后指定要以独立模式运行的脚步、业务用户的业务应用等。
+- **StreamingExecutor:** Streaming为流式应用,继承自ExecutableExecutor,需具备诊断、do checkpoint、采集作业信息、监控告警的能力。
+- **ComputationExecutor:** 是常用的交互式引擎Executor,处理交互式执行任务,并且具备状态查询、任务kill等交互式能力。
+- **ConcurrentComputationExecutor:** 用户并发引擎Executor,常用于JDBC类型引擎,执行脚本时,由管理员账户拉起引擎实例,所有用户共享引擎实例。
+
+## 2. 以JDBC引擎为例详解新引擎的实现步骤
+
+本章节以JDBC引擎举例,详解新引擎的实现过程,包括引擎代码的编译、安装、数据库配置,管理台引擎标签适配,以及Scripts中新引擎脚本类型扩展和工作流新引擎的任务节点扩展等。
+
+### 2.1 并发引擎设置默认启动用户
+
+JDBC引擎中的核心类`JDBCEngineConnExecutor`继承的抽象类是`ConcurrentComputationExecutor`,计算类引擎中的核心类`XXXEngineConnExecutor`继承的抽象类是`ComputationExecutor`。这导致两者最大的一个区别是:JDBC引擎实例由管理员用户启动,被所有用户共享,以提高机器资源利用率;而计算引擎类型的脚本在提交时,每个用户下会启动一个引擎实例,用户间引擎实例互相隔离。这个在此处暂不细说,因为无论是并发引擎还是计算引擎,下文提到的额外修改流程应是一致的。
+
+相应的,如果你新增的引擎是并发引擎,那么你需要关注下这个类:AMConfiguration.scala,如果你新增的引擎是计算类引擎,则可忽略。
+
+```scala
+object AMConfiguration {
+ // 如果你的引擎是多用户并发引擎,那么这个配置项需要关注下
+ val MULTI_USER_ENGINE_TYPES = CommonVars("wds.linkis.multi.user.engine.types", "jdbc,ck,es,io_file,appconn")
+
+ private def getDefaultMultiEngineUser(): String = {
+ // 此处应该是为了设置并发引擎拉起时的启动用户,默认jvmUser即是引擎服务Java进程的启动用户
+ val jvmUser = Utils.getJvmUser
+ s"""{jdbc:"$jvmUser", presto: "$jvmUser" es: "$jvmUser", ck:"$jvmUser", appconn:"$jvmUser", io_file:"root"}"""
+ }
+}
+```
+
+### 2.2 新引擎类型扩展
+
+实现`ComputationSingleExecutorEngineConnFactory`接口的类`JDBCEngineConnFactory`中,下面两个方法需要实现:
+
+```scala
+override protected def getEngineConnType: EngineType = EngineType.JDBC
+
+override protected def getRunType: RunType = RunType.JDBC
+```
+
+因此需要在EngineType和RunType中增加JDBC对应的变量。
+
+```scala
+// EngineType.scala中类似已存在引擎的变量定义,增加JDBC相关变量或代码
+object EngineType extends Enumeration with Logging {
+ val JDBC = Value("jdbc")
+}
+
+def mapStringToEngineType(str: String): EngineType = str match {
+ case _ if JDBC.toString.equalsIgnoreCase(str) => JDBC
+}
+
+// RunType.scla中
+object RunType extends Enumeration {
+ val JDBC = Value("jdbc")
+}
+```
+
+### 2.3 JDBC引擎标签中的版本号设置
+
+```scala
+// 在LabelCommonConfig中增加JDBC的version配置
+public class LabelCommonConfig {
+ public final static CommonVars JDBC_ENGINE_VERSION = CommonVars.apply("wds.linkis.jdbc.engine.version", "4");
+}
+
+// 在EngineTypeLabelCreator的init方法中补充jdbc的匹配逻辑
+// 如果这一步不做,代码提交到引擎上时,引擎标签信息中会缺少版本号
+public class EngineTypeLabelCreator {
+ private static void init() {
+ defaultVersion.put(EngineType.JDBC().toString(), LabelCommonConfig.JDBC_ENGINE_VERSION.getValue());
+ }
+}
+```
+
+### 2.4 允许脚本编辑器打开的脚本文件类型
+
+关注配置项:wds.linkis.storage.file.type
+
+```scala
+object LinkisStorageConf{
+ val FILE_TYPE = CommonVars("wds.linkis.storage.file.type", "dolphin,sql,scala,py,hql,python,out,log,text,sh,jdbc,ngql,psql,fql").getValue
+}
+```
+
+### 2.5 配置JDBC脚本变量存储和解析
+
+如果这个操作不做,JDBC的脚本中变量不能被正常存储和解析,脚本中直接使用${变量}时代码会执行失败!
+
+![变量解析](/Images-zh/EngineConnNew/variable_resolution.png)
+
+```scala
+// 通过CodeAndRunTypeUtils工具类中的CODE_TYPE_AND_RUN_TYPE_RELATION变量来维护codeType和runType间的对应关系
+val CODE_TYPE_AND_RUN_TYPE_RELATION = CommonVars("wds.linkis.codeType.runType.relation", "sql=>sql|hql|jdbc|hive|psql|fql,python=>python|py|pyspark,java=>java,scala=>scala,shell=>sh|shell")
+```
+
+参考PR:https://github.com/apache/linkis/pull/2047
+
+### 2.6 Linkis管理员台界面引擎管理器中加入JDBC引擎文字提示或图标
+
+linkis-web/src/dss/module/resourceSimple/engine.vue
+
+```js
+methods: {
+ calssifyName(params) {
+ switch (params) {
+ case 'jdbc':
+ return 'JDBC';
+ ......
+ }
+ }
+ // 图标过滤
+ supportIcon(item) {
+ const supportTypes = [
+ ......
+ { rule: 'jdbc', logo: 'fi-jdbc' },
+ ];
+ }
+}
+```
+
+
+
+最终呈现给用户的效果:
+
+![JDBC类型引擎](/Images-zh/EngineConnNew/jdbc_engine_view.png)
+
+### 2.7 JDBC引擎的编译打包和安装部署
+
+JDBC引擎模块编译的示例命令如下:
+
+```shell
+cd /linkis-project/linkis-engineconn-pluginsengineconn-plugins/jdbc
+
+mvn clean install -DskipTests
+```
+
+编译完整项目时,新增引擎默认不会加到最终的tar.gz压缩包中,如果需要,请修改如下文件:
+
+linkis-dist/src/main/assembly/distribution.xml
+
+```xml
+
+
+ ......
+
+
+ ../linkis-engineconn-plugins/jdbc/target/out/
+
+ linkis-package/lib/linkis-engineconn-plugins/
+
+ **/*
+
+
+
+```
+
+然后对在项目根目录运行编译命令:
+
+```shell
+mvn clean install -DskipTests
+```
+
+编译成功后在linkis-dist/target/apache-linkis-1.x.x-bin.tar.gz和linkis-engineconn-plugins/jdbc/target/目录下找到out.zip。
+
+上传out.zip文件到Linkis的部署节点,解压缩到Linkis安装目录/lib/linkis-engineconn-plugins/下面:
+
+![引擎安装](/Images-zh/EngineConnNew/engine_set_up.png)
+
+解压后别忘记删除out.zip,至此引擎编译和安装完成。
+
+### 2.8 JDBC引擎数据库配置
+
+在管理台选择添加引擎
+
+![添加引擎](/Images-zh/EngineConnNew/add_engine_conf.png)
+
+
+
+如果您希望在管理台支持引擎参数配置,可以按照JDBC引擎SQL示例修改数据库。
+
+此处以JDBC引擎为例,引擎安装完之后,要想运行新的引擎代码,还需对引擎进行数据库配置,以JDBC引擎为例,按照你自己实现的新引擎的情况,请按需修改。
+
+SQL参考如下:
+
+```sql
+SET @JDBC_LABEL="jdbc-4";
+
+SET @JDBC_ALL=CONCAT('*-*,',@JDBC_LABEL);
+SET @JDBC_IDE=CONCAT('*-IDE,',@JDBC_LABEL);
+SET @JDBC_NODE=CONCAT('*-nodeexecution,',@JDBC_LABEL);
+
+-- JDBC
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.instance', '范围:1-20,单位:个', 'jdbc引擎最大并发数', '2', 'NumInterval', '[1,20]', '0', '0', '1', '队列资源', 'jdbc');
+
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.driver', '取值范围:对应JDBC驱动名称', 'jdbc驱动名称','', 'None', '', '0', '0', '1', '数据源配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.connect.url', '例如:jdbc:hive2://127.0.0.1:10000', 'jdbc连接地址', 'jdbc:hive2://127.0.0.1:10000', 'None', '', '0', '0', '1', '数据源配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.version', '取值范围:jdbc3,jdbc4', 'jdbc版本','jdbc4', 'OFT', '[\"jdbc3\",\"jdbc4\"]', '0', '0', '1', '数据源配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.connect.max', '范围:1-20,单位:个', 'jdbc引擎最大连接数', '10', 'NumInterval', '[1,20]', '0', '0', '1', '数据源配置', 'jdbc');
+
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.auth.type', '取值范围:SIMPLE,USERNAME,KERBEROS', 'jdbc认证方式', 'USERNAME', 'OFT', '[\"SIMPLE\",\"USERNAME\",\"KERBEROS\"]', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.username', 'username', '数据库连接用户名', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.password', 'password', '数据库连接密码', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.principal', '例如:hadoop/host@KDC.COM', '用户principal', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.keytab.location', '例如:/data/keytab/hadoop.keytab', '用户keytab文件路径', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.proxy.user.property', '例如:hive.server2.proxy.user', '用户代理配置', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.java.driver.cores', '取值范围:1-8,单位:个', 'jdbc引擎初始化核心个数', '1', 'NumInterval', '[1,8]', '0', '0', '1', 'jdbc引擎设置', 'jdbc');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.java.driver.memory', '取值范围:1-8,单位:G', 'jdbc引擎初始化内存大小', '1g', 'Regex', '^([1-8])(G|g)$', '0', '0', '1', 'jdbc引擎设置', 'jdbc');
+
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@JDBC_ALL, 'OPTIONAL', 2, now(), now());
+
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+ (select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'jdbc' and label_value = @JDBC_ALL);
+
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@JDBC_IDE, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@JDBC_NODE, 'OPTIONAL', 2, now(), now());
+
+
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @JDBC_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @JDBC_NODE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+
+-- jdbc default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+ (select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @JDBC_ALL);
+```
+
+如果想重置引擎的数据库配置数据,参考文件如下,请按需进行修改使用:
+
+```sql
+-- 清除jdbc引擎的初始化数据
+SET @JDBC_LABEL="jdbc-4";
+
+SET @JDBC_ALL=CONCAT('*-*,',@JDBC_LABEL);
+SET @JDBC_IDE=CONCAT('*-IDE,',@JDBC_LABEL);
+SET @JDBC_NODE=CONCAT('*-nodeexecution,',@JDBC_LABEL);
+
+delete from `linkis_ps_configuration_config_value` where `config_label_id` in
+ (select `relation`.`engine_type_label_id` AS `config_label_id` FROM `linkis_ps_configuration_key_engine_relation` relation INNER JOIN `linkis_cg_manager_label` label ON relation.engine_type_label_id = label.id AND label.label_value = @JDBC_ALL);
+
+
+delete from `linkis_ps_configuration_key_engine_relation`
+where `engine_type_label_id` in
+ (select label.id FROM `linkis_ps_configuration_config_key` config
+ INNER JOIN `linkis_cg_manager_label` label
+ ON config.engine_conn_type = 'jdbc' and label_value = @JDBC_ALL);
+
+
+delete from `linkis_ps_configuration_category`
+where `label_id` in (select id from `linkis_cg_manager_label` where `label_value` in(@JDBC_IDE, @JDBC_NODE));
+
+
+delete from `linkis_ps_configuration_config_key` where `engine_conn_type` = 'jdbc';
+
+delete from `linkis_cg_manager_label` where `label_value` in (@JDBC_ALL, @JDBC_IDE, @JDBC_NODE);
+
+```
+
+最终的效果:
+
+![JDBC引擎](/Images-zh/EngineConnNew/jdbc_engine_conf_detail.png)
+
+这样配置完之后,linkis-cli以及Scripts提交引擎脚本时,才能正确匹配到引擎的标签信息和数据源的连接信息,然后才能拉起你新加的引擎。
+
+### 2.9 DSS Scripts中新增JDBC脚本类型以及图标等信息
+
+如果你使用到了DSS的Scripts功能,还需要对dss项目中web的前端文件进行一些小小的改动,改动的目的是为了在Scripts中支持新建、打开、执行JDBC引擎脚本类型,以及实现引擎对应的图标、字体等。
+
+#### 2.9.1 scriptis.js
+
+web/src/common/config/scriptis.js
+
+```js
+{
+ rule: /\.jdbc$/i,
+ lang: 'hql',
+ executable: true,
+ application: 'jdbc',
+ runType: 'jdbc',
+ ext: '.jdbc',
+ scriptType: 'jdbc',
+ abbr: 'jdbc',
+ logo: 'fi-jdbc',
+ color: '#444444',
+ isCanBeNew: true,
+ label: 'JDBC',
+ isCanBeOpen: true
+},
+```
+
+#### 2.9.2 脚本复制支持
+
+web/src/apps/scriptis/module/workSidebar/workSidebar.vue
+
+```js
+copyName() {
+ let typeArr = ['......', 'jdbc']
+}
+```
+
+#### 2.9.3 logo与字体配色
+
+web/src/apps/scriptis/module/workbench/title.vue
+
+```js
+ data() {
+ return {
+ isHover: false,
+ iconColor: {
+ 'fi-jdbc': '#444444',
+ },
+ };
+ },
+```
+
+web/src/apps/scriptis/module/workbench/modal.js
+
+```js
+let logoList = [
+ { rule: /\.jdbc$/i, logo: 'fi-jdbc' },
+];
+```
+
+web/src/components/tree/support.js
+
+```js
+export const supportTypes = [
+ // 这里大概没用到
+ { rule: /\.jdbc$/i, logo: 'fi-jdbc' },
+]
+```
+
+引擎图标展示
+
+web/src/dss/module/resourceSimple/engine.vue
+
+```js
+methods: {
+ calssifyName(params) {
+ switch (params) {
+ case 'jdbc':
+ return 'JDBC';
+ ......
+ }
+ }
+ // 图标过滤
+ supportIcon(item) {
+ const supportTypes = [
+ ......
+ { rule: 'jdbc', logo: 'fi-jdbc' },
+ ];
+ }
+}
+```
+
+web/src/dss/assets/projectIconFont/iconfont.css
+
+```css
+.fi-jdbc:before {
+ content: "\e75e";
+}
+```
+
+此处控制的应该是:
+
+![引擎图标](/Images-zh/EngineConnNew/jdbc_engine_logo.png)
+
+
+
+找一个引擎图标的svg文件
+
+web/src/components/svgIcon/svg/fi-jdbc.svg
+
+如果新引擎后续需要贡献社区,那么新引擎对应的svg图标、字体等需要确认其所属的开源协议,或获取其版权许可。
+
+### 2.10 DSS的工作流适配
+
+最终达成的效果:
+
+![工作流适配](/Images-zh/EngineConnNew/jdbc_job_flow.png)
+
+在dss_workflow_node表中保存新加JDBC引擎的定义数据,参考SQL:
+
+```sql
+# 引擎任务节点基本信息定义
+insert into `dss_workflow_node` (`id`, `name`, `appconn_name`, `node_type`, `jump_url`, `support_jump`, `submit_to_scheduler`, `enable_copy`, `should_creation_before_node`, `icon`) values('18','jdbc','-1','linkis.jdbc.jdbc',NULL,'1','1','1','0','svg文件');
+
+# svg文件对应新引擎任务节点图标
+
+# 引擎任务节点分类划分
+insert into `dss_workflow_node_to_group`(`node_id`,`group_id`) values (18, 2);
+
+# 引擎任务节点的基本信息(参数属性)绑定
+INSERT INTO `dss_workflow_node_to_ui`(`workflow_node_id`,`ui_id`) VALUES (18,45);
+
+# 在dss_workflow_node_ui表中定义了引擎任务节点相关的基本信息,然后以表单的形式在上图右侧中展示,你可以为新引擎扩充其他基础信息,然后自动被右侧表单渲染。
+```
+
+web/src/apps/workflows/service/nodeType.js
+
+```js
+import jdbc from '../module/process/images/newIcon/jdbc.svg';
+
+const NODETYPE = {
+ ......
+ JDBC: 'linkis.jdbc.jdbc',
+}
+
+const ext = {
+ ......
+ [NODETYPE.JDBC]: 'jdbc',
+}
+
+const NODEICON = {
+ [NODETYPE.JDBC]: {
+ icon: jdbc,
+ class: {'jdbc': true}
+ },
+}
+```
+
+在web/src/apps/workflows/module/process/images/newIcon/目录下增加新引擎的图标
+
+web/src/apps/workflows/module/process/images/newIcon/jdbc
+
+同样贡献社区时,请考虑svg文件的lincese或版权。
+
+## 3. 本章小结
+
+上述内容记录了新引擎的实现流程,以及额外需要做的一些引擎配置。目前,一个新引擎的扩展流程还是比较繁琐的,希望能在后续版本中,优化新引擎的扩展、以及安装等过程。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/new-microservice.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/new-microservice.md
new file mode 100644
index 00000000000..378b7a3dfd3
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/new-microservice.md
@@ -0,0 +1,381 @@
+---
+title: 如何实现新的微服务
+sidebar_position: 9.0
+---
+
+> 这篇文章介绍如何基于现有的Linkis微服务架构下,在本地开发调试一个新的微服务以及部署,方便有需要新增微服务的二次开发的同学参考。
+
+思维导图:
+
+![思维导图](/Images-zh/deployment/microservice/thinking.png)
+
+
+## 1. 新的微服务开发
+
+> 本文以新增微服务`linkis-new-microservice`为示例,进行介绍。 如何在IDEA中创建和注册一个属于linkis新的微服务
+
+**软件要求**
+- jdk1.8
+- maven3.5+
+
+### 1.1 新建子模块
+
+**注意**:在什么模块下新建子模块,这个并不是固定的因情况而定,一般按服务组来划分确认,这里只是举例子。
+
+- linkis-public-enhancements模块下 右键
+
+![new-module](/Images-zh/deployment/microservice/new-module.png)
+
+- 选择maven点击Nex下一步
+
+![maven-module](/Images-zh/deployment/microservice/maven-module.png)
+
+- 输入模块名点击Finsh
+
+![name-module](/Images-zh/deployment/microservice/name-module.png)
+
+- 创建成功
+
+![created-successfully](/Images-zh/deployment/microservice/created-successfully.png)
+
+#### 1.1.1 修改linkis-new-microservice模块的pom.xml文件
+
+**path**: linkis-public-enhancements/linkis-new-microservice/pom.xml
+
+```
+## 添加linkis的公共依赖模块和 mybatis模块依赖(如果不涉及数据库操作可以不添加mybatis)
+
+ org.apache.linkis
+ linkis-module
+ ${project.version}
+
+
+ org.ow2.asm
+ asm
+
+
+
+
+
+ org.apache.linkis
+ linkis-mybatis
+ ${project.version}
+
+```
+
+
+#### 1.1.2 新增服务对应的配置文件
+
+> 配置文件按 linkis-服务名.properties来命名,统一放在`linkis-dist/package/conf/`目录下,服务启动时候会加载linkis.properties 通用配置文件以及linkis-服务名.properties配置文件
+
+新增`linkis-new-microservice.properties`配置文件
+
+**path**: linkis-dist/package/conf/linkis-new-microservice.properties
+
+``` properties
+#
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+# http://www.apache.org/licenses/LICENSE-2.0
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+
+## 如不需提供接口Api则无需添加此配置
+##restful
+wds.linkis.server.restful.scan.packages=org.apache.linkis.newmicroservice.server.restful
+
+## mybatis 数据操作项目的配置
+wds.linkis.server.mybatis.mapperLocations=classpath*:org/apache/linkis/newmicroservice/server/dao/mapper/*.xml
+wds.linkis.server.mybatis.typeAliasesPackage=org.apache.linkis.newmicroservice.server.domain
+wds.linkis.server.mybatis.BasePackage=org.apache.linkis.newmicroservice.server.dao
+
+
+##切勿与其他服务的端口相同
+spring.server.port=9208
+
+```
+
+
+#### 1.1.4 开启调试模式
+
+> 方便进行接口的调式,无需进行登陆态的验证
+
+**path**: linkis-dist/package/conf/linkis.properties
+
+![test-mode](/Images-zh/deployment/microservice/test-mode.png)
+
+``` properties
+wds.linkis.test.mode=true # 打开测试模式
+wds.linkis.test.user=hadoop # 指定测试模式下,所有请求都代理给哪个用户
+
+```
+
+
+### 1.2 代码开发
+
+> 为方便大家学习,现以创建一个简单的API接口为示例。
+
+#### 1.2.1 新建接口类
+
+![new-microservice](/Images-zh/deployment/microservice/new-microservice.png)
+
+``` java
+package org.apache.linkis.newmicroservice.server.restful;
+
+
+import io.swagger.annotations.ApiOperation;
+import org.apache.linkis.server.Message;
+import org.springframework.web.bind.annotation.*;
+
+import io.swagger.annotations.Api;
+
+import java.util.HashMap;
+import java.util.Map;
+
+@Api(tags = "newmicroservice")
+@RestController
+@RequestMapping(path = "/newmicroservice")
+public class NewMicroservice {
+
+
+ @ApiOperation(value = "establish", httpMethod = "GET")
+ @RequestMapping(path = "establish", method = RequestMethod.GET)
+ public Message list() {
+ Map<String,String> map=new HashMap<>();
+ map.put("NewMicroservice","Hello! This is a new microservice I registered(这是我注册的一个新的微服务)");
+ return Message.ok("").data("map", map);
+ }
+
+}
+```
+
+#### 1.2.2 新建启动类
+
+![maven-module](/Images-zh/deployment/microservice/start-up.png)
+
+``` java
+
+package org.apache.linkis.newmicroservice.server;
+
+import org.apache.linkis.LinkisBaseServerApp;
+
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+
+public class LinkisNewMicroserviceApplication {
+
+ private static final Log logger = LogFactory.getLog(LinkisNewMicroserviceApplication.class);
+
+ public static void main(String[] args) throws ReflectiveOperationException {
+ logger.info("Start to running LinkisNewmicroserviceApplication");
+ LinkisBaseServerApp.main(args);
+ }
+}
+```
+
+### 1.3 启动eureka服务
+
+> 这一步骤的具体指引在 [调试指引](../development/debug) 文档中已有写 可直接访问,这里就不在过多介绍
+
+
+### 1.4 本地启动新微服务
+
+> 设置linkis-new-microservice的启动Application
+
+![commissioning-service](/Images-zh/deployment/microservice/commissioning-service.png)
+
+参数解释:
+
+```shell
+[Service Name]
+linkis-new-microservice
+
+[Module Name]
+linkis-new-microservice
+
+[VM Opitons]
+-DserviceName=linkis-new-microservice -Xbootclasspath/a:{YourPathPrefix}/linkis/linkis-dist/package/conf
+
+[main Class]
+org.apache.linkis.newmicroservice.server.LinkisNewmicroserviceApplication
+
+[Add provided scope to classpath]
+通过勾选Include dependencies with “Provided” scope ,可以在调试时,引入provided级别的依赖包。
+```
+
+> 上述设置完成之后,可直接运行此Application。运行成功后打开浏览器输入eureka注册中心的url
+
+``` text
+ http://ip:port/
+```
+
+![new-service](/Images-zh/deployment/microservice/new-service.png)
+
+> 当eureka注册中心出现linkis-new-microservice服务即为本地注册新的微服务成功。
+
+### 1.5 Postman 进行接口调试
+
+**URL**: http://ip:port/api/rest_j/v1/newmicroservice/establish
+
+![postman-test](/Images-zh/deployment/microservice/postman-test.png)
+
+
+
+## 2. 打包部署
+> 打包部署主要有有两个阶段 第一步是模块通过maven打包后 会将模块所需要的依赖 打包到模块对应的target目录下 linkis-new-microservice/target/out/lib。
+> 第二步是 组装完整的最终部署安装包时,需要将` linkis-new-microservice/target/out/lib` 自动拷贝至 `linkis-dist/target/apache-linkis-x.x.x-bin/linkis-package/lib`下
+
+### 2.1 修改新服务下的distribution.xml
+
+**path**: linkis-public-enhancements/linkis-new-microservice/src/main/assembly/distribution.xml
+
+![new-distribution](/Images-zh/deployment/microservice/new-distribution.png)
+
+> 由于需要排除的依赖比较多这里只贴部分代码
+
+``` xml
+
+ antlr:antlr:jar
+ aopalliance:aopalliance:jar
+ com.fasterxml.jackson.core:jackson-annotations:jar
+ com.fasterxml.jackson.core:jackson-core:jar
+
+```
+
+> 这里解释下为什么需要加`excludes`,因为服务启动脚本 linkis-dist/package/sbin/ext/linkis-common-start 中一般会默认加载通用的lib
+
+![common-start](/Images-zh/deployment/microservice/common-start.png)
+
+> 所以在打包服务依赖时候,可以排除已有的lib包.详细可以参考linkis-computation-governance/linkis-entrance/src/main/assembly/distribution.xml
+
+
+### 2.2 修改linkis-dist下的distribution.xml
+
+**path**: linkis-dist/src/main/assembly/distribution.xml
+
+
+> 添加fileSet 配置,改配置主要是控制编译打包时的能输出linkis-new-microservice服务包
+
+![fileset](/Images-zh/deployment/microservice/fileset.png)
+
+> 这里只贴出来需要新增的配置内容。
+
+``` xml
+
+
+ ../linkis-public-enhancements/linkis-new-microservice/target/out/lib
+
+
+ linkis-package/lib/linkis-public-enhancements/linkis-new-microservice
+
+
+ **/*
+
+
+
+```
+
+### 2.3 服务的运行配置脚本
+
+![new-configuration](/Images-zh/deployment/microservice/new-configuration.png)
+
+``` text
+
+#!/usr/bin/env bash
+#
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+# http://www.apache.org/licenses/LICENSE-2.0
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# description: manager start cmd
+#
+# Modified for Linkis 1.0.0
+
+
+export SERVER_SUFFIX="linkis-public-enhancements/linkis-new-microservice"
+
+
+export SERVER_CLASS=org.apache.linkis.newmicroservice.server.LinkisNewMicroserviceApplication
+
+#export DEBUG_PORT=
+
+export COMMON_START_BIN=$LINKIS_HOME/sbin/ext/linkis-common-start
+if [[ ! -f "${COMMON_START_BIN}" ]]; then
+ echo "The $COMMON_START_BIN does not exist!"
+ exit 1
+else
+ sh $COMMON_START_BIN
+fi
+
+```
+
+
+### 2.4 linkis-start-all.sh 配置修改
+
+**path**: linkis-dist/package/sbin/linkis-start-all.sh
+
+![start-script](/Images-zh/deployment/microservice/start-script.png)
+
+> 这里只贴出来需要新增的配置内容。
+
+``` text
+ ## 启动脚本
+ #linkis-new-microservice
+ SERVER_NAME="new-microservice"
+ startApp
+```
+
+![detection-script](/Images-zh/deployment/microservice/detection-script.png)
+
+> 这里只贴出来需要新增的配置内容。
+
+``` text
+ ##检测脚本
+ #linkis-new-microservice
+ SERVER_NAME="new-microservice"
+ checkServer
+```
+
+### 2.5 linkis-stop-all.sh 配置修改
+
+**path**:linkis-dist/package/sbin/linkis-stop-all.sh
+
+![stop-script](/Images-zh/deployment/microservice/stop-script.png)
+
+> 这里只贴出来需要新增的配置内容。
+
+``` text
+ ## 停止脚本
+ #linkis-new-microservice
+ export SERVER_NAME="new-microservice"
+ stopApp
+```
+
+### 2.6 安装包准备
+
+> 这一步骤的具体指引在 [后端编译](../development/build) 文档中已有写 可直接访问,这里就不在过多介绍
+
+### 2.7 服务器部署
+
+> 这里为单机部署做示例,而该步骤的具体指引在 [单机部署](../deployment/deploy-quick) 文档中已有写 可直接访问,这里就不在过多介绍
+当安装部署成功后可直接在浏览器中访问eureka注册中心,看中心是否已经成功注册linkis-new-microservice服务,如注册成功即为创建新的微服务成功。
+
+![new-service](/Images-zh/deployment/microservice/new-service.png)
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/swwager.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/swwager.md
new file mode 100644
index 00000000000..9b570a3f7af
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/swwager.md
@@ -0,0 +1,261 @@
+---
+title: Swagger 注解使用
+sidebar_position: 10.0
+---
+
+## 1. Swagger注解的作用域
+| API| 作用范围 | 使用位置 |
+| -------- | -------- | ----- |
+|@Api|协议集描述|用于controller类上|
+|@ApiOperation|协议描述|用在controller的方法上|
+|@ApiImplicitParams|非对象参数集|用在controller的方法上|
+|@ApiImplicitParam|非对象参数描述|用在@ApiImplicitParams的方法里边|
+|@ApiResponses|Response集|用在controller的方法上|
+|@ApiResponse|Response|用在 @ApiResponses里边|
+|@ApiModel|描述返回对象的意义| 用在返回对象类上|
+|@ApiModelProperty|对象属性|用在出入参数对象的字段上|
+|@ApiParam|协议描述|用在方法、参数、类的字段上|
+
+## 2. @Api
+使用位置即用在类上,对请求类进行描述。标识一个Controller类是Swagger文档类。
+
+### 2.1 注解的属性
+
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|描述,无实际意义。|
+|tags|String[]|""|分组|
+|basePath|String|""|基本路径|
+|protocols|String|int|请求协议|
+|authorizations|Authorization[]|@Authorization(value = "")|高级特性认证时的配置|
+|hidden|boolean|false|是否隐藏(不显示,默认为false)|
+
+
+### 2.2 属性value、tags二者的区别
+
+value属性作用在类和作用在方法上都用于描述;
+
+tags属性作用在类和作用在方法上都用于分组,但分组的效果区别很大:
+
+tags作用在类上时,会对全局的方法分组,即根据tags属性值复制多份,此时方法上的tags值无效,方法上tags配或不配效果都一样。
+
+tags作用在方法上时,会根据当前类的所有方法的tags值做分组,粒度更细。
+
+### 2.3 使用方法
+注意:java和scala在@Api注解上使用的区别
+
+```java
+*java
+@Api(tags = "Swagger测试相关接口")
+@RestController
+
+*scala
+@Api(tags = Array("Swagger测试相关接口"))
+@RestController
+```
+
+
+
+## 3. @ApiOperation
+用在方法上,对请求方法进行描述。
+### 3.1 注解的属性
+
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|描述|
+|notes|String|""| 详细描述|
+|tags|String[]|""|分组|
+|response|Class>|Void.class|响应参数类型|
+|responseReference|String[]|""|指定对响应类型的引用,本地/远程引用,并将覆盖任何其它指定的response()类|
+|httpMethod|String|""|http请求方式,如:GET、HEAD、POST、PUT、DELETE、OPTION、SPATCH|
+|hidden|boolean|false|是否隐藏(不显示)默认为false|
+|code|int|200|http的状态码|
+|extensions|Extension[]|@Extension(properties = @ExtensionProperty(name = "", value = "")|扩展属性|
+
+### 3.2 使用方法
+
+```java
+@GetMapping("test1")
+@ApiOperation(value = "test1接口",notes = "test1接口详细描述")
+public ApiResult test1(@RequestParam String aa, @RequestParam String bb, @RequestParam String cc) {
+ return ApiUtil.success("success");
+}
+```
+
+## 4. @ApiImplicitParams
+
+常用在方法上,对请求参数列表进行描述。
+其中的value属性可包含多个@ApiImplicitParam,对每个参加进行具体的描述。
+
+### 4.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|描述|
+
+## 5. @ApiImplicitParams
+
+用在方法上,对请求参数进行描述。当需要对多个参数进行描述时,作为@ApiImplicitParams的属性使用。
+
+### 5.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|描述|
+|name|String|""|参数说明|
+|defaultValue|String|""|默认值|
+|allowableValues|String|""|参数允许值|
+|required|boolean|false|是否必填,默认false|
+|access|String|""|参数过滤|
+|allowMultiple|boolean|false|参数是否可以通过多次出现来接受多个值,默认不允许|
+|dataType|String|""|参数的数据类型,可以使类名或原始数据类型|
+|dataTypeClass|Class>|Void.class|参数的数据类型,如果提供则覆盖 dataType|
+|paramType|String|""|参数类型,有效值为 path, query, body, header, form|
+|example|String|""|非body类型的参数示例|
+|examples|Example|@Example(value = @ExampleProperty(mediaType = “”, value = “”))|body类型的参数示例|
+|type|String|""|添加覆盖检测到的类型的功能|
+|format|String|""|添加提供自定义format格式的功能|
+|readOnly|boolean|false|添加被指定为只读的功能|
+
+### 5.2 使用方法
+
+```java
+@GetMapping("test1")
+@ApiOperation(value = "test1接口",notes = "test1接口详细描述")
+@ApiImplicitParams(value = {
+ @ApiImplicitParam(name = "aa",value = "aa的说明",defaultValue = "1",allowableValues = "1,2,3",required = true),
+ @ApiImplicitParam(name = "bb",value = "bb的说明",defaultValue = "1",allowableValues = "1,2,3",required = true),
+ @ApiImplicitParam(name = "cc",value = "cc的说明",defaultValue = "2",allowableValues = "1,2,3",required = true),
+
+})
+```
+
+## 6. @ApiParam
+
+用在方法、参数、类的字段上,对请求参数进行描述。
+
+### 6.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|描述|
+|name|String|""|参数说明|
+|defaultValue|String|""|默认值|
+|allowableValues|String|""|参数允许值|
+|required|boolean|false|是否必填,默认false|
+|access|String|""|参数过滤|
+|allowMultiple|boolean|false|参数是否可以通过多次出现来接受多个值,默认不允许|
+|dataType|String|""|参数的数据类型,可以使类名或原始数据类型|
+|dataTypeClass|Class>|Void.class|参数的数据类型,如果提供则覆盖 dataType|
+|paramType|String|""|参数类型,有效值为 path, query, body, header, form|
+|example|String|""|非body类型的参数示例|
+|examples|Example|@Example(value = @ExampleProperty(mediaType = “”, value = “”))|body类型的参数示例|
+|type|String|""|添加覆盖检测到的类型的功能|
+|format|String|""|添加提供自定义format格式的功能|
+|readOnly|boolean|false|添加被指定为只读的功能|
+
+### 6.2 使用方法
+
+```java
+@GetMapping("test2")
+@ApiOperation(value = "test2接口",notes = "test2接口详细描述")
+public ApiResult test2(@ApiParam(value = "aa的说明") @RequestParam String aa, @ApiParam(value = "bb的说明") @RequestParam String bb) {
+ return ApiUtil.success(new TestRes());
+}
+```
+## 7. @ApiModel
+
+用在类上,对请求、响应类,实体类进行描述。
+
+### 7.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""| 为提供模型的替代名称,默认情况下,使用类名|
+|description|String|""|类的描述|
+|parent|Class> parent|Void.class|为模型提供父类以允许描述继承关系|
+|discriminatory|String|""|支持模型继承和多态,使用鉴别器的字段的名称,可以断言需要使用哪个子类型|
+|subTypes|boolean|false|是否必填,默认false|
+|access|Class> parent|Void.class| 从此模型继承的子类型数组|
+|reference|boolean|false|指定对应类型定义的引用,覆盖指定的任何其他元数据|
+
+## 8 @ApiModelProperty
+
+用在类上,对请求、响应类,实体类进行描述。
+
+### 8.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|String|""|属性说明|
+|name|String|""|覆盖属性的名称|
+|allowableValues|String|""|参数允许值|
+|access|String|""|过滤属性|
+|required|boolean|false|是否必填,默认false|
+|dataType|String|""|参数的数据类型,可以使类名或原始数据类型|
+|hidden|boolean|false| 是否隐藏|
+|readOnly|String|""|添加被指定为只读的功能|
+|reference|String|""|指定对应类型定义的引用,覆盖指定的任何其他元数据|
+|allowEmptyValue|boolean|false|允许传空值|
+|example|String|""|属性的示例值|
+
+### 8.2 使用方法
+
+注意:java和scala在@ApiModelProperty注解上的使用的区别
+
+```java
+*java实体类
+@Data
+@ApiModel(description = "测试请求类")
+public class TestReq {
+
+ @ApiModelProperty(value = "用户ID",required = true)
+ private Long userId;
+ @ApiModelProperty(value = "用户名",example = "张三")
+}
+
+*scala实体类
+@Data
+@ApiModel(description = "测试响应类")
+public class TestRes {
+ @(ApiModelProperty @field)("用户ID")
+ private Long userId;
+ @(ApiModelProperty @field)("用户名")
+}
+```
+
+
+## 9. @ApiResponses
+
+用在方法、类上,对响应状态码列表进行描述。
+
+### 9.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|value|ApiResponse[]|""|响应状态码列表的描述|
+
+## 10. @ApiResponse
+
+用在方法上,对响应状态码进行描述。一般作为@ApiResponses的属性使用。
+
+### 10.1 注解的属性
+| 属性名称 | 属性类型 | 属性默认值 | 属性描述 |
+| -------- | -------- | ----- |----- |
+|code|int|""|响应的HTTP状态码|
+|message|String|""|响应的描述|
+|response|Class>|Void.class|用于描述消息有效负载的可选响应类,对应于响应消息对象的 schema 字段|
+|reference|String|""|指定对响应类型的引用,指定的应用可以使本地引用,也可以是远程引用,将按原样使用,并将覆盖任何指定的response()类|
+|responseHeaders|ResponseHeader[]|@ResponseHeader(name = "", response = Void.class)|可能响应的header列表|
+|responseContainer|String|""|声明响应的容器,有效值为List,Set,Map,任何其他值都将被忽略|
+
+
+### 10.2 使用方法
+
+```java
+@GetMapping("test2")
+@ApiOperation(value = "test2接口",notes = "test2接口详细描述")
+@ApiResponses(value = {
+ @ApiResponse(code = 200, message = "请求成功", responseHeaders = {@ResponseHeader(name = "header1", description = "header1的描述",response = String.class)}),
+ @ApiResponse(code = 401, message = "没有权限"),
+ @ApiResponse(code = 403, message = "禁止访问")
+})
+public ApiResult test2(@ApiParam(value = "aa的说明") @RequestParam String aa, @ApiParam(value = "bb的说明") @RequestParam String bb) {
+ return ApiUtil.success(new TestRes());
+}
+
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/table/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/table/_category_.json
new file mode 100644
index 00000000000..f565b1d581f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/table/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "表结构",
+ "position": 13
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/table/all.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/table/all.md
new file mode 100644
index 00000000000..e3d78b25c0f
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/table/all.md
@@ -0,0 +1,1782 @@
+---
+title: 库表结构
+sidebar_position: 1
+---
+
+## 1. linkis_cg_ec_resource_info_record
+
+> 历史引擎信息记录表 ec 为`engine conn` 缩写 ecm为 engineconn manager 服务缩写
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_value` | ec 的label标签 stringValue 如 `userCreator, engineType`->`hadoop-LINKISCLI,shell-1`| varchar(255) | | NO | | |
+| 3 | `create_user` | ec 的创建用户| varchar(128) | | NO | | |
+| 4 | `service_instance` | ec 实例信息 如 bdpdev01dss02:19756| varchar(128) | | YES | | |
+| 5 | `ecm_instance` | ecm 实例信息 如bdpdev01dss02:9102 | varchar(128) | | YES | | |
+| 6 | `ticket_id` | ec 的 ticket id | varchar(100) | MUL | NO | | |
+| 7 | `log_dir_suffix` | ec 日志log所在的路径 | varchar(128) | | YES | | |
+| 8 | `request_times` | 资源请求次数 | int(8) | | YES | | |
+| 9 | `request_resource` | 请求的资源 | varchar(1020) | | YES | | |
+| 10 | `used_times` | 资源使用次数 | int(8) | | YES | | |
+| 11 | `used_resource` | 使用的资源信息 | varchar(1020) | | YES | | |
+| 12 | `release_times` | 释放资源次数 | int(8) | | YES | | |
+| 13 | `released_resource` | 释放的资源 | varchar(1020) | | YES | | |
+| 14 | `release_time` | 释放的时间 | datetime | | YES | | |
+| 15 | `used_time` | 使用时间 | datetime | | YES | | |
+| 16 | `create_time` | 创建时间| datetime | | YES | | CURRENT_TIMESTAMP |
+
+
+**示例数据**
+
+| id | label_value | create_user | service_instance | ecm_instance | ticket_id | status | log_dir_suffix | request_times | request_resource | used_times | used_resource | release_times | released_resource | release_time | used_time | create_time |
+| ---: | --- | --- | --- | --- | --- | --- | --- | ---: | --- | ---: | --- | ---: | --- | --- | --- | --- |
+| 1 | hadoop-LINKISCLI,shell-1 | hadoop | bdpdev01dss02:19756 | bdpdev01dss02:9102 | fc0d442d-7e18-49f6-a01e-a4f4685f0155 | ShuttingDown | hadoop/20221025/shell/fc0d442d-7e18-49f6-a01e-a4f4685f0155/logs | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 2022-10-25 17:55:41 | 2022-10-25 17:53:09 | 2022-10-25 17:52:56 |
+| 2 | hadoop-LINKISCLI,hive-2.3.3 | hadoop | bdpdev01dss02:20903 | bdpdev01dss02:9102 | 63ea31dc-65b1-42c4-8963-5fe4468f0ae0 | ShuttingDown | hadoop/20221025/hive/63ea31dc-65b1-42c4-8963-5fe4468f0ae0/logs | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 2022-10-25 17:55:52 | 2022-10-25 17:54:36 | 2022-10-25 17:54:20 |
+| 3 | hadoop-LINKISCLI,python-python2 | hadoop | bdpdev01dss02:21320 | bdpdev01dss02:9102 | 3f8a4f73-fdbb-407e-ae1b-0b14b9d08bcf | ShuttingDown | hadoop/20221025/python/3f8a4f73-fdbb-407e-ae1b-0b14b9d08bcf/logs | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 1 | {"instance":1,"memory":"1024.0 MB","cpu":1} | 2022-10-25 17:57:41 | 2022-10-25 17:55:55 | 2022-10-25 17:55:44 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_tid` | 将`ticket_id` 列设置为普通索引 | INDEX | `ticket_id` |
+| 2 | `uniq_tid_lv` | 将`ticket_id`,`label_value`列设置为唯一索引 | UNIQUE KEY | `ticket_id`,`label_value` |
+
+
+
+## 2. linkis_cg_engine_conn_plugin_bml_resources
+
+> 引擎物料存储信息表 主要用于引擎实例启动时,根据对应的物料资源的进行下载,以及进行引擎物料刷新时会使用到。
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary key | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `engine_conn_type` |引擎名 如 hive | varchar(100) | | NO | | |
+| 3 | `version` | 物料版本 | varchar(100) | | YES | | |
+| 4 | `file_name` | 文件名 conf.zip/lib.zip | varchar(255) | | YES | | |
+| 5 | `file_size` | 大小 byte | bigint(20) | | NO | | 0 |
+| 6 | `last_modified` |最新修改时间| bigint(20) | | YES | | |
+| 7 | `bml_resource_id` | bml物料id | varchar(100) | | NO | | |
+| 8 | `bml_resource_version` | bml物料版本 | varchar(200) | | NO | | |
+| 9 | `create_time` | created time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 10 | `last_update_time` | updated time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | engine_conn_type | version | file_name | file_size | last_modified | bml_resource_id | bml_resource_version | create_time | last_update_time |
+| ---: | --- | --- | --- | ---: | ---: | --- | --- | --- | --- |
+| 3 | hive | 2.3.3 | conf.zip | 2363 | 1666683401000 | 8f9879b4-9950-43c9-8eca-5f570211e784 | v000001 | 2022-10-25 15:42:08 | 2022-10-25 15:42:08 |
+| 4 | hive | 2.3.3 | lib.zip | 106319116 | 1666683401000 | ac77aa15-e873-4f5f-9ed1-17435cad390f | v000001 | 2022-10-25 15:42:13 | 2022-10-25 15:42:13 |
+| 5 | elasticsearch | 7.6.2 | conf.zip | 1981 | 1666683401000 | f17874ca-54fa-4153-8edb-a4d31268847b | v000001 | 2022-10-25 15:42:14 | 2022-10-25 15:42:14 |
+| 6 | elasticsearch | 7.6.2 | lib.zip | 15935016 | 1666683401000 | 2f340471-a495-4b93-a197-b8eb362d04bb | v000001 | 2022-10-25 15:42:15 | 2022-10-25 15:42:15 |
+
+
+
+## 3. linkis_cg_manager_engine_em
+
+>引擎实例engine conn 和归属的ecm(engine conn manager)实例的关系表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `engine_instance` | ec 实例信息 | varchar(128) | | YES | | |
+| 3 | `em_instance` | ecm 实例信息 | varchar(128) | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | engine_instance | em_instance | update_time | create_time |
+| ---: | --- | --- | --- | --- |
+| 223 | localhost110003:10394 | localhost110003:9102 | 2022-11-12 23:30:09 | 2022-11-12 23:30:09 |
+| 224 | localhost110003:33483 | localhost110003:9102 | 2022-11-12 23:30:48 | 2022-11-12 23:30:48 |
+| 226 | localhost110003:19782 | localhost110003:9102 | 2022-11-13 01:48:05 | 2022-11-13 01:48:05 |
+
+
+
+## 4. linkis_cg_manager_label
+
+> 标签记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_key` | 标签 label | varchar(32) | MUL | NO | | |
+| 3 | `label_value` | 标签值 json格式 | varchar(255) | | NO | | |
+| 4 | `label_feature` | | varchar(16) | | NO | | |
+| 5 | `label_value_size` | 标签存储的元素个数 | int(20) | | NO | | |
+| 6 | `update_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 7 | `create_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+
+
+**示例数据**
+
+| id | label_key | label_value | label_feature | label_value_size | update_time | create_time |
+| ---: | --- | --- | --- | ---: | --- | --- |
+| 19 | combined_userCreator_engineType | *-nodeexecution,python-python2 | OPTIONAL | 2 | 2021-06-08 20:25:28 | 2021-06-08 20:25:28 |
+| 21 | serverAlias | {"alias":"linkis-cg-engineconnmanager"} | OPTIONAL | 1 | 2021-06-08 20:27:07 | 2021-06-08 20:27:07 |
+| 24 | combined_userCreator_engineType | {"creator":"IDE","user":"hadoop","engineType":"hive","version":"2.3.3"} | OPTIONAL | 4 | 2021-06-08 20:42:00 | 2021-06-08 20:42:00 |
+| 26 | userCreator | {"creator":"IDE","user":"hadoop"} | OPTIONAL | 2 | 2021-06-08 20:42:07 | 2021-06-08 20:42:07 |
+| 27 | engineType | {"engineType":"hive","version":"2.3.3"} | OPTIONAL | 2 | 2021-06-08 20:42:07 | 2021-06-08 20:42:07 |
+| 28 | serverAlias | {"alias":"EngineConn"} | OPTIONAL | 1 | 2021-06-08 20:42:07 | 2021-06-08 20:42:07 |
+| 29 | codeType | {"codeType":"hql"} | OPTIONAL | 1 | 2021-06-08 20:42:16 | 2021-06-08 20:42:16 |
+| 30 | combined_userCreator_engineType | {"creator":"IDE","user":"root","engineType":"io_file","version":"1.0"} | OPTIONAL | 4 | 2021-06-08 20:50:47 | 2021-06-08 20:50:47 |
+| 32 | userCreator | {"creator":"IDE","user":"root"} | OPTIONAL | 2 | 2021-06-08 20:50:52 | 2021-06-08 20:50:52 |
+| 33 | concurrentEngineConn | {} | OPTIONAL | 0 | 2021-06-08 20:50:52 | 2021-06-08 20:50:52 |
+| 34 | engineType | {"engineType":"io_file","version":"1.0"} | OPTIONAL | 2 | 2021-06-08 20:50:52 | 2021-06-08 20:50:52 |
+| 35 | codeType | {"codeType":"io_file"} | OPTIONAL | 1 | 2021-06-08 20:50:59 | 2021-06-08 20:50:59 |
+| 36 | combined_userCreator_engineType | johnnwang-*,*-* | OPTIONAL | 2 | 2021-06-08 22:07:07 | 2021-06-08 22:07:07 |
+| 37 | combined_userCreator_engineType | {"creator":"IDE","user":"johnnwang","engineType":"flink","version":"1.11.1"} | OPTIONAL | 4 | 2021-06-08 22:07:20 | 2021-06-08 22:07:20 |
+| 39 | userCreator | {"creator":"IDE","user":"johnnwang"} | OPTIONAL | 2 | 2021-06-08 22:07:26 | 2021-06-08 22:07:26 |
+| 40 | engineType | {"engineType":"flink","version":"1.11.1"} | OPTIONAL | 2 | 2021-06-08 22:07:26 | 2021-06-08 22:07:26 |
+| 41 | combined_userCreator_engineType | {"creator":"IDE","user":"johnnwang","engineType":"spark","version":"2.4.3"} | OPTIONAL | 4 | 2021-06-08 22:07:37 | 2021-06-08 22:07:37 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lk_lv` | 将`label_key`,`label_value` 列设置为唯一索引 | UNIQUE KEY | `label_key`,`label_value` |
+
+
+
+
+## 5. linkis_cg_manager_label_resource
+
+> 标签id 和资源id 的关联关系表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_id` | linkis_cg_manager_label的id | int(20) | UNI | YES | | |
+| 3 | `resource_id` | linkis_cg_manager_linkis_resources对应的id | int(20) | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | label_id | resource_id | update_time | create_time |
+| ---: | ---: | ---: | --- | --- |
+| 14217 | 13266 | 14218 | 2022-11-12 23:09:36 | 2022-11-12 23:09:36 |
+| 14218 | 24 | 14219 | 2022-11-12 23:30:09 | 2022-11-12 23:30:09 |
+| 14219 | 13267 | 14220 | 2022-11-12 23:30:09 | 2022-11-12 23:30:09 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_label_id` | 将`label_id` 列设置为唯一索引 | UNIQUE KEY | `label_id` |
+
+
+
+
+## 6. linkis_cg_manager_label_service_instance
+
+>引擎实例engine conn/ecm(engine conn manager)实例 标签记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_id` | linkis_cg_manager_label的id | int(20) | MUL | YES | | |
+| 3 | `service_instance` | 实例信息 | varchar(128) | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+
+**示例数据**
+
+| id | label_id | service_instance | update_time | create_time |
+| ---: | ---: | --- | --- | --- |
+| 200 | 94 | bdpdev01dss02:33755 | 2022-11-14 17:11:26 | 2022-11-14 17:11:26 |
+| 201 | 105 | bdpdev01dss02:9102 | 2022-11-15 14:54:56 | 2022-11-15 14:54:56 |
+| 202 | 23 | bdpdev01dss02:9102 | 2022-11-15 14:54:56 | 2022-11-15 14:54:56 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_lid_instance` | 将`label_id`,`service_instance` 列设置为普通索引 | INDEX | `label_id`,`service_instance` |
+
+
+
+## 7. linkis_cg_manager_label_user
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `username` | | varchar(255) | | YES | | |
+| 3 | `label_id` | | int(20) | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+
+## 8. linkis_cg_manager_label_value_relation
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_value_key` | | varchar(255) | MUL | NO | | |
+| 3 | `label_value_content` | | varchar(255) | | YES | | |
+| 4 | `label_id` | | int(20) | | YES | | |
+| 5 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 6 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lvk_lid` | 将`label_value_key`,`label_id` 列设置为唯一索引 | UNIQUE KEY | `label_value_key`,`label_id` |
+
+
+
+**示例数据**
+
+| label_value_key | label_value_content | label_id | update_time | create_time |
+| --- | --- | ---: | --- | --- |
+| creator | IDE | 7589 | 2022-05-16 19:31:13 | 2022-05-16 19:31:13 |
+| user | owenxu | 7589 | 2022-05-16 19:31:13 | 2022-05-16 19:31:13 |
+| creator | mide | 7511 | 2022-05-12 10:40:27 | 2022-05-12 10:40:27 |
+| user | davidhua | 7511 | 2022-05-12 10:40:27 | 2022-05-12 10:40:27 |
+
+
+## 9. linkis_cg_manager_linkis_resources
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `max_resource` | | varchar(1020) | | YES | | |
+| 3 | `min_resource` | | varchar(1020) | | YES | | |
+| 4 | `used_resource` | | varchar(1020) | | YES | | |
+| 5 | `left_resource` | | varchar(1020) | | YES | | |
+| 6 | `expected_resource` | | varchar(1020) | | YES | | |
+| 7 | `locked_resource` | | varchar(1020) | | YES | | |
+| 8 | `resourceType` | | varchar(255) | | YES | | |
+| 9 | `ticketId` | | varchar(255) | | YES | | |
+| 10 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 11 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 12 | `updator` | | varchar(255) | | YES | | |
+| 13 | `creator` | | varchar(255) | | YES | | |
+
+**示例数据**
+
+| id | max_resource | min_resource | used_resource | left_resource | expected_resource | locked_resource | resourceType | ticketId | update_time | create_time | updator | creator |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
+| 14219 | {"memory":21474836480,"cores":10,"instance":10} | {"memory":0,"cores":0,"instance":0} | {"memory":1073741824,"cores":1,"instance":1} | {"memory":20401094656,"cores":9,"instance":9} | \N | {"memory":0,"cores":0,"instance":0} | LoadInstance | \N | \N | 2022-11-12 23:30:09 | hadoop-IDE,hive-2.3.3 | hadoop-IDE,hive-2.3.3 |
+| 14220 | {"memory":1073741824,"cores":1,"instance":1} | {"memory":1073741824,"cores":1,"instance":1} | {"memory":1073741824,"cores":1,"instance":1} | {"memory":0,"cores":0,"instance":0} | \N | {"memory":0,"cores":0,"instance":0} | LoadInstance | 24f8c8a8-d481-4976-a11a-5765f81d9795 | \N | 2022-11-12 23:30:09 | hadoop-IDE,hive-2.3.3 | hadoop-IDE,hive-2.3.3 |
+| 14221 | {"DriverAndYarnResource":{"loadInstanceResource":{"memory":21474836480,"cores":10,"instances":5},"yarnResource":{"queueMemory":322122547200,"queueCores":150,"queueInstances":30,"queueName":"dws","applicationId":""}}} | {"DriverAndYarnResource":{"loadInstanceResource":{"memory":0,"cores":0,"instances":0},"yarnResource":{"queueMemory":0,"queueCores":0,"queueInstances":0,"queueName":"default","applicationId":""}}} | {"DriverAndYarnResource":{"loadInstanceResource":{"memory":1073741824,"cores":1,"instances":1},"yarnResource":{"queueMemory":6442450944,"queueCores":4,"queueInstances":0,"queueName":"dws","applicationId":""}}} | {"DriverAndYarnResource":{"loadInstanceResource":{"memory":20401094656,"cores":9,"instances":4},"yarnResource":{"queueMemory":315680096256,"queueCores":146,"queueInstances":30,"queueName":"dws","applicationId":""}}} | \N | {"DriverAndYarnResource":{"loadInstanceResource":{"memory":0,"cores":0,"instances":0},"yarnResource":{"queueMemory":0,"queueCores":0,"queueInstances":0,"queueName":"dws","applicationId":""}}} | DriverAndYarn | \N | \N | 2022-11-12 23:30:47 | hadoop-IDE,spark-2.4.3 | hadoop-IDE,spark-2.4.3 |
+
+
+## 10. linkis_cg_manager_lock
+
+> 通用的用于实现分布式锁
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `lock_object` | | varchar(255) | UNI | YES | | |
+| 3 | `time_out` | | longtext | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+
+## 11. linkis_cg_manager_metrics_history
+
+//todo 可以移除?
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `instance_status` | | int(20) | | YES | | |
+| 3 | `overload` | | varchar(255) | | YES | | |
+| 4 | `heartbeat_msg` | | varchar(255) | | YES | | |
+| 5 | `healthy_status` | | int(20) | | YES | | |
+| 6 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 7 | `creator` | | varchar(255) | | YES | | |
+| 8 | `ticketID` | | varchar(255) | | YES | | |
+| 9 | `serviceName` | | varchar(255) | | YES | | |
+| 10 | `instance` | | varchar(255) | | YES | | |
+
+
+## 12. linkis_cg_manager_service_instance
+
+> 引擎服务实例/引擎资源管理服务实例 信息表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `instance` | 实例信息 localhost110004:9102| varchar(128) | UNI | YES | | |
+| 3 | `name` | 服务名 linkis-cg-engineconnmanager/linkis-cg-engineconn | varchar(32) | | YES | | |
+| 4 | `owner` | 服务实例的启动用户| varchar(32) | | YES | | |
+| 5 | `mark` | //todo | varchar(32) | | YES | | |
+| 6 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 7 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 8 | `updator` | | varchar(32) | | YES | | |
+| 9 | `creator` | | varchar(32) | | YES | | |
+
+**示例数据**
+
+| id | instance | name | owner | mark | update_time | create_time | updator | creator |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- |
+| 121637 | localhost110004:9102 | linkis-cg-engineconnmanager | hadoop | process | 2022-11-08 09:52:08 | 2022-11-08 09:52:08 | hadoop | hadoop |
+| 121640 | localhost110002:9102 | linkis-cg-engineconnmanager | hadoop | process | 2022-11-08 09:52:16 | 2022-11-08 09:52:16 | hadoop | hadoop |
+| 121686 | gz.xg.localhost110001.webank:35932 | linkis-cg-engineconn | neiljianliu | process | 2022-11-08 10:40:39 | 2022-11-08 10:40:23 | neiljianliu | neiljianliu |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_instance` | 将`instance` 列设置为唯一索引 | UNIQUE KEY | `instance` |
+
+
+
+## 13. linkis_cg_manager_service_instance_metrics
+
+> 引擎服务实例/引擎资源管理服务的内存等信息 指标表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `instance` | 实例| varchar(128) | PRI | NO | | |
+| 2 | `instance_status` |状态 | int(11) | | YES | | |
+| 3 | `overload` | 资源过载情况 | varchar(255) | | YES | | |
+| 4 | `heartbeat_msg` | 心跳信息| text | | YES | | |
+| 5 | `healthy_status` | 心跳状态| varchar(255) | | YES | | |
+| 6 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 7 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| instance | instance_status | overload | heartbeat_msg | healthy_status | update_time | create_time |
+| --- | ---: | --- | --- | --- | --- | --- |
+| localhost110003:9102 | 5 | {"maxMemory":67385790464,"usedMemory":3662913536,"systemCPUUsed":null,"systemLeftMemory":63722876928} | | {"nodeHealthy":"Healthy","msg":""} | 2022-11-16 14:29:56 | 2022-11-15 15:59:17 |
+| localhost110004:10781 | 1 | {"maxMemory":1073741824,"usedMemory":175014896,"systemCPUUsed":6.29,"systemLeftMemory":2746556416} | \N | {"nodeHealthy":"Healthy","msg":""} | 2022-11-16 14:30:18 | 2022-11-16 11:53:48 |
+| localhost110004:12845 | 1 | {"maxMemory":1073741824,"usedMemory":104839664,"systemCPUUsed":6.29,"systemLeftMemory":2800877568} | \N | {"nodeHealthy":"Healthy","msg":""} | 2022-11-16 14:30:17 | 2022-11-16 12:03:20 |
+
+
+## 14. linkis_cg_rm_external_resource_provider
+
+> 资源扩展信息配置表 目前主要用于yarn资源信息的配置
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(10) | PRI | NO | auto_increment | |
+| 2 | `resource_type` | 资源类型 Yarn| varchar(32) | | NO | | |
+| 3 | `name` | 名称| varchar(32) | | NO | | |
+| 4 | `labels` | 标签| varchar(32) | | YES | | |
+| 5 | `config` | 连接信息 | text | | NO | | |
+
+
+```scala
+//默认使用的为default 通过配置项wds.linkis.rm.default.yarn.cluster.name 控制
+ val DEFAULT_YARN_CLUSTER_NAME = CommonVars("wds.linkis.rm.default.yarn.cluster.name", "default")
+ val DEFAULT_YARN_TYPE = CommonVars("wds.linkis.rm.default.yarn.cluster.type", "Yarn")
+```
+
+**示例数据**
+
+| id | resource_type | name | labels | config |
+| ---: | --- | --- | --- | --- |
+| 1 | Yarn | sit | \N | {"rmWebAddress": "http://127.0.0.1:8088","hadoopVersion": "2.7.2","authorEnable":true,"user":"hadoop","pwd":"123456"} |
+| 2 | Yarn | DEV | \N | {"rmWebAddress": "http://127.0.0.1:8088","hadoopVersion": "2.7.2","authorEnable":true,"user":"hadoop","pwd":"123456"} |
+| 3 | Yarn | PROD | \N | {"rmWebAddress": "http://127.0.0.1:8088","hadoopVersion": "2.7.2","authorEnable":true,"user":"hadoop","pwd":"123456"} |
+
+
+
+
+## 15. linkis_cg_rm_resource_action_record
+
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_value` | | varchar(100) | MUL | NO | | |
+| 3 | `ticket_id` | | varchar(100) | | NO | | |
+| 4 | `request_times` | | int(8) | | YES | | |
+| 5 | `request_resource_all` | | varchar(100) | | YES | | |
+| 6 | `used_times` | | int(8) | | YES | | |
+| 7 | `used_resource_all` | | varchar(100) | | YES | | |
+| 8 | `release_times` | | int(8) | | YES | | |
+| 9 | `release_resource_all` | | varchar(100) | | YES | | |
+| 10 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 11 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | label_value | ticket_id | request_times | request_resource_all | used_times | used_resource_all | release_times | release_resource_all | update_time | create_time |
+| ---: | --- | --- | ---: | --- | ---: | --- | ---: | --- | --- | --- |
+| 6 | leebai-IDE,hive-2.3.3 | 0dff1547-6867-4e5c-8baa-4bb561d586e3 | 1 | {"memory":1073741824,"cores":2,"instance":1} | 0 | {"memory":0,"cores":0,"instance":0} | 0 | {"memory":0,"cores":0,"instance":0} | 2021-12-30 19:29:21 | 2021-12-30 19:29:21 |
+| 7 | hadoop-Schedulis,spark-2.4.3 | e3a1aeeb-c04a-44cb-a94b-d84e54e55185 | 1 | {"memory":2147483648,"cores":1,"instance":1} | 0 | {"memory":0,"cores":0,"instance":0} | 0 | {"memory":0,"cores":0,"instance":0} | 2021-12-30 19:47:37 | 2021-12-30 19:47:37 |
+
+
+
+
+
+## 16. linkis_mg_gateway_auth_token
+
+> gateway 的token方式认证的 token令牌信息记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `token_name` | token 名 | varchar(128) | UNI | NO | | |
+| 3 | `legal_users` | 合法可使用用户 * 为所有| text | | YES | | |
+| 4 | `legal_hosts` | 合法可请求的源ip * 为所有 | text | | YES | | |
+| 5 | `business_owner` | 业务归属方 | varchar(32) | | YES | | |
+| 6 | `create_time` | | date | | YES | | |
+| 7 | `update_time` | | date | | YES | | |
+| 8 | `elapse_day` | 过期天数 -1 为永久有效| bigint(20) | | YES | | |
+| 9 | `update_by` | | varchar(32) | | YES | | |
+
+
+**示例数据**
+
+| id | token_name | legal_users | legal_hosts | business_owner | create_time | update_time | elapse_day | update_by |
+| ---: | --- | --- | --- | --- | --- | --- | ---: | --- |
+| 2 | BML-AUTH | * | * | BDP | 2021-09-15 | 2021-09-15 | -1 | LINKIS |
+| 3 | WS-AUTH | * | * | BDP | 2021-09-15 | 2021-09-15 | -1 | LINKIS |
+| 4 | dss-AUTH | * | * | BDP | 2021-09-15 | 2021-09-15 | -1 | LINKIS |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_token_name` | 将`token_name` 列设置为唯一索引 | UNIQUE KEY | `token_name` |
+
+
+
+## 17. linkis_ps_bml_project
+
+> bml 物料管理工程项目记录 主要提供给dss 工程空间的项目列表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(10) | PRI | NO | auto_increment | |
+| 2 | `name` | 项目名| varchar(128) | UNI | YES | | |
+| 3 | `system` | 使用系统 | varchar(64) | | NO | | dss |
+| 4 | `source` | | varchar(1024) | | YES | | |
+| 5 | `description` | | varchar(1024) | | YES | | |
+| 6 | `creator` | | varchar(128) | | NO | | |
+| 7 | `enabled` | | tinyint(4) | | YES | | 1 |
+| 8 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | name | system | source | description | creator | enabled | create_time |
+| ---: | --- | --- | --- | --- | --- | ---: | --- |
+| 2524 | metabase_test_ywz_1234 | dss | \N | jinyangrao 在bml创建的工程 | jinyangrao | 1 | 2022-11-16 09:36:58 |
+| 2523 | metabase_test_tjg_345 | dss | \N | jinyangrao 在bml创建的工程 | jinyangrao | 1 | 2022-11-16 09:11:08 |
+| 2522 | test_1114_54_copynull | dss | \N | stacyyan 在bml创建的工程 | stacyyan | 1 | 2022-11-15 10:44:27 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_name` | 将`name` 列设置为唯一索引 | UNIQUE KEY | `name` |
+
+
+
+## 18. linkis_ps_bml_project_resource
+
+> bml项目和对应的资源id关系表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(10) | PRI | NO | auto_increment | |
+| 2 | `project_id` | 项目id | int(10) | | NO | | |
+| 3 | `resource_id` | 资源存储的resource id | varchar(128) | | YES | | |
+
+
+**示例数据**
+
+| id | project_id | resource_id |
+| ---: | ---: | --- |
+| 1 | 1 | 103cb0cc-e12b-4c2e-b8de-a8f58ad17d75 |
+| 2 | 1 | 86bcd05d-4ed9-46be-ab26-d8a76433138b |
+| 3 | 1 | 01697abe-7658-4d3f-b49b-bac4c809a7ba |
+
+
+
+## 19. linkis_ps_bml_project_user
+
+> bml项目和用户关系表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(10) | PRI | NO | auto_increment | |
+| 2 | `project_id` | 项目id | int(10) | | NO | | |
+| 3 | `username` | | varchar(64) | MUL | YES | | |
+| 4 | `priv` | rwx 421 权限值为7。8为管理员,可以授权其他用户| int(10) | | NO | | 7 |
+| 5 | `creator` | 创建者 | varchar(128) | | NO | | |
+| 6 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 7 | `expire_time` | | datetime | | YES | | |
+
+
+**示例数据**
+
+| id | project_id | username | priv | creator | create_time | expire_time |
+| ---: | ---: | --- | ---: | --- | --- | --- |
+| 22 | 21 | jianfuzhang | 7 | jianfuzhang | 2021-05-10 15:20:48 | \N |
+| 23 | 22 | neiljianliu | 7 | neiljianliu | 2021-05-10 15:26:23 | \N |
+| 24 | 22 | jianfuzhang | 5 | neiljianliu | 2021-05-10 15:26:23 | \N |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_name_pid` | 将`username`, `project_id` 列设置为唯一索引 | UNIQUE KEY | `username`, `project_id` |
+
+
+
+## 20. linkis_ps_bml_resources
+
+> bml 物料资源存储信息表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary key | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `resource_id` | 资源的 uuid | varchar(50) | | NO | | |
+| 3 | `is_private` | 资源是否私有,0表示私有,1表示公共 | tinyint(1) | | YES | | 0 |
+| 4 | `resource_header` | 分类,0表示未分类,1表示分类 | tinyint(1) | | YES | | 0 |
+| 5 | `downloaded_file_name` | 下载时的文件名 | varchar(200) | | YES | | |
+| 6 | `sys` | 归属系统 | varchar(100) | | NO | | |
+| 7 | `create_time` | 创建时间 | datetime | | NO | | CURRENT_TIMESTAMP |
+| 8 | `owner` | 资源所有则 | varchar(200) | | NO | | |
+| 9 | `is_expire` | 是否过期,0表示未过期,1表示过期| tinyint(1) | | YES | | 0 |
+| 10 | `expire_type` | 到期类型,date指的是在指定的日期到期,TIME指的是时间| varchar(50) | | YES | | |
+| 11 | `expire_time` | 过期时间,默认一天 | varchar(50) | | YES | | |
+| 12 | `max_version` | 默认为10,表示保留最新的10个版本 | int(20) | | YES | | 10 |
+| 13 | `update_time` | Updated time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 14 | `updator` | updator | varchar(50) | | YES | | |
+| 15 | `enable_flag` | 状态,1:正常,0:冻结 | tinyint(1) | | NO | | 1 |
+
+**示例数据**
+
+| id | resource_id | is_private | resource_header | downloaded_file_name | sys | create_time | owner | is_expire | expire_type | expire_time | max_version | update_time | updator | enable_flag |
+| ---: | --- | ---: | ---: | --- | --- | --- | --- | ---: | --- | --- | ---: | --- | --- | ---: |
+| 332800 | 72eac098-0d71-42c9-962c-e9580ac5ac0b | 1 | \N | 72eac098-0d71-42c9-962c-e9580ac5ac0b | WTSS | 2022-07-27 09:47:06 | hadoop | 0 | \N | \N | 10 | 2022-07-27 09:47:06 | \N | 1 |
+| 398336 | 273611e6-e1be-480e-8556-c2534910e855 | 1 | \N | 273611e6-e1be-480e-8556-c2534910e855 | WTSS | 2022-07-29 06:31:44 | hadoop | 0 | \N | \N | 10 | 2022-07-29 06:31:44 | \N | 1 |
+| 463872 | a111ab00-bafd-4341-a17b-ab9101970abd | 1 | \N | a111ab00-bafd-4341-a17b-ab9101970abd | WTSS | 2022-08-03 06:18:32 | hadoop | 0 | \N | \N | 10 | 2022-08-03 06:18:32 | \N | 1 |
+
+
+## 21. linkis_ps_bml_resources_permission
+
+ // todo 未使用?
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary key | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `resource_id` | Resource uuid | varchar(50) | | NO | | |
+| 3 | `permission` | permission | varchar(10) | | NO | | |
+| 4 | `create_time` | created time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 5 | `system` | creator | varchar(50) | | YES | | dss |
+| 6 | `update_time` | updated time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 7 | `updator` | updator | varchar(50) | | NO | | |
+
+
+## 22. linkis_ps_bml_resources_task
+
+> bml 物料资源操作记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `resource_id` | 资源uuid | varchar(50) | | YES | | |
+| 3 | `version` | 当前操作的资源版本号 | varchar(20) | | YES | | |
+| 4 | `operation` |操作类型。 上传 = 0,更新 = 1 | varchar(20) | | NO | | |
+| 5 | `state` | 任务当前状态:Schduled, Running, Succeed, Failed,Cancelled | varchar(20) | | NO | | Schduled |
+| 6 | `submit_user` | 作业提交用户名 | varchar(20) | | NO | | |
+| 7 | `system` | 系统名称 如: wtss | varchar(20) | | YES | | dss |
+| 8 | `instance` | 提供服务的实例| varchar(128) | | NO | | |
+| 9 | `client_ip` | 请求方ip | varchar(50) | | YES | | |
+| 10 | `extra_params` | 附加关键信息。 比如批量删除的资源ID和版本,资源下的所有版本都被删除 | text | | YES | | |
+| 11 | `err_msg` | 任务失败信息。e.getMessage | varchar(2000) | | YES | | |
+| 12 | `start_time` | 开始时间 | datetime | | NO | | CURRENT_TIMESTAMP |
+| 13 | `end_time` | 结束时间 | datetime | | YES | | |
+| 14 | `last_update_time` | 最后更新时间 | datetime | | NO | | |
+
+**示例数据**
+
+| id | resource_id | version | operation | state | submit_user | system | instance | client_ip | extra_params | err_msg | start_time | end_time | last_update_time |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
+| 183039 | 873513f8-9ad0-4473-b7b9-1cc2500abab7 | \N | copyResource | success | stacyyan | \N | localhost11ide01:9107 | 127.0.0.1 | \N | \N | 2022-03-24 20:11:18 | 2022-03-24 20:11:19 | 2022-03-24 20:11:19 |
+| 259846 | 7ae110d2-5649-4c57-9e4c-b48bb62f3382 | \N | deleteResource | success | stacyyan | WTSS | localhost11ide01:9107 | 127.0.0.1 | delete resourceId:7ae110d2-5649-4c57-9e4c-b48bb62f3382, and delete versions is :v000001 | \N | 2022-06-01 14:38:42 | 2022-06-01 14:38:43 | 2022-06-01 14:38:43 |
+| 12551 | 8678bbd5-cfc7-411b-a838-1b145dab8473 | \N | deleteResource | success | neiljianliu | WTSS | localhost11ide01:9107 | 127.0.0.1 | delete resourceId:8678bbd5-cfc7-411b-a838-1b145dab8473, and delete versions is :v000001 | \N | 2021-07-16 14:47:15 | 2021-07-16 14:47:15 | 2021-07-16 14:47:15 |
+| 36360 | eadc8908-e00c-4604-ab30-6671f33e753e | \N | deleteResource | success | neiljianliu | WTSS | localhost11ide01:9107 | 127.0.0.1 | delete resourceId:eadc8908-e00c-4604-ab30-6671f33e753e, and delete versions is :v000001 | \N | 2021-10-26 17:46:15 | 2021-10-26 17:46:15 | 2021-10-26 17:46:15 |
+| 549888 | dfbd7603-d513-413a-b491-d79a62a25407 | v000001 | upload | success | hadoop | dss | localhost11ide01:9107 | 127.0.0.1 | \N | \N | 2022-07-29 00:26:43 | 2022-07-29 00:26:43 | 2022-07-29 00:26:43 |
+| 51775 | ba304c46-ab63-404e-b2aa-69f522ef3baa | v000004 | rollbackVersion | success | johnnwang | \N | localhost11ide01:9107 | 127.0.0.1 | \N | \N | 2021-11-27 17:04:28 | 2021-11-27 17:04:28 | 2021-11-27 17:04:28 |
+| 28 | d07d8636-5415-418f-9aff-dde1b3a69569 | v000005 | update | success | hadoop | WTSS | localhost11ide01:9107 | 127.0.0.1 | \N | \N | 2021-04-29 14:24:36 | 2021-04-29 14:24:36 | 2021-04-29 14:24:36 |
+
+
+## 23. linkis_ps_bml_resources_version
+
+>资源和对应的版本信息关联表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary key | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `resource_id` | 资源uuid | varchar(50) | MUL | NO | | |
+| 3 | `file_md5` | 文件的md5摘要 | varchar(32) | | NO | | |
+| 4 | `version` | 资源版本(v 后面加五位数字) | varchar(20) | | NO | | |
+| 5 | `size` | 文件大小 | int(10) | | NO | | |
+| 6 | `start_byte` | 开始字节 | bigint(20) unsigned | | NO | | 0 |
+| 7 | `end_byte` | 结束字节 | bigint(20) unsigned | | NO | | 0 |
+| 8 | `resource` | 资源内容(文件信息包括路径和文件名) | varchar(2000) | | NO | | |
+| 9 | `description` | 说明 | varchar(2000) | | YES | | |
+| 10 | `start_time` | 开始时间 | datetime | | NO | | CURRENT_TIMESTAMP |
+| 11 | `end_time` | 停止时间 | datetime | | NO | | CURRENT_TIMESTAMP |
+| 12 | `client_ip` | 客户端ip | varchar(200) | | NO | | |
+| 13 | `updator` | updator | varchar(50) | | YES | | |
+| 14 | `enable_flag` | 状态,1:正常,0:冻结| tinyint(1) | | NO | | 1 |
+
+
+**示例数据**
+
+| id | resource_id | file_md5 | version | size | start_byte | end_byte | resource | description | start_time | end_time | client_ip | updator | enable_flag |
+| ---: | --- | --- | --- | ---: | ---: | ---: | --- | --- | --- | --- | --- | --- | ---: |
+| 1 | 863846e2-bd31-49ba-babe-9a2b96616d71 | b8fd956fd8f83d09d203bf9e4b40543f | v000001 | 1668 | 1 | 1668 | hdfs:///apps-data/hadoop/bml/20210429/863846e2-bd31-49ba-babe-9a2b96616d71 | \N | 2021-04-29 12:21:07 | 2021-04-29 12:21:07 | 127.0.0.1 | \N | 1 |
+| 2 | 9d39cb8e-1447-46d5-a11d-b597b2e3200f | 46bf4ff26651c448efb85ffa9c54907f | v000001 | 58965932 | 1 | 58965932 | hdfs:///apps-data/hadoop/bml/20210429/9d39cb8e-1447-46d5-a11d-b597b2e3200f | \N | 2021-04-29 12:21:10 | 2021-04-29 12:21:10 | 127.0.0.1 | \N | 1 |
+| 3 | bc620bfd-d3f4-4fa5-84f7-1c484fac2241 | 8e13ba687fa1ee04e113bff50290a5c6 | v000001 | 1745 | 1 | 1745 | hdfs:///apps-data/hadoop/bml/20210429/bc620bfd-d3f4-4fa5-84f7-1c484fac2241 | \N | 2021-04-29 12:21:14 | 2021-04-29 12:21:14 | 127.0.0.1 | \N | 1 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_rid_version` | 将`resource_id`, `version` 列设置为唯一索引 | UNIQUE KEY | `resource_id`, `version` |
+
+
+
+## 24. linkis_ps_common_lock
+
+> 通用的用于实现分布式锁
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `lock_object` | | varchar(255) | UNI | YES | | |
+| 3 | `time_out` | | longtext | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+
+
+## 25. linkis_ps_configuration_category
+
+> 参数配置目录树表 对应于管理台的`参数配置页面`
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_id` | linkis_cg_manager_label 标签的id | int(20) | UNI | NO | | |
+| 3 | `level` | 1为应用类型级别 2 为引擎类型级别 | int(20) | | NO | | |
+| 4 | `description` | | varchar(200) | | YES | | |
+| 5 | `tag` | | varchar(200) | | YES | | |
+| 6 | `update_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 7 | `create_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lock_object` | 将`lock_object` 列设置为唯一索引 | UNIQUE KEY | `lock_object` |
+
+
+**示例数据**
+
+| id | label_id | level | description | tag | update_time | create_time |
+| ---: | ---: | ---: | --- | --- | --- | --- |
+| 101 | 46586 | 1 | | \N | 2021-08-19 20:07:09 | 2021-08-19 20:07:09 |
+| 102 | 46587 | 2 | | \N | 2021-08-19 20:07:20 | 2021-08-19 20:07:20 |
+| 103 | 47340 | 1 | | \N | 2021-08-23 10:50:02 | 2021-08-23 10:50:02 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_label_id` | 将`label_id` 列设置为唯一索引 | UNIQUE INDEX | `label_id` |
+
+
+
+## 26. linkis_ps_configuration_config_key
+
+> 引擎相关参数的配置表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `key` | 配置项的key 如 spark.executor.instances | varchar(50) | | YES | | |
+| 3 | `description` | 描述 | varchar(200) | | YES | | |
+| 4 | `name` | 名称 | varchar(50) | | YES | | |
+| 5 | `default_value` | 当用户未进行设置时,使用默认值 | varchar(200) | | YES | | |
+| 6 | `validate_type` | 验证类型,以下之一:None、NumInterval、FloatInterval、Include、Regex、OPF、Custom Rules| varchar(50) | | YES | | |
+| 7 | `validate_range` | 验证范围 | varchar(50) | | YES | | |
+| 8 | `engine_conn_type` | 引擎类型,如 spark、hive 等| varchar(50) | | YES | | |
+| 9 | `is_hidden` | 是否对用户隐藏。 如果设置为 1(true),则用户不能修改,但仍然可以在后端使用 | tinyint(1) | | YES | | |
+| 10 | `is_advanced` | 是否为高级参数。 如果设置为 1(true),参数将仅在用户选择【显示高级参数】时显示 | tinyint(1) | | YES | | |
+| 11 | `level` | 前端显示排序的依据。 级别越高,参数优先显示| tinyint(1) | | YES | | |
+| 12 | `treeName` | 配置项的engineType的子目录分类 | varchar(20) | | YES | | |
+
+
+**示例数据**
+
+| id | key | description | name | default_value | validate_type | validate_range | engine_conn_type | is_hidden | is_advanced | level | treeName |
+| ---: | --- | --- | --- | --- | --- | --- | --- | ---: | ---: | ---: | --- |
+| 1 | wds.linkis.rm.yarnqueue | yarn队列名 | yarn队列名 | default | None | \N | \N | 0 | 0 | 1 | 队列资源 |
+| 2 | wds.linkis.rm.yarnqueue.instance.max | 取值范围:1-128,单位:个 | yarn队列实例最大个数 | 30 | Regex | ^(?:[1-9]\d?|[1234]\d{2}|200)$ | \N | 1 | 0 | 1 | 队列资源 |
+| 3 | wds.linkis.rm.yarnqueue.cores.max | 取值范围:1-1500,单位:个 | 队列CPU使用上限 | 150 | Regex | ^(?:[1-9]\d{0,2}|1[0-4]\d{2}|1500)$ | \N | 0 | 0 | 1 | 队列资源 |
+| 4 | wds.linkis.rm.yarnqueue.memory.max | 取值范围:1-5000,单位:G | 队列内存使用上限 | 300G | Regex | ^([1-9]\d{0,2}|[1-4]\d{3}|5000)(G|g)$ | \N | 0 | 0 | 1 | 队列资源 |
+
+
+## 27. linkis_ps_configuration_config_value
+
+> 参数配置项key对应的配置值表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `config_key_id` | linkis_ps_configuration_config_key的id | bigint(20) | MUL | YES | | |
+| 3 | `config_value` | 设置的值 | varchar(200) | | YES | | |
+| 4 | `config_label_id` | 对应的linkis_cg_manager_label 的id | int(20) | | YES | | |
+| 5 | `update_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 6 | `create_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | config_key_id | config_value | config_label_id | update_time | create_time |
+| ---: | ---: | --- | ---: | --- | --- |
+| 57 | 1 | dws | 25716 | 2022-04-08 16:35:37 | 2021-06-08 16:07:49 |
+| 61 | 30 | python2 | 30819 | 2022-07-04 11:17:25 | 2021-06-08 16:35:23 |
+| 62 | 1 | dws | 519 | 2022-11-07 19:13:29 | 2021-06-08 17:19:44 |
+| 64 | 19 | python2 | 3300 | 2022-08-09 17:38:15 | 2021-06-08 20:15:04 |
+| 65 | 5 | 50G | 1348 | 2022-05-16 15:39:44 | 2021-06-10 17:55:11 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_kid_lid` | 将 `config_key_id`, `config_label_id` 列设置为唯一索引 | UNIQUE INDEX | `config_key_id`, `config_label_id` |
+
+
+
+## 28. linkis_ps_configuration_key_engine_relation
+
+>配置项和引擎的关联关系,设置引擎配置参数模板
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `config_key_id` | config key id | bigint(20) | MUL | NO | | |
+| 3 | `engine_type_label_id` | 对应的linkis_cg_manager_label 的id | bigint(20) | | NO | | |
+
+
+**示例数据**
+
+| id | config_key_id | engine_type_label_id |
+| ---: | ---: | ---: |
+| 1 | 1 | 5 |
+| 73 | 1 | 46586 |
+| 80 | 1 | 47340 |
+| 2 | 2 | 5 |
+| 74 | 2 | 46586 |
+| 81 | 2 | 47340 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_kid_lid` | 将`config_key_id`, `engine_type_label_id` 列设置为唯一索引 | UNIQUE INDEX | `config_key_id`, `engine_type_label_id` |
+
+
+
+## 29. linkis_ps_cs_context_history
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `context_id` | | int(11) | | YES | | |
+| 3 | `source` | | text | | YES | | |
+| 4 | `context_type` | | varchar(32) | | YES | | |
+| 5 | `history_json` | | text | | YES | | |
+| 6 | `keyword` | | varchar(255) | MUL | YES | | |
+| 7 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 8 | `create_time` | create time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 9 | `access_time` | last access time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_keyword` | 将`keyword` 列设置为普通索引 | INDEX | `keyword` |
+
+
+
+
+## 30. linkis_ps_cs_context_id
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `user` | | varchar(32) | | YES | | |
+| 3 | `application` | | varchar(32) | | YES | | |
+| 4 | `source` | | varchar(255) | | YES | | |
+| 5 | `expire_type` | | varchar(32) | | YES | | |
+| 6 | `expire_time` | | datetime | | YES | | |
+| 7 | `instance` | | varchar(128) | MUL | YES | | |
+| 8 | `backup_instance` | | varchar(255) | MUL | YES | | |
+| 9 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 10 | `create_time` | create time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 11 | `access_time` | last access time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | user | application | source | expire_type | expire_time | instance | backup_instance | update_time | create_time | access_time |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
+| 62131 | jinyangrao | \N | {"className":"org.apache.linkis.cs.common.entity.source.LinkisHAWorkFlowContextID","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | \N | \N | cs_1_dev | cs_1_dev | 2022-11-16 14:48:58 | 2022-11-16 14:48:58 | 2022-11-16 14:48:58 |
+| 62126 | alexwu | \N | {"className":"org.apache.linkis.cs.common.entity.source.LinkisHAWorkFlowContextID","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | \N | \N | cs_1_dev | cs_1_dev | 2022-11-16 14:45:49 | 2022-11-16 14:45:49 | 2022-11-16 14:45:49 |
+| 62122 | stacyyan | \N | {"className":"org.apache.linkis.cs.common.entity.source.LinkisHAWorkFlowContextID","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | \N | \N | cs_2_dev | cs_1_dev | 2022-11-16 14:43:54 | 2022-11-16 14:43:54 | 2022-11-16 14:43:54 |
+| 62120 | alexwu | \N | {"className":"org.apache.linkis.cs.common.entity.source.LinkisHAWorkFlowContextID","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | \N | \N | cs_2_dev | cs_1_dev | 2022-11-16 14:32:16 | 2022-11-16 14:32:16 | 2022-11-16 14:32:16 |
+
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_instance` | 将`instance` 列设置为普通索引 | INDEX | `instance` |
+| 2 | `idx_backup_instance` | 将`backup_instance` 列设置为普通索引 | INDEX | `backup_instance` |
+| 3 | `idx_instance_bin` | 将`instance`(128),`backup_instance` 列设置为普通索引 | INDEX | `instance`(128),`backup_instance` |
+
+
+
+## 31. linkis_ps_cs_context_listener
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `listener_source` | | varchar(255) | | YES | | |
+| 3 | `context_id` | | int(11) | | YES | | |
+| 4 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | create time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 6 | `access_time` | last access time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+
+## 32. linkis_ps_cs_context_map
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `key` | | varchar(128) | MUL | YES | | |
+| 3 | `context_scope` | | varchar(32) | | YES | | |
+| 4 | `context_type` | | varchar(32) | | YES | | |
+| 5 | `props` | | text | | YES | | |
+| 6 | `value` | | mediumtext | | YES | | |
+| 7 | `context_id` | | int(11) | | YES | | |
+| 8 | `keywords` | | varchar(255) | MUL | YES | | |
+| 9 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 10 | `create_time` | create time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 11 | `access_time` | last access time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | key | context_scope | context_type | props | value | context_id | keywords | update_time | create_time | access_time |
+| ---: | --- | --- | --- | --- | --- | ---: | --- | --- | --- | --- |
+| 45 | node.sql_1742.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":3735}"} | 1 | ["node.sql_1742.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 51 | node.widget_1508.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":5167}"} | 1 | ["node.widget_1508.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 170 | node.display_3009.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":3738}"} | 1 | ["node.display_3009.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 172 | node.dashboard_7941.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":3740}"} | 1 | ["node.dashboard_7941.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 166 | node.sql_1742.table.cs_tmp_sql_1742_rs1 | PUBLIC | METADATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSTable","value":"{\"name\":\"cs_tmp_sql_1742_rs1\",\"alias\":null,\"creator\":\"jianfuzhang\",\"comment\":\"cs temp table\",\"createTime\":\"2021-05-15T19:18:05+0800\",\"productName\":null,\"projectName\":null,\"usage\":null,\"lifecycle\":null,\"useWay\":null,\"isImport\":false,\"modelLevel\":null,\"isExternalUse\":true,\"isPartitionTable\":false,\"isAvailable\":true,\"isView\":true,\"location\":\"hdfs:///tmp/linkis/jianfuzhang/linkis/20210515_191700/nodeexecution/3735/_0.dolphin\",\"columns\":[{\"name\":\"id\",\"alias\":null,\"type\":\"int\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"name\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"sex\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"age\",\"alias\":null,\"type\":\"int\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"class\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"lesson\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"city\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"teacher\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"score\",\"alias\":null,\"type\":\"double\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"fee\",\"alias\":null,\"type\":\"double\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"birthday\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"exam_date\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null}],\"partitions\":null,\"db\":null}"} | 1 | ["cs_tmp_sql_1742_rs1","hdfs:///tmp/linkis/jianfuzhang/linkis/20210515_191700/nodeexecution/3735/_0.dolphin","node.sql_1742.table.cs_tmp_sql_1742_rs1"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 1744 | node.widget_1508.table.cs_tmp_widget_1508_rs1 | PUBLIC | METADATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSTable","value":"{\"name\":\"cs_tmp_widget_1508_rs1\",\"alias\":null,\"creator\":\"jianfuzhang\",\"comment\":\"cs temp table\",\"createTime\":\"2021-05-18T11:38:47+0800\",\"productName\":null,\"projectName\":null,\"usage\":null,\"lifecycle\":null,\"useWay\":null,\"isImport\":false,\"modelLevel\":null,\"isExternalUse\":true,\"isPartitionTable\":false,\"isAvailable\":true,\"isView\":true,\"location\":\"hdfs:///tmp/linkis/jianfuzhang/linkis/20210518_113844/nodeexecution/5167/_0.dolphin\",\"columns\":[{\"name\":\"birthday\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null}],\"partitions\":null,\"db\":null}"} | 1 | ["hdfs:///tmp/linkis/jianfuzhang/linkis/20210518_113844/nodeexecution/5167/_0.dolphin","cs_tmp_widget_1508_rs1","node.widget_1508.table.cs_tmp_widget_1508_rs1"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 173 | flow.variable.user.to.proxy | PUBLIC | OBJECT | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisVariable","value":"{\"key\":\"user.to.proxy\",\"value\":\"jianfuzhang\"}"} | 1 | ["user.to.proxy","flow.variable.user.to.proxy"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 174 | flow.infos | PUBLIC | OBJECT | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSFlowInfos","value":"{\"infos\":{\"parent\":\"null\",\"id_nodeName\":{\"3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1\":\"sql_1742\",\"a1dfd377-32a1-4b34-b70c-7123a9890bd8\":\"widget_1508\",\"fa7334ed-5811-48a4-9a26-7498e83348dd\":\"display_3009\",\"c5cc7633-a3ef-42dc-8103-550ca4a3d3ce\":\"dashboard_7941\"},\"edges\":[{\"source\":\"3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1\",\"target\":\"a1dfd377-32a1-4b34-b70c-7123a9890bd8\",\"sourceLocation\":\"bottom\",\"targetLocation\":\"top\"},{\"source\":\"a1dfd377-32a1-4b34-b70c-7123a9890bd8\",\"target\":\"fa7334ed-5811-48a4-9a26-7498e83348dd\",\"sourceLocation\":\"bottom\",\"targetLocation\":\"top\"},{\"source\":\"fa7334ed-5811-48a4-9a26-7498e83348dd\",\"target\":\"c5cc7633-a3ef-42dc-8103-550ca4a3d3ce\",\"sourceLocation\":\"bottom\",\"targetLocation\":\"top\"}]}}"} | 1 | ["flow.infos"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 42 | node.sql_1742.resource.3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1.sql | PUBLIC | RESOURCE | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"linkisBMLResource","value":"{\"resourceId\":\"850d6dc7-4489-4b06-90f4-1d2b5b65d0b7\",\"version\":\"v000001\",\"isPrivate\":null,\"resourceHeader\":null,\"downloadedFileName\":\"3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1.sql\",\"sys\":null,\"createTime\":null,\"isExpire\":null,\"expireType\":null,\"expireTime\":null,\"updateTime\":null,\"updator\":null,\"maxVersion\":null,\"user\":null,\"system\":null,\"enableFlag\":null}"} | 1 | ["v000001","3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1.sql","850d6dc7-4489-4b06-90f4-1d2b5b65d0b7","node.sql_1742.resource.3c72ebe1-6fa1-4093-9da6-c3d8b0fe26f1.sql"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 79 | flow.infos | PUBLIC | RESOURCE | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSFlowInfos","value":"{\"infos\":{\"parent\":\"flow2\",\"id_nodeName\":{\"90a6ee94-4bd6-47d9-a536-f92660c4c051\":\"sql\",\"90a6ee94-4bd6-47d9-a536-f92660c4c052\":\"hql\"},\"edges\":[{\"sourceLocation\":\"bottom\",\"source\":\"sql \",\"targetLocation\":\"top\",\"target\":\"hql\"}]}}"} | 2 | ["flow.infos"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 199 | node.sql_3999.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":344064}"} | 3 | ["node.sql_3999.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 210 | node.widget_654.jobID | PUBLIC | DATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisJobData","value":"{\"jobID\":3808}"} | 3 | ["node.widget_654.jobID"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 31327 | node.sql_3999.table.cs_tmp_sql_3999_rs1 | PUBLIC | METADATA | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSTable","value":"{\"name\":\"cs_tmp_sql_3999_rs1\",\"alias\":null,\"creator\":\"hadoop\",\"comment\":\"cs temp table\",\"createTime\":\"2021-07-28T17:55:56+0800\",\"productName\":null,\"projectName\":null,\"usage\":null,\"lifecycle\":null,\"useWay\":null,\"isImport\":false,\"modelLevel\":null,\"isExternalUse\":true,\"isPartitionTable\":false,\"isAvailable\":true,\"isView\":true,\"location\":\"hdfs:///apps-data/hadoop/linkis/20210728_175555/nodeexecution/344064/_0.dolphin\",\"columns\":[{\"name\":\"database\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"tableName\",\"alias\":null,\"type\":\"string\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null},{\"name\":\"isTemporary\",\"alias\":null,\"type\":\"boolean\",\"comment\":null,\"express\":null,\"rule\":null,\"isPrimary\":null,\"length\":null}],\"partitions\":null,\"db\":null}"} | 3 | ["node.sql_3999.table.cs_tmp_sql_3999_rs1","hdfs:///apps-data/hadoop/linkis/20210728_175555/nodeexecution/344064/_0.dolphin","cs_tmp_sql_3999_rs1"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 31325 | flow.variable.user.to.proxy | PUBLIC | OBJECT | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"LinkisVariable","value":"{\"key\":\"user.to.proxy\",\"value\":\"alexyang\"}"} | 3 | ["user.to.proxy","flow.variable.user.to.proxy"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+| 31326 | flow.infos | PUBLIC | OBJECT | {"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKeyValue","subs":[{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextKey","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]},{"className":"com.webank.wedatasphere.linkis.cs.common.entity.source.CommonContextValue","subs":[],"fieldNames":[],"fieldValues":[],"fieldTypes":[]}],"fieldNames":[],"fieldValues":[],"fieldTypes":[]} | {"type":"CSFlowInfos","value":"{\"infos\":{\"parent\":\"null\",\"id_nodeName\":{\"b08c3f5e-f5d7-4209-866b-f4f963196b3d\":\"sql_3999\",\"4b9b446b-304d-451f-90b6-67d9ad5d3e49\":\"widget_654\"},\"edges\":[{\"source\":\"b08c3f5e-f5d7-4209-866b-f4f963196b3d\",\"target\":\"4b9b446b-304d-451f-90b6-67d9ad5d3e49\",\"sourceLocation\":\"right\",\"targetLocation\":\"left\"}]}}"} | 3 | ["flow.infos"] | 2022-06-01 11:38:30 | 2022-06-01 11:38:32 | 2022-06-06 15:37:42 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_key_cid_ctype` | 将`key`,`context_id`,`context_type`列设置为唯一索引 | UNIQUE INDEX | `key`,`context_id`,`context_type` |
+| 2 | `idx_keywords` | 将`keywords`列设置为普通索引 | INDEX | `keywords` |
+
+
+## 33. linkis_ps_cs_context_map_listener
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `listener_source` | | varchar(255) | | YES | | |
+| 3 | `key_id` | | int(11) | | YES | | |
+| 4 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | create time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 6 | `access_time` | last access time | datetime | | NO | | CURRENT_TIMESTAMP |
+
+
+
+## 34. linkis_ps_datasource_access
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `table_id` | | bigint(20) | | NO | | |
+| 3 | `visitor` | | varchar(16) | | NO | | |
+| 4 | `fields` | | varchar(255) | | YES | | |
+| 5 | `application_id` | | int(4) | | NO | | |
+| 6 | `access_time` | | datetime | | NO | | |
+
+
+## 35. linkis_ps_datasource_field
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `table_id` | | bigint(20) | | NO | | |
+| 3 | `name` | | varchar(64) | | NO | | |
+| 4 | `alias` | | varchar(64) | | YES | | |
+| 5 | `type` | | varchar(64) | | NO | | |
+| 6 | `comment` | | varchar(255) | | YES | | |
+| 7 | `express` | | varchar(255) | | YES | | |
+| 8 | `rule` | | varchar(128) | | YES | | |
+| 9 | `is_partition_field` | | tinyint(1) | | NO | | |
+| 10 | `is_primary` | | tinyint(1) | | NO | | |
+| 11 | `length` | | int(11) | | YES | | |
+
+
+**示例数据**
+
+| id | table_id | name | alias | type | comment | express | rule | is_partition_field | is_primary | length | mode_info |
+| ---: | ---: | --- | --- | --- | --- | --- | --- | ---: | ---: | ---: | --- |
+| 4396 | 216 | ds | | string | | \N | \N | 1 | 0 | 8 | \N |
+| 4395 | 216 | b | | string | | \N | | 0 | 0 | \N | \N |
+| 4394 | 216 | a | | string | | \N | | 0 | 0 | \N | \N |
+| 4393 | 215 | ds | | string | | \N | \N | 1 | 0 | 8 | \N |
+| 4392 | 215 | col_3 | | string | | | | 0 | 0 | \N | \N |
+| 4391 | 215 | col_2 | | string | | | | 0 | 0 | \N | \N |
+| 4390 | 215 | col_1 | | string | | | | 0 | 0 | \N | \N |
+
+
+
+## 36. linkis_ps_datasource_import
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `table_id` | | bigint(20) | | NO | | |
+| 3 | `import_type` | | int(4) | | NO | | |
+| 4 | `args` | | varchar(255) | | NO | | |
+
+
+**示例数据**
+
+| id | table_id | import_type | args |
+| ---: | ---: | ---: | --- |
+| 94 | 215 | 1 | {"exportPath":"/mnt/bdap/stacyyan/aa/aaa125.csv","type":"share","separator":",","chartset":"utf-8","quote":"","isHasHeader":"false"} |
+| 93 | 214 | 0 | {"database":"stacyyan_ind","table":"00153d26da1a11eb8c30813d0f05b1af1"} |
+| 92 | 213 | 2 | {"exportPath":"/mnt/bdap/stacyyan/aa/studentInfo.xlsx","type":"share","isHasHeader":"false"} |
+| 88 | 170 | 1 | {"exportPath":"/mnt/bdap/janicegong/file测试/上传文件/orc.csv","type":"share","separator":",","chartset":"utf-8","quote":"","isHasHeader":"false"} |
+| 87 | 169 | 1 | {"exportPath":"/mnt/bdap/johnnwang/test1_hql__1652150994191.csv","type":"share","separator":",","chartset":"utf-8","quote":"","isHasHeader":"false"} |
+
+
+
+## 37. linkis_ps_datasource_lineage
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `table_id` | | bigint(20) | | YES | | |
+| 3 | `source_table` | | varchar(64) | | YES | | |
+| 4 | `update_time` | | datetime | | YES | | |
+
+**示例数据**
+
+| id | table_id | source_table | update_time |
+| ---: | ---: | --- | --- |
+| 40 | 214 | stacyyan_ind.00153d26da1a11eb8c30813d0f05b1af1 | 2022-11-08 21:14:41 |
+| 39 | 162 | janicegong_ind.aa | 2022-09-04 17:28:46 |
+| 38 | 156 | jin_ind.test_0902j | 2022-09-02 19:47:20 |
+
+
+
+## 38. linkis_ps_datasource_table
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(255) | PRI | NO | auto_increment | |
+| 2 | `database` | | varchar(64) | MUL | NO | | |
+| 3 | `name` | | varchar(64) | | NO | | |
+| 4 | `alias` | | varchar(64) | | YES | | |
+| 5 | `creator` | | varchar(16) | | NO | | |
+| 6 | `comment` | | varchar(255) | | YES | | |
+| 7 | `create_time` | | datetime | | NO | | |
+| 8 | `product_name` | | varchar(64) | | YES | | |
+| 9 | `project_name` | | varchar(255) | | YES | | |
+| 10 | `usage` | | varchar(128) | | YES | | |
+| 11 | `lifecycle` | | int(4) | | NO | | |
+| 12 | `use_way` | | int(4) | | NO | | |
+| 13 | `is_import` | | tinyint(1) | | NO | | |
+| 14 | `model_level` | | int(4) | | NO | | |
+| 15 | `is_external_use` | | tinyint(1) | | NO | | |
+| 16 | `is_partition_table` | | tinyint(1) | | NO | | |
+| 17 | `is_available` | | tinyint(1) | | NO | | |
+
+
+**示例数据**
+
+| id | database | name | alias | creator | comment | create_time | product_name | project_name | usage | lifecycle | use_way | is_import | model_level | is_external_use | is_partition_table | is_available |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- | --- | ---: | ---: | ---: | ---: | ---: | ---: | ---: |
+| 216 | stacyyan_ind | aa_1109 | 表别名_1109 | stacyyan | | 2022-11-09 16:15:03 | | | | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
+| 215 | jin_ind | test_1109aaa | test_1109aaa | stacyyan | | 2022-11-09 09:51:41 | | | | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
+| 214 | stacyyan_ind | test_1108ar | test_1108ar | stacyyan | | 2022-11-08 21:14:41 | | | | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_db_name` | 将`database`,`name` 列设置为唯一索引 | UNIQUE INDEX |`database`,`name` |
+
+
+
+## 39. linkis_ps_datasource_table_info
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `table_id` | | bigint(20) | | NO | | |
+| 3 | `table_last_update_time` | | datetime | | NO | | |
+| 4 | `row_num` | | bigint(20) | | NO | | |
+| 5 | `file_num` | | int(11) | | NO | | |
+| 6 | `table_size` | | varchar(32) | | NO | | |
+| 7 | `partitions_num` | | int(11) | | NO | | |
+| 8 | `update_time` | | datetime | | NO | | |
+| 9 | `field_num` | | int(11) | | NO | | |
+
+
+## 40. linkis_ps_dm_datasource
+
+> 配置的数据源信息表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `datasource_name` | 数据源名称 | varchar(255) | | NO | | |
+| 3 | `datasource_desc` | 数据源描述 | varchar(255) | | YES | | |
+| 4 | `datasource_type_id` |数据源类型ID linkis_ps_dm_datasource_type对应的id | int(11) | | NO | | |
+| 5 | `create_identify` |标识 | varchar(255) | | YES | | |
+| 6 | `create_system` | 创建数据源的系统 | varchar(255) | | YES | | |
+| 7 | `parameter` | 数据源参数,注意 不做存储,实体类parameter字段通过linkis_ps_dm_datasource_version的parameter获取 | varchar(255) | | YES | | |
+| 8 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 9 | `modify_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 10 | `create_user` | | varchar(255) | | YES | | |
+| 11 | `modify_user` | | varchar(255) | | YES | | |
+| 12 | `labels` | 数据源标签 | varchar(255) | | YES | | |
+| 13 | `version_id` | 数据源版本ID | int(11) | | YES | | |
+| 14 | `expire` | 数据源是否过期 | tinyint(1) | | YES | | 0 |
+| 15 | `published_version_id` |数据源发布版本号 | int(11) | | YES | | |
+
+
+**示例数据**
+
+| id | datasource_name | datasource_desc | datasource_type_id | create_identify | create_system | parameter | create_time | modify_time | create_user | modify_user | labels | version_id | expire | published_version_id |
+| ---: | --- | --- | ---: | --- | --- | --- | --- | --- | --- | --- | --- | ---: | ---: | ---: |
+| 243 | mongodb_test_20221020101428 | create | 6 | \N | Linkis | {"dataSourceTypeId":"6","host":"127.0.0.1","port":"20500","params":"{\"connectTimeout\":\"100\"}","database":"dpvcs-dev","username":"dpvcsopr","password":"dpvcsopr"} | 2022-10-20 10:14:36 | 2022-10-20 10:14:36 | janicegong | \N | auto_test20220801 | 2 | 0 | 1 |
+| 244 | elasticsearch_test__20221020101428 | create | 7 | \N | Linkis | {"dataSourceTypeId":"7","username":"test","password":"123456","elasticUrls":"[\"http://127.0.0.1:9101\"]"} | 2022-10-20 10:14:38 | 2022-10-20 10:14:38 | janicegong | \N | auto_test20220801 | 2 | 1 | 1 |
+| 245 | mysql_test_1027 | mysql | 1 | | MYSQL | {"host":"127.0.0.1","port":"15304","params":"{\"tinyInt1isBit\":\"false\"}","username":"test","password":"123456"} | 2022-10-27 20:35:05 | 2022-10-27 20:35:05 | stacyyan | \N | demo,勿删 | 1 | 0 | 1 |
+| 246 | hive_test_sit | demo,勿删 | 4 | | HIVE | {"envId":"2"} | 2022-10-27 20:35:55 | 2022-10-27 20:35:55 | stacyyan | \N | | 1 | 0 | 1 |
+
+
+
+## 41. linkis_ps_dm_datasource_env
+
+> 数据源环境信息 主要用户hive类型数据源的配置 通过hive集群环境进行数据源连接配置的选择
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `env_name` | 环境名| varchar(32) | | NO | | |
+| 3 | `env_desc` | 环境描述 | varchar(255) | | YES | | |
+| 4 | `datasource_type_id` | 数据源类型ID linkis_ps_dm_datasource_type对应的id | int(11) | | NO | | |
+| 5 | `parameter` | 数据源环境参数| varchar(255) | | YES | | |
+| 6 | `create_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 7 | `create_user` | | varchar(255) | | YES | | |
+| 8 | `modify_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 9 | `modify_user` | | varchar(255) | | YES | | |
+
+
+**示例数据**
+
+| id | env_name | env_desc | datasource_type_id | parameter | create_time | create_user | modify_time | modify_user |
+| ---: | --- | --- | ---: | --- | --- | --- | --- | --- |
+| 1 | BDP-UAT | BDP-UAT测试环境 | 4 | {"uris":"thrift://localhost100001:9083", "hadoopConf":{"hive.metastore.execute.setugi":"true"}} | 2022-04-12 22:34:11 | \N | 2022-04-12 22:34:11 | \N |
+| 2 | BDAP-UAT | BDAP-UAT测试环境 | 4 | {"uris":"thrift://localhost110001:9083", "hadoopConf":{"hive.metastore.execute.setugi":"true"}} | 2022-04-12 22:34:11 | \N | 2022-04-12 22:34:11 | \N |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_env_name` | 将`env_name` 列设置为唯一索引 | UNIQUE KEY | `env_name` |
+| 2 | `uniq_name_dtid` | 将`env_name`, `datasource_type_id` 列设置为唯一索引 | UNIQUE INDEX | `env_name`, `datasource_type_id` |
+
+
+
+## 42. linkis_ps_dm_datasource_type
+
+> 数据源类型表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `name` | 数据源类型名称 | varchar(32) | | NO | | |
+| 3 | `description` | 数据源类型描述 | varchar(255) | | YES | | |
+| 4 | `option` | 数据源所属类型| varchar(32) | | YES | | |
+| 5 | `classifier` | 数据源类型分类词 | varchar(32) | | NO | | |
+| 6 | `icon` | 数据源图片显示路径| varchar(255) | | YES | | |
+| 7 | `layers` | 数据源类型层次 | int(3) | | NO | | |
+
+**示例数据**
+
+| id | name | description | option | classifier | icon | layers |
+| ---: | --- | --- | --- | --- | --- | ---: |
+| 1 | mysql | mysql数据库 | mysql数据库 | 关系型数据库(Relational DB) | | 3 |
+| 2 | kafka | kafka | kafka | 消息队列(Message DB) | | 2 |
+| 3 | presto | presto SQL | presto | 大数据存储(BigData) | | 3 |
+| 4 | hive | hive数据库 | hive | 大数据存储(BigData) | | 3 |
+| 6 | mongodb | mongodb 数据源 | mongodb | 半结构化数据库 | \N | 3 |
+| 7 | elasticsearch | ES description | es无结构存储 | 分布式全文索引 | \N | 3 |
+| 8 | oracle | This is oracle datasource | oracle关系型数据库 | 关系型数据库 | \N | 3 |
+
+
+
+
+## 43. linkis_ps_dm_datasource_type_key
+
+> 不同数据源类型所需要进行配置的参数
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `data_source_type_id` | 数据源类型ID linkis_ps_dm_datasource_type对应的id | int(11) | | NO | | |
+| 3 | `key` | 数据源参数key值| varchar(32) | | NO | | |
+| 4 | `name` | 数据源参数名称 用于前端展示 | varchar(32) | | NO | | |
+| 5 | `name_en` | 数据源参数名称 英文 用于前端展示 | varchar(32) | | NO | | |
+| 6 | `default_value` | 数据源参数默认值 | varchar(50) | | YES | | |
+| 7 | `value_type` | 数据源参数类型 | varchar(50) | | NO | | |
+| 8 | `scope` | 数据源参数范围 一般未使用到 | varchar(50) | | YES | | |
+| 9 | `require` | 数据源参数是否必须 | tinyint(1) | | YES | | 0 |
+| 10 | `description` | 数据源参数描述 用于前端展示| varchar(200) | | YES | | |
+| 11 | `description_en` | 数据源参数描述 英文 用于前端展示| varchar(200) | | YES | | |
+| 12 | `value_regex` | 数据源参数正则| varchar(200) | | YES | | |
+| 13 | `ref_id` | | bigint(20) | | YES | | |
+| 14 | `ref_value` | | varchar(50) | | YES | | |
+| 15 | `data_source` |数据来源 可以从是一个接口获取 | varchar(200) | | YES | | |
+| 16 | `update_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+| 17 | `create_time` | | datetime | | NO | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | data_source_type_id | key | name | default_value | value_type | scope | require | description | value_regex | ref_id | ref_value | data_source | update_time | create_time |
+| ---: | ---: | --- | --- | --- | --- | --- | ---: | --- | --- | ---: | --- | --- | --- | --- |
+| 1 | 1 | host | Host | \N | TEXT | \N | 1 | mysql Host | \N | \N | \N | \N | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+| 2 | 1 | port | 端口 | \N | TEXT | \N | 1 | 端口 | \N | \N | \N | \N | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+| 3 | 1 | params | 连接参数 | \N | TEXT | \N | 0 | 输入JSON格式: {"param":"value"} | \N | \N | \N | \N | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+| 4 | 1 | username | 用户名 | \N | TEXT | \N | 1 | 用户名 | ^[0-9A-Za-z_-]+$ | \N | \N | \N | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+| 5 | 1 | password | 密码 | \N | PASSWORD | \N | 1 | 密码 | | \N | \N | \N | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+| 6 | 4 | envId | 集群环境 | \N | SELECT | \N | 1 | 集群环境 | \N | \N | \N | /data-source-manager/env-list/all/type/4 | 2022-04-12 22:34:11 | 2022-04-12 22:34:11 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_dstid_key` | 将`data_source_type_id`, `key` 列设置为唯一索引 | UNIQUE KEY | `data_source_type_id`, `key` |
+
+
+
+## 44. linkis_ps_dm_datasource_version
+
+> 数据源版本信息表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `version_id` | 数据源版本ID | int(11) | PRI | NO | auto_increment | |
+| 2 | `datasource_id` | 数据源ID linkis_ps_dm_datasourc 对应的id | int(11) | PRI | NO | | |
+| 3 | `parameter` | 数据源该版本参数 | varchar(2048) | | YES | | |
+| 4 | `comment` | | varchar(255) | | YES | | |
+| 5 | `create_time` | | datetime | | YES | | CURRENT_TIMESTAMP |
+| 6 | `create_user` | | varchar(255) | | YES | | |
+
+
+**示例数据**
+
+| version_id | datasource_id | parameter | comment | create_time | create_user |
+| ---: | ---: | --- | --- | --- | --- |
+| 1 | 41 | {"envId":"2"} | 初始化版本 | 2022-05-25 12:26:44 | neiljianliu |
+| 1 | 42 | {"password":"1234123213","subSystem":"","port":"123","appid":null,"host":"123","authType":null,"objectid":null,"username":"123","mkPrivate":null,"timestamp":null} | qualitis | 2022-05-27 19:56:41 | allenzhou |
+| 1 | 43 | {"host":"333","port":"333","username":"333","password":"1234123213"} | 初始化版本 | 2022-05-30 12:31:42 | janicegong |
+
+
+
+## 45. linkis_ps_error_code
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `error_code` | | varchar(50) | | NO | | |
+| 3 | `error_desc` | | varchar(1024) | | NO | | |
+| 4 | `error_regex` | | varchar(1024) | | YES | | |
+| 5 | `error_type` | | int(3) | | YES | | 0 |
+
+
+**示例数据**
+
+| id | error_code | error_desc | error_regex | error_type |
+| ---: | --- | --- | --- | ---: |
+| 1 | 01001 | 您的任务没有路由到后台ECM,请联系管理员 | The em of labels | 0 |
+| 2 | 01002 | Linkis服务负载过高,请联系管理员扩容 | Unexpected end of file from server | 0 |
+| 3 | 01003 | Linkis服务负载过高,请联系管理员扩容 | failed to ask linkis Manager Can be retried SocketTimeoutException | 0 |
+| 4 | 01004 | 引擎在启动时被Kill,请联系管理员 | [0-9]+ Killed | 0 |
+
+## 46. linkis_ps_instance_info
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(11) | PRI | NO | auto_increment | |
+| 2 | `instance` | structure like ${host\|machine}:${port} | varchar(128) | UNI | YES | | |
+| 3 | `name` | equal application name in registry | varchar(128) | | YES | | |
+| 4 | `update_time` | update unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | create unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_instance` | 将`instance` 列设置为唯一索引 | UNIQUE KEY | `instance` |
+
+
+
+## 47. linkis_ps_instance_label
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_key` | string key | varchar(32) | MUL | NO | | |
+| 3 | `label_value` | string value | varchar(255) | | NO | | |
+| 4 | `label_feature` | store the feature of label, but it may be redundant | varchar(16) | | NO | | |
+| 5 | `label_value_size` | size of key -> value map | int(20) | | NO | | |
+| 6 | `update_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+| 7 | `create_time` | update unix timestamp | datetime | | NO | | CURRENT_TIMESTAMP |
+
+
+**示例数据**
+
+| id | label_key | label_value | label_feature | label_value_size | update_time | create_time |
+| ---: | --- | --- | --- | ---: | --- | --- |
+| 68 | route | offline | OPTIONAL | 0 | 2022-11-15 12:51:48 | 2022-11-08 21:58:36 |
+| 64 | route | cs_1_dev | OPTIONAL | 0 | 2022-11-08 09:51:26 | 2022-02-16 17:28:31 |
+| 5 | route | cs_2_dev | OPTIONAL | 0 | 2022-11-08 09:51:23 | 2021-05-26 14:46:00 |
+| 58 | route | auto_test | OPTIONAL | 0 | 2022-11-04 16:51:04 | 2021-09-08 14:19:23 |
+| 67 | route | cs_1_dev1 | OPTIONAL | 0 | 2022-10-31 15:58:07 | 2022-10-31 15:58:07 |
+| 66 | route | et1 | OPTIONAL | 0 | 2022-08-07 21:39:55 | 2022-08-07 21:39:55 |
+| 65 | route | test114 | OPTIONAL | 0 | 2022-07-05 00:18:52 | 2022-07-05 00:18:52 |
+| 39 | route | test | OPTIONAL | 0 | 2022-06-28 13:24:19 | 2021-08-02 15:30:03 |
+| 62 | route | gjy_test | OPTIONAL | 0 | 2022-02-24 19:25:11 | 2022-01-05 17:27:46 |
+| 6 | route | cs_3_dev | OPTIONAL | 0 | 2022-02-17 14:20:33 | 2021-05-26 14:57:12 |
+| 63 | route | test_A | OPTIONAL | 0 | 2022-01-06 15:04:35 | 2022-01-06 15:04:35 |
+| 61 | userCreator | auto-test | OPTIONAL | 2 | 2021-12-22 14:36:33 | 2021-12-22 14:36:33 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lk_lv` | 将`label_key`,`label_value` 列设置为唯一索引 | UNIQUE KEY | `label_key`,`label_value` |
+
+
+
+**示例数据**
+
+| id | instance | name | update_time | create_time |
+| ---: | --- | --- | --- | --- |
+| 1527 | localhost110004:8008 | visualis-prod | 2022-06-28 14:14:36 | 2022-06-28 14:14:36 |
+| 1537 | localhost110004:9008 | visualis-dev | 2022-06-30 15:39:19 | 2022-06-30 15:39:18 |
+| 1702 | localhost110004:9108 | linkis-ps-cs | 2022-11-08 09:51:23 | 2022-11-08 09:51:23 |
+
+
+## 48. linkis_ps_instance_label_relation
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_id` | id reference linkis_ps_instance_label -> id | int(20) | MUL | YES | | |
+| 3 | `service_instance` | structure like ${host\|machine}:${port} | varchar(128) | | NO | | |
+| 4 | `update_time` | update unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+| 5 | `create_time` | create unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| id | label_id | service_instance | update_time | create_time |
+| ---: | ---: | --- | --- | --- |
+| 562 | 2 | localhost110002:9108 | 2022-02-14 11:58:57 | 2022-02-14 11:58:57 |
+| 875 | 5 | localhost110004:9108 | 2022-11-08 09:51:23 | 2022-11-08 09:51:23 |
+| 876 | 64 | localhost11ide01:9108 | 2022-11-08 09:51:26 | 2022-11-08 09:51:26 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lid_instance` | 将`label_id`,`service_instance` 列设置为唯一索引 | UNIQUE KEY | `label_id`,`service_instance` |
+
+
+
+## 49. linkis_ps_instance_label_value_relation
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `label_value_key` | value key | varchar(255) | MUL | NO | | |
+| 3 | `label_value_content` | value content | varchar(255) | | YES | | |
+| 4 | `label_id` | id reference linkis_ps_instance_label -> id | int(20) | | YES | | |
+| 5 | `update_time` | update unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+| 6 | `create_time` | create unix timestamp | datetime | | YES | | CURRENT_TIMESTAMP |
+
+**示例数据**
+
+| label_value_key | label_value_content | label_id | update_time | create_time |
+| --- | --- | ---: | --- | --- |
+| creator | test | 61 | 2021-12-22 14:36:33 | 2021-12-22 14:36:33 |
+| user | auto | 61 | 2021-12-22 14:36:33 | 2021-12-22 14:36:33 |
+| creator | a | 50 | 2021-08-03 19:40:48 | 2021-08-03 19:40:48 |
+| user | a | 50 | 2021-08-03 19:40:48 | 2021-08-03 19:40:48 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_lvk_lid` | 将`label_value_key`,`label_id` 列设置为唯一索引 | UNIQUE KEY | `label_value_key`,`label_id` |
+
+
+
+## 50. linkis_ps_job_history_detail
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary Key, auto increment | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `job_history_id` | ID of JobHistory | bigint(20) | | NO | | |
+| 3 | `result_location` | File path of the resultsets | varchar(500) | | YES | | |
+| 4 | `execution_content` | The script code or other execution content executed by this Job | text | | YES | | |
+| 5 | `result_array_size` | size of result array | int(4) | | YES | | 0 |
+| 6 | `job_group_info` | Job group info/path | text | | YES | | |
+| 7 | `created_time` | Creation time | datetime(3) | | YES | | CURRENT_TIMESTAMP(3) |
+| 8 | `updated_time` | Update time | datetime(3) | | YES | | CURRENT_TIMESTAMP(3) |
+| 9 | `status` | status | varchar(32) | | YES | | |
+| 10 | `priority` | order of subjob | int(4) | | YES | | 0 |
+
+**示例数据**
+
+| id | job_history_id | result_location | execution_content | result_array_size | job_group_info | created_time | updated_time | status | priority |
+| ---: | ---: | --- | --- | ---: | --- | --- | --- | --- | ---: |
+| 1700001 | 1561337 | hdfs:///apps-data/neiljianliu/linkis/20211225_201252/nodeexecution/1561337 | select * from default.dwc_vsbi_students_demo limit 5000 | 1 | | 2021-12-25 20:12:52 | 2021-12-25 20:12:54 | Succeed | 0 |
+| 1700002 | 1561339 | \N | {"configuration":{},"variable":{"user.to.proxy":"neiljianliu","run_date":"20211224"},"run_date":"20211224","labels":{"labels":"{\"route\":\"prod\"}"}} | \N | | 2021-12-25 20:15:51 | 2021-12-25 20:15:52 | Failed | 0 |
+| 1700003 | 1561338 | hdfs:///apps-data/neiljianliu/linkis/20211225_201551/nodeexecution/1561338 | {"config":"","description":"","id":380.0,"model":"","name":"view_3142","projectId":864.0,"roles":"","source":{"id":318.0,"name":"hiveDataSource"},"sourceId":318.0,"sql":"","variable":""} | 1 | | 2021-12-25 20:15:51 | 2021-12-25 20:15:55 | Succeed | 0 |
+| 1700004 | 1561340 | hdfs:///apps-data/neiljianliu/linkis/20211225_201552/nodeexecution/1561340 | select * from default.dwc_vsbi_students_demo limit 5000 | 1 | | 2021-12-25 20:15:52 | 2021-12-25 20:15:54 | Succeed | 0 |
+| 1700005 | 1561341 | hdfs:///apps-data/neiljianliu/linkis/20211225_201852/nodeexecution/1561341 | {"config":"","description":"","id":380.0,"model":"","name":"view_3142","projectId":864.0,"roles":"","source":{"id":318.0,"name":"hiveDataSource"},"sourceId":318.0,"sql":"","variable":""} | 1 | | 2021-12-25 20:18:52 | 2021-12-25 20:18:56 | Succeed | 0 |
+| 1700006 | 1561342 | \N | {"configuration":{},"variable":{"user.to.proxy":"neiljianliu","run_date":"20211224"},"run_date":"20211224","labels":{"labels":"{\"route\":\"prod\"}"}} | \N | | 2021-12-25 20:18:52 | 2021-12-25 20:18:52 | Failed | 0 |
+
+
+
+
+
+## 51. linkis_ps_job_history_group_history
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | Primary Key, auto increment | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `job_req_id` | job execId | varchar(64) | | YES | | |
+| 3 | `submit_user` | who submitted this Job | varchar(50) | MUL | YES | | |
+| 4 | `execute_user` | who actually executed this Job | varchar(50) | | YES | | |
+| 5 | `source` | job source | text | | YES | | |
+| 6 | `labels` | job labels | text | | YES | | |
+| 7 | `params` | job params | text | | YES | | |
+| 8 | `progress` | Job execution progress | varchar(32) | | YES | | |
+| 9 | `status` | Script execution status, must be one of the following: Inited, WaitForRetry, Scheduled, Running, Succeed, Failed, Cancelled, Timeout | varchar(50) | | YES | | |
+| 10 | `log_path` | File path of the job log | varchar(200) | | YES | | |
+| 11 | `error_code` | Error code. Generated when the execution of the script fails | int(11) | | YES | | |
+| 12 | `error_desc` | Execution description. Generated when the execution of script fails | varchar(1000) | | YES | | |
+| 13 | `created_time` | Creation time | datetime(3) | MUL | YES | | CURRENT_TIMESTAMP(3) |
+| 14 | `updated_time` | Update time | datetime(3) | | YES | | CURRENT_TIMESTAMP(3) |
+| 15 | `instances` | Entrance instances | varchar(250) | | YES | | |
+| 16 | `metrics` | Job Metrics | text | | YES | | |
+| 17 | `engine_type` | Engine type | varchar(32) | | YES | | |
+| 18 | `execution_code` | Job origin code or code path | text | | YES | | |
+| 19 | `result_location` | File path of the resultsets | varchar(500) | | YES | | |
+
+
+**示例数据**
+
+| id | job_req_id | submit_user | execute_user | source | labels | params | progress | status | log_path | error_code | error_desc | created_time | updated_time | instances | metrics | engine_type | execution_code | result_location |
+| ---: | --- | --- | --- | --- | --- | --- | --- | --- | --- | ---: | --- | --- | --- | --- | --- | --- | --- | --- |
+| 3400407 | nodeexecution_owenxu_spark_29 | owenxu | owenxu | {"nodeName":"sql_9024","requestIP":"127.0.0.1","projectName":"testpubauthority","flowName":"test01"} | {"codeType":"sql","engineType":"spark-2.4.3","userCreator":"owenxu-nodeexecution"} | {"configuration":{"runtime":{"nodeName":"sql_9024","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"+PHsmq+A1AkWQ3olJILCuFspWs9RflbL2HLiVea4FcQ\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","wds.dss.workflow.submit.user":"owenxu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"owenxu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"testpubauthority\\\",\\\"flow\\\":\\\"test01\\\",\\\"contextId\\\":\\\"8-8--cs_1_devcs_1_dev58211\\\",\\\"version\\\":\\\"v000003\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","nodeType":"sql","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/owenxu/linkis/2022-11-16/155518/nodeexecution/3400407","source":{"nodeName":"sql_9024","projectName":"testpubauthority","flowName":"test01","requestIP":"127.0.0.1"},"jobId":"3400407","job":{"#rt_rs_store_path":"hdfs:///apps-data/owenxu/linkis/2022-11-16/155518/nodeexecution/3400407"}},"startup":{"jobId":"3400407"}},"variable":{"user.to.proxy":"owenxu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"owenxu-schedulis","codeType":"sql","engineType":"spark-2.4.3","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/owenxu/3400407.log | 0 | | 2022-11-16 15:55:18.000 | 2022-11-16 15:55:20.387 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:55:19+0800","timeToOrchestrator":"2022-11-16T15:55:19+0800","engineconnMap":{"gz.xg.localhost110001.webank:27735":{"engineInstance":"gz.xg.localhost110001.webank:27735","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400407_otJobId_astJob_647_codeExec_647","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_647"}},"submitTime":"2022-11-16T15:55:18+0800","yarnResource":{},"completeTime":"2022-11-16T15:55:20+0800"} | spark | select 1| hdfs:///apps-data/owenxu/linkis/2022-11-16/155518/nodeexecution/3400407 |
+| 3400406 | nodeexecution_johnnwang_spark_42 | johnnwang | johnnwang | {"nodeName":"sql_2947","requestIP":"127.0.0.1","projectName":"hmh0901","flowName":"flow001"} | {"codeType":"sql","engineType":"spark-2.4.3","userCreator":"johnnwang-nodeexecution"} | {"configuration":{"startup":{"spark.executor.memory":"3G","spark.driver.memory":"3G","spark.executor.cores":"2","spark.executor.instances":"2","wds.linkis.rm.yarnqueue":"dws","ReuseEngine":"true","jobId":"3400406"},"runtime":{"nodeName":"sql_2947","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"Lg76z9Wq/bjKI3Kp1nTKBNZnRJ6dDz3v5E4e2cL2cD4\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","wds.dss.workflow.submit.user":"johnnwang","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"johnnwang\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"hmh0901\\\",\\\"flow\\\":\\\"flow001\\\",\\\"contextId\\\":\\\"8-8--cs_1_devcs_1_dev61373\\\",\\\"version\\\":\\\"v000005\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","nodeType":"sql","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400406","source":{"nodeName":"sql_2947","projectName":"hmh0901","flowName":"flow001","requestIP":"127.0.0.1"},"jobId":"3400406","job":{"#rt_rs_store_path":"hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400406"}}},"variable":{"user.to.proxy":"johnnwang","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"johnnwang-schedulis","codeType":"sql","engineType":"spark-2.4.3","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/johnnwang/3400406.log | 0 | | 2022-11-16 15:52:17.000 | 2022-11-16 15:52:19.328 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"gz.xg.localhost110001.webank:35637":{"engineInstance":"gz.xg.localhost110001.webank:35637","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400406_otJobId_astJob_646_codeExec_646","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_646"}},"submitTime":"2022-11-16T15:52:17+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:19+0800"} | spark | show tables;| hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400406 |
+| 3400405 | nodeexecution_johnnwang_appconn_42 | johnnwang | johnnwang | {"nodeName":"sqoop_6588","requestIP":"127.0.0.1","projectName":"hmh0901","flowName":"flow001"} | {"codeType":"exchangis.sqoop","engineType":"appconn-1","userCreator":"johnnwang-nodeexecution"} | {"configuration":{"runtime":{"nodeName":"sqoop_6588","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"Lg76z9Wq/bjKI3Kp1nTKBNZnRJ6dDz3vupd1m5IsFA0\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","variables":{"user.to.proxy":"johnnwang","run_today_h":"2022111615","run_date":"20221115"},"wds.dss.workflow.submit.user":"johnnwang","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"johnnwang\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"hmh0901\\\",\\\"flow\\\":\\\"flow001\\\",\\\"contextId\\\":\\\"8-8--cs_1_devcs_1_dev61373\\\",\\\"version\\\":\\\"v000005\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","nodeType":"exchangis.sqoop","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400405","source":{"nodeName":"sqoop_6588","projectName":"hmh0901","flowName":"flow001","requestIP":"127.0.0.1"},"jobId":"3400405","job":{"#rt_rs_store_path":"hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400405"}},"startup":{"jobId":"3400405"}},"variable":{"user.to.proxy":"johnnwang","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"johnnwang-schedulis","codeType":"exchangis.sqoop","engineType":"appconn-1","labels":"{\"route\":\"prod\"}"}} | 1.0 | Failed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/johnnwang/3400405.log | \N | 21304, Task(codeExec_645) status not succeed,is Failed | 2022-11-16 15:52:17.000 | 2022-11-16 15:52:18.475 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:10781":{"engineInstance":"localhost110004:10781","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400405_otJobId_astJob_645_codeExec_645","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_645"}},"submitTime":"2022-11-16T15:52:17+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:18+0800"} | appconn | {"id":5924} | hdfs:///apps-data/johnnwang/linkis/2022-11-16/155217/nodeexecution/3400405 |
+| 3400404 | nodeexecution_allenlliu_shell_25 | allenlliu | allenlliu | {"nodeName":"shell_4441","requestIP":"127.0.0.1","projectName":"mytest_xq_0032","flowName":"test_workflow001"} | {"codeType":"shell","engineType":"shell-1","userCreator":"allenlliu-nodeexecution"} | {"configuration":{"runtime":{"nodeName":"shell_4441","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"y4h8zre1zbG7a5OlwX8oULazMLTJJpelCaiwk84RsEk\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","wds.dss.workflow.submit.user":"allenlliu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"allenlliu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"mytest_xq_0032\\\",\\\"flow\\\":\\\"test_workflow001\\\",\\\"contextId\\\":\\\"8-8--cs_2_devcs_2_dev10489\\\",\\\"version\\\":\\\"v000009\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","nodeType":"sh","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400404","source":{"nodeName":"shell_4441","projectName":"mytest_xq_0032","flowName":"test_workflow001","requestIP":"127.0.0.1"},"jobId":"3400404","job":{"#rt_rs_store_path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400404"}},"startup":{"jobId":"3400404"}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"allenlliu-schedulis","codeType":"shell","engineType":"shell-1","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/allenlliu/3400404.log | 0 | | 2022-11-16 15:52:17.000 | 2022-11-16 15:52:18.359 | localhost110002:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:14499":{"engineInstance":"localhost110004:14499","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400404_otJobId_astJob_532_codeExec_532","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_532"}},"submitTime":"2022-11-16T15:52:17+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:18+0800"} | shell | echo 'hello'| hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400404 |
+| 3400403 | nodeexecution_allenlliu_appconn_111 | allenlliu | allenlliu | {"nodeName":"datachecker_90101_copy_copy","requestIP":"127.0.0.1","projectName":"mytest_xq_0032","flowName":"test_workflow001"} | {"codeType":"datachecker","engineType":"appconn-1","userCreator":"allenlliu-nodeexecution"} | {"configuration":{"startup":{"ReuseEngine":"true","jobId":"3400403"},"runtime":{"max.check.hours":"1","nodeName":"datachecker_90101_copy_copy","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"y4h8zre1zbG7a5OlwX8oUNZnRJ6dDz3vcFfovQF97E8\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","variables":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"wds.dss.workflow.submit.user":"allenlliu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"allenlliu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"mytest_xq_0032\\\",\\\"flow\\\":\\\"test_workflow001\\\",\\\"contextId\\\":\\\"8-8--cs_2_devcs_2_dev10489\\\",\\\"version\\\":\\\"v000009\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","check.object":"allenlliu_ind.a","nodeType":"datachecker","source.type":"hivedb","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400403","source":{"nodeName":"datachecker_90101_copy_copy","projectName":"mytest_xq_0032","flowName":"test_workflow001","requestIP":"127.0.0.1"},"jobId":"3400403","job":{"#rt_rs_store_path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400403"}}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"allenlliu-schedulis","codeType":"datachecker","engineType":"appconn-1","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/allenlliu/3400403.log | 0 | | 2022-11-16 15:52:17.000 | 2022-11-16 15:52:18.060 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:10781":{"engineInstance":"localhost110004:10781","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400403_otJobId_astJob_644_codeExec_644","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_644"}},"submitTime":"2022-11-16T15:52:17+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:18+0800"} | appconn | {"configuration":{"startup":{"ReuseEngine":"true"},"runtime":{"max.check.hours":"1","check.object":"allenlliu_ind.a","source.type":"hivedb"}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"labels":"{\"route\":\"prod\"}"}} | hdfs:///apps-data/allenlliu/linkis/2022-11-16/155217/nodeexecution/3400403 |
+| 3400402 | nodeexecution_allenlliu_spark_32 | allenlliu | allenlliu | {"nodeName":"sql_3520","requestIP":"127.0.0.1","projectName":"mytest_xq_0032","flowName":"test_workflow001"} | {"codeType":"sql","engineType":"spark-2.4.3","userCreator":"allenlliu-nodeexecution"} | {"configuration":{"runtime":{"nodeName":"sql_3520","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"y4h8zre1zbG7a5OlwX8oULazMLTJJpelslfPQ0jh9bw\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","wds.dss.workflow.submit.user":"allenlliu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"allenlliu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"mytest_xq_0032\\\",\\\"flow\\\":\\\"test_workflow001\\\",\\\"contextId\\\":\\\"8-8--cs_2_devcs_2_dev10489\\\",\\\"version\\\":\\\"v000009\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","nodeType":"sql","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400402","source":{"nodeName":"sql_3520","projectName":"mytest_xq_0032","flowName":"test_workflow001","requestIP":"127.0.0.1"},"jobId":"3400402","job":{"#rt_rs_store_path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400402"}},"startup":{"jobId":"3400402"}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"allenlliu-schedulis","codeType":"sql","engineType":"spark-2.4.3","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/allenlliu/3400402.log | 0 | | 2022-11-16 15:52:16.000 | 2022-11-16 15:52:18.436 | localhost110002:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:25145":{"engineInstance":"localhost110004:25145","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400402_otJobId_astJob_531_codeExec_531","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_531"}},"submitTime":"2022-11-16T15:52:16+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:18+0800"} | spark | show tables| hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400402 |
+| 3400401 | nodeexecution_allenlliu_appconn_85 | allenlliu | allenlliu | {"nodeName":"datachecker_90101","requestIP":"127.0.0.1","projectName":"mytest_xq_0032","flowName":"test_workflow001"} | {"codeType":"datachecker","engineType":"appconn-1","userCreator":"allenlliu-nodeexecution"} | {"configuration":{"startup":{"ReuseEngine":"true","jobId":"3400401"},"runtime":{"max.check.hours":"1","nodeName":"datachecker_90101","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"y4h8zre1zbG7a5OlwX8oULazMLTJJpelHY1ioj7PF6w\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","variables":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"wds.dss.workflow.submit.user":"allenlliu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"allenlliu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"mytest_xq_0032\\\",\\\"flow\\\":\\\"test_workflow001\\\",\\\"contextId\\\":\\\"8-8--cs_2_devcs_2_dev10489\\\",\\\"version\\\":\\\"v000009\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","check.object":"allenlliu_ind.a","nodeType":"datachecker","source.type":"hivedb","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400401","source":{"nodeName":"datachecker_90101","projectName":"mytest_xq_0032","flowName":"test_workflow001","requestIP":"127.0.0.1"},"jobId":"3400401","job":{"#rt_rs_store_path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400401"}}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"allenlliu-schedulis","codeType":"datachecker","engineType":"appconn-1","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/allenlliu/3400401.log | 0 | | 2022-11-16 15:52:16.000 | 2022-11-16 15:52:17.718 | localhost110002:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:10781":{"engineInstance":"localhost110004:10781","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400401_otJobId_astJob_530_codeExec_530","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_530"}},"submitTime":"2022-11-16T15:52:16+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:17+0800"} | appconn | {"configuration":{"startup":{"ReuseEngine":"true"},"runtime":{"max.check.hours":"1","check.object":"allenlliu_ind.a","source.type":"hivedb"}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"labels":"{\"route\":\"prod\"}"}} | hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400401 |
+| 3400400 | nodeexecution_allenlliu_appconn_110 | allenlliu | allenlliu | {"nodeName":"datachecker_90101_copy","requestIP":"127.0.0.1","projectName":"mytest_xq_0032","flowName":"test_workflow001"} | {"codeType":"datachecker","engineType":"appconn-1","userCreator":"allenlliu-nodeexecution"} | {"configuration":{"startup":{"ReuseEngine":"true","jobId":"3400400"},"runtime":{"max.check.hours":"1","nodeName":"datachecker_90101_copy","workspace":"{\"workspaceId\":224,\"workspaceName\":\"bdapWorkspace\",\"cookies\":{\"linkis_user_session_ticket_id_v1\":\"y4h8zre1zbG7a5OlwX8oULazMLTJJpelBtBXO2lr2rM\u003d\",\"dataworkcloud_inner_request\":\"true\",\"workspaceName\":\"bdapWorkspace\",\"workspaceId\":\"224\"},\"dssUrl\":\"http://localhost11ide01:9001\"}","variables":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"wds.dss.workflow.submit.user":"allenlliu","contextID":"{\"type\":\"HAWorkFlowContextID\",\"value\":\"{\\\"instance\\\":null,\\\"backupInstance\\\":null,\\\"user\\\":\\\"allenlliu\\\",\\\"workspace\\\":\\\"bdapWorkspace\\\",\\\"project\\\":\\\"mytest_xq_0032\\\",\\\"flow\\\":\\\"test_workflow001\\\",\\\"contextId\\\":\\\"8-8--cs_2_devcs_2_dev10489\\\",\\\"version\\\":\\\"v000009\\\",\\\"env\\\":\\\"BDAP_DEV\\\"}\"}","check.object":"allenlliu_ind.a","nodeType":"datachecker","source.type":"hivedb","labels":"{\"route\":\"prod\"}","wds.linkis.resultSet.store.path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400400","source":{"nodeName":"datachecker_90101_copy","projectName":"mytest_xq_0032","flowName":"test_workflow001","requestIP":"127.0.0.1"},"jobId":"3400400","job":{"#rt_rs_store_path":"hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400400"}}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"userCreator":"allenlliu-schedulis","codeType":"datachecker","engineType":"appconn-1","labels":"{\"route\":\"prod\"}"}} | 1.0 | Succeed | hdfs:///appcom/logs/linkis/log/2022-11-16/nodeexecution/allenlliu/3400400.log | 0 | | 2022-11-16 15:52:16.000 | 2022-11-16 15:52:17.736 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:52:17+0800","timeToOrchestrator":"2022-11-16T15:52:17+0800","engineconnMap":{"localhost110004:10781":{"engineInstance":"localhost110004:10781","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400400_otJobId_astJob_643_codeExec_643","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_643"}},"submitTime":"2022-11-16T15:52:16+0800","yarnResource":{},"completeTime":"2022-11-16T15:52:17+0800"} | appconn | {"configuration":{"startup":{"ReuseEngine":"true"},"runtime":{"max.check.hours":"1","check.object":"allenlliu_ind.a","source.type":"hivedb"}},"variable":{"user.to.proxy":"allenlliu","run_today_h":"2022111615","run_date":"20221115"},"run_today_h":"2022111615","run_date":"20221115","labels":{"labels":"{\"route\":\"prod\"}"}} | hdfs:///apps-data/allenlliu/linkis/2022-11-16/155216/nodeexecution/3400400 |
+| 3400399 | IDE_connorliuyude_spark_1 | connorliuyude | connorliuyude | {"DSS-Scriptis":"import_to_connorliuyude_qml.peter_100w_1000_a_1668585127900.scala","requestIP":"127.0.0.1"} | {"codeType":"scala","engineType":"spark-2.4.3","userCreator":"connorliuyude-IDE"} | {"configuration":{"special":{},"runtime":{"args":"","env":[],"wds.linkis.resultSet.store.path":"hdfs:///apps-data/connorliuyude/linkis/2022-11-16/155208/IDE/3400399","source":{"DSS-Scriptis":"import_to_connorliuyude_qml.peter_100w_1000_a_1668585127900.scala","requestIP":"127.0.0.1"},"jobId":"3400399","job":{"#rt_rs_store_path":"hdfs:///apps-data/connorliuyude/linkis/2022-11-16/155208/IDE/3400399"}},"startup":{"jobId":"3400399"}},"variable":{}} | 0.7191358 | Running | hdfs:///appcom/logs/linkis/log/2022-11-16/IDE/connorliuyude/3400399.log | \N | \N | 2022-11-16 15:52:08.000 | 2022-11-16 15:55:38.556 | localhost11ide01:9205 | {"scheduleTime":"2022-11-16T15:52:09+0800","timeToOrchestrator":"2022-11-16T15:52:09+0800","engineconnMap":{"gz.xg.localhost110001.webank:33228":{"engineInstance":"gz.xg.localhost110001.webank:33228","taskClassname":"CodeLogicalUnitExecTask","idInfo":"TaskID_3400399_otJobId_astJob_642_codeExec_642","taskName":"CodeLogicalUnitExecTask","execId":"codeExec_642"}},"submitTime":"2022-11-16T15:52:08+0800","yarnResource":{"application_1662051718074_332612":{"queueMemory":107374182400,"queueCores":20,"queueInstances":0,"jobStatus":"COMPLETED","queue":"queue_0701_01"}}} | spark | val source = """{"path":"/apps-data/connorliuyude/peter_100w_1000_a.csv","pathType":"hdfs","encoding":"utf-8","fieldDelimiter":",","hasHeader":true,"sheet":"","quote":"","escapeQuotes":false}""" val destination = """hdfs:///tmp/bdp-ide/connorliuyude/executionCode/20221116/_bgservice;454023#74026""" org.apache.linkis.engineplugin.spark.imexport.LoadData.loadDataToTableByFile(spark,destination,source) | hdfs:///apps-data/connorliuyude/linkis/2022-11-16/155208/IDE/3400399 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_created_time` | 将`created_time` 列设置为普通索引 | INDEX | `created_time` |
+| 2 | `idx_submit_user` | 将`submit_user` 列设置为普通索引 | INDEX | `submit_user` |
+
+
+## 52. linkis_ps_resources_download_history
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | primary key | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `start_time` | start time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 3 | `end_time` | stop time | datetime | | NO | | CURRENT_TIMESTAMP |
+| 4 | `client_ip` | client ip | varchar(200) | | NO | | |
+| 5 | `state` | Download status, 0 download successful, 1 download failed | tinyint(1) | | NO | | |
+| 6 | `resource_id` | | varchar(50) | | NO | | |
+| 7 | `version` | | varchar(20) | | NO | | |
+| 8 | `downloader` | Downloader | varchar(50) | | NO | | |
+
+
+**示例数据**
+
+| id | start_time | end_time | client_ip | state | resource_id | version | downloader |
+| ---: | --- | --- | --- | ---: | --- | --- | --- |
+| 1859617 | 2022-11-16 15:56:17 | 2022-11-16 15:56:18 | 127.0.0.1 | 0 | 11b8ca20-3437-4f31-a808-915a6f016a87 | v000001 | owenxu |
+| 1859614 | 2022-11-16 15:55:18 | 2022-11-16 15:55:18 | 127.0.0.1 | 0 | 836ba735-3a46-4303-8e9f-c4276a356386 | v000001 | owenxu |
+| 1859613 | 2022-11-16 15:53:06 | 2022-11-16 15:53:07 | 127.0.0.1 | 0 | cb407155-242b-4303-8365-1da6256a01e3 | v000173 | hadoop |
+| 1859612 | 2022-11-16 15:52:17 | 2022-11-16 15:52:17 | 127.0.0.1 | 0 | 665fe5ce-fdc6-4b9a-ab08-955e48b1f8d4 | v000001 | owenxu |
+
+
+## 53. linkis_ps_udf
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `create_user` | | varchar(50) | | NO | | |
+| 3 | `udf_name` | | varchar(255) | | NO | | |
+| 4 | `udf_type` | | int(11) | | YES | | 0 |
+| 5 | `path` | Path of the referenced function | varchar(255) | | YES | | |
+| 6 | `register_format` | | varchar(255) | | YES | | |
+| 7 | `use_format` | | varchar(255) | | YES | | |
+| 8 | `description` | | varchar(255) | | YES | | |
+| 9 | `is_expire` | | bit(1) | | YES | | |
+| 10 | `is_shared` | | bit(1) | | YES | | |
+| 11 | `tree_id` | | bigint(20) | | NO | | |
+| 12 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 13 | `update_time` | | timestamp | | NO | | CURRENT_TIMESTAMP |
+
+
+**示例数据**
+
+| id | create_user | udf_name | udf_type | path | register_format | use_format | description | is_expire | is_shared | tree_id | create_time | update_time |
+| ---: | --- | --- | ---: | --- | --- | --- | --- | ---: | ---: | ---: | --- | --- |
+| 204 | neiljianliu | jar_udf | 0 | /mnt/bdap/neiljianliu/zy_test/Wbjar_1.0.0.jar | create temporary function jar_udf as "com.webank.bdp.mask.udf.BdpBankCardNoFirstEightMask" | String jar_udf(String) | | 0 | 0 | 145 | 2021-11-09 09:52:31 | 2021-11-09 09:52:31 |
+| 205 | neiljianliu | jar_udf1 | 0 | /mnt/bdap/neiljianliu/zy_test/Wbjar_1.1.jar | create temporary function jar_udf1 as "com.webank.bdp.mask.udf.BdpBankCardNoFirstEightMask" | String jar_udf1(String) | | 0 | 0 | 145 | 2021-11-09 09:43:28 | 2021-11-09 09:43:28 |
+
+
+
+
+## 54. linkis_ps_udf_baseinfo
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `create_user` | | varchar(50) | | NO | | |
+| 3 | `udf_name` | | varchar(255) | | NO | | |
+| 4 | `udf_type` | | int(11) | | YES | | 0 |
+| 5 | `tree_id` | | bigint(20) | | NO | | |
+| 6 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 7 | `update_time` | | timestamp | | NO | | CURRENT_TIMESTAMP |
+| 8 | `sys` | source system | varchar(255) | | NO | | ide |
+| 9 | `cluster_name` | | varchar(255) | | NO | | |
+| 10 | `is_expire` | | bit(1) | | YES | | |
+| 11 | `is_shared` | | bit(1) | | YES | | |
+
+
+**示例数据**
+
+| id | create_user | udf_name | udf_type | tree_id | create_time | update_time | sys | cluster_name | is_expire | is_shared |
+| ---: | --- | --- | ---: | ---: | --- | --- | --- | --- | ---: | ---: |
+| 318 | neiljianliu | h01 | 3 | 1370 | 2022-08-08 19:39:39 | 2021-11-04 20:36:46 | IDE | all | 0 | 1 |
+| 321 | neiljianliu | h14 | 1 | 1331 | 2021-11-01 23:28:25 | 2021-10-29 10:39:08 | IDE | all | 0 | 0 |
+| 324 | stacyyan | udf_jar_834 | 0 | 133 | 2021-10-29 11:28:10 | 2021-10-29 11:28:10 | ide | all | 0 | 0 |
+
+## 55. linkis_ps_udf_manager
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `user_name` | | varchar(20) | | YES | | |
+
+**示例数据**
+
+| id | user_name |
+| ---: | --- |
+| 1 | stacyyan |
+| 2 | johnnwang |
+| 3 | neiljianliu |
+
+
+
+
+## 56. linkis_ps_udf_shared_group
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | bigint(20) | | NO | | |
+| 3 | `shared_group` | | varchar(50) | | NO | | |
+
+**示例数据**
+
+| id | udf_id | user_name |
+| ---: | ---: | --- |
+| 1 | 36 | jianfuzhang |
+| 2 | 36 | stacyyan |
+| 3 | 38 | shanhuang |
+| 4 | 38 | stacyyan |
+
+
+
+
+## 57. linkis_ps_udf_shared_info
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | bigint(20) | | NO | | |
+| 3 | `user_name` | | varchar(50) | | NO | | |
+
+
+## 58. linkis_ps_udf_shared_user
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | bigint(20) | | NO | | |
+| 3 | `user_name` | | varchar(50) | | NO | | |
+
+**示例数据**
+
+| id | udf_id | user_name |
+| ---: | ---: | --- |
+| 63 | 117 | jianfuzhang |
+| 64 | 119 | neiljianliu |
+| 65 | 119 | johnnwang |
+| 66 | 126 | jianfuzhang |
+
+
+
+## 59. linkis_ps_udf_tree
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `parent` | | bigint(20) | | NO | | |
+| 3 | `name` | Category name of the function. It would be displayed in the front-end | varchar(100) | | YES | | |
+| 4 | `user_name` | | varchar(50) | | NO | | |
+| 5 | `description` | | varchar(255) | | YES | | |
+| 6 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 7 | `update_time` | | timestamp | | NO | | CURRENT_TIMESTAMP |
+| 8 | `category` | Used to distinguish between udf and function | varchar(50) | | YES | | |
+
+
+**示例数据**
+
+| id | parent | name | user_name | description | create_time | update_time | category |
+| ---: | ---: | --- | --- | --- | --- | --- | --- |
+| 21 | -1 | 系统函数 | sys | | 2021-04-29 19:22:07 | 2021-04-29 19:22:07 | function |
+| 22 | -1 | BDAP函数 | bdp | | 2021-04-29 19:22:07 | 2021-04-29 19:22:07 | function |
+| 23 | -1 | 共享函数 | share | | 2021-04-29 19:22:07 | 2021-04-29 19:22:07 | function |
+| 24 | -1 | 个人函数 | jianfuzhang | | 2021-04-29 19:22:07 | 2021-04-29 19:22:07 | function |
+| 25 | -1 | 个人函数 | hduser05 | | 2021-04-30 10:15:14 | 2021-04-30 10:15:14 | udf |
+| 26 | -1 | 系统函数 | sys | | 2021-04-30 11:21:13 | 2021-04-30 11:21:13 | udf |
+| 27 | -1 | BDAP函数 | bdp | | 2021-04-30 11:21:13 | 2021-04-30 11:21:13 | udf |
+| 28 | -1 | 共享函数 | share | | 2021-04-30 11:21:13 | 2021-04-30 11:21:13 | udf |
+| 29 | -1 | 个人函数 | alexyang | | 2021-05-06 20:41:48 | 2021-05-06 20:41:48 | function |
+| 30 | -1 | 个人函数 | johnnwang | | 2021-05-06 21:47:52 | 2021-05-06 21:47:52 | udf |
+| 1587 | -1 | 个人函数 | aronlv | | 2022-11-15 10:47:27 | 2022-11-15 10:47:27 | udf |
+| 1586 | -1 | 个人函数 | aronlv | | 2022-11-15 10:47:26 | 2022-11-15 10:47:26 | function |
+| 1585 | -1 | 个人函数 | jackyxxie | | 2022-11-14 14:59:44 | 2022-11-14 14:59:44 | udf |
+| 1584 | 36 | 自定义分类1 | stacyyan | | 2022-11-11 17:10:56 | 2022-11-11 17:10:56 | udf |
+| 1583 | -1 | 个人函数 | alvinzhou | | 2022-11-09 11:23:04 | 2022-11-09 11:23:04 | function |
+| 1582 | 36 | qualitis自定义分类 | stacyyan | | 2022-11-08 16:22:31 | 2022-11-08 16:22:31 | udf |
+| 1581 | 36 | qualitis测试 | stacyyan | | 2022-11-07 12:21:30 | 2022-11-07 12:21:30 | udf |
+| 1580 | 29 | fun自动化测试 | alexyang | | 2022-11-04 19:16:29 | 2022-11-04 19:16:29 | function |
+| 1579 | 20 | udf自动化测试 | alexyang | | 2022-11-04 19:16:25 | 2022-11-04 19:16:25 | udf |
+| 1578 | 20 | 测试 | alexyang | | 2022-11-01 11:05:46 | 2022-11-01 11:05:46 | udf |
+| 1577 | -1 | 个人函数 | jeromepeng | | 2022-10-31 10:54:33 | 2022-10-31 10:54:33 | function |
+| 1576 | -1 | 个人函数 | jeromepeng | | 2022-10-31 10:54:31 | 2022-10-31 10:54:31 | udf |
+
+
+## 60. linkis_ps_udf_user_load
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | bigint(20) | | NO | | |
+| 3 | `user_name` | | varchar(50) | | NO | | |
+
+**示例数据**
+
+| udf_id | user_name |
+| ---: | --- |
+| 34 | johnnwang |
+| 53 | johnnwang |
+| 34 | neiljianliu |
+| 109 | stacyyan |
+| 110 | stacyyan |
+
+
+
+
+
+## 61. linkis_ps_udf_user_load_info
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | int(11) | | NO | | |
+| 3 | `user_name` | | varchar(50) | | NO | | |
+
+
+**示例数据**
+
+| id | udf_id | user_name |
+| ---: | ---: | --- |
+| 1 | 13 | hadoop |
+| 2 | 14 | bob |
+| 3 | 18 | testuser |
+
+
+
+## 62. linkis_ps_udf_version
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | | bigint(20) | | NO | | |
+| 3 | `path` | Source path for uploading files | varchar(255) | | NO | | |
+| 4 | `bml_resource_id` | | varchar(50) | | NO | | |
+| 5 | `bml_resource_version` | | varchar(20) | | NO | | |
+| 6 | `is_published` | is published | bit(1) | | YES | | |
+| 7 | `register_format` | | varchar(255) | | YES | | |
+| 8 | `use_format` | | varchar(255) | | YES | | |
+| 9 | `description` | version desc | varchar(255) | | NO | | |
+| 10 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 11 | `md5` | | varchar(100) | | YES | | |
+
+**示例数据**
+
+| id | udf_id | path | bml_resource_id | bml_resource_version | is_published | register_format | use_format | description | create_time | md5 |
+| ---: | ---: | --- | --- | --- | ---: | --- | --- | --- | --- | --- |
+| 80 | 34 | file:///mnt/bdap/johnnwang/wds_functions1_0_0.jar | aee4698a-0aad-4dfe-9e3c-0d2c674c81f9 | v000001 | 0 | create temporary function cf_charcount_s as "com.webank.wedatasphere.willink.bdp.udf.CountTotalCharInStr" | int cf_charcount_s(string,string) | | 2021-10-20 16:50:57 | \N |
+| 93 | 34 | file:///mnt/bdap/johnnwang/wds_functions1_0_0.jar | aee4698a-0aad-4dfe-9e3c-0d2c674c81f9 | v000002 | 1 | create temporary function cf_charcount_s as "com.webank.wedatasphere.willink.bdp.udf.CountTotalCharInStr" | int cf_charcount_s(string,string) | | 2021-10-20 18:53:59 | \N |
+| 205 | 96 | file:///mnt/bdap/stacyyan/tm_client_1.6_cp.jar | 759c6179-060e-4c61-9ff9-8f6e18d0efaf | v000001 | 0 | create temporary function udf_jar_834 as "com.webank.bdp.mask.udf.BdpBankCardNoFirstEightMask" | udf_jar_834() | | 2021-10-23 16:57:00 | \N |
+| 250 | 109 | file:///mnt/bdap/stacyyan/scala系统函数调用.scala | 4519f563-ac8a-48a3-a487-36b0d629bc59 | v000001 | 0 | \N | String aadfdff() | | 2021-10-25 16:56:04 | \N |
+| 251 | 110 | file:///mnt/bdap/stacyyan/scala系统函数调用.scala | e0caa4a5-754e-4517-9d0d-5610c7712d82 | v000001 | 0 | \N | String df78() | | 2021-10-25 16:56:28 | \N |
+| 257 | 116 | file:///mnt/bdap/udf/udf_pyspark_011621477729461.py | 2917d57a-0078-455f-8eda-45d18d90adb3 | v000001 | 1 | udf.register("udf_hello_0518",hello) | String udf_hello_0518(String) | aaaad | 2021-10-25 17:31:43 | \N |
+
+
+## 63. linkis_ps_variable_key
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `key` | Key of the global variable | varchar(50) | | YES | | |
+| 3 | `description` | Reserved word | varchar(200) | | YES | | |
+| 4 | `name` | Reserved word | varchar(50) | | YES | | |
+| 5 | `application_id` | Reserved word | bigint(20) | MUL | YES | | |
+| 6 | `default_value` | Reserved word | varchar(200) | | YES | | |
+| 7 | `value_type` | Reserved word | varchar(50) | | YES | | |
+| 8 | `value_regex` | Reserved word | varchar(100) | | YES | | |
+
+**示例数据**
+
+| id | key | description | name | application_id | default_value | value_type | value_regex |
+| ---: | --- | --- | --- | ---: | --- | --- | --- |
+| 1 | di_marw_warn_flow_dcn_d | \N | \N | -1 | \N | \N | \N |
+| 2 | table_a | \N | \N | -1 | \N | \N | \N |
+| 3 | table_a | \N | \N | -1 | \N | \N | \N |
+| 4 | aaaa | \N | \N | -1 | \N | \N | \N |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_aid` | 将`application_id` 列设置为普通索引 | INDEX | `application_id` |
+
+
+
+## 64. linkis_ps_variable_key_user
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `application_id` | Reserved word | bigint(20) | MUL | YES | | |
+| 3 | `key_id` | | bigint(20) | MUL | YES | | |
+| 4 | `user_name` | | varchar(50) | | YES | | |
+| 5 | `value` | Value of the global variable | varchar(200) | | YES | | |
+
+
+**示例数据**
+
+| id | application_id | key_id | user_name | value |
+| ---: | ---: | ---: | --- | --- |
+| 1 | -1 | 1 | neiljianliu | d |
+| 2 | -1 | 2 | stacyyan | student |
+| 3 | -1 | 3 | jianfuzhang | a_01 |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `idx_key_id` | 将`key_id` 列设置为普通索引 | INDEX | `key_id` |
+| 2 | `uniq_aid_kid_uname` | 将`application_id`,`key_id`,`user_name` 列设置为普通索引 | INDEX | `application_id`,`key_id`,`user_name` |
+| 3 | `idx_aid` | 将`application_id` 列设置为普通索引 | INDEX | `application_id` |
+
+## 65.linkis_cg_user_ip_config
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `user` | | varchar(50) | NO | | | |
+| 3 | `creator` | | varchar(50) | NO | | | |
+| 4 | `ip_list` | | text | NO | | | |
+| 5 | `create_time` | | datetime |NO | | | |
+| 6 | `update_time` | | datetime |NO | | | |
+| 7 | `desc` | | varchar(100) |NO | | | |
+| 8 | `bussiness_user` | | varchar(50) |NO | | | |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uniq_user_creator` | 将`user`,`creator` 列设置为唯一索引 | UNIQUE KEY | `user`,`creator` |
+
+
+## 66.linkis_cg_tenant_label_config
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+| :--: | :--: | :--: | :--: | :--: | :--: | :--: | :--: |
+| 1 | `id` | | int(20) | PRI | NO | auto_increment | |
+| 2 | `user` | | varchar(50) | NO | | | |
+| 3 | `creator` | | varchar(50) | NO | | | |
+| 4 | `tenant_value` | | varchar(128) | NO | | | |
+| 5 | `create_time` | | datetime |NO | | | |
+| 6 | `update_time` | | datetime |NO | | | |
+| 7 | `desc` | | varchar(100) |NO | | | |
+| 8 | `bussiness_user` | | varchar(50) |NO | | | |
+
+**索引说明**
+
+| 序号 | 名称 | 描述 | 类型 | 字段 |
+| :--: | :--: | :--: | :--: | :--: |
+| 1 | `uin_user_creator` | 将`user`,`creator` 列设置为唯一索引 | UNIQUE KEY | `user`,`creator` |
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/table/udf-table.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/table/udf-table.md
new file mode 100644
index 00000000000..e7f88fbd95e
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/development/table/udf-table.md
@@ -0,0 +1,99 @@
+---
+title: UDF 表结构
+sidebar_position: 2
+---
+
+## 1.linkis_ps_udf_baseinfo
+
+udf函数的基本信息表,存储udf名称/类型等基础信息
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | 主键自增id | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `create_user` | 创建用户 | varchar(50) | | NO | | |
+| 3 | `udf_name` | udf名称 | varchar(255) | | NO | | |
+| 4 | `udf_type` | udf类型 | int(11) | | YES | | 0 |
+| 5 | `tree_id` | linkis_ps_udf_tree的id | bigint(20) | | NO | | |
+| 6 | `create_time` | 创建时间 | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 7 | `update_time` | 更新时间 | timestamp | | NO | | CURRENT_TIMESTAMP |
+| 8 | `sys` | source system | varchar(255) | | NO | | ide |
+| 9 | `cluster_name` | 集群名 ,暂时未使用到,默认都是all | varchar(255) | | NO | | |
+| 10 | `is_expire` | 是否过期 | bit(1) | | YES | | |
+| 11 | `is_shared` | 是否被分享 | bit(1) | | YES | | |
+
+
+udf_type
+```
+udf_type 0:udf函数-通用
+udf_type 2: udf函数-spark
+
+udf_type 3:自定义函数-python函数
+udf_type 4:自定义函数-scala 函数
+```
+
+## 2.linkis_ps_udf_manager
+
+udf函数的管理员用户表,具有共享权限,只有udf管理员 前端才有共享的入口
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `user_name` | | varchar(20) | | YES | | |
+
+## 3.linkis_ps_udf_shared_info
+
+udf共享的记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | linkis_ps_udf_baseinfo的id | bigint(20) | | NO | | |
+| 3 | `user_name` | 共享使用的用户名 | varchar(50) | | NO | | |
+
+## 4.linkis_ps_udf_tree
+
+udf分类的树形层级记录表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `parent` | 父级分类 | bigint(20) | | NO | | |
+| 3 | `name` | 函数的分类名称 | varchar(100) | | YES | | |
+| 4 | `user_name` | 用户名 | varchar(50) | | NO | | |
+| 5 | `description` | 描述信息 | varchar(255) | | YES | | |
+| 6 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 7 | `update_time` | | timestamp | | NO | | CURRENT_TIMESTAMP |
+| 8 | `category` | 类别区分 udf / function | varchar(50) | | YES | | |
+
+## 5.linkis_ps_udf_user_load
+
+udf是否默认加载的配置
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | linkis_ps_udf_baseinfo的id | int(11) | | NO | | |
+| 3 | `user_name` | 归属用户 | varchar(50) | | NO | | |
+
+## 6.linkis_ps_udf_version
+
+udf的版本信息表
+
+| 序号 | 名称 | 描述 | 类型 | 键 | 为空 | 额外 | 默认值 |
+|------ |------ |------ |------ |------ |------ |------ |------ |
+| 1 | `id` | | bigint(20) | PRI | NO | auto_increment | |
+| 2 | `udf_id` | linkis_ps_udf_baseinfo的id | bigint(20) | | NO | | |
+| 3 | `path` | 上传的脚本/jar包的文件本地路径 | varchar(255) | | NO | | |
+| 4 | `bml_resource_id` | bml中的物料资源id | varchar(50) | | NO | | |
+| 5 | `bml_resource_version` | bml物料版本 | varchar(20) | | NO | | |
+| 6 | `is_published` | 是否发布 | bit(1) | | YES | | |
+| 7 | `register_format` | 注册格式 | varchar(255) | | YES | | |
+| 8 | `use_format` | 使用格式 | varchar(255) | | YES | | |
+| 9 | `description` | 版本描述 | varchar(255) | | NO | | |
+| 10 | `create_time` | | timestamp | | NO | on update CURRENT_TIMESTAMP | CURRENT_TIMESTAMP |
+| 11 | `md5` | | varchar(100) | | YES | | |
+
+
+## ER图
+
+![image](/Images-zh/table/udf.png)
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/_category_.json b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/_category_.json
new file mode 100644
index 00000000000..d8d839fbfd6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/_category_.json
@@ -0,0 +1,4 @@
+{
+ "label": "引擎使用",
+ "position": 5
+}
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/elasticsearch.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/elasticsearch.md
new file mode 100644
index 00000000000..1cde1a50605
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/elasticsearch.md
@@ -0,0 +1,243 @@
+---
+title: ElasticSearch
+sidebar_position: 10
+---
+
+本文主要介绍在 `Linkis` 中,`ElasticSearch` 引擎连接器的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 引擎连接器安装
+
+如果您希望在您的 `Linkis` 服务上使用 `ElasticSearch` 引擎连接器,您需要安装 `ElasticSearch` 服务并保证服务可用。
+
+### 1.2 服务验证
+通过如下命令验证 `ElasticSearch` 引擎连接器服务是否可用,如服务已开启用户验证则需要增加 `--user username:password`
+```
+curl [--user username:password] http://ip:port/_cluster/healty?pretty
+```
+输出如下内容代表 `ElasticSearch` 服务可用,注意集群 `status` 为 `green`
+```json
+{
+ "cluster_name" : "docker-cluster",
+ "status" : "green",
+ "timed_out" : false,
+ "number_of_nodes" : 1,
+ "number_of_data_nodes" : 1,
+ "active_primary_shards" : 7,
+ "active_shards" : 7,
+ "relocating_shards" : 0,
+ "initializing_shards" : 0,
+ "unassigned_shards" : 0,
+ "delayed_unassigned_shards" : 0,
+ "number_of_pending_tasks" : 0,
+ "number_of_in_flight_fetch" : 0,
+ "task_max_waiting_in_queue_millis" : 0,
+ "active_shards_percent_as_number" : 100.0
+}
+```
+## 2. 引擎连接器安装
+
+### 2.1 引擎连接器准备(二选一)[非默认引擎连接器](./overview.md)
+
+方式一:直接下载引擎连接器包
+
+[Linkis 引擎连接器下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎连接器(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/elasticsearch/
+mvn clean install
+# 编译出来的引擎连接器包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/elasticsearch/target/out/
+```
+
+[EngineConnPlugin 引擎连接器安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎连接器的上传和加载
+
+将 2.1 中的引擎连接器包上传到服务器的引擎连接器目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── elasticsearch
+│ ├── dist
+│ │ └── 7.6.2
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 7.6.2
+```
+### 2.3 引擎连接器刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎连接器
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎连接器是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3.引擎连接器使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+**`-codeType` 参数说明**
+- `essql`:通过 `SQL` 脚本的方式执行 `ElasticSearch` 引擎连接器任务
+- `esjson`:通过 `JSON` 脚本的方式执行 `ElasticSearch` 引擎连接器任务
+
+**`essql` 方式示例**
+
+**注意:** 使用这种形式, `ElasticSearch` 服务必须安装SQL插件,安装方式参考:https://github.com/NLPchina/elasticsearch-sql#elasticsearch-762
+```shell
+ sh ./bin/linkis-cli -submitUser hadoop \
+ -engineType elasticsearch-7.6.2 -codeType essql \
+ -code '{"sql": "select * from kibana_sample_data_ecommerce limit 10' \
+ -runtimeMap linkis.es.http.method=GET \
+ -runtimeMap linkis.es.http.endpoint=/_sql \
+ -runtimeMap linkis.es.datasource=hadoop \
+ -runtimeMap linkis.es.cluster=127.0.0.1:9200
+```
+
+**`esjson` 方式示例**
+```shell
+sh ./bin/linkis-cli -submitUser hadoop \
+-engineType elasticsearch-7.6.2 -codeType esjson \
+-code '{"query": {"match": {"order_id": "584677"}}}' \
+-runtimeMap linkis.es.http.method=GET \
+-runtimeMap linkis.es.http.endpoint=/kibana_sample_data_ecommerce/_search \
+-runtimeMap linkis.es.datasource=hadoop \
+-runtimeMap linkis.es.cluster=127.0.0.1:9200
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 4. 引擎连接器配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| linkis.es.cluster | 127.0.0.1:9200 |是 | ElasticSearch 集群,多个节点使用逗号分隔 |
+| linkis.es.datasource | hadoop |是 | ElasticSearch datasource |
+| linkis.es.username | 无 |否 | ElasticSearch 集群用户名 |
+| linkis.es.password | 无 |否 | ElasticSearch 集群密码 |
+| linkis.es.auth.cache | false |否 | 客户端是否缓存认证 |
+| linkis.es.sniffer.enable | false |否 | 客户端是否开启 sniffer |
+| linkis.es.http.method | GET |否 | 调用方式 |
+| linkis.es.http.endpoint | /_search |否 | JSON 脚本调用的 Endpoint |
+| linkis.es.sql.endpoint | /_sql |否 | SQL 脚本调用的 Endpoint |
+| linkis.es.sql.format | {"query":"%s"} |否| SQL 脚本调用的模板,%s 替换成 SQL 作为请求体请求Es 集群 |
+| linkis.es.headers.* | 无 |否| 客户端 Headers 配置 |
+| linkis.engineconn.concurrent.limit | 100|否 | 引擎连接器最大并发 |
+
+### 4.2 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 管理台配置
+
+![](./images/es-manage.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE -submitUser hadoop \
+-engineType elasticsearch-7.6.2 -codeType esjson \
+-code '{"query": {"match": {"order_id": "584677"}}}' \
+-runtimeMap linkis.es.http.method=GET \
+-runtimeMap linkis.es.http.endpoint=/kibana_sample_data_ecommerce/_search
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "select * from kibana_sample_data_ecommerce limit 10;", "runType": "essql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "linkis.es.cluster":"http://127.0.0.1:9200",
+ "linkis.es.datasource":"hadoop",
+ "linkis.es.username":"",
+ "linkis.es.password":""
+ }
+ }
+ },
+ "labels": {
+ "engineType": "elasticsearch-7.6.2",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+#### 4.2.3 文件配置
+通过修改目录 `${LINKIS_HOME}/lib/linkis-engineconn-plugins/elasticsearch/dist/7.6.2/conf/` 中的 `linkis-engineconn.properties` 文件进行配置,如下图:
+
+![](./images/es-config.png)
+
+### 4.3 引擎连接器相关数据表
+
+`Linkis` 是通过引擎连接器标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎连接器的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎连接器label如:elasticsearch-7.6.2
+linkis_ps_configuration_category: 插入引擎连接器的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎连接器需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎连接器的关联关系
+```
+
+表中与引擎连接器相关的初始数据如下
+
+```sql
+-- set variable
+SET @ENGINE_LABEL="elasticsearch-7.6.2";
+SET @ENGINE_ALL=CONCAT('*-*,',@ENGINE_LABEL);
+SET @ENGINE_IDE=CONCAT('*-IDE,',@ENGINE_LABEL);
+SET @ENGINE_NAME="elasticsearch";
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @ENGINE_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @ENGINE_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from `linkis_cg_manager_label` where label_value = @ENGINE_IDE;
+insert into `linkis_ps_configuration_category` (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.cluster', '例如:http://127.0.0.1:9200', '连接地址', 'http://127.0.0.1:9200', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.datasource', '连接别名', '连接别名', 'hadoop', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.username', 'username', 'ES集群用户名', '无', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.password', 'password', 'ES集群密码', '无', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.auth.cache', '客户端是否缓存认证', '客户端是否缓存认证', 'false', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.sniffer.enable', '客户端是否开启 sniffer', '客户端是否开启 sniffer', 'false', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.http.method', '调用方式', 'HTTP请求方式', 'GET', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.http.endpoint', '/_search', 'JSON 脚本调用的 Endpoint', '/_search', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.sql.endpoint', '/_sql', 'SQL 脚本调用的 Endpoint', '/_sql', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.sql.format', 'SQL 脚本调用的模板,%s 替换成 SQL 作为请求体请求Es 集群', '请求体', '{"query":"%s"}', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.es.headers.*', '客户端 Headers 配置', '客户端 Headers 配置', '无', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.engineconn.concurrent.limit', '引擎连接器最大并发', '引擎连接器最大并发', '100', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as config_key_id, label.id AS engine_type_label_id FROM `linkis_ps_configuration_config_key` config
+INNER JOIN `linkis_cg_manager_label` label ON config.engine_conn_type = @ENGINE_NAME and label_value = @ENGINE_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select relation.config_key_id AS config_key_id, '' AS config_value, relation.engine_type_label_id AS config_label_id FROM `linkis_ps_configuration_key_engine_relation` relation
+INNER JOIN `linkis_cg_manager_label` label ON relation.engine_type_label_id = label.id AND label.label_value = @ENGINE_ALL);
+
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/flink.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/flink.md
new file mode 100644
index 00000000000..b506bd3b04b
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/flink.md
@@ -0,0 +1,191 @@
+---
+title: Flink
+sidebar_position: 6
+---
+
+# Flink 引擎使用文档
+
+本文主要介绍在 `Linkis` 中,`flink` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 引擎环境配置
+
+如果您希望在您的服务器上使用 `Flink` 引擎,您需要保证以下的环境变量已经设置正确并且引擎的启动用户是有这些环境变量的。
+
+### 1.2 引擎验证
+
+强烈建议您在执行 `Flink` 任务之前,检查下执行用户的这些环境变量。具体方式是
+```
+sudo su - ${username}
+echo ${JAVA_HOME}
+echo ${FLINK_HOME}
+```
+
+| 环境变量名 | 环境变量内容 | 备注 |
+|-----------------|----------------|----------------------------------------|
+| JAVA_HOME | JDK安装路径 | 必须 |
+| HADOOP_HOME | Hadoop安装路径 | 必须 |
+| HADOOP_CONF_DIR | Hadoop配置路径 | Linkis启动Flink引擎采用的Flink on yarn的模式,所以需要yarn的支持。 |
+| FLINK_HOME | Flink安装路径 | 必须 |
+| FLINK_CONF_DIR | Flink配置路径 | 必须,如 ${FLINK_HOME}/conf |
+| FLINK_LIB_DIR | Flink包路径 | 必须,${FLINK_HOME}/lib |
+
+
+## 2. 引擎插件安装
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/flink/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/flink/target/out/
+```
+
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── flink
+│ ├── dist
+│ │ └── 1.12.2
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 1.12.2
+```
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+
+## 3. Flink引擎的使用
+
+`Linkis` 的 `Flink` 引擎是通过 `flink on yarn` 的方式进行启动的,所以需要指定用户使用的队列,如下图所示。
+
+![yarn](./images/yarn-conf.png)
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType flink-1.12.2 \
+-codeType sql -code "show tables" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+更多 `Linkis-Cli` 命令参数参考: [`Linkis-Cli` 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过 `ComputationEngineConn` 提交任务
+
+`FlinkSQL` 可以支持多种数据源,例如 `binlog` , `kafka` , `hive` 等,如果您想要在 `Flink` 代码中使用这些数据源,您需要将这些 `connector` 的插件 `jar` 包放置到 `Flink` 引擎的 `lib` 中,并重启下 `Linkis` 的 `EnginePlugin` 服务。如你想要在您的 `FlinkSQL` 中使用 `binlog` 作为数据源,那么您需要将 `flink-connector-mysql-cdc-1.1.1.jar` 放置到 `Flink` 引擎的 `lib` 中。
+
+为了方便大家进行采样调试,我们在 `Scriptis` 新增了 `fql` 的脚本类型,专门用于执行 `FlinkSQL` 。但是需要保证您的 `DSS` 已经升级到 `DSS1.0.0` 。升级到 `DSS1.0.0` 之后,您可以直接进入 `Scriptis` ,新建 `fql` 脚本进行编辑和执行。
+
+`FlinkSQL` 的编写示例,以 `binlog` 为例
+```sql
+CREATE TABLE mysql_binlog (
+ id INT NOT NULL,
+ name STRING,
+ age INT
+) WITH (
+ 'connector' = 'mysql-cdc',
+ 'hostname' = 'ip',
+ 'port' = 'port',
+ 'username' = 'username',
+ 'password' = 'password',
+ 'database-name' = 'dbname',
+ 'table-name' = 'tablename',
+ 'debezium.snapshot.locking.mode' = 'none' --建议添加,不然会要求锁表
+);
+select * from mysql_binlog where id > 10;
+```
+在 `Scriptis` 中使用 `select` 语法进行调试的时候,`Flink` 引擎会有一个自动 `cancel` 的机制,即到了指定的时间或者采样的行数到了指定的数量,`Flink` 引擎将会主动将任务 `cancel` ,并且将已经获取到的结果集持久化,然后前端会调用打开结果集的接口将结果集在前端进行展示。
+
+### 3.3 通过 `OnceEngineConn` 提交任务
+
+`OnceEngineConn` 的使用方式是用于正式启动 `Flink` 的流式应用,具体的是通过 `LinkisManagerClient` 调用 `LinkisManager` `的createEngineConn` 的接口,并将代码发给创建的 `Flink` 引擎,然后 `Flink` 引擎就开始执行,此方式可以被其他系统进行调用,比如 `Streamis` 。 `Client` 的使用方式也很简单,首先新建一个 `maven` 项目,或者在您的项目中引入以下的依赖。
+```xml
+
+ org.apache.linkis
+ linkis-computation-client
+ ${linkis.version}
+
+```
+然后新建 `scala` 测试文件,点击执行,就完成了从一个 `binlog` 数据进行解析并插入到另一个 `mysql` 数据库的表中。但是需要注意的是,您必须要在 `maven` 项目中新建一个 `resources` 目录,放置一个 `linkis.properties` 文件,并指定 `linkis` 的 `gateway` 地址和 `api` 版本,如
+```properties
+wds.linkis.server.version=v1
+wds.linkis.gateway.url=http://ip:9001/
+```
+```java
+object OnceJobTest {
+ def main(args: Array[String]): Unit = {
+ val sql = """CREATE TABLE mysql_binlog (
+ | id INT NOT NULL,
+ | name STRING,
+ | age INT
+ |) WITH (
+ | 'connector' = 'mysql-cdc',
+ | 'hostname' = 'ip',
+ | 'port' = 'port',
+ | 'username' = '${username}',
+ | 'password' = '${password}',
+ | 'database-name' = '${database}',
+ | 'table-name' = '${tablename}',
+ | 'debezium.snapshot.locking.mode' = 'none'
+ |);
+ |CREATE TABLE sink_table (
+ | id INT NOT NULL,
+ | name STRING,
+ | age INT,
+ | primary key(id) not enforced
+ |) WITH (
+ | 'connector' = 'jdbc',
+ | 'url' = 'jdbc:mysql://${ip}:port/${database}',
+ | 'table-name' = '${tablename}',
+ | 'driver' = 'com.mysql.jdbc.Driver',
+ | 'username' = '${username}',
+ | 'password' = '${password}'
+ |);
+ |INSERT INTO sink_table SELECT id, name, age FROM mysql_binlog;
+ |""".stripMargin
+ val onceJob = SimpleOnceJob.builder().setCreateService("Flink-Test").addLabel(LabelKeyUtils.ENGINE_TYPE_LABEL_KEY, "flink-1.12.2")
+ .addLabel(LabelKeyUtils.USER_CREATOR_LABEL_KEY, "hadoop-Streamis").addLabel(LabelKeyUtils.ENGINE_CONN_MODE_LABEL_KEY, "once")
+ .addStartupParam(Configuration.IS_TEST_MODE.key, true)
+ // .addStartupParam("label." + LabelKeyConstant.CODE_TYPE_KEY, "sql")
+ .setMaxSubmitTime(300000)
+ .addExecuteUser("hadoop").addJobContent("runType", "sql").addJobContent("code", sql).addSource("jobName", "OnceJobTest")
+ .build()
+ onceJob.submit()
+ println(onceJob.getId)
+ onceJob.waitForCompleted()
+ System.exit(0)
+ }
+}
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/hbase.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/hbase.md
new file mode 100644
index 00000000000..fb09c8905f6
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/hbase.md
@@ -0,0 +1,101 @@
+---
+title: HBase
+sidebar_position: 15
+---
+
+# HBase 引擎使用文档
+
+本文主要介绍在 `Linkis` 中,`HBase` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+
+### 1.1 引擎验证
+
+强烈建议您在执行 `HBase` 任务之前,检查下执行用户的这些环境变量。具体方式是
+```
+sudo su - ${username}
+echo ${JAVA_HOME}
+```
+
+## 2. 引擎插件安装
+
+### 2.1 引擎插件准备 [非默认引擎](./overview.md)
+
+单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/hbase/
+mvn clean install -DskipTests -Dhbase.profile=1.2|1.4|2.2|2.5
+
+# hbase.profile 支持1.2|1.4|2.2|2.5,对应的HBase版本是1.2.0,1.4.3,2.2.6,2.5.3
+# 默认hbase.profile=2.5,按需编译不同HBase版本的插件
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/hbase/target/out/
+```
+
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineplugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── hbase
+│ ├── dist
+│ │ └── 2.5.3
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 2.5.3
+```
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+
+## 3. HBase引擎的使用
+
+`Linkis` 的 `HBase` 引擎是通过后台运行一个Jruby环境来执行hbase-shell中的指令,完全兼容hbase-shell的指令。
+
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+ sh bin/linkis-cli -engineType hbase-2.5.3 -code "list" \
+ -codeType shell -runtimeMap linkis.hbase.zookeeper.quorum=zk1,zk2,zk3
+```
+
+更多 `Linkis-Cli` 命令参数参考: [`Linkis-Cli` 使用](../user-guide/linkiscli-manual.md)
+
+HBase引擎,支持的连接参数有:
+
+| 配置名称 | 备注及默认值信息 | 是否必须 |
+|-----------------|----------------|----------------------------------------|
+| linkis.hbase.zookeeper.quorum | 连接hbase的zk地址,如:zk1,zk2,zk3, 默认值:localhost | 必须 |
+| linkis.hbase.zookeeper.property.clientPort | 连接hbase的zk端口,默认值:2181 | 非必须,一般就是默认值 |
+| linkis.zookeeper.znode.parent | 连接HBase的zk znode path,默认值:/hbase | 非必须,一般就是默认值 |
+| linkis.hbase.rootdir | HBase集群的hdfs根目录,默认值:/hbase | 非必须,一般就是默认值 |
+| linkis.hbase.security.authentication | HBase集群连接的认证方式:simple|kerberos,默认值:simple | 非必须,视自己集群情况定 |
+| linkis.hbase.kerberos.principal | HBase kerberos认证principal,如:hbase@HADOOP.LINKIS.COM | kerberos认证方式下必须 |
+| linkis.hbase.keytab.file | HBase kerberos认证所需keytab文件地址,如:/tmp/hbase.keytab | kerberos认证方式下必须 |
+| linkis.hbase.kerberos.proxy.user | kerberos代理用户,需保证kerberos认证用户有代理普通用户的权限 | 非必须,可以不用代理用户 |
+| linkis.hbase.regionserver.kerberos.principal | 如:hbase/_HOST@HADOOP.LINKIS.COM,自行从集群配置文件中获取 | kerberos认证方式下必须 |
+| linkis.hbase.master.kerberos.principal | 如:hbase/_HOST@HADOOP.LINKIS.COM,自行从集群配置文件中获取 | kerberos认证方式下必须 |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/hive.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/hive.md
new file mode 100644
index 00000000000..4a5e724bd0d
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/hive.md
@@ -0,0 +1,293 @@
+---
+title: Hive
+sidebar_position: 2
+---
+
+本文主要介绍在 `Linkis` 中, `Hive` 引擎连接器的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 擎使用前的环境配置
+
+如果您希望在您的服务器上使用 `Hive` 引擎连接器,您需要保证以下的环境变量已经设置正确并且引擎连接器的启动用户是有这些环境变量的。
+
+强烈建议您在执行 `Hive` 任务之前,检查下执行用户的这些环境变量。
+
+| 环境变量名 | 环境变量内容 | 备注 |
+|-----------------|----------------|------|
+| JAVA_HOME | JDK安装路径 | 必须 |
+| HADOOP_HOME | Hadoop安装路径 | 必须 |
+| HADOOP_CONF_DIR | Hadoop配置路径 | 必须 |
+| HIVE_CONF_DIR | Hive配置路径 | 必须 |
+
+### 1.1 环境验证
+```
+# 链接hive
+bin/hive
+
+# 测试命令
+show databases;
+
+# 能够链接成功,并正常输出数据库信息代表环境配置成功
+hive (default)> show databases;
+OK
+databases_name
+default
+```
+
+## 2. 引擎插件安装 [默认引擎](./overview.md)
+
+`linkis` 发布的二进制安装包中默认包含了 `Hive` 引擎插件,用户无需额外安装。
+
+`Hive` 的版本是支持 `Hive1.x` 和` Hive2.x` ,默认是支持 `Hive on MapReduce` ,如果您想改成 `Hive on Tez`,
+Linkis是可以兼容hive on tez的需要以下步骤:
+- 需要将Tez相关的依赖拷贝到 {LINKIS_HOME}/lib/linkis-engineconn-plugins/hive/dist/3.1.3/lib 是dist not plugin 目录[1]. 你也可以修改hive ec pom增加tez dependency重新编译
+- vim {LINKIS_HOME}/lib/linkis-engineconn-plugins/hive/dist/3.1.3/conf/linkis-engineconn.properties and update linkis.hive.engine.type=tez
+- sh linkis-daemon.sh restart linkis-cg-manager
+
+
+默认支持的 `Hive` 版本是 3.1.3 ,如果您想修改 `Hive` 的版本,您可以找到 `linkis-engineplugin-hive` 模块,修改 `` 标签,然后单独编译此模块即可
+
+[EngineConnPlugin引擎插件安装](../deployment/install-engineconn.md)
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType hive-3.1.3 \
+-codeType hql -code "show databases" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+更多 `Linkis-Cli` 命令参数参考: [`Linkis-Cli` 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过Linkis SDK提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。对于 `Hive` 任务你只需要修改 `Demo` 中的 `EngineConnType` 和 `CodeType` 参数即可:
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "hive-3.1.3"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "hql"); // required codeType
+```
+
+## 4. 引擎连接器配置说明
+
+### 4.1 默认配置说明
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| wds.linkis.rm.instance | 10 |否 | 引擎连接器最大并发数 |
+| wds.linkis.engineconn.java.driver.memory | 1g |否 | 引擎连接器初始化内存大小 |
+| wds.linkis.engineconn.max.free.time | 1h |否 | 引擎连接器空闲退出时间 |
+
+### 4.2 队列资源配置
+`Hive` 的 `MapReduce` 任务是需要用到 `yarn` 的资源,所以需要设置队列。
+
+![yarn](./images/yarn-conf.png)
+
+### 4.3 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.3.1 管理台配置
+
+![hive](./images/hive-config.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE \
+-engineType hive-3.1.3 -codeType hql \
+-code "show databases" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.3.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "show databases;", "runType": "sql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "wds.linkis.rm.instance":"10"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "hive-3.1.3",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+### 4.4 引擎连接器相关数据表
+
+`Linkis` 是通过引擎连接器标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎连接器的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎连接器标签如:hive-3.1.3
+linkis_ps_configuration_category: 插入引擎连接器的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎连接器需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎连接器的关联关系
+```
+
+表中与引擎连接器相关的初始数据如下
+
+```sql
+-- set variable
+SET @HIVE_LABEL="hive-3.1.3";
+SET @HIVE_ALL=CONCAT('*-*,',@HIVE_LABEL);
+SET @HIVE_IDE=CONCAT('*-IDE,',@HIVE_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @HIVE_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @HIVE_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @HIVE_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.instance', '范围:1-20,单位:个', 'hive引擎连接器最大并发数', '10', 'NumInterval', '[1,20]', '0', '0', '1', '队列资源', 'hive');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.java.driver.memory', '取值范围:1-10,单位:G', 'hive引擎连接器初始化内存大小','1g', 'Regex', '^([1-9]|10)(G|g)$', '0', '0', '1', 'hive引擎连接器设置', 'hive');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('hive.client.java.opts', 'hive客户端进程参数', 'hive引擎连接器启动时jvm参数','', 'None', NULL, '1', '1', '1', 'hive引擎连接器设置', 'hive');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('mapred.reduce.tasks', '范围:-1-10000,单位:个', 'reduce数', '-1', 'NumInterval', '[-1,10000]', '0', '1', '1', 'hive资源设置', 'hive');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.max.free.time', '取值范围:3m,15m,30m,1h,2h', '引擎连接器空闲退出时间','1h', 'OFT', '[\"1h\",\"2h\",\"30m\",\"15m\",\"3m\"]', '0', '0', '1', 'hive引擎连接器设置', 'hive');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'hive' and label_value = @HIVE_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @HIVE_ALL);
+```
+
+## 5. Hive修改日志展示
+默认的日志界面是不显示 `application_id` 以及 `task` 完成数量的,用户可以根据需要输出该日志
+引擎连接器内的 `log4j2-engineconn.xml/log4j2.xml` 配置文件中需要修改的代码块如下
+1. `appenders` 组件下需要添加
+```xml
+
+
+
+```
+2. `root` 组件下需要添加
+```xml
+
+```
+3. `loggers` 组件下需要添加
+```xml
+
+
+
+```
+进行如上相关修改后日志可以增加任务 `task` 进度信息,显示为如下样式
+```
+2022-04-08 11:06:50.228 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Status: Running (Executing on YARN cluster with App id application_1631114297082_432445)
+2022-04-08 11:06:50.248 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Map 1: -/- Reducer 2: 0/1
+2022-04-08 11:06:52.417 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Map 1: 0/1 Reducer 2: 0/1
+2022-04-08 11:06:55.060 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Map 1: 0(+1)/1 Reducer 2: 0/1
+2022-04-08 11:06:57.495 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Map 1: 1/1 Reducer 2: 0(+1)/1
+2022-04-08 11:06:57.899 INFO [Linkis-Default-Scheduler-Thread-3] SessionState 1111 printInfo - Map 1: 1/1 Reducer 2: 1/1
+```
+
+完整 `xml` 配置文件范例如下:
+```xml
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/check-seatunnel.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/check-seatunnel.png
new file mode 100644
index 00000000000..982c227195b
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/check-seatunnel.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/datasourceconntest.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/datasourceconntest.png
new file mode 100644
index 00000000000..9b1308a10ba
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/datasourceconntest.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/datasourcemanage.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/datasourcemanage.png
new file mode 100644
index 00000000000..f59d64c7483
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/datasourcemanage.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/es-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/es-config.png
new file mode 100644
index 00000000000..d06c2b878ba
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/es-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/es-manage.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/es-manage.png
new file mode 100644
index 00000000000..f4a4616a528
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/es-manage.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/historical_information.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/historical_information.png
new file mode 100644
index 00000000000..6c10cd71b7c
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/historical_information.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/hive-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/hive-config.png
new file mode 100644
index 00000000000..9e57ec2ebfc
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/hive-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/hive-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/hive-run.png
new file mode 100644
index 00000000000..287b1abfdef
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/hive-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/jdbc-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/jdbc-config.png
new file mode 100644
index 00000000000..2977040d148
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/jdbc-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/jdbc-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/jdbc-run.png
new file mode 100644
index 00000000000..fe51598b235
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/jdbc-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/job_state.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/job_state.png
new file mode 100644
index 00000000000..cadf1d1cd90
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/job_state.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/k8s-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/k8s-config.png
new file mode 100644
index 00000000000..d9986c972a4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/k8s-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/k8s-ecm-label.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/k8s-ecm-label.png
new file mode 100644
index 00000000000..a6f116b7418
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/k8s-ecm-label.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/muti-data-source-usage.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/muti-data-source-usage.png
new file mode 100644
index 00000000000..cc017a53935
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/muti-data-source-usage.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/new_pipeline_script.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/new_pipeline_script.png
new file mode 100644
index 00000000000..8a1b59ce29e
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/new_pipeline_script.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/openlookeng-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/openlookeng-config.png
new file mode 100644
index 00000000000..00abce5093a
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/openlookeng-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/pipeline-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/pipeline-conf.png
new file mode 100644
index 00000000000..325efe24c84
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/pipeline-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/presto-console.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/presto-console.png
new file mode 100644
index 00000000000..d3a92de1a57
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/presto-console.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/presto-file.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/presto-file.png
new file mode 100644
index 00000000000..49c00b99656
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/presto-file.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/presto-psql.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/presto-psql.png
new file mode 100644
index 00000000000..505f0a7a8c1
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/presto-psql.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/pyspakr-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/pyspakr-run.png
new file mode 100644
index 00000000000..c80c85bae00
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/pyspakr-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/python-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/python-conf.png
new file mode 100644
index 00000000000..3417af1c1e1
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/python-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/python-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/python-config.png
new file mode 100644
index 00000000000..acfb69a6482
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/python-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/python-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/python-run.png
new file mode 100644
index 00000000000..65467afca15
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/python-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/queue-set.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/queue-set.png
new file mode 100644
index 00000000000..78fc0f3e6a4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/queue-set.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/scala-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/scala-run.png
new file mode 100644
index 00000000000..7c01aadcdf8
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/scala-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/shell-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/shell-run.png
new file mode 100644
index 00000000000..734bdb22dce
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/shell-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/spark-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/spark-conf.png
new file mode 100644
index 00000000000..d452a3f4ad8
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/spark-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/sparksql-run.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/sparksql-run.png
new file mode 100644
index 00000000000..f0b1d1bcaf2
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/sparksql-run.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/to_write.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/to_write.png
new file mode 100644
index 00000000000..e75ab0638e4
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/to_write.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/trino-config.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/trino-config.png
new file mode 100644
index 00000000000..0f7cc9c94ac
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/trino-config.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/workflow.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/workflow.png
new file mode 100644
index 00000000000..3a5919f2594
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/workflow.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/yarn-conf.png b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/yarn-conf.png
new file mode 100644
index 00000000000..15256381f92
Binary files /dev/null and b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/images/yarn-conf.png differ
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/impala.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/impala.md
new file mode 100644
index 00000000000..eb1170a7550
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/impala.md
@@ -0,0 +1,219 @@
+---
+title: Impala
+sidebar_position: 12
+---
+
+本文主要介绍在 `Linkis` 中,`Impala` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+
+### 1.1 环境安装
+
+如果您希望在您的服务器上使用 Impala 引擎,您需要准备 Impala 服务并提供连接信息,如 Impala 集群的连接地址、SASL用户名和密码等
+
+### 1.2 环境验证
+
+执行 impala-shell 命令得到如下输出代表 impala 服务可用。
+```
+[root@8f43473645b1 /]# impala-shell
+Starting Impala Shell without Kerberos authentication
+Connected to 8f43473645b1:21000
+Server version: impalad version 2.12.0-cdh5.15.0 RELEASE (build 23f574543323301846b41fa5433690df32efe085)
+***********************************************************************************
+Welcome to the Impala shell.
+(Impala Shell v2.12.0-cdh5.15.0 (23f5745) built on Thu May 24 04:07:31 PDT 2018)
+
+When pretty-printing is disabled, you can use the '--output_delimiter' flag to set
+the delimiter for fields in the same row. The default is ','.
+***********************************************************************************
+[8f43473645b1:21000] >
+```
+
+## 2. 引擎插件部署
+
+编译 `Impala` 引擎之前需要进行 `Linkis` 项目全量编译 , `Linkis` 默认发布的安装部署包中默认不包含此引擎插件。
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/impala/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/impala/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── impala
+│ ├── dist
+│ │ └── 3.4.0
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 3.4.0
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -submitUser impala \
+-engineType impala-3.4.0 -code 'show databases;' \
+-runtimeMap linkis.es.http.method=GET \
+-runtimeMap linkis.impala.servers=127.0.0.1:21050
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 | 说明 | 是否必须 |
+| -------------------------------------- | --------------------- | ------------------------------------------- | -------- |
+| linkis.impala.default.limit | 5000 | 是 | 查询的结果集返回条数限制 |
+| linkis.impala.engine.user | ${HDFS_ROOT_USER} | 是 | 默认引擎启动用户 |
+| linkis.impala.user.isolation.mode | false | 是 | 以多用户模式启动引擎 |
+| linkis.impala.servers | 127.0.0.1:21050 | 是 | Impala服务器地址,','分隔 |
+| linkis.impala.maxConnections | 10 | 是 | 对每台Impala服务器的连接数上限 |
+| linkis.impala.ssl.enable | false | 是 | 是否启用SSL连接 |
+| linkis.impala.ssl.keystore.type | JKS | 否 | SSL Keystore类型 |
+| linkis.impala.ssl.keystore | null | 否 | SSL Keystore路径 |
+| linkis.impala.ssl.keystore.password | null | 否 | SSL Keystore密码 |
+| linkis.impala.ssl.truststore.type | JKS | 否 | SSL Truststore类型 |
+| linkis.impala.ssl.truststore | null | 否 | SSL Truststore路径 |
+| linkis.impala.ssl.truststore.password | null | 否 | SSL Truststore密码 |
+| linkis.impala.sasl.enable | false | 是 | 是否启用SASL认证 |
+| linkis.impala.sasl.mechanism | PLAIN | 否 | SASL Mechanism |
+| linkis.impala.sasl.authorizationId | null | 否 | SASL AuthorizationId |
+| linkis.impala.sasl.protocol | LDAP | 否 | SASL Protocol |
+| linkis.impala.sasl.properties | null | 否 | SASL Properties: key1=value1,key2=value2 |
+| linkis.impala.sasl.username | ${impala.engine.user}| 否 | SASL Username |
+| linkis.impala.sasl.password | null | 否 | SASL Password |
+| linkis.impala.sasl.password.cmd | null | 否 | SASL Password获取命令 |
+| linkis.impala.heartbeat.seconds | 1 | 是 | 任务状态更新间隔 |
+| linkis.impala.query.timeout.seconds | 0 | 否 | 任务执行超时时间 |
+| linkis.impala.query.batchSize | 1000 | 是 | 结果集获取批次大小 |
+| linkis.impala.query.options | null | 否 | 查询提交参数: key1=value1,key2=value2 |
+
+### 4.2 配置修改
+
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "show databases;", "runType": "sql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "linkis.impala.servers"="127.0.0.1:21050"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "impala-3.4.0",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:impala-3.4.0
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+
+```sql
+-- set variable
+SET @ENGINE_LABEL="impala-3.4.0";
+SET @ENGINE_IDE=CONCAT('*-IDE,',@ENGINE_LABEL);
+SET @ENGINE_ALL=CONCAT('*-*,',@ENGINE_LABEL);
+SET @ENGINE_NAME="impala";
+
+-- add impala engine to IDE
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @ENGINE_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @ENGINE_IDE, 'OPTIONAL', 2, now(), now());
+select @label_id := id from `linkis_cg_manager_label` where label_value = @ENGINE_IDE;
+insert into `linkis_ps_configuration_category` (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- insert configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.default.limit', '查询的结果集返回条数限制', '结果集条数限制', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.engine.user', '默认引擎启动用户', '默认启动用户', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.user.isolation.mode', '以多用户模式启动引擎', '多用户模式', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.servers', 'Impala服务器地址', '服务地址', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.maxConnections ', '对每台Impala服务器的连接数上限', '最大连接数', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.enable', '是否启用SSL连接', '启用SSL', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.keystore.type', 'SSL Keystore类型', 'SSL Keystore类型', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.keystore', 'SSL Keystore路径', 'SSL Keystore路径', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.keystore.password', 'SSL Keystore密码', 'SSL Keystore密码', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.truststore.type', 'SSL Truststore类型', 'SSL Truststore类型', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.truststore', 'SSL Truststore路径', 'SSL Truststore路径', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.ssl.truststore.password', 'SSL Truststore密码', 'SSL Truststore密码', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.enable', '是否启用SASL认证', '启用SASL', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.mechanism', 'SASL Mechanism', 'SASL Mechanism', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.authorizationId', 'SASL AuthorizationId', 'SASL AuthorizationId', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.protocol', 'SASL Protocol', 'SASL Protocol', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.properties', 'SASL Properties: key1=value1,key2=value2', 'SASL Properties', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.username', 'SASL Username', 'SASL Username', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.password', 'SASL Password', 'SASL Password', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.sasl.password.cmd', 'SASL Password获取命令', 'SASL Password获取命令', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.heartbeat.seconds', '任务状态更新间隔', '任务状态更新间隔', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.query.timeout.seconds', '任务执行超时时间', '任务执行超时时间', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.query.batchSize', '结果集获取批次大小', '结果集获取批次大小', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.impala.query.options', '查询提交参数: key1=value1,key2=value2', '查询提交参数', 'null', 'None', '', @ENGINE_NAME, 0, 0, 1, '数据源配置');
+-- impala engine -*
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as config_key_id, label.id AS engine_type_label_id FROM `linkis_ps_configuration_config_key` config
+INNER JOIN `linkis_cg_manager_label` label ON config.engine_conn_type = @ENGINE_NAME and label_value = @ENGINE_ALL);
+-- impala engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select relation.config_key_id AS config_key_id, '' AS config_value, relation.engine_type_label_id AS config_label_id FROM `linkis_ps_configuration_key_engine_relation` relation
+INNER JOIN `linkis_cg_manager_label` label ON relation.engine_type_label_id = label.id AND label.label_value = @ENGINE_ALL);
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/jdbc.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/jdbc.md
new file mode 100644
index 00000000000..b549fa7a1f2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/jdbc.md
@@ -0,0 +1,275 @@
+---
+title: JDBC
+sidebar_position: 5
+---
+
+本文主要介绍在 `Linkis` 中, `JDBC` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 环境安装
+
+如果您希望在您的服务器上使用 `JDBC` 引擎,您需要准备 `JDBC` 连接信息,如 `MySQL` 数据库的连接地址、用户名和密码等
+
+### 1.2 环境验证(以 `Mysql` 为例)
+```
+mysql -uroot -P 3306 -h 127.0.0.1 -p 123456
+```
+输出如下信息代表 `JDBC` 连接信息可用
+```
+mysql: [Warning] Using a password on the command line interface can be insecure.
+Welcome to the MySQL monitor. Commands end with ; or \g.
+Your MySQL connection id is 9
+Server version: 5.7.39 MySQL Community Server (GPL)
+
+Copyright (c) 2000, 2022, Oracle and/or its affiliates.
+
+Oracle is a registered trademark of Oracle Corporation and/or its
+affiliates. Other names may be trademarks of their respective
+owners.
+
+Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
+
+mysql>
+```
+
+## 2. 引擎插件安装
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/jdbc/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/jdbc/target/out/
+```
+
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── jdbc
+│ ├── dist
+│ │ └── 4
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 4
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType jdbc-4 \
+-codeType jdbc -code "show tables" \
+-submitUser hadoop -proxyUser hadoop \
+-runtimeMap wds.linkis.jdbc.connect.url=jdbc:mysql://127.0.0.1:3306/linkis_db \
+-runtimeMap wds.linkis.jdbc.driver=com.mysql.jdbc.Driver \
+-runtimeMap wds.linkis.jdbc.username=test \
+-runtimeMap wds.linkis.jdbc.password=123456
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过 `Linkis SDK` 提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。对于 `JDBC` 任务您只需要修改 `Demo` 中的 `EngineConnType` 和 `CodeType` 参数即可:
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "jdbc-4"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "jdbc"); // required codeType
+```
+
+### 3.3 多数据源支持
+从 `Linkis 1.2.0` 开始,提供了 `JDBC` 引擎多数据源的支持,我们首先可以在控制台管理不同的数据源。地址:登陆管理台-->数据源管理-->新增数据源
+
+![](./images/datasourcemanage.png)
+
+图3-3 数据源管理
+
+![](./images/datasourceconntest.png)
+
+图3-4 数据源连接测试
+
+数据源添加完成之后,就可以使用 `JDBC` 引擎的多数据源切换功能,有两种方式:
+1、 通过接口参数指定数据源名称参数
+参数示例:
+```json
+{
+ "executionContent": {
+ "code": "show databases",
+ "runType": "jdbc"
+ },
+ "params": {
+ "variable": {},
+ "configuration": {
+ "startup": {},
+ "runtime": {
+ "wds.linkis.engine.runtime.datasource": "test_mysql"
+ }
+ }
+ },
+ "source": {
+ "scriptPath": ""
+ },
+ "labels": {
+ "engineType": "jdbc-4",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+参数:`wds.linkis.engine.runtime.datasource` 为固定名称的配置,不要随意修改名称定义
+
+2、 通过 `DSS` 的 `Scripts` 代码提交入口下拉筛选需要提交的数据源,如下图:
+![](./images/muti-data-source-usage.png)
+当前 `dss-1.1.0` 还暂不支持下拉选择数据源名称, `PR` 在开发中,可以等后续发版或关注相关 `PR` :
+(https://github.com/WeBankFinTech/DataSphereStudio/issues/940)
+
+
+多数据源的功能说明:
+
+1)在之前的版本中, `JDBC` 引擎对数据源的支持不够完善,尤其是搭配 `Scripts` 使用的时候, `JDBC` 脚本类型只能绑定控制台的一套 `JDBC` 引擎参数,
+当我们有多数据源的切换需求时,只能修改 `JDBC` 引擎的连接参数,比较麻烦。
+
+2)配合数据源管理,我们引入 `JDBC` 引擎的多数据源切换功能,可以实现只设置数据源名称,就可把作业提交到不同的 `JDBC` 服务之上,普通用户不需要
+维护数据源的连接信息,避免了配置繁琐,也满足了数据源连接密码等配置的安全性需要。
+
+3)多数据源管理中设置的数据源,只有发布之后,并且没有过期的数据源才能被 `JDBC` 引擎加载到,否则会反馈给用户不同类型的异常提示。
+
+4) `JDBC` 引擎参数的加载优先级为:任务提交传参 > 选择数据源的参数 > 控制台JDBC引擎的参数
+
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| wds.linkis.jdbc.connect.url | jdbc:mysql://127.0.0.1:10000 |是 | jdbc连接地址 |
+| wds.linkis.jdbc.driver | 无 |是 | jdbc连接驱动 |
+| wds.linkis.jdbc.username | 无 |是 | 数据库连接用户名 |
+| wds.linknis.jdbc.password | 无 |是 | 数据库链接密码 |
+| wds.linkis.jdbc.connect.max | 10 |否 | jdbc引擎最大连接数 |
+| wds.linkis.jdbc.version | jdbc4 |否 | jdbc版本 |
+
+### 4.2 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+
+#### 4.2.1 管理台配置
+
+![jdbc](./images/jdbc-config.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE \
+-engineType jdbc-4 -codeType jdbc \
+-code "show tables" \
+-submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "show databases;", "runType": "jdbc"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "wds.linkis.jdbc.connect.url":"jdbc:mysql://127.0.0.1:3306/test",
+ "wds.linkis.jdbc.driver":"com.mysql.jdbc.Driver",
+ "wds.linkis.jdbc.username":"test",
+ "wds.linkis.jdbc.password":"test23"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "jdbc-4",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:jdbc-4
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+```sql
+-- set variable
+SET @JDBC_LABEL="jdbc-4";
+SET @JDBC_ALL=CONCAT('*-*,',@JDBC_LABEL);
+SET @JDBC_IDE=CONCAT('*-IDE,',@JDBC_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @JDBC_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @JDBC_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @JDBC_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.connect.url', '例如:jdbc:mysql://127.0.0.1:10000', 'jdbc连接地址', 'jdbc:mysql://127.0.0.1:10000', 'Regex', '^\\s*jdbc:\\w+://([^:]+)(:\\d+)(/[^\\?]+)?(\\?\\S*)?$', '0', '0', '1', '数据源配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.driver', '例如:com.mysql.jdbc.Driver', 'jdbc连接驱动', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.version', '取值范围:jdbc3,jdbc4', 'jdbc版本','jdbc4', 'OFT', '[\"jdbc3\",\"jdbc4\"]', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.username', 'username', '数据库连接用户名', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.password', 'password', '数据库连接密码', '', 'None', '', '0', '0', '1', '用户配置', 'jdbc');
+insert into `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.jdbc.connect.max', '范围:1-20,单位:个', 'jdbc引擎最大连接数', '10', 'NumInterval', '[1,20]', '0', '0', '1', '数据源配置', 'jdbc');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'jdbc' and label_value = @JDBC_ALL);
+
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @JDBC_ALL);
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/nebula.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/nebula.md
new file mode 100644
index 00000000000..e4f14cfccb8
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/nebula.md
@@ -0,0 +1,109 @@
+---
+title: Nebula
+sidebar_position: 17
+---
+
+本文主要介绍在 `Linkis` 中,`Nebula` 引擎插件的安装、使用和配置。
+
+
+## 1. 前置工作
+
+### 1.1 引擎安装
+
+如果您希望在您的 `Linkis` 服务上使用 `Nebula` 引擎,您需要安装 `Nebula` 服务并保证服务可用。
+
+### 1.2 服务验证
+
+```shell
+# 执行任务
+./usr/local/bin/nebula-console -u root -p password --address=graphd --port=9669
+
+CREATE SPACE IF NOT EXISTS my_space_1 (vid_type=FIXED_STRING(30));SHOW SPACES;
+
+# 得到如下输出代表服务可用
++--------------+
+| Name |
++--------------+
+| "my_space_1" |
++--------------+
+```
+
+## 2. 引擎插件部署
+
+### 2.1 引擎插件准备[非默认引擎](./overview.md)
+
+单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/nebula/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/nebula/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineplugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── nebula
+│ ├── dist
+│ │ └── 3.0.0
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 3.0.0
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType nebula-3.0.0 -codeType nebula \
+ -code 'CREATE SPACE IF NOT EXISTS my_space_1 (vid_type=FIXED_STRING(30));SHOW SPACES;' \
+ -runtimeMap linkis.nebula.port=9669 -runtimeMap linkis.nebula.host=wds07
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 | 是否必须 | 说明 |
+| -------------------------------------- |-----------|-------------|--------|
+| linkis.nebula.host | 127.0.0.1 | 否 | host |
+| linkis.nebula.port | 9669 | 否 | 端口 |
+| linkis.nebula.username | root | 否 | 用户名 |
+| linkis.nebula.password | nebula | 否 | 密码 |
+| linkis.nebula.max.conn.size | 100 | 否 | 最大连接数 |
+| linkis.nebula.reconnect.enabled | false | 否 | 连接断开后是否重试 |
+| linkis.engineconn.concurrent.limit | 100 | 否 | 引擎最大并发数 |
+| linkis.nebula.default.limit | 5000 | 否 | 结果集条数限制 |
+
+
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/openlookeng.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/openlookeng.md
new file mode 100644
index 00000000000..c851141b995
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/openlookeng.md
@@ -0,0 +1,210 @@
+---
+title: openLooKeng
+sidebar_position: 7
+---
+
+本文主要介绍在 `Linkis` `中,openLooKeng` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 环境安装
+
+如果您希望部署使用 `openLooKeng` 引擎,您需要准备一套可用的 `openLooKeng` 环境。
+
+### 1.2 服务验证
+
+```shell
+# 准备 hetu-cli
+wget https://download.openlookeng.io/1.5.0/hetu-cli-1.5.0-executable.jar
+mv hetu-cli-1.5.0-executable.jar hetu-cli
+chmod +x hetu-cli
+
+# 链接服务
+./hetu-cli --server 127.0.0.1:9090 --catalog tpcds --schema default
+
+# 执行查询语句
+lk:default> select d_date_sk, d_date_id, d_date, d_month_seq from tpcds.sf1.date_dim order by d_date limit 5;
+
+# 得到如下输出代表服务可用
+ d_date_sk | d_date_id | d_date | d_month_seq
+-----------+------------------+------------+-------------
+ 2415022 | AAAAAAAAOKJNECAA | 1900-01-02 | 0
+ 2415023 | AAAAAAAAPKJNECAA | 1900-01-03 | 0
+ 2415024 | AAAAAAAAALJNECAA | 1900-01-04 | 0
+ 2415025 | AAAAAAAABLJNECAA | 1900-01-05 | 0
+ 2415026 | AAAAAAAACLJNECAA | 1900-01-06 | 0
+(5 rows)
+
+Query 20221110_043803_00011_m9gmv, FINISHED, 1 node
+Splits: 33 total, 33 done (100.00%)
+0:00 [73K rows, 0B] [86.8K rows/s, 0B/s]
+```
+
+## 2. 引擎插件安装
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+${linkis_code_dir}/linkis-enginepconn-pugins/engineconn-plugins/openlookeng/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/openlookeng/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── openlookeng
+│ ├── dist
+│ │ └── 1.5.0
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 1.5.0
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType openlookeng-1.5.0 \
+-codeType sql -code 'select * from tpcds.sf1.date_dim;' \
+-submitUser hadoop -proxyUser hadoop \
+-runtimeMap linkis.openlookeng.url=http://127.0.0.1:8080
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过 `Linkis SDK` 提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。对于 `JDBC` 任务您只需要修改 `Demo` 中的 `EngineConnType` 和 `CodeType` 参数即可:
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "openlookeng-1.5.0"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "sql"); // required codeType
+```
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| linkis.openlookeng.url | http://127.0.0.1:8080 |是 | 链接地址 |
+| linkis.openlookeng.catalog | system |是 | catalog |
+| linkis.openlookeng.source | global |否 | source |
+
+### 4.2 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 管理台配置
+
+![](./images/openlookeng-config.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE \
+-engineType openlookeng-1.5.0 -codeType sql \
+-code 'select * from tpcds.sf1.date_dim;' \
+-submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "select * from tpcds.sf1.date_dim;", "runType": "sql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "linkis.openlookeng.url":"http://127.0.0.1:9090"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "openlookeng-1.5.0",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:openlookeng-1.5.0
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+```sql
+-- set variable
+SET @OPENLOOKENG_LABEL="openlookeng-1.5.0";
+SET @OPENLOOKENG_ALL=CONCAT('*-*,',@OPENLOOKENG_LABEL);
+SET @OPENLOOKENG_IDE=CONCAT('*-IDE,',@OPENLOOKENG_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @OPENLOOKENG_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @OPENLOOKENG_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @OPENLOOKENG_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.url', '例如:http://127.0.0.1:8080', '连接地址', 'http://127.0.0.1:8080', 'Regex', '^\\s*http://([^:]+)(:\\d+)(/[^\\?]+)?(\\?\\S*)?$', 'openlookeng', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.catalog', 'catalog', 'catalog', 'system', 'None', '', 'openlookeng', 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('linkis.openlookeng.source', 'source', 'source', 'global', 'None', '', 'openlookeng', 0, 0, 1, '数据源配置');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'openlookeng' and label_value = @OPENLOOKENG_ALL);
+
+-- openlookeng default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @OPENLOOKENG_ALL);
+
+```
+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/overview.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/overview.md
new file mode 100644
index 00000000000..5d99947915c
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/overview.md
@@ -0,0 +1,27 @@
+---
+title: 总览
+sidebar_position: 0
+---
+## 1. 概述
+`Linkis` 作为一款功能强大的计算中间件,可以方便的对接不同的计算引擎,通过屏蔽不同计算引擎的使用细节,并向上提供了一套统一的使用接口,
+使得部署和应用 `Linkis` 的大数据平台的运维成本大大降低,目前, `Linkis` 已经对接了几款主流的计算引擎,基本上涵盖了上生产上对数据的需求,
+为了提供更好的可拓展性, `Linkis` 同时提供了接入新引擎的相关接口,可以利用该接口接入新的计算引擎。
+
+引擎是提供给用户数据处理和分析能力的组件,目前已经接入 `Linkis` 的引擎,有主流的大数据计算引擎 `Spark` 、 `Hive` 、 `Presto` 等,也有 `python` 、 `Shell` 这些脚本处理数据能力的引擎。
+`DataSphereStudio` 作为对接了 `Linkis` 的一站式数据操作平台,用户可以方便的在 `DataSphereStudio` 中使用 `Linkis` 支持的引擎完成交互式数据分析任务和工作流任务。
+
+支持引擎及版本信息如下:
+
+| 引擎 | 默认引擎 | 默认版本 |
+|-------------| -- | ---- |
+| [Spark](./spark.md) | 是 | 3.2.1 |
+| [Hive](./hive.md) | 是 | 3.1.3 |
+| [Python](./python.md) | 是 | python2 |
+| [Shell](./shell.md) | 是 | 1 |
+| [JDBC](./jdbc.md) | 否 | 4 |
+| [Flink](./flink.md) | 否 | 1.12.2 |
+| [openLooKeng](./openlookeng.md) | 否 | 1.5.0 |
+| [Pipeline](./pipeline.md) | 否 | 1 |
+| [Presto](./presto.md) | 否 | 0.234 |
+| [Sqoop](./sqoop.md) | 否 | 1.4.6 |
+| [Elasticsearch](./elasticsearch.md) | 否 | 7.6.2 |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/pipeline.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/pipeline.md
new file mode 100644
index 00000000000..8d550872869
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/pipeline.md
@@ -0,0 +1,175 @@
+---
+title: Pipeline
+sidebar_position: 9
+---
+`Pipeline` 主要是用来对文件进行导入和导出的。本文主要介绍在 `Linkis` 中, `Pipeline` 引擎插件的安装、使用和配置。
+
+## 1. 引擎插件安装
+
+### 1.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/pipeline/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/pipeline/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 1.2 引擎插件的上传和加载
+
+将 1.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── pipeline
+│ ├── dist
+│ │ └── 1
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 1
+```
+### 1.3 引擎刷新
+
+#### 1.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 1.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 2 引擎的使用
+
+因为 `Pipeline` 引擎主要用来导入导出文件为主,现在我们假设从A向B导入文件为介绍案例
+
+### 2.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh bin/linkis-cli -submitUser hadoop \
+-engineType pipeline-1 -codeType pipeline \
+-code "from hdfs:///000/000/000/A.dolphin to file:///000/000/000/B.csv"
+```
+`from hdfs:///000/000/000/A.dolphin to file:///000/000/000/B.csv` 该内容 2.3 有解释
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 3. 引擎配置说明
+
+### 3.1 默认配置说明
+
+| 配置 | 默认值 |是否必须 | 说明 |
+| ------------------------ | ------------------- | ---|---------------------------------------- |
+| pipeline.output.mold | csv |否 |结果集导出类型 |
+| pipeline.field.split | , |否 | csv分隔符 |
+| pipeline.output.charset | gbk |否 | 结果集导出字符集 |
+| pipeline.output.isoverwrite | true |否 | 是否覆写 |
+| wds.linkis.rm.instance | 3 |否 | pipeline引擎最大并发数 |
+| pipeline.output.shuffle.null.type | NULL |否 | 空值替换 |
+| wds.linkis.engineconn.java.driver.memory | 2g |否 | pipeline引擎初始化内存大小 |
+
+### 4.2 配置修改
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 管理台配置
+
+![](./images/pipeline-conf.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh bin/linkis-cli -creator IDE \
+-submitUser hadoop \
+-engineType pipeline-1 \
+-codeType pipeline \
+-code "from hdfs:///000/000/000/A.dolphin to file:///000/000/000/B.csv"
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "from hdfs:///000/000/000/A.dolphin to file:///000/000/000/B.csv", "runType": "pipeline"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "pipeline.output.mold":"csv",
+ "pipeline.output.charset":"gbk"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "pipeline-1",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:pipeline-1
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+```sql
+-- set variable
+SET @PIPELINE_LABEL="pipeline-1";
+SET @PIPELINE_ALL=CONCAT('*-*,',@PIPELINE_LABEL);
+SET @PIPELINE_IDE=CONCAT('*-IDE,',@PIPELINE_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @PIPELINE_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @PIPELINE_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @PIPELINE_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('pipeline.output.mold', '取值范围:csv或excel', '结果集导出类型','csv', 'OFT', '[\"csv\",\"excel\"]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('pipeline.field.split', '取值范围:,或\\t', 'csv分隔符',',', 'OFT', '[\",\",\"\\\\t\"]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('pipeline.output.charset', '取值范围:utf-8或gbk', '结果集导出字符集','gbk', 'OFT', '[\"utf-8\",\"gbk\"]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('pipeline.output.isoverwrite', '取值范围:true或false', '是否覆写','true', 'OFT', '[\"true\",\"false\"]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.instance', '范围:1-3,单位:个', 'pipeline引擎最大并发数','3', 'NumInterval', '[1,3]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.java.driver.memory', '取值范围:1-10,单位:G', 'pipeline引擎初始化内存大小','2g', 'Regex', '^([1-9]|10)(G|g)$', '0', '0', '1', 'pipeline资源设置', 'pipeline');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('pipeline.output.shuffle.null.type', '取值范围:NULL或者BLANK', '空值替换','NULL', 'OFT', '[\"NULL\",\"BLANK\"]', '0', '0', '1', 'pipeline引擎设置', 'pipeline');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'pipeline' and label_value = @PIPELINE_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @PIPELINE_ALL);
+
+```
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/presto.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/presto.md
new file mode 100644
index 00000000000..6c5bd98b0ea
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/presto.md
@@ -0,0 +1,228 @@
+---
+title: Presto
+sidebar_position: 11
+---
+
+本文主要介绍在 `Linkis` 中,`Presto` 引擎插件的安装、使用和配置。
+
+
+## 1. 前置工作
+
+### 1.1 引擎安装
+
+如果您希望在您的 `Linkis` 服务上使用 `Presto` 引擎,您需要安装 `Presto` 服务并保证服务可用。
+
+### 1.2 服务验证
+
+```shell
+# 准备 presto-cli
+wget https://repo1.maven.org/maven2/com/facebook/presto/presto-cli/0.234/presto-cli-0.234-executable.jar
+mv presto-cli-0.234-executable.jar presto-cli
+chmod +x presto-cli
+
+# 执行任务
+./presto-cli --server localhost:8082 --execute 'show tables from system.jdbc'
+
+# 得到如下输出代表服务可用
+"attributes"
+"catalogs"
+"columns"
+"procedure_columns"
+"procedures"
+"pseudo_columns"
+"schemas"
+"super_tables"
+"super_types"
+"table_types"
+"tables"
+"types"
+"udts"
+```
+
+## 2. 引擎插件部署
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/presto/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/presto/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── presto
+│ ├── dist
+│ │ └── 0.234
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 0.234
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+ sh ./bin/linkis-cli -engineType presto-0.234 \
+ -codeType psql -code 'show tables;' \
+ -submitUser hadoop -proxyUser hadoop
+```
+
+如果管理台,任务接口,配置文件,均未配置(配置方式见 4.2 )时可在 `Linkis-cli` 客户端中通过 `-runtimeMap` 属性进行配置
+
+```shell
+sh ./bin/linkis-cli -engineType presto-0.234 \
+-codeType tsql -code 'show tables;' \
+-runtimeMap wds.linkis.presto.url=http://127.0.0.1:8080 \
+-runtimeMap wds.linkis.presto.catalog=hive \
+-runtimeMap wds.linkis.presto.schema=default \
+-submitUser hadoop -proxyUser hadoop
+```
+
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 | 说明 | 是否必须 |
+| -------------------------------------- | --------------------- | ------------------------------------------- | -------- |
+| wds.linkis.presto.url | http://127.0.0.1:8080 | Presto 集群连接 | true |
+| wds.linkis.presto.username | default | Presto 集群用户名 | false |
+| wds.linkis.presto.password | 无 | Presto 集群密码 | false |
+| wds.linkis.presto.catalog | system | 查询的 Catalog | true |
+| wds.linkis.presto.schema | 无 | 查询的 Schema | true |
+| wds.linkis.presto.source | global | 查询使用的 source | false |
+| presto.session.query_max_total_memory | 8GB | 查询使用最大的内存 | false |
+| wds.linkis.presto.http.connectTimeout | 60 | Presto 客户端的 connect timeout(单位:秒) | false |
+| wds.linkis.presto.http.readTimeout | 60 | Presto 客户端的 read timeout(单位:秒) | false |
+| wds.linkis.engineconn.concurrent.limit | 100 | Presto 引擎最大并发数 | false |
+
+### 4.2 配置修改
+
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 管理台配置
+
+![](./images/presto-console.png)
+
+注意: 修改 `IDE` 标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE \
+-engineType presto-0.234 -codeType tsql \
+-code 'show tables;' \
+-submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "show teblas;", "runType": "psql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "wds.linkis.presto.url":"http://127.0.0.1:9090",
+ "wds.linkis.presto.catalog ":"hive",
+ "wds.linkis.presto.schema ":"default",
+ "wds.linkis.presto.source ":""
+ }
+ }
+ },
+ "source": {"scriptPath": "file:///mnt/bdp/hadoop/1.sql"},
+ "labels": {
+ "engineType": "presto-0.234",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
+
+#### 4.2.3 文件配置
+通过修改目录 `install path/lib/linkis-engineconn-plugins/presto/dist/0.234/conf/` 中的 `linkis-engineconn.properties` 文件进行配置,如下图:
+
+![](./images/presto-file.png)
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:presto-0.234
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+
+```sql
+-- set variable
+SET @PRESTO_LABEL="presto-0.234";
+SET @PRESTO_ALL=CONCAT('*-*,',@PRESTO_LABEL);
+SET @PRESTO_IDE=CONCAT('*-IDE,',@PRESTO_LABEL);
+SET @PRESTO_NAME="presto";
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@PRESTO_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType',@PRESTO_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from `linkis_cg_manager_label` where `label_value` = @PRESTO_IDE;
+insert into `linkis_ps_configuration_category` (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('wds.linkis.presto.url', 'Presto 集群连接', 'presto连接地址', 'http://127.0.0.1:8080', 'None', NULL, @PRESTO_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('wds.linkis.presto.catalog', '查询的 Catalog ', 'presto连接的catalog', 'hive', 'None', NULL, @PRESTO_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('wds.linkis.presto.schema', '查询的 Schema ', '数据库连接schema', '', 'None', NULL, @PRESTO_NAME, 0, 0, 1, '数据源配置');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `engine_conn_type`, `is_hidden`, `is_advanced`, `level`, `treeName`) VALUES ('wds.linkis.presto.source', '查询使用的 source ', '数据库连接source', '', 'None', NULL, @PRESTO_NAME, 0, 0, 1, '数据源配置');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = @PRESTO_NAME and label_value = @PRESTO_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @PRESTO_ALL);
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/python.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/python.md
new file mode 100644
index 00000000000..86e4a9847e2
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/python.md
@@ -0,0 +1,182 @@
+---
+title: Python
+sidebar_position: 3
+---
+
+本文主要介绍在 `Linkis` 中, `Python` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 环境安装
+
+如果您希望在您的服务器上使用 `Python` 引擎,您需要保证用户的 `PATH` 中是有 `Python` 的执行目录和执行权限。
+
+### 1.2 环境验证
+```
+python --version
+```
+正常输出 `Python` 版本信息代表 `Python` 环境可用
+```
+Python 3.6.0
+```
+
+## 2. 引擎插件安装 [默认引擎](./overview.md)
+
+`Linkis` 发布的二进制安装包中默认包含了 `Python` 引擎插件,用户无需额外安装。
+
+[EngineConnPlugin引擎插件安装](../deployment/install-engineconn.md)
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType python-python2 \
+-codeType python -code "print(\"hello\")" \
+-submitUser hadoop -proxyUser hadoop
+```
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过 `Linkis SDK` 提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。 具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。对于 `Python` 任务您只需要修改 `EngineConnType` 和 `CodeType` 参数即可。
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "python-python2"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "python"); // required codeType
+```
+
+## 4. 引擎配置说明
+
+### 4.1 配置修改
+`Python` 引擎插件支持 `Python2` 和 `Python3` ,您可以简单更改配置就可以完成 `Python` 版本的切换,不需要重新编译 `Python` 的引擎版本。 `Python` 引擎支持多种配置修改方式,具体操作如下。
+
+#### 4.1.1 通过命令参数显示指定(仅当前命令生效)
+
+```shell
+#1:cli的方式提交任务进行版本切换,命令末端设置版本 python.version=python3 (python3:创建软连接时生成文件的名称,可自定义命名)
+sh ./bin/linkis-cli -engineType python-python2 \
+-codeType python -code "print(\"hello\")" \
+-submitUser hadoop -proxyUser hadoop \
+-confMap python.version=python3
+
+#2:cli的方式提交任务进行版本切换,命令设置加入版本路径 python.version=/usr/bin/python (/usr/bin/python:创建软连接时生成文件的路径)
+sh ./bin/linkis-cli -engineType python-python2 \
+-codeType python -code "print(\"hello\")" \
+-submitUser hadoop -proxyUser hadoop \
+-confMap python.version=/usr/bin/python
+
+```
+
+#### 4.1.2 管理台配置
+
+![](./images/python-config.png)
+
+注意: 修改IDE标签下的配置后需要指定 `-creator IDE` 才会生效(其它标签类似),如:
+
+```shell
+sh ./bin/linkis-cli -creator IDE -engineType \
+python-python2 -codeType python -code "print(\"hello\")" \
+-submitUser hadoop -proxyUser hadoop \
+-confMap python.version=python3
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": "print(\"hello\")", "runType": "python"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "python.version":"python2",
+ "wds.linkis.engineconn.max.free.time":"1h"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "python-python2",
+ "userCreator": "IDE"
+ }
+}
+```
+
+#### 4.2.3 文件配置
+通过修改目录 `${LINKIS_HOME}/lib/linkis-engineconn-plugins/python/dist/python2/conf/` 中的 `linkis-engineconn.properties` 文件进行配置,如下图:
+
+![](./images/python-conf.png)
+
+### 4.3 引擎相关数据表
+
+`Linkis` 是通过引擎标签来进行管理的,所涉及的数据表信息如下所示。
+
+```
+linkis_ps_configuration_config_key: 插入引擎的配置参数的key和默认values
+linkis_cg_manager_label:插入引擎label如:python-python2
+linkis_ps_configuration_category: 插入引擎的目录关联关系
+linkis_ps_configuration_config_value: 插入引擎需要展示的配置
+linkis_ps_configuration_key_engine_relation:配置项和引擎的关联关系
+```
+
+表中与引擎相关的初始数据如下
+
+```sql
+-- set variable
+SET @PYTHON_LABEL="python-python2";
+SET @PYTHON_ALL=CONCAT('*-*,',@PYTHON_LABEL);
+SET @PYTHON_IDE=CONCAT('*-IDE,',@PYTHON_LABEL);
+
+-- engine label
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @PYTHON_ALL, 'OPTIONAL', 2, now(), now());
+insert into `linkis_cg_manager_label` (`label_key`, `label_value`, `label_feature`, `label_value_size`, `update_time`, `create_time`) VALUES ('combined_userCreator_engineType', @PYTHON_IDE, 'OPTIONAL', 2, now(), now());
+
+select @label_id := id from linkis_cg_manager_label where `label_value` = @PYTHON_IDE;
+insert into linkis_ps_configuration_category (`label_id`, `level`) VALUES (@label_id, 2);
+
+-- configuration key
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.client.memory.max', '取值范围:1-100,单位:G', 'python驱动器内存使用上限', '20G', 'Regex', '^([1-9]\\d{0,1}|100)(G|g)$', '0', '0', '1', '队列资源', 'python');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.client.core.max', '取值范围:1-128,单位:个', 'python驱动器核心个数上限', '10', 'Regex', '^(?:[1-9]\\d?|[1234]\\d{2}|128)$', '0', '0', '1', '队列资源', 'python');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.rm.instance', '范围:1-20,单位:个', 'python引擎最大并发数', '10', 'NumInterval', '[1,20]', '0', '0', '1', '队列资源', 'python');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.java.driver.memory', '取值范围:1-2,单位:G', 'python引擎初始化内存大小', '1g', 'Regex', '^([1-2])(G|g)$', '0', '0', '1', 'python引擎设置', 'python');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('python.version', '取值范围:python2,python3', 'python版本','python2', 'OFT', '[\"python3\",\"python2\"]', '0', '0', '1', 'python引擎设置', 'python');
+INSERT INTO `linkis_ps_configuration_config_key` (`key`, `description`, `name`, `default_value`, `validate_type`, `validate_range`, `is_hidden`, `is_advanced`, `level`, `treeName`, `engine_conn_type`) VALUES ('wds.linkis.engineconn.max.free.time', '取值范围:3m,15m,30m,1h,2h', '引擎空闲退出时间','1h', 'OFT', '[\"1h\",\"2h\",\"30m\",\"15m\",\"3m\"]', '0', '0', '1', 'python引擎设置', 'python');
+
+-- key engine relation
+insert into `linkis_ps_configuration_key_engine_relation` (`config_key_id`, `engine_type_label_id`)
+(select config.id as `config_key_id`, label.id AS `engine_type_label_id` FROM linkis_ps_configuration_config_key config
+INNER JOIN linkis_cg_manager_label label ON config.engine_conn_type = 'python' and label_value = @PYTHON_ALL);
+
+-- engine default configuration
+insert into `linkis_ps_configuration_config_value` (`config_key_id`, `config_value`, `config_label_id`)
+(select `relation`.`config_key_id` AS `config_key_id`, '' AS `config_value`, `relation`.`engine_type_label_id` AS `config_label_id` FROM linkis_ps_configuration_key_engine_relation relation
+INNER JOIN linkis_cg_manager_label label ON relation.engine_type_label_id = label.id AND label.label_value = @PYTHON_ALL);
+```
+
+
+### 4.4 其他python样例代码
+
+```python
+import pandas as pd
+
+data = {'name': ['aaaaaa', 'bbbbbb', 'cccccc'], 'pay': [4000, 5000, 6000]}
+frame = pd.DataFrame(data)
+show.show(frame)
+
+
+print('new reuslt')
+
+from matplotlib import pyplot as plt
+
+x=[4,8,10]
+y=[12,16,6]
+x2=[6,9,11]
+y2=[6,15,7]
+plt.bar(x,y,color='r',align='center')
+plt.bar(x2,y2,color='g',align='center')
+plt.show()
+
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/repl.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/repl.md
new file mode 100644
index 00000000000..4e65f5cc363
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/repl.md
@@ -0,0 +1,124 @@
+---
+title: Repl
+sidebar_position: 16
+---
+
+# Repl 引擎使用文档
+
+本文主要介绍在 `Linkis` 中,`Repl` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+
+### 1.1 引擎验证
+
+强烈建议您在执行 `Repl` 任务之前,检查下执行用户的这些环境变量。具体方式是
+```
+sudo su - ${username}
+echo ${JAVA_HOME}
+```
+
+## 2. 引擎插件安装
+
+### 2.1 引擎插件准备[非默认引擎](./overview.md)
+
+单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/repl/
+mvn clean install
+
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/repl/target/out/
+```
+
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎插件包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineplugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── repl
+│ ├── dist
+│ │ └── 1
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 1
+```
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的 `last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到linkis的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+
+## 3. Repl引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交`java`任务
+
+单个方法
+```shell
+ sh bin/linkis-cli -engineType repl-1 -code \
+"import org.apache.commons.lang3.StringUtils;
+ public void sayHello() {
+ System.out.println(\"hello\");
+ System.out.println(StringUtils.isEmpty(\"hello\"));
+ }" \
+ -codeType repl -runtimeMap linkis.repl.type=java
+```
+
+多个方法
+```shell
+ sh bin/linkis-cli -engineType repl-1 -code \
+"import org.apache.commons.lang3.StringUtils;
+
+ public void sayHello() {
+ System.out.println(\"hello\");
+ System.out.println(StringUtils.isEmpty(\"hello\"));
+ }
+ public void sayHi() {
+ System.out.println(\"hi\");
+ System.out.println(StringUtils.isEmpty(\"hi\"));
+ }" \
+ -codeType repl -runtimeMap linkis.repl.type=java -runtimeMap linkis.repl.method.name=sayHi
+```
+
+### 3.2 通过 `Linkis-cli` 提交`scala`任务
+
+```shell
+ sh bin/linkis-cli -engineType repl-1 -code \
+"import org.apache.commons.io.FileUtils
+import java.io.File
+
+val x = 2 + 3;
+println(x);
+FileUtils.forceMkdir(new File(\"/tmp/linkis_repl_scala_test\"));" \
+ -codeType repl -runtimeMap linkis.repl.type=scala
+```
+
+更多 `Linkis-Cli` 命令参数参考: [`Linkis-Cli` 使用](../user-guide/linkiscli-manual.md)
+
+
+Repl引擎,支持的连接参数有:
+
+| 配置名称 | 备注及默认值信息 | 是否必须 |
+|-----------------|------------------------------|----------------------------------------|
+| linkis.repl.type | repl类型,支持java和scala,默认值:java | 非必须 |
+| linkis.repl.method.name | 执行的方法名称,默认值为空 | 非必须 |
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/seatunnel.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/seatunnel.md
new file mode 100644
index 00000000000..e560c388ff3
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/seatunnel.md
@@ -0,0 +1,254 @@
+---
+title: Seatunnel
+sidebar_position: 13
+---
+
+本文主要介绍在 `Linkis` 中,`Seatunnel` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+
+### 1.1 引擎安装
+
+如果您希望在您的 `Linkis` 服务上使用 `Seatunnel` 引擎,您需要安装 `Seatunnel` 引擎。而且 `Seatunnel` 是依赖 `Spark` 或 `Flink` 环境,使用 `linkis-seatunnel` 引擎前,强烈建议本地跑通 `Seatunnel` 环境。
+
+`Seatunnel 2.1.2` 下载地址:https://dlcdn.apache.org/incubator/seatunnel/2.1.2/apache-seatunnel-incubating-2.1.2-bin.tar.gz
+
+| 环境变量名称 | 环境变量内容 | 是否需要 |
+|-----------------|----------------|----------------------------------------|
+| JAVA_HOME | JDK安装路径 | 需要 |
+| SEATUNNEL_HOME | Seatunnel安装路径 | 需要 |
+|SPARK_HOME| Spark安装路径 | Seatunnel执行基于Spark就需要 |
+|FLINK_HOME| Flink安装路径 | Seatunnel执行基于Flink就需要 |
+
+表1-1 环境配置清单
+
+| Linkis变量名称 | 变量内容 | 是否必须 |
+| --------------------------- | ---------------------------------------------------------- | ------------------------------------------------------------ |
+| wds.linkis.engine.seatunnel.plugin.home | Seatunnel安装路径 | 是 |
+
+### 1.2 引擎环境验证
+
+以执行 `Spark` 任务为例
+
+```shell
+cd $SEATUNNEL_HOME
+./bin/start-seatunnel-spark.sh --master local[4] --deploy-mode client --config ./config/spark.batch.conf.template
+```
+输出结果如下:
+
+![](./images/check-seatunnel.png)
+
+## 2. 引擎插件部署
+
+### 2.1 引擎插件准备(二选一)[非默认引擎](./overview.md)
+
+方式一:直接下载引擎插件包
+
+[Linkis 引擎插件下载](https://linkis.apache.org/zh-CN/blog/2022/04/15/how-to-download-engineconn-plugin)
+
+方式二:单独编译引擎插件(需要有 `maven` 环境)
+
+```
+# 编译
+cd ${linkis_code_dir}/linkis-engineconn-plugins/seatunnel/
+mvn clean install
+# 编译出来的引擎插件包,位于如下目录中
+${linkis_code_dir}/linkis-engineconn-plugins/seatunnel/target/out/
+```
+[EngineConnPlugin 引擎插件安装](../deployment/install-engineconn.md)
+
+### 2.2 引擎插件的上传和加载
+
+将 2.1 中的引擎包上传到服务器的引擎目录下
+```bash
+${LINKIS_HOME}/lib/linkis-engineconn-plugins
+```
+上传后目录结构如下所示
+```
+linkis-engineconn-plugins/
+├── seatunnel
+│ ├── dist
+│ │ └── 2.1.2
+│ │ ├── conf
+│ │ └── lib
+│ └── plugin
+│ └── 2.1.2
+```
+
+### 2.3 引擎刷新
+
+#### 2.3.1 重启刷新
+通过重启 `linkis-cg-linkismanager` 服务刷新引擎
+```bash
+cd ${LINKIS_HOME}/sbin
+sh linkis-daemon.sh restart cg-linkismanager
+```
+
+### 2.3.2 检查引擎是否刷新成功
+可以查看数据库中的 `linkis_engine_conn_plugin_bml_resources` 这张表的`last_update_time` 是否为触发刷新的时间。
+
+```sql
+#登陆到 `linkis` 的数据库
+select * from linkis_cg_engine_conn_plugin_bml_resources;
+```
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+
+```shell
+sh ./bin/linkis-cli --mode once -code 'test' -engineType seatunnel-2.1.2 -codeType sspark -labelMap userCreator=hadoop-seatunnel -labelMap engineConnMode=once -jobContentMap code='env {
+ spark.app.name = "SeaTunnel"
+ spark.executor.instances = 2
+ spark.executor.cores = 1
+ spark.executor.memory = "1g"
+ }
+ source {
+ Fake {
+ result_table_name = "my_dataset"
+ }
+ }
+ transform {}
+ sink {Console {}}' -jobContentMap master=local[4] -jobContentMap deploy-mode=client -sourceMap jobName=OnceJobTest -submitUser hadoop -proxyUser hadoop
+```
+
+### 3.2 通过 OnceEngineConn 提交任务
+
+OnceEngineConn 通过 LinkisManagerClient 调用 LinkisManager 的 createEngineConn 接口,并将代码发送到创建的 Seatunnel 引擎,然后 Seatunnel 引擎开始执行。 Client 的使用也非常简单,首先创建一个新的 maven 项目,或者在项目中引入以下依赖项
+
+```xml
+
+ org.apache.linkis
+ linkis-computation-client
+ ${linkis.version}
+
+```
+
+**示例代码**
+```java
+package org.apache.linkis.computation.client;
+import org.apache.linkis.common.conf.Configuration;
+import org.apache.linkis.computation.client.once.simple.SubmittableSimpleOnceJob;
+import org.apache.linkis.computation.client.utils.LabelKeyUtils;
+public class SeatunnelOnceJobTest {
+ public static void main(String[] args) {
+ LinkisJobClient.config().setDefaultServerUrl("http://ip:9001");
+ String code =
+ "\n"
+ + "env {\n"
+ + " spark.app.name = \"SeaTunnel\"\n"
+ + " spark.executor.instances = 2\n"
+ + " spark.executor.cores = 1\n"
+ + " spark.executor.memory = \"1g\"\n"
+ + "}\n"
+ + "\n"
+ + "source {\n"
+ + " Fake {\n"
+ + " result_table_name = \"my_dataset\"\n"
+ + " }\n"
+ + "\n"
+ + "}\n"
+ + "\n"
+ + "transform {\n"
+ + "}\n"
+ + "\n"
+ + "sink {\n"
+ + " Console {}\n"
+ + "}";
+ SubmittableSimpleOnceJob onceJob =
+ LinkisJobClient.once()
+ .simple()
+ .builder()
+ .setCreateService("seatunnel-Test")
+ .setMaxSubmitTime(300000)
+ .addLabel(LabelKeyUtils.ENGINE_TYPE_LABEL_KEY(), "seatunnel-2.1.2")
+ .addLabel(LabelKeyUtils.USER_CREATOR_LABEL_KEY(), "hadoop-seatunnel")
+ .addLabel(LabelKeyUtils.ENGINE_CONN_MODE_LABEL_KEY(), "once")
+ .addStartupParam(Configuration.IS_TEST_MODE().key(), true)
+ .addExecuteUser("hadoop")
+ .addJobContent("runType", "sspark")
+ .addJobContent("code", code)
+ .addJobContent("master", "local[4]")
+ .addJobContent("deploy-mode", "client")
+ .addSource("jobName", "OnceJobTest")
+ .build();
+ onceJob.submit();
+ System.out.println(onceJob.getId());
+ onceJob.waitForCompleted();
+ System.out.println(onceJob.getStatus());
+ LinkisJobMetrics jobMetrics = onceJob.getJobMetrics();
+ System.out.println(jobMetrics.getMetrics());
+ }
+}
+```
+## 4. 引擎配置说明
+
+### 4.1 默认配置说明
+
+| 配置 | 默认值 | 说明 | 是否必须 |
+| -------------------------------------- | --------------------- | ------------------------------------------- | -------- |
+| wds.linkis.engine.seatunnel.plugin.home | /opt/linkis/seatunnel | Seatunnel安装路径 | true |
+### 4.2 配置修改
+
+如果默认参数不满足时,有如下几中方式可以进行一些基础参数配置
+
+#### 4.2.1 客户端配置参数
+
+```shell
+sh ./bin/linkis-cli --mode once -code 'test' \
+-engineType seatunnel-2.1.2 -codeType sspark \
+-labelMap userCreator=hadoop-seatunnel -labelMap engineConnMode=once \
+-jobContentMap code='env {
+ spark.app.name = "SeaTunnel"
+ spark.executor.instances = 2
+ spark.executor.cores = 1
+ spark.executor.memory = "1g"
+ }
+ source {
+ Fake {
+ result_table_name = "my_dataset"
+ }
+ }
+ transform {}
+ sink {Console {}}' -jobContentMap master=local[4] \
+ -jobContentMap deploy-mode=client \
+ -sourceMap jobName=OnceJobTest \
+ -runtimeMap wds.linkis.engine.seatunnel.plugin.home=/opt/linkis/seatunnel \
+ -submitUser hadoop -proxyUser hadoop
+```
+
+#### 4.2.2 任务接口配置
+提交任务接口,通过参数 `params.configuration.runtime` 进行配置
+
+```shell
+http 请求参数示例
+{
+ "executionContent": {"code": 'env {
+ spark.app.name = "SeaTunnel"
+ spark.executor.instances = 2
+ spark.executor.cores = 1
+ spark.executor.memory = "1g"
+ }
+ source {
+ Fake {
+ result_table_name = "my_dataset"
+ }
+ }
+ transform {}
+ sink {Console {}}',
+ "runType": "sql"},
+ "params": {
+ "variable": {},
+ "configuration": {
+ "runtime": {
+ "wds.linkis.engine.seatunnel.plugin.home":"/opt/linkis/seatunnel"
+ }
+ }
+ },
+ "labels": {
+ "engineType": "seatunnel-2.1.2",
+ "userCreator": "hadoop-IDE"
+ }
+}
+```
\ No newline at end of file
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/shell.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/shell.md
new file mode 100644
index 00000000000..650540bba52
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/shell.md
@@ -0,0 +1,55 @@
+---
+title: Shell
+sidebar_position: 4
+---
+
+本文主要介绍在 `Linkis` 中, `Shell` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+
+### 1.1 环境安装
+如果您希望在您的服务器上使用 `Shell` 引擎,您需要保证用户的 `PATH` 中是有 `bash` 的执行目录和执行权限。
+
+### 1.2 环境验证
+```
+echo $SHELL
+```
+输出如下信息代表shell环境可用
+```
+/bin/bash
+```
+或
+```
+/bin/sh
+```
+
+## 2. 引擎插件安装 [默认引擎](./overview.md)
+
+`Linkis` 发布的二进制安装包中默认包含了 `Shell` 引擎插件,用户无需额外安装。
+
+[EngineConnPlugin引擎插件安装](../deployment/install-engineconn.md)
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+sh ./bin/linkis-cli -engineType shell-1 \
+-codeType shell -code "echo \"hello\" " \
+-submitUser hadoop -proxyUser hadoop
+```
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过Linkis SDK提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。 对于 `Shell` 任务您只需要修改 `Demo` 中的 `EngineConnType` 和 `CodeType` 参数即可:
+
+```java
+Map labels = new HashMap();
+labels.put(LabelKeyConstant.ENGINE_TYPE_KEY, "shell-1"); // required engineType Label
+labels.put(LabelKeyConstant.USER_CREATOR_TYPE_KEY, "hadoop-IDE");// required execute user and creator
+labels.put(LabelKeyConstant.CODE_TYPE_KEY, "shell"); // required codeType
+```
+## 4. 引擎配置说明
+
+`Shell` 引擎一般可以设置引擎 `JVM` 的最大内存。
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/spark.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/spark.md
new file mode 100644
index 00000000000..7d098976e95
--- /dev/null
+++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-1.7.0/engine-usage/spark.md
@@ -0,0 +1,425 @@
+---
+title: Spark
+sidebar_position: 1
+---
+
+本文主要介绍在 `Linkis` 中, `Spark` 引擎插件的安装、使用和配置。
+
+## 1. 前置工作
+### 1.1 引擎安装
+
+如果您希望在您的服务器上使用 `Spark` 引擎,您需要保证以下的环境变量已经设置正确并且引擎的启动用户是有这些环境变量的。
+
+强烈建议您在执行 `Spark` 任务之前,检查下执行用户的这些环境变量。
+
+| 环境变量名 | 环境变量内容 | 备注 |
+|-----------------|----------------|----------------------------------------|
+| JAVA_HOME | JDK安装路径 | 必须 |
+| HADOOP_HOME | Hadoop安装路径 | 必须 |
+| HADOOP_CONF_DIR | Hadoop配置路径 | 必须 |
+| HIVE_CONF_DIR | Hive配置路径 | 必须 |
+| SPARK_HOME | Spark安装路径 | 必须 |
+| SPARK_CONF_DIR | Spark配置路径 | 必须 |
+| python | python | 建议使用anaconda的python作为默认python |
+
+### 1.2 环境验证
+通过 `pyspark` 验证 `Spark` 是否安装成功
+```
+pyspark
+
+#进入pyspark虚拟环境后,出现spark的logo则说明环境安装成功
+Welcome to
+ ____ __
+ / __/__ ___ _____/ /__
+ _\ \/ _ \/ _ `/ __/ '_/
+ /__ / .__/\_,_/_/ /_/\_\ version 3.2.1
+ /_/
+
+Using Python version 2.7.13 (default, Sep 30 2017 18:12:43)
+SparkSession available as 'spark'.
+```
+
+## 2. 引擎插件安装 [默认引擎](./overview.md)
+
+`Linkis` 发布的二进制安装包中默认包含了 `Spark` 引擎插件,用户无需额外安装。
+
+理论上 `Linkis` 支持的 `Spark2.x` 以上的所有版本。默认支持的版本为 `Spark3.2.1` 。如果您想使用其他的 `Spark` 版本,如 `Spark2.1.0` ,则您仅仅需要将插件 `Spark` 的版本进行修改,然后进行编译即可。具体的,您可以找到 `linkis-engineplugin-spark` 模块,将 `maven` 依赖中 `` 标签的值改成 2.1.0 ,然后单独编译此模块即可。
+
+[EngineConnPlugin引擎插件安装](../deployment/install-engineconn.md)
+
+## 3. 引擎的使用
+
+### 3.1 通过 `Linkis-cli` 提交任务
+
+```shell
+# codeType对应关系 py-->pyspark sql-->sparkSQL scala-->Spark scala
+sh ./bin/linkis-cli -engineType spark-3.2.1 -codeType sql -code "show databases" -submitUser hadoop -proxyUser hadoop
+
+# 可以在提交参数通过-confMap wds.linkis.yarnqueue=dws 来指定yarn 队列
+sh ./bin/linkis-cli -engineType spark-3.2.1 -codeType sql -confMap wds.linkis.yarnqueue=dws -code "show databases" -submitUser hadoop -proxyUser hadoop
+```
+更多 `Linkis-Cli` 命令参数参考: [Linkis-Cli 使用](../user-guide/linkiscli-manual.md)
+
+### 3.2 通过 `Linkis SDK` 提交任务
+
+`Linkis` 提供了 `Java` 和 `Scala` 的 `SDK` 向 `Linkis` 服务端提交任务。具体可以参考 [JAVA SDK Manual](../user-guide/sdk-manual.md)。对于 `Spark` 任务你只需要修改 `Demo` 中的 `EngineConnType` 和 `CodeType` 参数即可:
+
+```java
+Map labels = new HashMap