You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@dolphinscheduler.apache.org by gi...@apache.org on 2020/09/02 09:13:35 UTC

[incubator-dolphinscheduler-website] branch asf-site updated: Automated deployment: Wed Sep 2 09:11:33 UTC 2020 1538f427f687b7981e7b2858007e52c86896c1ab

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

github-bot pushed a commit to branch asf-site
in repository https://gitbox.apache.org/repos/asf/incubator-dolphinscheduler-website.git


The following commit(s) were added to refs/heads/asf-site by this push:
     new 8df30e2  Automated deployment: Wed Sep  2 09:11:33 UTC 2020 1538f427f687b7981e7b2858007e52c86896c1ab
8df30e2 is described below

commit 8df30e24800c93a404012c7b11efafd721558466
Author: qiaozhanwei <qi...@users.noreply.github.com>
AuthorDate: Wed Sep 2 09:11:33 2020 +0000

    Automated deployment: Wed Sep  2 09:11:33 UTC 2020 1538f427f687b7981e7b2858007e52c86896c1ab
---
 build/blog.js                                      |    6 +-
 build/blogDetail.js                                |    6 +-
 build/community.js                                 |    6 +-
 build/documentation.js                             |   12 +-
 build/home.js                                      |    6 +-
 en-us/docs/1.3.2/user_doc/cluster-deployment.html  |  400 +++
 en-us/docs/1.3.2/user_doc/cluster-deployment.json  |    6 +
 .../docs/1.3.2/user_doc/hardware-environment.html  |  127 +
 .../docs/1.3.2/user_doc/hardware-environment.json  |    6 +
 en-us/docs/1.3.2/user_doc/metadata-1.3.html        |  655 ++++
 en-us/docs/1.3.2/user_doc/metadata-1.3.json        |    6 +
 en-us/docs/1.3.2/user_doc/quick-start.html         |  101 +
 en-us/docs/1.3.2/user_doc/quick-start.json         |    6 +
 .../docs/1.3.2/user_doc/standalone-deployment.html |  393 +++
 .../docs/1.3.2/user_doc/standalone-deployment.json |    6 +
 zh-cn/docs/1.3.2/user_doc/architecture-design.html |  353 +++
 zh-cn/docs/1.3.2/user_doc/architecture-design.json |    6 +
 zh-cn/docs/1.3.2/user_doc/cluster-deployment.html  |  429 +++
 zh-cn/docs/1.3.2/user_doc/cluster-deployment.json  |    6 +
 zh-cn/docs/1.3.2/user_doc/configuration-file.html  |  993 ++++++
 zh-cn/docs/1.3.2/user_doc/configuration-file.json  |    6 +
 .../docs/1.3.2/user_doc/hardware-environment.html  |  127 +
 .../docs/1.3.2/user_doc/hardware-environment.json  |    6 +
 zh-cn/docs/1.3.2/user_doc/metadata-1.3.html        |  743 +++++
 zh-cn/docs/1.3.2/user_doc/metadata-1.3.json        |    6 +
 zh-cn/docs/1.3.2/user_doc/quick-start.html         |   97 +
 zh-cn/docs/1.3.2/user_doc/quick-start.json         |    6 +
 .../docs/1.3.2/user_doc/standalone-deployment.html |  332 ++
 .../docs/1.3.2/user_doc/standalone-deployment.json |    6 +
 zh-cn/docs/1.3.2/user_doc/system-manual.html       |  986 ++++++
 zh-cn/docs/1.3.2/user_doc/system-manual.json       |    6 +
 zh-cn/docs/1.3.2/user_doc/task-structure.html      | 3282 ++++++++++++++++++++
 zh-cn/docs/1.3.2/user_doc/task-structure.json      |    6 +
 zh-cn/docs/1.3.2/user_doc/upgrade.html             |  126 +
 zh-cn/docs/1.3.2/user_doc/upgrade.json             |    6 +
 35 files changed, 9252 insertions(+), 18 deletions(-)

diff --git a/build/blog.js b/build/blog.js
index d392c84..fdc9373 100644
--- a/build/blog.js
+++ b/build/blog.js
@@ -1,4 +1,4 @@
-!function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/build/",t(t.s=122 [...]
+!function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/build/",t(t.s=122 [...]
   Copyright (c) 2017 Jed Watson.
   Licensed under the MIT License (MIT), see
   http://jedwatson.github.io/classnames
@@ -10,7 +10,7 @@ object-assign
 (c) Sindre Sorhus
 @license MIT
 */
-var o=Object.getOwnPropertySymbols,i=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map(function(e){return t[e]}).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach(function(e){r[e]=e}),"abcdefghijklmn [...]
+var o=Object.getOwnPropertySymbols,i=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map(function(e){return t[e]}).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach(function(e){r[e]=e}),"abcdefghijklmn [...]
 //! moment.js locale configuration
 var t=function(e){return 0===e?0:1===e?1:2===e?2:e%100>=3&&e%100<=10?3:e%100>=11?4:5},n={s:["أقل من ثانية","ثانية واحدة",["ثانيتان","ثانيتين"],"%d ثوان","%d ثانية","%d ثانية"],m:["أقل من دقيقة","دقيقة واحدة",["دقيقتان","دقيقتين"],"%d دقائق","%d دقيقة","%d دقيقة"],h:["أقل من ساعة","ساعة واحدة",["ساعتان","ساعتين"],"%d ساعات","%d ساعة","%d ساعة"],d:["أقل من يوم","يوم واحد",["يومان","يومين"],"%d أيام","%d يومًا","%d يوم"],M:["أقل من شهر","شهر واحد",["شهران","شهرين"],"%d أشهر","%d شهرا","%d ش [...]
 //! moment.js locale configuration
@@ -170,4 +170,4 @@ Object.defineProperty(t,"__esModule",{value:!0});var i="function"==typeof Symbol
  * Copyright © 2012-2019 Faisal Salman <f...@faisalman.com>
  * Licensed under MIT License
  */
-return"string"==typeof e?e.replace(/[^\d\.]/g,"").split(".")[0]:void 0},trim:function(e){return e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")}},m={rgx:function(e,t){for(var n,r,o,i,a,c,s=0;s<t.length&&!a;){var l=t[s],u=t[s+1];for(n=r=0;n<l.length&&!a;)if(a=l[n++].exec(e))for(o=0;o<u.length;o++)c=a[++r],i=u[o],"object"==typeof i&&i.length>0?2==i.length?"function"==typeof i[1]?this[i[0]]=i[1].call(this,c):this[i[0]]=i[1]:3==i.length?"function"!=typeof i[1]||i[1].exec&&i[1].test?this[i [...]
\ No newline at end of file
+return"string"==typeof e?e.replace(/[^\d\.]/g,"").split(".")[0]:void 0},trim:function(e){return e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")}},m={rgx:function(e,t){for(var n,r,o,i,a,c,s=0;s<t.length&&!a;){var l=t[s],u=t[s+1];for(n=r=0;n<l.length&&!a;)if(a=l[n++].exec(e))for(o=0;o<u.length;o++)c=a[++r],i=u[o],"object"==typeof i&&i.length>0?2==i.length?"function"==typeof i[1]?this[i[0]]=i[1].call(this,c):this[i[0]]=i[1]:3==i.length?"function"!=typeof i[1]||i[1].exec&&i[1].test?this[i [...]
\ No newline at end of file
diff --git a/build/blogDetail.js b/build/blogDetail.js
index 7131841..e959a99 100644
--- a/build/blogDetail.js
+++ b/build/blogDetail.js
@@ -1,4 +1,4 @@
-!function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/build/",t(t.s=122 [...]
+!function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/build/",t(t.s=122 [...]
   Copyright (c) 2017 Jed Watson.
   Licensed under the MIT License (MIT), see
   http://jedwatson.github.io/classnames
@@ -10,7 +10,7 @@ object-assign
 (c) Sindre Sorhus
 @license MIT
 */
-var o=Object.getOwnPropertySymbols,i=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map(function(e){return t[e]}).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach(function(e){r[e]=e}),"abcdefghijklmn [...]
+var o=Object.getOwnPropertySymbols,i=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map(function(e){return t[e]}).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach(function(e){r[e]=e}),"abcdefghijklmn [...]
 //! moment.js locale configuration
 var t=function(e){return 0===e?0:1===e?1:2===e?2:e%100>=3&&e%100<=10?3:e%100>=11?4:5},n={s:["أقل من ثانية","ثانية واحدة",["ثانيتان","ثانيتين"],"%d ثوان","%d ثانية","%d ثانية"],m:["أقل من دقيقة","دقيقة واحدة",["دقيقتان","دقيقتين"],"%d دقائق","%d دقيقة","%d دقيقة"],h:["أقل من ساعة","ساعة واحدة",["ساعتان","ساعتين"],"%d ساعات","%d ساعة","%d ساعة"],d:["أقل من يوم","يوم واحد",["يومان","يومين"],"%d أيام","%d يومًا","%d يوم"],M:["أقل من شهر","شهر واحد",["شهران","شهرين"],"%d أشهر","%d شهرا","%d ش [...]
 //! moment.js locale configuration
@@ -170,4 +170,4 @@ Object.defineProperty(t,"__esModule",{value:!0});var i="function"==typeof Symbol
  * Copyright © 2012-2019 Faisal Salman <f...@faisalman.com>
  * Licensed under MIT License
  */
-return"string"==typeof e?e.replace(/[^\d\.]/g,"").split(".")[0]:void 0},trim:function(e){return e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")}},m={rgx:function(e,t){for(var n,r,o,i,a,c,s=0;s<t.length&&!a;){var l=t[s],u=t[s+1];for(n=r=0;n<l.length&&!a;)if(a=l[n++].exec(e))for(o=0;o<u.length;o++)c=a[++r],i=u[o],"object"==typeof i&&i.length>0?2==i.length?"function"==typeof i[1]?this[i[0]]=i[1].call(this,c):this[i[0]]=i[1]:3==i.length?"function"!=typeof i[1]||i[1].exec&&i[1].test?this[i [...]
\ No newline at end of file
+return"string"==typeof e?e.replace(/[^\d\.]/g,"").split(".")[0]:void 0},trim:function(e){return e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")}},m={rgx:function(e,t){for(var n,r,o,i,a,c,s=0;s<t.length&&!a;){var l=t[s],u=t[s+1];for(n=r=0;n<l.length&&!a;)if(a=l[n++].exec(e))for(o=0;o<u.length;o++)c=a[++r],i=u[o],"object"==typeof i&&i.length>0?2==i.length?"function"==typeof i[1]?this[i[0]]=i[1].call(this,c):this[i[0]]=i[1]:3==i.length?"function"!=typeof i[1]||i[1].exec&&i[1].test?this[i [...]
\ No newline at end of file
diff --git a/build/community.js b/build/community.js
index 7a28976..4c31a38 100644
--- a/build/community.js
+++ b/build/community.js
@@ -1,4 +1,4 @@
-!function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/build/",t(t.s=122 [...]
+!function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/build/",t(t.s=122 [...]
   Copyright (c) 2017 Jed Watson.
   Licensed under the MIT License (MIT), see
   http://jedwatson.github.io/classnames
@@ -10,7 +10,7 @@ object-assign
 (c) Sindre Sorhus
 @license MIT
 */
-var o=Object.getOwnPropertySymbols,i=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map(function(e){return t[e]}).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach(function(e){r[e]=e}),"abcdefghijklmn [...]
+var o=Object.getOwnPropertySymbols,i=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map(function(e){return t[e]}).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach(function(e){r[e]=e}),"abcdefghijklmn [...]
 //! moment.js locale configuration
 var t=function(e){return 0===e?0:1===e?1:2===e?2:e%100>=3&&e%100<=10?3:e%100>=11?4:5},n={s:["أقل من ثانية","ثانية واحدة",["ثانيتان","ثانيتين"],"%d ثوان","%d ثانية","%d ثانية"],m:["أقل من دقيقة","دقيقة واحدة",["دقيقتان","دقيقتين"],"%d دقائق","%d دقيقة","%d دقيقة"],h:["أقل من ساعة","ساعة واحدة",["ساعتان","ساعتين"],"%d ساعات","%d ساعة","%d ساعة"],d:["أقل من يوم","يوم واحد",["يومان","يومين"],"%d أيام","%d يومًا","%d يوم"],M:["أقل من شهر","شهر واحد",["شهران","شهرين"],"%d أشهر","%d شهرا","%d ش [...]
 //! moment.js locale configuration
@@ -170,4 +170,4 @@ Object.defineProperty(t,"__esModule",{value:!0});var i="function"==typeof Symbol
  * Copyright © 2012-2019 Faisal Salman <f...@faisalman.com>
  * Licensed under MIT License
  */
-return"string"==typeof e?e.replace(/[^\d\.]/g,"").split(".")[0]:void 0},trim:function(e){return e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")}},m={rgx:function(e,t){for(var n,r,o,i,a,c,s=0;s<t.length&&!a;){var l=t[s],u=t[s+1];for(n=r=0;n<l.length&&!a;)if(a=l[n++].exec(e))for(o=0;o<u.length;o++)c=a[++r],i=u[o],"object"==typeof i&&i.length>0?2==i.length?"function"==typeof i[1]?this[i[0]]=i[1].call(this,c):this[i[0]]=i[1]:3==i.length?"function"!=typeof i[1]||i[1].exec&&i[1].test?this[i [...]
\ No newline at end of file
+return"string"==typeof e?e.replace(/[^\d\.]/g,"").split(".")[0]:void 0},trim:function(e){return e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")}},m={rgx:function(e,t){for(var n,r,o,i,a,c,s=0;s<t.length&&!a;){var l=t[s],u=t[s+1];for(n=r=0;n<l.length&&!a;)if(a=l[n++].exec(e))for(o=0;o<u.length;o++)c=a[++r],i=u[o],"object"==typeof i&&i.length>0?2==i.length?"function"==typeof i[1]?this[i[0]]=i[1].call(this,c):this[i[0]]=i[1]:3==i.length?"function"!=typeof i[1]||i[1].exec&&i[1].test?this[i [...]
\ No newline at end of file
diff --git a/build/documentation.js b/build/documentation.js
index 2c8b384..bd2095f 100644
--- a/build/documentation.js
+++ b/build/documentation.js
@@ -1,16 +1,16 @@
-!function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/build/",t(t.s=122 [...]
+!function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/build/",t(t.s=122 [...]
   Copyright (c) 2017 Jed Watson.
   Licensed under the MIT License (MIT), see
   http://jedwatson.github.io/classnames
 */
-!function(){"use strict";function n(){for(var e=[],t=0;t<arguments.length;t++){var r=arguments[t];if(r){var o=typeof r;if("string"===o||"number"===o)e.push(r);else if(Array.isArray(r)&&r.length){var a=n.apply(null,r);a&&e.push(a)}else if("object"===o)for(var c in r)i.call(r,c)&&r[c]&&e.push(c)}}return e.join(" ")}var i={}.hasOwnProperty;void 0!==e&&e.exports?(n.default=n,e.exports=n):(r=[],void 0!==(o=function(){return n}.apply(t,r))&&(e.exports=o))}()},function(e,t,n){(function(e){var t [...]
+!function(){"use strict";function n(){for(var e=[],t=0;t<arguments.length;t++){var r=arguments[t];if(r){var o=typeof r;if("string"===o||"number"===o)e.push(r);else if(Array.isArray(r)&&r.length){var a=n.apply(null,r);a&&e.push(a)}else if("object"===o)for(var c in r)i.call(r,c)&&r[c]&&e.push(c)}}return e.join(" ")}var i={}.hasOwnProperty;void 0!==e&&e.exports?(n.default=n,e.exports=n):(r=[],void 0!==(o=function(){return n}.apply(t,r))&&(e.exports=o))}()},function(e,t,n){(function(e){var t [...]
 //! moment.js
-return sa.isValid=Dt,sa.abs=zr,sa.add=Nr,sa.subtract=Vr,sa.as=Ir,sa.asMilliseconds=Ki,sa.asSeconds=Wi,sa.asMinutes=Bi,sa.asHours=Ui,sa.asDays=qi,sa.asWeeks=Gi,sa.asMonths=Ji,sa.asQuarters=$i,sa.asYears=Xi,sa.valueOf=Kr,sa._bubble=Yr,sa.clone=Br,sa.get=Ur,sa.milliseconds=Zi,sa.seconds=Qi,sa.minutes=ea,sa.hours=ta,sa.days=na,sa.weeks=Gr,sa.months=ra,sa.years=oa,sa.humanize=Qr,sa.toISOString=to,sa.toString=to,sa.toJSON=to,sa.locale=Pn,sa.localeData=jn,sa.toIsoString=M("toIsoString() is depr [...]
+return sa.isValid=Dt,sa.abs=zr,sa.add=Nr,sa.subtract=Vr,sa.as=Ir,sa.asMilliseconds=Ki,sa.asSeconds=Wi,sa.asMinutes=Bi,sa.asHours=Ui,sa.asDays=qi,sa.asWeeks=Gi,sa.asMonths=Ji,sa.asQuarters=$i,sa.asYears=Xi,sa.valueOf=Kr,sa._bubble=Yr,sa.clone=Br,sa.get=Ur,sa.milliseconds=Qi,sa.seconds=Zi,sa.minutes=ea,sa.hours=ta,sa.days=na,sa.weeks=Gr,sa.months=ra,sa.years=oa,sa.humanize=Zr,sa.toISOString=to,sa.toString=to,sa.toJSON=to,sa.locale=Pn,sa.localeData=jn,sa.toIsoString=M("toIsoString() is depr [...]
 object-assign
 (c) Sindre Sorhus
 @license MIT
 */
-var o=Object.getOwnPropertySymbols,i=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map(function(e){return t[e]}).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach(function(e){r[e]=e}),"abcdefghijklmn [...]
+var o=Object.getOwnPropertySymbols,i=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map(function(e){return t[e]}).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach(function(e){r[e]=e}),"abcdefghijklmn [...]
 //! moment.js locale configuration
 var t=function(e){return 0===e?0:1===e?1:2===e?2:e%100>=3&&e%100<=10?3:e%100>=11?4:5},n={s:["أقل من ثانية","ثانية واحدة",["ثانيتان","ثانيتين"],"%d ثوان","%d ثانية","%d ثانية"],m:["أقل من دقيقة","دقيقة واحدة",["دقيقتان","دقيقتين"],"%d دقائق","%d دقيقة","%d دقيقة"],h:["أقل من ساعة","ساعة واحدة",["ساعتان","ساعتين"],"%d ساعات","%d ساعة","%d ساعة"],d:["أقل من يوم","يوم واحد",["يومان","يومين"],"%d أيام","%d يومًا","%d يوم"],M:["أقل من شهر","شهر واحد",["شهران","شهرين"],"%d أشهر","%d شهرا","%d ش [...]
 //! moment.js locale configuration
@@ -138,7 +138,7 @@ var t={1:"'inci",5:"'inci",8:"'inci",70:"'inci",80:"'inci",2:"'nci",7:"'nci",20:
 //! moment.js locale configuration
 function t(e,t){var n=e.split("_");return t%10==1&&t%100!=11?n[0]:t%10>=2&&t%10<=4&&(t%100<10||t%100>=20)?n[1]:n[2]}function n(e,n,r){var o={ss:n?"секунда_секунди_секунд":"секунду_секунди_секунд",mm:n?"хвилина_хвилини_хвилин":"хвилину_хвилини_хвилин",hh:n?"година_години_годин":"годину_години_годин",dd:"день_дні_днів",MM:"місяць_місяці_місяців",yy:"рік_роки_років"};return"m"===r?n?"хвилина":"хвилину":"h"===r?n?"година":"годину":e+" "+t(o[r],+e)}function r(e,t){var n,r={nominative:"неділя_ [...]
 //! moment.js locale configuration
-var t=["جنوری","فروری","مارچ","اپریل","مئی","جون","جولائی","اگست","ستمبر","اکتوبر","نومبر","دسمبر"],n=["اتوار","پیر","منگل","بدھ","جمعرات","جمعہ","ہفتہ"];return e.defineLocale("ur",{months:t,monthsShort:t,weekdays:n,weekdaysShort:n,weekdaysMin:n,longDateFormat:{LT:"HH:mm",LTS:"HH:mm:ss",L:"DD/MM/YYYY",LL:"D MMMM YYYY",LLL:"D MMMM YYYY HH:mm",LLLL:"dddd، D MMMM YYYY HH:mm"},meridiemParse:/صبح|شام/,isPM:function(e){return"شام"===e},meridiem:function(e,t,n){return e<12?"صبح":"شام"},calendar [...]
+var t=["جنوری","فروری","مارچ","اپریل","مئی","جون","جولائی","اگست","ستمبر","اکتوبر","نومبر","دسمبر"],n=["اتوار","پیر","منگل","بدھ","جمعرات","جمعہ","ہفتہ"];return e.defineLocale("ur",{months:t,monthsShort:t,weekdays:n,weekdaysShort:n,weekdaysMin:n,longDateFormat:{LT:"HH:mm",LTS:"HH:mm:ss",L:"DD/MM/YYYY",LL:"D MMMM YYYY",LLL:"D MMMM YYYY HH:mm",LLLL:"dddd، D MMMM YYYY HH:mm"},meridiemParse:/صبح|شام/,isPM:function(e){return"شام"===e},meridiem:function(e,t,n){return e<12?"صبح":"شام"},calendar [...]
  * react-is.production.min.js
  *
  * Copyright (c) Facebook, Inc. and its affiliates.
@@ -170,4 +170,4 @@ Object.defineProperty(t,"__esModule",{value:!0});var i="function"==typeof Symbol
  * Copyright © 2012-2019 Faisal Salman <f...@faisalman.com>
  * Licensed under MIT License
  */
-return"string"==typeof e?e.replace(/[^\d\.]/g,"").split(".")[0]:void 0},trim:function(e){return e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")}},m={rgx:function(e,t){for(var n,r,o,i,a,c,s=0;s<t.length&&!a;){var l=t[s],u=t[s+1];for(n=r=0;n<l.length&&!a;)if(a=l[n++].exec(e))for(o=0;o<u.length;o++)c=a[++r],i=u[o],"object"==typeof i&&i.length>0?2==i.length?"function"==typeof i[1]?this[i[0]]=i[1].call(this,c):this[i[0]]=i[1]:3==i.length?"function"!=typeof i[1]||i[1].exec&&i[1].test?this[i [...]
\ No newline at end of file
+return"string"==typeof e?e.replace(/[^\d\.]/g,"").split(".")[0]:void 0},trim:function(e){return e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")}},m={rgx:function(e,t){for(var n,r,o,i,a,c,s=0;s<t.length&&!a;){var l=t[s],u=t[s+1];for(n=r=0;n<l.length&&!a;)if(a=l[n++].exec(e))for(o=0;o<u.length;o++)c=a[++r],i=u[o],"object"==typeof i&&i.length>0?2==i.length?"function"==typeof i[1]?this[i[0]]=i[1].call(this,c):this[i[0]]=i[1]:3==i.length?"function"!=typeof i[1]||i[1].exec&&i[1].test?this[i [...]
\ No newline at end of file
diff --git a/build/home.js b/build/home.js
index 239fbfb..874dadc 100644
--- a/build/home.js
+++ b/build/home.js
@@ -1,4 +1,4 @@
-!function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/build/",t(t.s=122 [...]
+!function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/build/",t(t.s=123 [...]
   Copyright (c) 2017 Jed Watson.
   Licensed under the MIT License (MIT), see
   http://jedwatson.github.io/classnames
@@ -10,7 +10,7 @@ object-assign
 (c) Sindre Sorhus
 @license MIT
 */
-var o=Object.getOwnPropertySymbols,i=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map(function(e){return t[e]}).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach(function(e){r[e]=e}),"abcdefghijklmn [...]
+var o=Object.getOwnPropertySymbols,i=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map(function(e){return t[e]}).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach(function(e){r[e]=e}),"abcdefghijklmn [...]
 //! moment.js locale configuration
 var t=function(e){return 0===e?0:1===e?1:2===e?2:e%100>=3&&e%100<=10?3:e%100>=11?4:5},n={s:["أقل من ثانية","ثانية واحدة",["ثانيتان","ثانيتين"],"%d ثوان","%d ثانية","%d ثانية"],m:["أقل من دقيقة","دقيقة واحدة",["دقيقتان","دقيقتين"],"%d دقائق","%d دقيقة","%d دقيقة"],h:["أقل من ساعة","ساعة واحدة",["ساعتان","ساعتين"],"%d ساعات","%d ساعة","%d ساعة"],d:["أقل من يوم","يوم واحد",["يومان","يومين"],"%d أيام","%d يومًا","%d يوم"],M:["أقل من شهر","شهر واحد",["شهران","شهرين"],"%d أشهر","%d شهرا","%d ش [...]
 //! moment.js locale configuration
@@ -170,4 +170,4 @@ Object.defineProperty(t,"__esModule",{value:!0});var i="function"==typeof Symbol
  * Copyright © 2012-2019 Faisal Salman <f...@faisalman.com>
  * Licensed under MIT License
  */
-return"string"==typeof e?e.replace(/[^\d\.]/g,"").split(".")[0]:void 0},trim:function(e){return e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")}},m={rgx:function(e,t){for(var n,r,o,i,a,c,s=0;s<t.length&&!a;){var l=t[s],u=t[s+1];for(n=r=0;n<l.length&&!a;)if(a=l[n++].exec(e))for(o=0;o<u.length;o++)c=a[++r],i=u[o],"object"==typeof i&&i.length>0?2==i.length?"function"==typeof i[1]?this[i[0]]=i[1].call(this,c):this[i[0]]=i[1]:3==i.length?"function"!=typeof i[1]||i[1].exec&&i[1].test?this[i [...]
\ No newline at end of file
+return"string"==typeof e?e.replace(/[^\d\.]/g,"").split(".")[0]:void 0},trim:function(e){return e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")}},m={rgx:function(e,t){for(var n,r,o,i,a,c,s=0;s<t.length&&!a;){var l=t[s],u=t[s+1];for(n=r=0;n<l.length&&!a;)if(a=l[n++].exec(e))for(o=0;o<u.length;o++)c=a[++r],i=u[o],"object"==typeof i&&i.length>0?2==i.length?"function"==typeof i[1]?this[i[0]]=i[1].call(this,c):this[i[0]]=i[1]:3==i.length?"function"!=typeof i[1]||i[1].exec&&i[1].test?this[i [...]
\ No newline at end of file
diff --git a/en-us/docs/1.3.2/user_doc/cluster-deployment.html b/en-us/docs/1.3.2/user_doc/cluster-deployment.html
new file mode 100644
index 0000000..c96e391
--- /dev/null
+++ b/en-us/docs/1.3.2/user_doc/cluster-deployment.html
@@ -0,0 +1,400 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="cluster-deployment" />
+	<meta name="description" content="cluster-deployment" />
+	<!-- 网页标签标题 -->
+	<title>cluster-deployment</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/en-us/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">中</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass ant [...]
+<h1>1、Before you begin (please install requirement basic software by yourself)</h1>
+<ul>
+<li>PostgreSQL (8.2.15+) or MySQL (5.7)  :  Choose One</li>
+<li><a href="https://www.oracle.com/technetwork/java/javase/downloads/index.html">JDK</a> (1.8+) :  Required. Double-check configure JAVA_HOME and PATH environment variables in /etc/profile</li>
+<li>ZooKeeper (3.4.6+) :Required</li>
+<li>Hadoop (2.6+) or MinIO :Optional. If you need to upload a resource function, you can choose a local file directory as the upload folder for a single machine (this operation does not need to deploy Hadoop). Of course, you can also choose to upload to Hadoop or MinIO.</li>
+</ul>
+<pre><code class="language-markdown"> Tips:DolphinScheduler itself does not rely on Hadoop, Hive, Spark, only use their clients for the corresponding task of running.
+</code></pre>
+<h1>2、Download the binary package.</h1>
+<ul>
+<li>Please download the latest version of the default installation package to the server deployment directory. For example, use /opt/dolphinscheduler as the installation and deployment directory. Download address: <a href="https://dolphinscheduler.apache.org/en-us/docs/release/download.html">Download</a>,Download the package and move to the installation and deployment directory. Then unzip it.</li>
+</ul>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> Create the deployment directory. Do not choose a deployment directory with a high-privilege directory such as / root or / home.</span>
+mkdir -p /opt/dolphinscheduler;
+cd /opt/dolphinscheduler;
+<span class="hljs-meta">#</span><span class="bash"> unzip</span>
+tar -zxvf apache-dolphinscheduler-incubating-1.3.1-dolphinscheduler-bin.tar.gz -C /opt/dolphinscheduler;
+
+mv apache-dolphinscheduler-incubating-1.3.1-dolphinscheduler-bin  dolphinscheduler-bin
+</code></pre>
+<h1>3、Create deployment user and hosts mapping</h1>
+<ul>
+<li>Create a deployment user on the ** all ** deployment machines, and be sure to configure sudo passwordless. If we plan to deploy DolphinScheduler on 4 machines: ds1, ds2, ds3, and ds4, we first need to create a deployment user on each machine.</li>
+</ul>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> To create a user, you need to <span class="hljs-built_in">log</span> <span class="hljs-keyword">in</span> as root and <span class="hljs-built_in">set</span> the deployment user name. Please modify it yourself. The following uses dolphinscheduler as an example.</span>
+useradd dolphinscheduler;
+<span class="hljs-meta">
+#</span><span class="bash"> Set the user password, please modify it yourself. The following takes dolphinscheduler123 as an example.</span>
+echo "dolphinscheduler123" | passwd --stdin dolphinscheduler
+<span class="hljs-meta">
+#</span><span class="bash"> Configure sudo passwordless</span>
+echo 'dolphinscheduler  ALL=(ALL)  NOPASSWD: NOPASSWD: ALL' &gt;&gt; /etc/sudoers
+sed -i 's/Defaults    requirett/#Defaults    requirett/g' /etc/sudoers
+
+</code></pre>
+<pre><code> Notes:
+ - Because the task execution service is based on 'sudo -u {linux-user}' to switch between different Linux users to implement multi-tenant running jobs, the deployment user needs to have sudo permissions and is passwordless. The first-time learners who can ignore it if they don't understand.
+ - If find the &quot;Default requiretty&quot; in the &quot;/etc/sudoers&quot; file, also comment out.
+ - If you need to use resource upload, you need to assign the user of permission to operate the local file system, HDFS or MinIO.
+</code></pre>
+<h1>4、Configure hosts mapping and ssh access and modify directory permissions.</h1>
+<ul>
+<li>
+<p>Use the first machine (hostname is ds1) as the deployment machine, configure the hosts of all machines to be deployed on ds1, and login as root on ds1.</p>
+<pre><code class="language-shell">vi /etc/hosts
+<span class="hljs-meta">
+#</span><span class="bash">add ip hostname</span>
+192.168.xxx.xxx ds1
+192.168.xxx.xxx ds2
+192.168.xxx.xxx ds3
+192.168.xxx.xxx ds4
+</code></pre>
+<p><em>Note: Please delete or comment out the line 127.0.0.1</em></p>
+</li>
+<li>
+<p>Sync /etc/hosts on ds1 to all deployment machines</p>
+<pre><code class="language-shell">for ip in ds2 ds3;     # Please replace ds2 ds3 here with the hostname of machines you want to deploy
+do
+    sudo scp -r /etc/hosts  $ip:/etc/          # Need to enter root password during operation
+done
+</code></pre>
+<p><em>Note: can use <code>sshpass -p xxx sudo scp -r /etc/hosts $ip:/etc/</code> to avoid type password.</em></p>
+<blockquote>
+<p>Install sshpass in Centos:</p>
+<ol>
+<li>
+<p>Install epel</p>
+<p>yum install -y epel-release</p>
+<p>yum repolist</p>
+</li>
+<li>
+<p>After installing epel, you can install sshpass</p>
+<p>yum install -y sshpass</p>
+</li>
+</ol>
+</blockquote>
+</li>
+<li>
+<p>On ds1, switch to the deployment user and configure ssh passwordless login</p>
+<pre><code class="language-shell"> su dolphinscheduler;
+
+ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa
+cat ~/.ssh/id_rsa.pub &gt;&gt; ~/.ssh/authorized_keys
+chmod 600 ~/.ssh/authorized_keys
+</code></pre>
+</li>
+</ul>
+<p>​      Note: <em>If configure success, the dolphinscheduler user does not need to enter a password when executing the command <code>ssh localhost</code></em></p>
+<ul>
+<li>
+<p>On ds1, configure the deployment user dolphinscheduler ssh to connect to other machines to be deployed.</p>
+<pre><code class="language-shell">su dolphinscheduler;
+for ip in ds2 ds3;     # Please replace ds2 ds3 here with the hostname of the machine you want to deploy.
+do
+    ssh-copy-id  $ip   # You need to manually enter the password of the dolphinscheduler user during the operation.
+done
+<span class="hljs-meta">#</span><span class="bash"> can use `sshpass -p xxx ssh-copy-id <span class="hljs-variable">$ip</span>` to avoid <span class="hljs-built_in">type</span> password.</span>
+</code></pre>
+</li>
+<li>
+<p>On ds1, modify the directory permissions so that the deployment user has operation permissions on the dolphinscheduler-bin directory.</p>
+<pre><code class="language-shell">sudo chown -R dolphinscheduler:dolphinscheduler dolphinscheduler-bin
+</code></pre>
+</li>
+</ul>
+<h1>5、Database initialization</h1>
+<ul>
+<li>Into the database. The default database is PostgreSQL. If you select MySQL, you need to add the mysql-connector-java driver package to the lib directory of DolphinScheduler.</li>
+</ul>
+<pre><code>mysql -h192.168.xx.xx -P3306 -uroot -p
+</code></pre>
+<ul>
+<li>After entering the database command line window, execute the database initialization command and set the user and password. <strong>Note: {user} and {password} need to be replaced with a specific database username and password</strong></li>
+</ul>
+<pre><code class="language-mysql">   mysql&gt; CREATE DATABASE dolphinscheduler DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_general_ci;
+   mysql&gt; GRANT ALL PRIVILEGES ON dolphinscheduler.* TO '{user}'@'%' IDENTIFIED BY '{password}';
+   mysql&gt; GRANT ALL PRIVILEGES ON dolphinscheduler.* TO '{user}'@'localhost' IDENTIFIED BY '{password}';
+   mysql&gt; flush privileges;
+</code></pre>
+<ul>
+<li>
+<p>Create tables and import basic data</p>
+<ul>
+<li>Modify the following configuration in datasource.properties under the conf directory</li>
+</ul>
+<pre><code class="language-shell">  vi conf/datasource.properties
+</code></pre>
+<ul>
+<li>If you choose Mysql, please comment out the relevant configuration of PostgreSQL (vice versa), you also need to manually add the [[mysql-connector-java driver jar] (<a href="https://downloads.mysql.com/archives/c-j/">https://downloads.mysql.com/archives/c-j/</a>)] package to lib under the directory, and then configure the database connection information correctly.</li>
+</ul>
+<pre><code class="language-properties"><span class="hljs-comment">  #postgre</span>
+<span class="hljs-comment">  #spring.datasource.driver-class-name=org.postgresql.Driver</span>
+<span class="hljs-comment">  #spring.datasource.url=jdbc:postgresql://localhost:5432/dolphinscheduler</span>
+<span class="hljs-comment">  # mysql</span>
+  <span class="hljs-meta">spring.datasource.driver-class-name</span>=<span class="hljs-string">com.mysql.jdbc.Driver</span>
+  <span class="hljs-meta">spring.datasource.url</span>=<span class="hljs-string">jdbc:mysql://xxx:3306/dolphinscheduler?useUnicode=true&amp;characterEncoding=UTF-8&amp;allowMultiQueries=true     # Replace the correct IP address</span>
+  <span class="hljs-meta">spring.datasource.username</span>=<span class="hljs-string">xxx						# replace the correct {user} value</span>
+  <span class="hljs-meta">spring.datasource.password</span>=<span class="hljs-string">xxx						# replace the correct {password} value</span>
+</code></pre>
+<ul>
+<li>After modifying and saving, execute the create table and import data script in the script directory.</li>
+</ul>
+<pre><code class="language-shell">sh script/create-dolphinscheduler.sh
+</code></pre>
+</li>
+</ul>
+<p>​       <em>Note: If you execute the above script and report &quot;/bin/java: No such file or directory&quot; error, please configure JAVA_HOME and PATH variables in /etc/profile</em></p>
+<h1>6、Modify runtime parameters.</h1>
+<ul>
+<li>
+<p>Modify the environment variable in <code>dolphinscheduler_env.sh</code> file which on the 'conf/env' directory (take the relevant software installed under '/opt/soft' as an example)</p>
+<pre><code class="language-shell">    export HADOOP_HOME=/opt/soft/hadoop
+    export HADOOP_CONF_DIR=/opt/soft/hadoop/etc/hadoop
+    #export SPARK_HOME1=/opt/soft/spark1
+    export SPARK_HOME2=/opt/soft/spark2
+    export PYTHON_HOME=/opt/soft/python
+    export JAVA_HOME=/opt/soft/java
+    export HIVE_HOME=/opt/soft/hive
+    export FLINK_HOME=/opt/soft/flink
+    export DATAX_HOME=/opt/soft/datax/bin/datax.py
+    export PATH=$HADOOP_HOME/bin:$SPARK_HOME2/bin:$PYTHON_HOME:$JAVA_HOME/bin:$HIVE_HOME/bin:$PATH:$FLINK_HOME/bin:$DATAX_HOME:$PATH
+
+    ```
+
+ `Note: This step is very important. For example, JAVA_HOME and PATH must be configured. Those that are not used can be ignored or commented out.`
+
+
+
+</code></pre>
+</li>
+<li>
+<p>Create Soft link jdk to /usr/bin/java (still JAVA_HOME=/opt/soft/java as an example)</p>
+<pre><code class="language-shell">sudo ln -s /opt/soft/java/bin/java /usr/bin/java
+</code></pre>
+</li>
+<li>
+<p>Modify the parameters in the one-click deployment config file <code>conf/config/install_config.conf</code>, pay special attention to the configuration of the following parameters.</p>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> choose mysql or postgresql</span>
+dbtype="mysql"
+<span class="hljs-meta">
+#</span><span class="bash"> Database connection address and port</span>
+dbhost="192.168.xx.xx:3306"
+<span class="hljs-meta">
+#</span><span class="bash"> database name</span>
+dbname="dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> database username</span>
+username="xxx"
+<span class="hljs-meta">
+#</span><span class="bash"> database password</span>
+<span class="hljs-meta">#</span><span class="bash"> NOTICE: <span class="hljs-keyword">if</span> there are special characters, please use the \ to escape, <span class="hljs-keyword">for</span> example, `[` escape to `\[`</span>
+password="xxx"
+<span class="hljs-meta">
+#</span><span class="bash">Zookeeper cluster</span>
+zkQuorum="192.168.xx.xx:2181,192.168.xx.xx:2181,192.168.xx.xx:2181"
+<span class="hljs-meta">
+#</span><span class="bash"> Note: the target installation path <span class="hljs-keyword">for</span> dolphinscheduler, please not config as the same as the current path (<span class="hljs-built_in">pwd</span>)</span>
+installPath="/opt/soft/dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> deployment user</span>
+<span class="hljs-meta">#</span><span class="bash"> Note: the deployment user needs to have sudo privileges and permissions to operate hdfs. If hdfs is enabled, the root directory needs to be created by itself</span>
+deployUser="dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> alert config,take QQ email <span class="hljs-keyword">for</span> example</span>
+<span class="hljs-meta">#</span><span class="bash"> mail protocol</span>
+mailProtocol="SMTP"
+<span class="hljs-meta">
+#</span><span class="bash"> mail server host</span>
+mailServerHost="smtp.qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> mail server port</span>
+<span class="hljs-meta">#</span><span class="bash"> note: Different protocols and encryption methods correspond to different ports, when SSL/TLS is enabled, make sure the port is correct.</span>
+mailServerPort="25"
+<span class="hljs-meta">
+#</span><span class="bash"> mail sender</span>
+mailSender="xxx@qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> mail user</span>
+mailUser="xxx@qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> mail sender password</span>
+<span class="hljs-meta">#</span><span class="bash"> note: The mail.passwd is email service authorization code, not the email login password.</span>
+mailPassword="xxx"
+<span class="hljs-meta">
+#</span><span class="bash"> Whether TLS mail protocol is supported,<span class="hljs-literal">true</span> is supported and <span class="hljs-literal">false</span> is not supported</span>
+starttlsEnable="true"
+<span class="hljs-meta">
+#</span><span class="bash"> Whether TLS mail protocol is supported,<span class="hljs-literal">true</span> is supported and <span class="hljs-literal">false</span> is not supported。</span>
+<span class="hljs-meta">#</span><span class="bash"> note: only one of TLS and SSL can be <span class="hljs-keyword">in</span> the <span class="hljs-literal">true</span> state.</span>
+sslEnable="false"
+<span class="hljs-meta">
+#</span><span class="bash"> note: sslTrust is the same as mailServerHost</span>
+sslTrust="smtp.qq.com"
+<span class="hljs-meta">
+
+#</span><span class="bash"> resource storage <span class="hljs-built_in">type</span>:HDFS,S3,NONE</span>
+resourceStorageType="HDFS"
+<span class="hljs-meta">
+#</span><span class="bash"> <span class="hljs-keyword">if</span> resourceStorageType is HDFS,defaultFS write namenode address,HA you need to put core-site.xml and hdfs-site.xml <span class="hljs-keyword">in</span> the conf directory.</span>
+<span class="hljs-meta">#</span><span class="bash"> <span class="hljs-keyword">if</span> S3,write S3 address,HA,<span class="hljs-keyword">for</span> example :s3a://dolphinscheduler,</span>
+<span class="hljs-meta">#</span><span class="bash"> Note,s3 be sure to create the root directory /dolphinscheduler</span>
+defaultFS="hdfs://mycluster:8020"
+<span class="hljs-meta">
+
+#</span><span class="bash"> <span class="hljs-keyword">if</span> not use hadoop resourcemanager, please keep default value; <span class="hljs-keyword">if</span> resourcemanager HA <span class="hljs-built_in">enable</span>, please <span class="hljs-built_in">type</span> the HA ips ; <span class="hljs-keyword">if</span> resourcemanager is single, make this value empty</span>
+yarnHaIps="192.168.xx.xx,192.168.xx.xx"
+<span class="hljs-meta">
+#</span><span class="bash"> <span class="hljs-keyword">if</span> resourcemanager HA <span class="hljs-built_in">enable</span> or not use resourcemanager, please skip this value setting; If resourcemanager is single, you only need to replace yarnIp1 to actual resourcemanager hostname.</span>
+singleYarnIp="yarnIp1"
+<span class="hljs-meta">
+#</span><span class="bash"> resource store on HDFS/S3 path, resource file will store to this hadoop hdfs path, self configuration, please make sure the directory exists on hdfs and have <span class="hljs-built_in">read</span> write permissions。/dolphinscheduler is recommended</span>
+resourceUploadPath="/dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> who have permissions to create directory under HDFS/S3 root path</span>
+<span class="hljs-meta">#</span><span class="bash"> Note: <span class="hljs-keyword">if</span> kerberos is enabled, please config hdfsRootUser=</span>
+hdfsRootUser="hdfs"
+<span class="hljs-meta">
+
+
+#</span><span class="bash"> install hosts</span>
+<span class="hljs-meta">#</span><span class="bash"> Note: install the scheduled hostname list. If it is pseudo-distributed, just write a pseudo-distributed hostname</span>
+ips="ds1,ds2,ds3,ds4"
+<span class="hljs-meta">
+#</span><span class="bash"> ssh port, default 22</span>
+<span class="hljs-meta">#</span><span class="bash"> Note: <span class="hljs-keyword">if</span> ssh port is not default, modify here</span>
+sshPort="22"
+<span class="hljs-meta">
+#</span><span class="bash"> run master machine</span>
+<span class="hljs-meta">#</span><span class="bash"> Note: list of hosts hostname <span class="hljs-keyword">for</span> deploying master</span>
+masters="ds1,ds2"
+<span class="hljs-meta">
+#</span><span class="bash"> run worker machine</span>
+<span class="hljs-meta">#</span><span class="bash"> note: need to write the worker group name of each worker, the default value is <span class="hljs-string">"default"</span></span>
+workers="ds3:default,ds4:default"
+<span class="hljs-meta">
+#</span><span class="bash"> run alert machine</span>
+<span class="hljs-meta">#</span><span class="bash"> note: list of machine hostnames <span class="hljs-keyword">for</span> deploying alert server</span>
+alertServer="ds2"
+<span class="hljs-meta">
+#</span><span class="bash"> run api machine</span>
+<span class="hljs-meta">#</span><span class="bash"> note: list of machine hostnames <span class="hljs-keyword">for</span> deploying api server</span>
+apiServers="ds1"
+
+</code></pre>
+<p><em>Attention:</em></p>
+<ul>
+<li>If you need to upload resources to the Hadoop cluster, and the NameNode of the Hadoop cluster is configured with HA, you need to enable HDFS resource upload, and you need to copy the core-site.xml and hdfs-site.xml in the Hadoop cluster to /opt/ dolphinscheduler/conf. Non-NameNode HA skips the next step.</li>
+</ul>
+</li>
+</ul>
+<h1>7、Automated Deployment</h1>
+<ul>
+<li>
+<p>Switch to the deployment user and execute the one-click deployment script</p>
+<p><code>sh install.sh</code></p>
+<pre><code>Note:
+For the first deployment, the following message appears in step 3 of `3, stop server` during operation. This message can be ignored.
+sh: bin/dolphinscheduler-daemon.sh: No such file or directory
+</code></pre>
+</li>
+<li>
+<p>After the script is completed, the following 5 services will be started. Use the <code>jps</code> command to check whether the services are started (<code>jps</code> comes with <code>java JDK</code>)</p>
+</li>
+</ul>
+<pre><code class="language-aidl">    MasterServer         ----- master service
+    WorkerServer         ----- worker service
+    LoggerServer         ----- logger service
+    ApiApplicationServer ----- api service
+    AlertServer          ----- alert service
+</code></pre>
+<p>If the above services are started normally, the automatic deployment is successful.</p>
+<p>After the deployment is successful, you can view the logs. The logs are stored in the logs folder.</p>
+<pre><code class="language-log"> logs/
+    ├── dolphinscheduler-alert-server.log
+    ├── dolphinscheduler-master-server.log
+    |—— dolphinscheduler-worker-server.log
+    |—— dolphinscheduler-api-server.log
+    |—— dolphinscheduler-logger-server.log
+</code></pre>
+<h1>8、login</h1>
+<ul>
+<li>
+<p>Access the address of the front page, interface IP (self-modified)
+<a href="http://192.168.xx.xx:12345/dolphinscheduler">http://192.168.xx.xx:12345/dolphinscheduler</a></p>
+ <p align="center">
+   <img src="/img/login.png" width="60%" />
+ </p>
+</li>
+</ul>
+<h1>9、Start and stop service</h1>
+<ul>
+<li>
+<p>Stop all services</p>
+<p><code>sh ./bin/stop-all.sh</code></p>
+</li>
+<li>
+<p>Start all services</p>
+<p><code>sh ./bin/start-all.sh</code></p>
+</li>
+<li>
+<p>Start and stop master service</p>
+</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start master-server
+sh ./bin/dolphinscheduler-daemon.sh stop master-server
+</code></pre>
+<ul>
+<li>Start and stop worker Service</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start worker-server
+sh ./bin/dolphinscheduler-daemon.sh stop worker-server
+</code></pre>
+<ul>
+<li>Start and stop api Service</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start api-server
+sh ./bin/dolphinscheduler-daemon.sh stop api-server
+</code></pre>
+<ul>
+<li>Start and stop logger Service</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start logger-server
+sh ./bin/dolphinscheduler-daemon.sh stop logger-server
+</code></pre>
+<ul>
+<li>Start and stop alert service</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start alert-server
+sh ./bin/dolphinscheduler-daemon.sh stop alert-server
+</code></pre>
+<p><code>Note: Please refer to the &quot;Architecture Design&quot; section for service usage</code></p>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>Documentation</dt><dd><a href="/en-us/docs/development/architecture-design.html" target="_self">Overview</a></dd><dd><a href="/en-us/docs/1.2.0/user_doc/quick-start.html" target="_self">Quick start</a></dd><dd><a href="/en-us/docs/development/backend-development.html" target="_self">Developer guide</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http:/ [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/en-us/docs/1.3.2/user_doc/cluster-deployment.json b/en-us/docs/1.3.2/user_doc/cluster-deployment.json
new file mode 100644
index 0000000..e6676ee
--- /dev/null
+++ b/en-us/docs/1.3.2/user_doc/cluster-deployment.json
@@ -0,0 +1,6 @@
+{
+  "filename": "cluster-deployment.md",
+  "__html": "<h1>Cluster Deployment</h1>\n<h1>1、Before you begin (please install requirement basic software by yourself)</h1>\n<ul>\n<li>PostgreSQL (8.2.15+) or MySQL (5.7)  :  Choose One</li>\n<li><a href=\"https://www.oracle.com/technetwork/java/javase/downloads/index.html\">JDK</a> (1.8+) :  Required. Double-check configure JAVA_HOME and PATH environment variables in /etc/profile</li>\n<li>ZooKeeper (3.4.6+) :Required</li>\n<li>Hadoop (2.6+) or MinIO :Optional. If you need to upload a [...]
+  "link": "/en-us/docs/1.3.2/user_doc/cluster-deployment.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/en-us/docs/1.3.2/user_doc/hardware-environment.html b/en-us/docs/1.3.2/user_doc/hardware-environment.html
new file mode 100644
index 0000000..a320eea
--- /dev/null
+++ b/en-us/docs/1.3.2/user_doc/hardware-environment.html
@@ -0,0 +1,127 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="hardware-environment" />
+	<meta name="description" content="hardware-environment" />
+	<!-- 网页标签标题 -->
+	<title>hardware-environment</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/en-us/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">中</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass ant [...]
+<p>DolphinScheduler, as an open-source distributed workflow task scheduling system, can be well deployed and run in Intel architecture server environments and mainstream virtualization environments, and supports mainstream Linux operating system environments.</p>
+<h2>1. Linux operating system version requirements</h2>
+<table>
+<thead>
+<tr>
+<th style="text-align:left">OS</th>
+<th style="text-align:center">Version</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td style="text-align:left">Red Hat Enterprise Linux</td>
+<td style="text-align:center">7.0 and above</td>
+</tr>
+<tr>
+<td style="text-align:left">CentOS</td>
+<td style="text-align:center">7.0 and above</td>
+</tr>
+<tr>
+<td style="text-align:left">Oracle Enterprise Linux</td>
+<td style="text-align:center">7.0 and above</td>
+</tr>
+<tr>
+<td style="text-align:left">Ubuntu LTS</td>
+<td style="text-align:center">16.04 and above</td>
+</tr>
+</tbody>
+</table>
+<blockquote>
+<p><strong>Attention:</strong>
+The above Linux operating systems can run on physical servers and mainstream virtualization environments such as VMware, KVM, and XEN.</p>
+</blockquote>
+<h2>2. Recommended server configuration</h2>
+<p>DolphinScheduler supports 64-bit hardware platforms with Intel x86-64 architecture. The following recommendation is made for server hardware configuration in a production environment:</p>
+<h3>Production Environment</h3>
+<table>
+<thead>
+<tr>
+<th><strong>CPU</strong></th>
+<th><strong>MEM</strong></th>
+<th><strong>HD</strong></th>
+<th><strong>NIC</strong></th>
+<th><strong>Num</strong></th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>4 core+</td>
+<td>8 GB+</td>
+<td>SAS</td>
+<td>GbE</td>
+<td>1+</td>
+</tr>
+</tbody>
+</table>
+<blockquote>
+<p><strong>Attention:</strong></p>
+<ul>
+<li>The above-recommended configuration is the minimum configuration for deploying DolphinScheduler. The higher configuration is strongly recommended for production environments.</li>
+<li>The hard disk size configuration is recommended by more than 50GB. The system disk and data disk are separated.</li>
+</ul>
+</blockquote>
+<h2>3. Network requirements</h2>
+<p>DolphinScheduler provides the following network port configurations for normal operation:</p>
+<table>
+<thead>
+<tr>
+<th>Server</th>
+<th>Port</th>
+<th>Desc</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>MasterServer</td>
+<td>5678</td>
+<td>Not the communication port. Require the native ports do not conflict</td>
+</tr>
+<tr>
+<td>WorkerServer</td>
+<td>1234</td>
+<td>Not the communication port. Require the native ports do not conflict</td>
+</tr>
+<tr>
+<td>ApiApplicationServer</td>
+<td>12345</td>
+<td>Backend communication port</td>
+</tr>
+</tbody>
+</table>
+<blockquote>
+<p><strong>Attention:</strong></p>
+<ul>
+<li>MasterServer and WorkerServer do not need to enable communication between the networks. As long as the local ports do not conflict.</li>
+<li>Administrators can adjust relevant ports on the network side and host-side according to the deployment plan of DolphinScheduler components in the actual environment.</li>
+</ul>
+</blockquote>
+<h2>4. Browser requirements</h2>
+<p>DolphinScheduler recommends Chrome and the latest browsers which using Chrome Kernel to access the front-end visual operator page.</p>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>Documentation</dt><dd><a href="/en-us/docs/development/architecture-design.html" target="_self">Overview</a></dd><dd><a href="/en-us/docs/1.2.0/user_doc/quick-start.html" target="_self">Quick start</a></dd><dd><a href="/en-us/docs/development/backend-development.html" target="_self">Developer guide</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http:/ [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/en-us/docs/1.3.2/user_doc/hardware-environment.json b/en-us/docs/1.3.2/user_doc/hardware-environment.json
new file mode 100644
index 0000000..d0b4327
--- /dev/null
+++ b/en-us/docs/1.3.2/user_doc/hardware-environment.json
@@ -0,0 +1,6 @@
+{
+  "filename": "hardware-environment.md",
+  "__html": "<h1>Hareware Environment</h1>\n<p>DolphinScheduler, as an open-source distributed workflow task scheduling system, can be well deployed and run in Intel architecture server environments and mainstream virtualization environments, and supports mainstream Linux operating system environments.</p>\n<h2>1. Linux operating system version requirements</h2>\n<table>\n<thead>\n<tr>\n<th style=\"text-align:left\">OS</th>\n<th style=\"text-align:center\">Version</th>\n</tr>\n</thead>\n [...]
+  "link": "/en-us/docs/1.3.2/user_doc/hardware-environment.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/en-us/docs/1.3.2/user_doc/metadata-1.3.html b/en-us/docs/1.3.2/user_doc/metadata-1.3.html
new file mode 100644
index 0000000..a93c01b
--- /dev/null
+++ b/en-us/docs/1.3.2/user_doc/metadata-1.3.html
@@ -0,0 +1,655 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="metadata-1.3" />
+	<meta name="description" content="metadata-1.3" />
+	<!-- 网页标签标题 -->
+	<title>metadata-1.3</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/en-us/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">中</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass ant [...]
+<p><a name="V5KOl"></a></p>
+<h3>Dolphin Scheduler 1.2 DB Table Overview</h3>
+<table>
+<thead>
+<tr>
+<th style="text-align:center">Table Name</th>
+<th style="text-align:center">Comment</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td style="text-align:center">t_ds_access_token</td>
+<td style="text-align:center">token for access ds backend</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_alert</td>
+<td style="text-align:center">alert detail</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_alertgroup</td>
+<td style="text-align:center">alert group</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_command</td>
+<td style="text-align:center">command detail</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_datasource</td>
+<td style="text-align:center">data source</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_error_command</td>
+<td style="text-align:center">error command detail</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_process_definition</td>
+<td style="text-align:center">process difinition</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_process_instance</td>
+<td style="text-align:center">process instance</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_project</td>
+<td style="text-align:center">project</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_queue</td>
+<td style="text-align:center">queue</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_datasource_user</td>
+<td style="text-align:center">datasource related to user</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_process_instance</td>
+<td style="text-align:center">sub process</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_project_user</td>
+<td style="text-align:center">project related to user</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_resources_user</td>
+<td style="text-align:center">resource related to user</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_udfs_user</td>
+<td style="text-align:center">UDF related to user</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_user_alertgroup</td>
+<td style="text-align:center">alert group related to user</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_resources</td>
+<td style="text-align:center">resoruce center file</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_schedules</td>
+<td style="text-align:center">process difinition schedule</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_session</td>
+<td style="text-align:center">user login session</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_task_instance</td>
+<td style="text-align:center">task instance</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_tenant</td>
+<td style="text-align:center">tenant</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_udfs</td>
+<td style="text-align:center">UDF resource</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_user</td>
+<td style="text-align:center">user detail</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_version</td>
+<td style="text-align:center">ds version</td>
+</tr>
+</tbody>
+</table>
+<hr>
+<p><a name="XCLy1"></a></p>
+<h3>E-R Diagram</h3>
+<p><a name="5hWWZ"></a></p>
+<h4>User Queue DataSource</h4>
+<p><img src="/img/metadata-erd/user-queue-datasource.png" alt="image.png"></p>
+<ul>
+<li>Multiple users can belong to one tenant</li>
+<li>The queue field in t_ds_user table stores the queue_name information in t_ds_queue table, but t_ds_tenant stores queue infomation using queue_id. During the execution of the process definition, the user queue has the highest priority. If the user queue is empty, the tenant queue is used.</li>
+<li>The user_id field in the t_ds_datasource table indicates the user who created the data source. The user_id in t_ds_relation_datasource_user indicates the user who has permission to the data source.
+<a name="7euSN"></a></li>
+</ul>
+<h4>Project Resource Alert</h4>
+<p><img src="/img/metadata-erd/project-resource-alert.png" alt="image.png"></p>
+<ul>
+<li>User can have multiple projects, User project authorization completes the relationship binding using project_id and user_id in t_ds_relation_project_user table</li>
+<li>The user_id in the t_ds_projcet table represents the user who created the project, and the user_id in the t_ds_relation_project_user table represents users who have permission to the project</li>
+<li>The user_id in the t_ds_resources table represents the user who created the resource, and the user_id in t_ds_relation_resources_user represents the user who has permissions to the resource</li>
+<li>The user_id in the t_ds_udfs table represents the user who created the UDF, and the user_id in the t_ds_relation_udfs_user table represents a user who has permission to the UDF
+<a name="JEw4v"></a></li>
+</ul>
+<h4>Command Process Task</h4>
+<p><img src="/img/metadata-erd/command.png" alt="image.png"><br /><img src="/img/metadata-erd/process-task.png" alt="image.png"></p>
+<ul>
+<li>A project has multiple process definitions, a process definition can generate multiple process instances, and a process instance can generate multiple task instances</li>
+<li>The t_ds_schedulers table stores the timing schedule information for process difinition</li>
+<li>The data stored in the t_ds_relation_process_instance table is used to deal with that the process definition contains sub-processes, parent_process_instance_id field represents the id of the main process instance containing the child process, process_instance_id field represents the id of the sub-process instance, parent_task_instance_id field represents the task instance id of the sub-process node</li>
+<li>The process instance table and the task instance table correspond to the t_ds_process_instance table and the t_ds_task_instance table, respectively.</li>
+</ul>
+<hr>
+<p><a name="yd79T"></a></p>
+<h3>Core Table Schema</h3>
+<p><a name="6bVhH"></a></p>
+<h4>t_ds_process_definition</h4>
+<table>
+<thead>
+<tr>
+<th>Field</th>
+<th>Type</th>
+<th>Comment</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>id</td>
+<td>int</td>
+<td>primary key</td>
+</tr>
+<tr>
+<td>name</td>
+<td>varchar</td>
+<td>process definition name</td>
+</tr>
+<tr>
+<td>version</td>
+<td>int</td>
+<td>process definition version</td>
+</tr>
+<tr>
+<td>release_state</td>
+<td>tinyint</td>
+<td>process definition release state:0:offline,1:online</td>
+</tr>
+<tr>
+<td>project_id</td>
+<td>int</td>
+<td>project id</td>
+</tr>
+<tr>
+<td>user_id</td>
+<td>int</td>
+<td>process definition creator id</td>
+</tr>
+<tr>
+<td>process_definition_json</td>
+<td>longtext</td>
+<td>process definition json content</td>
+</tr>
+<tr>
+<td>description</td>
+<td>text</td>
+<td>process difinition desc</td>
+</tr>
+<tr>
+<td>global_params</td>
+<td>text</td>
+<td>global parameters</td>
+</tr>
+<tr>
+<td>flag</td>
+<td>tinyint</td>
+<td>process is available: 0 not available, 1 available</td>
+</tr>
+<tr>
+<td>locations</td>
+<td>text</td>
+<td>Node location information</td>
+</tr>
+<tr>
+<td>connects</td>
+<td>text</td>
+<td>Node connection information</td>
+</tr>
+<tr>
+<td>receivers</td>
+<td>text</td>
+<td>receivers</td>
+</tr>
+<tr>
+<td>receivers_cc</td>
+<td>text</td>
+<td>carbon copy list</td>
+</tr>
+<tr>
+<td>create_time</td>
+<td>datetime</td>
+<td>create time</td>
+</tr>
+<tr>
+<td>timeout</td>
+<td>int</td>
+<td>timeout</td>
+</tr>
+<tr>
+<td>tenant_id</td>
+<td>int</td>
+<td>tenant id</td>
+</tr>
+<tr>
+<td>update_time</td>
+<td>datetime</td>
+<td>update time</td>
+</tr>
+</tbody>
+</table>
+<p><a name="t5uxM"></a></p>
+<h4>t_ds_process_instance</h4>
+<table>
+<thead>
+<tr>
+<th>Field</th>
+<th>Type</th>
+<th>Comment</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>id</td>
+<td>int</td>
+<td>primary key</td>
+</tr>
+<tr>
+<td>name</td>
+<td>varchar</td>
+<td>process instance name</td>
+</tr>
+<tr>
+<td>process_definition_id</td>
+<td>int</td>
+<td>process definition id</td>
+</tr>
+<tr>
+<td>state</td>
+<td>tinyint</td>
+<td>process instance Status: 0 commit succeeded, 1 running, 2 prepare to pause, 3 pause, 4 prepare to stop, 5 stop, 6 fail, 7 succeed, 8 need fault tolerance, 9 kill, 10 wait for thread, 11 wait for dependency to complete</td>
+</tr>
+<tr>
+<td>recovery</td>
+<td>tinyint</td>
+<td>process instance failover flag:0:normal,1:failover instance</td>
+</tr>
+<tr>
+<td>start_time</td>
+<td>datetime</td>
+<td>process instance start time</td>
+</tr>
+<tr>
+<td>end_time</td>
+<td>datetime</td>
+<td>process instance end time</td>
+</tr>
+<tr>
+<td>run_times</td>
+<td>int</td>
+<td>process instance run times</td>
+</tr>
+<tr>
+<td>host</td>
+<td>varchar</td>
+<td>process instance host</td>
+</tr>
+<tr>
+<td>command_type</td>
+<td>tinyint</td>
+<td>command type:0 start ,1 Start from the current node,2 Resume a fault-tolerant process,3 Resume Pause Process, 4 Execute from the failed node,5 Complement, 6 dispatch, 7 re-run, 8 pause, 9 stop ,10 Resume waiting thread</td>
+</tr>
+<tr>
+<td>command_param</td>
+<td>text</td>
+<td>json command parameters</td>
+</tr>
+<tr>
+<td>task_depend_type</td>
+<td>tinyint</td>
+<td>task depend type. 0: only current node,1:before the node,2:later nodes</td>
+</tr>
+<tr>
+<td>max_try_times</td>
+<td>tinyint</td>
+<td>max try times</td>
+</tr>
+<tr>
+<td>failure_strategy</td>
+<td>tinyint</td>
+<td>failure strategy. 0:end the process when node failed,1:continue running the other nodes when node failed</td>
+</tr>
+<tr>
+<td>warning_type</td>
+<td>tinyint</td>
+<td>warning type. 0:no warning,1:warning if process success,2:warning if process failed,3:warning if success</td>
+</tr>
+<tr>
+<td>warning_group_id</td>
+<td>int</td>
+<td>warning group id</td>
+</tr>
+<tr>
+<td>schedule_time</td>
+<td>datetime</td>
+<td>schedule time</td>
+</tr>
+<tr>
+<td>command_start_time</td>
+<td>datetime</td>
+<td>command start time</td>
+</tr>
+<tr>
+<td>global_params</td>
+<td>text</td>
+<td>global parameters</td>
+</tr>
+<tr>
+<td>process_instance_json</td>
+<td>longtext</td>
+<td>process instance json(copy的process definition 的json)</td>
+</tr>
+<tr>
+<td>flag</td>
+<td>tinyint</td>
+<td>process instance is available: 0 not available, 1 available</td>
+</tr>
+<tr>
+<td>update_time</td>
+<td>timestamp</td>
+<td>update time</td>
+</tr>
+<tr>
+<td>is_sub_process</td>
+<td>int</td>
+<td>whether the process is sub process:  1 sub-process,0 not sub-process</td>
+</tr>
+<tr>
+<td>executor_id</td>
+<td>int</td>
+<td>executor id</td>
+</tr>
+<tr>
+<td>locations</td>
+<td>text</td>
+<td>Node location information</td>
+</tr>
+<tr>
+<td>connects</td>
+<td>text</td>
+<td>Node connection information</td>
+</tr>
+<tr>
+<td>history_cmd</td>
+<td>text</td>
+<td>history commands of process instance operation</td>
+</tr>
+<tr>
+<td>dependence_schedule_times</td>
+<td>text</td>
+<td>depend schedule fire time</td>
+</tr>
+<tr>
+<td>process_instance_priority</td>
+<td>int</td>
+<td>process instance priority. 0 Highest,1 High,2 Medium,3 Low,4 Lowest</td>
+</tr>
+<tr>
+<td>worker_group_id</td>
+<td>int</td>
+<td>worker group id</td>
+</tr>
+<tr>
+<td>timeout</td>
+<td>int</td>
+<td>time out</td>
+</tr>
+<tr>
+<td>tenant_id</td>
+<td>int</td>
+<td>tenant id</td>
+</tr>
+</tbody>
+</table>
+<p><a name="tHZsY"></a></p>
+<h4>t_ds_task_instance</h4>
+<table>
+<thead>
+<tr>
+<th>Field</th>
+<th>Type</th>
+<th>Comment</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>id</td>
+<td>int</td>
+<td>primary key</td>
+</tr>
+<tr>
+<td>name</td>
+<td>varchar</td>
+<td>task name</td>
+</tr>
+<tr>
+<td>task_type</td>
+<td>varchar</td>
+<td>task type</td>
+</tr>
+<tr>
+<td>process_definition_id</td>
+<td>int</td>
+<td>process definition id</td>
+</tr>
+<tr>
+<td>process_instance_id</td>
+<td>int</td>
+<td>process instance id</td>
+</tr>
+<tr>
+<td>task_json</td>
+<td>longtext</td>
+<td>task content json</td>
+</tr>
+<tr>
+<td>state</td>
+<td>tinyint</td>
+<td>Status: 0 commit succeeded, 1 running, 2 prepare to pause, 3 pause, 4 prepare to stop, 5 stop, 6 fail, 7 succeed, 8 need fault tolerance, 9 kill, 10 wait for thread, 11 wait for dependency to complete</td>
+</tr>
+<tr>
+<td>submit_time</td>
+<td>datetime</td>
+<td>task submit time</td>
+</tr>
+<tr>
+<td>start_time</td>
+<td>datetime</td>
+<td>task start time</td>
+</tr>
+<tr>
+<td>end_time</td>
+<td>datetime</td>
+<td>task end time</td>
+</tr>
+<tr>
+<td>host</td>
+<td>varchar</td>
+<td>host of task running on</td>
+</tr>
+<tr>
+<td>execute_path</td>
+<td>varchar</td>
+<td>task execute path in the host</td>
+</tr>
+<tr>
+<td>log_path</td>
+<td>varchar</td>
+<td>task log path</td>
+</tr>
+<tr>
+<td>alert_flag</td>
+<td>tinyint</td>
+<td>whether alert</td>
+</tr>
+<tr>
+<td>retry_times</td>
+<td>int</td>
+<td>task retry times</td>
+</tr>
+<tr>
+<td>pid</td>
+<td>int</td>
+<td>pid of task</td>
+</tr>
+<tr>
+<td>app_link</td>
+<td>varchar</td>
+<td>yarn app id</td>
+</tr>
+<tr>
+<td>flag</td>
+<td>tinyint</td>
+<td>taskinstance is available: 0 not available, 1 available</td>
+</tr>
+<tr>
+<td>retry_interval</td>
+<td>int</td>
+<td>retry interval when task failed</td>
+</tr>
+<tr>
+<td>max_retry_times</td>
+<td>int</td>
+<td>max retry times</td>
+</tr>
+<tr>
+<td>task_instance_priority</td>
+<td>int</td>
+<td>task instance priority:0 Highest,1 High,2 Medium,3 Low,4 Lowest</td>
+</tr>
+<tr>
+<td>worker_group_id</td>
+<td>int</td>
+<td>worker group id</td>
+</tr>
+</tbody>
+</table>
+<p><a name="gLGtm"></a></p>
+<h4>t_ds_command</h4>
+<table>
+<thead>
+<tr>
+<th>Field</th>
+<th>Type</th>
+<th>Comment</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>id</td>
+<td>int</td>
+<td>primary key</td>
+</tr>
+<tr>
+<td>command_type</td>
+<td>tinyint</td>
+<td>Command type: 0 start workflow, 1 start execution from current node, 2 resume fault-tolerant workflow, 3 resume pause process, 4 start execution from failed node, 5 complement, 6 schedule, 7 rerun, 8 pause, 9 stop, 10 resume waiting thread</td>
+</tr>
+<tr>
+<td>process_definition_id</td>
+<td>int</td>
+<td>process definition id</td>
+</tr>
+<tr>
+<td>command_param</td>
+<td>text</td>
+<td>json command parameters</td>
+</tr>
+<tr>
+<td>task_depend_type</td>
+<td>tinyint</td>
+<td>Node dependency type: 0 current node, 1 forward, 2 backward</td>
+</tr>
+<tr>
+<td>failure_strategy</td>
+<td>tinyint</td>
+<td>Failed policy: 0 end, 1 continue</td>
+</tr>
+<tr>
+<td>warning_type</td>
+<td>tinyint</td>
+<td>Alarm type: 0 is not sent, 1 process is sent successfully, 2 process is sent failed, 3 process is sent successfully and all failures are sent</td>
+</tr>
+<tr>
+<td>warning_group_id</td>
+<td>int</td>
+<td>warning group</td>
+</tr>
+<tr>
+<td>schedule_time</td>
+<td>datetime</td>
+<td>schedule time</td>
+</tr>
+<tr>
+<td>start_time</td>
+<td>datetime</td>
+<td>start time</td>
+</tr>
+<tr>
+<td>executor_id</td>
+<td>int</td>
+<td>executor id</td>
+</tr>
+<tr>
+<td>dependence</td>
+<td>varchar</td>
+<td>dependence</td>
+</tr>
+<tr>
+<td>update_time</td>
+<td>datetime</td>
+<td>update time</td>
+</tr>
+<tr>
+<td>process_instance_priority</td>
+<td>int</td>
+<td>process instance priority: 0 Highest,1 High,2 Medium,3 Low,4 Lowest</td>
+</tr>
+<tr>
+<td>worker_group_id</td>
+<td>int</td>
+<td>worker group id</td>
+</tr>
+</tbody>
+</table>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>Documentation</dt><dd><a href="/en-us/docs/development/architecture-design.html" target="_self">Overview</a></dd><dd><a href="/en-us/docs/1.2.0/user_doc/quick-start.html" target="_self">Quick start</a></dd><dd><a href="/en-us/docs/development/backend-development.html" target="_self">Developer guide</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http:/ [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/en-us/docs/1.3.2/user_doc/metadata-1.3.json b/en-us/docs/1.3.2/user_doc/metadata-1.3.json
new file mode 100644
index 0000000..2d113f4
--- /dev/null
+++ b/en-us/docs/1.3.2/user_doc/metadata-1.3.json
@@ -0,0 +1,6 @@
+{
+  "filename": "metadata-1.3.md",
+  "__html": "<h1>Dolphin Scheduler 1.3 MetaData</h1>\n<p><a name=\"V5KOl\"></a></p>\n<h3>Dolphin Scheduler 1.2 DB Table Overview</h3>\n<table>\n<thead>\n<tr>\n<th style=\"text-align:center\">Table Name</th>\n<th style=\"text-align:center\">Comment</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td style=\"text-align:center\">t_ds_access_token</td>\n<td style=\"text-align:center\">token for access ds backend</td>\n</tr>\n<tr>\n<td style=\"text-align:center\">t_ds_alert</td>\n<td style=\"text-align [...]
+  "link": "/en-us/docs/1.3.2/user_doc/metadata-1.3.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/en-us/docs/1.3.2/user_doc/quick-start.html b/en-us/docs/1.3.2/user_doc/quick-start.html
new file mode 100644
index 0000000..d8c68bd
--- /dev/null
+++ b/en-us/docs/1.3.2/user_doc/quick-start.html
@@ -0,0 +1,101 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="quick-start" />
+	<meta name="description" content="quick-start" />
+	<!-- 网页标签标题 -->
+	<title>quick-start</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/en-us/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">中</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass ant [...]
+<ul>
+<li>
+<p>Administrator user login</p>
+<blockquote>
+<p>Address:192.168.xx.xx:8888  Username and password:admin/dolphinscheduler123</p>
+</blockquote>
+</li>
+</ul>
+<p align="center">
+   <img src="/img/login_en.png" width="60%" />
+ </p>
+<ul>
+<li>Create queue</li>
+</ul>
+<p align="center">
+   <img src="/img/create-queue-en.png" width="60%" />
+ </p>
+<ul>
+<li>Create tenant  <p align="center">
+<img src="/img/create-tenant-en.png" width="60%" />
+</li>
+</ul>
+  </p>
+<ul>
+<li>Creating Ordinary Users</li>
+</ul>
+<p align="center">
+      <img src="/img/create-user-en.png" width="60%" />
+ </p>
+<ul>
+<li>Create an alarm group</li>
+</ul>
+ <p align="center">
+    <img src="/img/alarm-group-en.png" width="60%" />
+  </p>
+<ul>
+<li>Create an worker group</li>
+</ul>
+   <p align="center">
+      <img src="/img/worker-group-en.png" width="60%" />
+    </p>
+<ul>
+<li>
+<p>Create an token</p>
+<p align="center">
+   <img src="/img/token-en.png" width="60%" />
+ </p>
+</li>
+<li>
+<p>Log in with regular users</p>
+</li>
+</ul>
+<blockquote>
+<p>Click on the user name in the upper right corner to &quot;exit&quot; and re-use the normal user login.</p>
+</blockquote>
+<ul>
+<li>Project Management - &gt; Create Project - &gt; Click on Project Name</li>
+</ul>
+<p align="center">
+      <img src="/img/create_project_en.png" width="60%" />
+ </p>
+<ul>
+<li>Click Workflow Definition - &gt; Create Workflow Definition - &gt; Online Process Definition</li>
+</ul>
+<p align="center">
+   <img src="/img/process_definition_en.png" width="60%" />
+ </p>
+<ul>
+<li>Running Process Definition - &gt; Click Workflow Instance - &gt; Click Process Instance Name - &gt; Double-click Task Node - &gt; View Task Execution Log</li>
+</ul>
+ <p align="center">
+   <img src="/img/log_en.png" width="60%" />
+</p>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>Documentation</dt><dd><a href="/en-us/docs/development/architecture-design.html" target="_self">Overview</a></dd><dd><a href="/en-us/docs/1.2.0/user_doc/quick-start.html" target="_self">Quick start</a></dd><dd><a href="/en-us/docs/development/backend-development.html" target="_self">Developer guide</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http:/ [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/en-us/docs/1.3.2/user_doc/quick-start.json b/en-us/docs/1.3.2/user_doc/quick-start.json
new file mode 100644
index 0000000..ce5463e
--- /dev/null
+++ b/en-us/docs/1.3.2/user_doc/quick-start.json
@@ -0,0 +1,6 @@
+{
+  "filename": "quick-start.md",
+  "__html": "<h1>Quick Start</h1>\n<ul>\n<li>\n<p>Administrator user login</p>\n<blockquote>\n<p>Address:192.168.xx.xx:8888  Username and password:admin/dolphinscheduler123</p>\n</blockquote>\n</li>\n</ul>\n<p align=\"center\">\n   <img src=\"/img/login_en.png\" width=\"60%\" />\n </p>\n<ul>\n<li>Create queue</li>\n</ul>\n<p align=\"center\">\n   <img src=\"/img/create-queue-en.png\" width=\"60%\" />\n </p>\n<ul>\n<li>Create tenant  <p align=\"center\">\n<img src=\"/img/create-tenant-en. [...]
+  "link": "/en-us/docs/1.3.2/user_doc/quick-start.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/en-us/docs/1.3.2/user_doc/standalone-deployment.html b/en-us/docs/1.3.2/user_doc/standalone-deployment.html
new file mode 100644
index 0000000..e6fb6ed
--- /dev/null
+++ b/en-us/docs/1.3.2/user_doc/standalone-deployment.html
@@ -0,0 +1,393 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="standalone-deployment" />
+	<meta name="description" content="standalone-deployment" />
+	<!-- 网页标签标题 -->
+	<title>standalone-deployment</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/en-us/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">中</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass ant [...]
+<h1>1、Before you begin (please install requirement basic software by yourself)</h1>
+<ul>
+<li>PostgreSQL (8.2.15+) or MySQL (5.7)  :  Choose One</li>
+<li><a href="https://www.oracle.com/technetwork/java/javase/downloads/index.html">JDK</a> (1.8+) :  Required. Double-check configure JAVA_HOME and PATH environment variables in /etc/profile</li>
+<li>ZooKeeper (3.4.6+) :Required</li>
+<li>Hadoop (2.6+) or MinIO :Optional. If you need to upload a resource function, you can choose a local file directory as the upload folder for a single machine (this operation does not need to deploy Hadoop). Of course, you can also choose to upload to Hadoop or MinIO.</li>
+</ul>
+<pre><code class="language-markdown"> Tips:DolphinScheduler itself does not rely on Hadoop, Hive, Spark, only use their clients for the corresponding task of running.
+</code></pre>
+<h1>2、Download the binary package.</h1>
+<ul>
+<li>Please download the latest version of the default installation package to the server deployment directory. For example, use /opt/dolphinscheduler as the installation and deployment directory. Download address: <a href="https://dolphinscheduler.apache.org/en-us/docs/release/download.html">Download</a>,Download the package and move to the installation and deployment directory. Then unzip it.</li>
+</ul>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> Create the deployment directory. Do not choose a deployment directory with a high-privilege directory such as / root or / home.</span>
+mkdir -p /opt/dolphinscheduler;
+cd /opt/dolphinscheduler;
+<span class="hljs-meta">#</span><span class="bash"> unzip</span>
+tar -zxvf apache-dolphinscheduler-incubating-1.3.1-dolphinscheduler-bin.tar.gz -C /opt/dolphinscheduler;
+
+mv apache-dolphinscheduler-incubating-1.3.1-dolphinscheduler-bin  dolphinscheduler-bin
+</code></pre>
+<h1>3、Create deployment user and hosts mapping</h1>
+<ul>
+<li>Create a deployment user on the ** all ** deployment machines, and be sure to configure sudo passwordless. If we plan to deploy DolphinScheduler on 4 machines: ds1, ds2, ds3, and ds4, we first need to create a deployment user on each machine.</li>
+</ul>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> To create a user, you need to <span class="hljs-built_in">log</span> <span class="hljs-keyword">in</span> as root and <span class="hljs-built_in">set</span> the deployment user name. Please modify it yourself. The following uses dolphinscheduler as an example.</span>
+useradd dolphinscheduler;
+<span class="hljs-meta">
+#</span><span class="bash"> Set the user password, please modify it yourself. The following takes dolphinscheduler123 as an example.</span>
+echo "dolphinscheduler123" | passwd --stdin dolphinscheduler
+<span class="hljs-meta">
+#</span><span class="bash"> Configure sudo passwordless</span>
+echo 'dolphinscheduler  ALL=(ALL)  NOPASSWD: NOPASSWD: ALL' &gt;&gt; /etc/sudoers
+sed -i 's/Defaults    requirett/#Defaults    requirett/g' /etc/sudoers
+
+</code></pre>
+<pre><code> Notes:
+ - Because the task execution service is based on 'sudo -u {linux-user}' to switch between different Linux users to implement multi-tenant running jobs, the deployment user needs to have sudo permissions and is passwordless. The first-time learners who can ignore it if they don't understand.
+ - If find the &quot;Default requiretty&quot; in the &quot;/etc/sudoers&quot; file, also comment out.
+ - If you need to use resource upload, you need to assign the user of permission to operate the local file system, HDFS or MinIO.
+</code></pre>
+<h1>4、Configure hosts mapping and ssh access and modify directory permissions.</h1>
+<ul>
+<li>
+<p>Use the first machine (hostname is ds1) as the deployment machine, configure the hosts of all machines to be deployed on ds1, and login as root on ds1.</p>
+<pre><code class="language-shell">vi /etc/hosts
+<span class="hljs-meta">
+#</span><span class="bash">add ip hostname</span>
+192.168.xxx.xxx ds1
+192.168.xxx.xxx ds2
+192.168.xxx.xxx ds3
+192.168.xxx.xxx ds4
+</code></pre>
+<p><em>Note: Please delete or comment out the line 127.0.0.1</em></p>
+</li>
+<li>
+<p>Sync /etc/hosts on ds1 to all deployment machines</p>
+<pre><code class="language-shell">for ip in ds2 ds3;     # Please replace ds2 ds3 here with the hostname of machines you want to deploy
+do
+    sudo scp -r /etc/hosts  $ip:/etc/          # Need to enter root password during operation
+done
+</code></pre>
+<p><em>Note: can use <code>sshpass -p xxx sudo scp -r /etc/hosts $ip:/etc/</code> to avoid type password.</em></p>
+<blockquote>
+<p>Install sshpass in Centos:</p>
+<ol>
+<li>
+<p>Install epel</p>
+<p>yum install -y epel-release</p>
+<p>yum repolist</p>
+</li>
+<li>
+<p>After installing epel, you can install sshpass</p>
+<p>yum install -y sshpass</p>
+</li>
+</ol>
+</blockquote>
+</li>
+<li>
+<p>On ds1, switch to the deployment user and configure ssh passwordless login</p>
+<pre><code class="language-shell"> su dolphinscheduler;
+
+ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa
+cat ~/.ssh/id_rsa.pub &gt;&gt; ~/.ssh/authorized_keys
+chmod 600 ~/.ssh/authorized_keys
+</code></pre>
+</li>
+</ul>
+<p>​      Note: <em>If configure success, the dolphinscheduler user does not need to enter a password when executing the command <code>ssh localhost</code></em></p>
+<ul>
+<li>
+<p>On ds1, configure the deployment user dolphinscheduler ssh to connect to other machines to be deployed.</p>
+<pre><code class="language-shell">su dolphinscheduler;
+for ip in ds2 ds3;     # Please replace ds2 ds3 here with the hostname of the machine you want to deploy.
+do
+    ssh-copy-id  $ip   # You need to manually enter the password of the dolphinscheduler user during the operation.
+done
+<span class="hljs-meta">#</span><span class="bash"> can use `sshpass -p xxx ssh-copy-id <span class="hljs-variable">$ip</span>` to avoid <span class="hljs-built_in">type</span> password.</span>
+</code></pre>
+</li>
+<li>
+<p>On ds1, modify the directory permissions so that the deployment user has operation permissions on the dolphinscheduler-bin directory.</p>
+<pre><code class="language-shell">sudo chown -R dolphinscheduler:dolphinscheduler dolphinscheduler-bin
+</code></pre>
+</li>
+</ul>
+<h1>5、Database initialization</h1>
+<ul>
+<li>Into the database. The default database is PostgreSQL. If you select MySQL, you need to add the mysql-connector-java driver package to the lib directory of DolphinScheduler.</li>
+</ul>
+<pre><code>mysql -uroot -p
+</code></pre>
+<ul>
+<li>After entering the database command line window, execute the database initialization command and set the user and password. <strong>Note: {user} and {password} need to be replaced with a specific database username and password</strong></li>
+</ul>
+<pre><code class="language-mysql">   mysql&gt; CREATE DATABASE dolphinscheduler DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_general_ci;
+   mysql&gt; GRANT ALL PRIVILEGES ON dolphinscheduler.* TO '{user}'@'%' IDENTIFIED BY '{password}';
+   mysql&gt; GRANT ALL PRIVILEGES ON dolphinscheduler.* TO '{user}'@'localhost' IDENTIFIED BY '{password}';
+   mysql&gt; flush privileges;
+</code></pre>
+<ul>
+<li>
+<p>Create tables and import basic data</p>
+<ul>
+<li>Modify the following configuration in datasource.properties under the conf directory</li>
+</ul>
+<pre><code class="language-shell">  vi conf/datasource.properties
+</code></pre>
+<ul>
+<li>If you choose Mysql, please comment out the relevant configuration of PostgreSQL (vice versa), you also need to manually add the [[mysql-connector-java driver jar] (<a href="https://downloads.mysql.com/archives/c-j/">https://downloads.mysql.com/archives/c-j/</a>)] package to lib under the directory, and then configure the database connection information correctly.</li>
+</ul>
+<pre><code class="language-properties"><span class="hljs-comment">  #postgre</span>
+<span class="hljs-comment">  #spring.datasource.driver-class-name=org.postgresql.Driver</span>
+<span class="hljs-comment">  #spring.datasource.url=jdbc:postgresql://localhost:5432/dolphinscheduler</span>
+<span class="hljs-comment">  # mysql</span>
+  <span class="hljs-meta">spring.datasource.driver-class-name</span>=<span class="hljs-string">com.mysql.jdbc.Driver</span>
+  <span class="hljs-meta">spring.datasource.url</span>=<span class="hljs-string">jdbc:mysql://xxx:3306/dolphinscheduler?useUnicode=true&amp;characterEncoding=UTF-8&amp;allowMultiQueries=true     # Replace the correct IP address</span>
+  <span class="hljs-meta">spring.datasource.username</span>=<span class="hljs-string">xxx						# replace the correct {user} value</span>
+  <span class="hljs-meta">spring.datasource.password</span>=<span class="hljs-string">xxx						# replace the correct {password} value</span>
+</code></pre>
+<ul>
+<li>After modifying and saving, execute the create table and import data script in the script directory.</li>
+</ul>
+<pre><code class="language-shell">sh script/create-dolphinscheduler.sh
+</code></pre>
+</li>
+</ul>
+<p>​       <em>Note: If you execute the above script and report &quot;/bin/java: No such file or directory&quot; error, please configure JAVA_HOME and PATH variables in /etc/profile</em></p>
+<h1>6、Modify runtime parameters.</h1>
+<ul>
+<li>
+<p>Modify the environment variable in <code>dolphinscheduler_env.sh</code> file which on the 'conf/env' directory (take the relevant software installed under '/opt/soft' as an example)</p>
+<pre><code class="language-shell">    export HADOOP_HOME=/opt/soft/hadoop
+    export HADOOP_CONF_DIR=/opt/soft/hadoop/etc/hadoop
+    #export SPARK_HOME1=/opt/soft/spark1
+    export SPARK_HOME2=/opt/soft/spark2
+    export PYTHON_HOME=/opt/soft/python
+    export JAVA_HOME=/opt/soft/java
+    export HIVE_HOME=/opt/soft/hive
+    export FLINK_HOME=/opt/soft/flink
+    export DATAX_HOME=/opt/soft/datax/bin/datax.py
+    export PATH=$HADOOP_HOME/bin:$SPARK_HOME2/bin:$PYTHON_HOME:$JAVA_HOME/bin:$HIVE_HOME/bin:$PATH:$FLINK_HOME/bin:$DATAX_HOME:$PATH
+
+    ```
+
+ `Note: This step is very important. For example, JAVA_HOME and PATH must be configured. Those that are not used can be ignored or commented out.`
+
+
+
+</code></pre>
+</li>
+<li>
+<p>Create Soft link jdk to /usr/bin/java (still JAVA_HOME=/opt/soft/java as an example)</p>
+<pre><code class="language-shell">sudo ln -s /opt/soft/java/bin/java /usr/bin/java
+</code></pre>
+</li>
+<li>
+<p>Modify the parameters in the one-click deployment config file <code>conf/config/install_config.conf</code>, pay special attention to the configuration of the following parameters.</p>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> choose mysql or postgresql</span>
+dbtype="mysql"
+<span class="hljs-meta">
+#</span><span class="bash"> Database connection address and port</span>
+dbhost="localhost:3306"
+<span class="hljs-meta">
+#</span><span class="bash"> database name</span>
+dbname="dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> database username</span>
+username="xxx"
+<span class="hljs-meta">
+#</span><span class="bash"> database password</span>
+<span class="hljs-meta">#</span><span class="bash"> NOTICE: <span class="hljs-keyword">if</span> there are special characters, please use the \ to escape, <span class="hljs-keyword">for</span> example, `[` escape to `\[`</span>
+password="xxx"
+<span class="hljs-meta">
+#</span><span class="bash"> Zookeeper address, localhost:2181, remember the port 2181</span>
+zkQuorum="localhost:2181"
+<span class="hljs-meta">
+#</span><span class="bash"> Note: the target installation path <span class="hljs-keyword">for</span> dolphinscheduler, please not config as the same as the current path (<span class="hljs-built_in">pwd</span>)</span>
+installPath="/opt/soft/dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> deployment user</span>
+<span class="hljs-meta">#</span><span class="bash"> Note: the deployment user needs to have sudo privileges and permissions to operate hdfs. If hdfs is enabled, the root directory needs to be created by itself</span>
+deployUser="dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> alert config,take QQ email <span class="hljs-keyword">for</span> example</span>
+<span class="hljs-meta">#</span><span class="bash"> mail protocol</span>
+mailProtocol="SMTP"
+<span class="hljs-meta">
+#</span><span class="bash"> mail server host</span>
+mailServerHost="smtp.qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> mail server port</span>
+<span class="hljs-meta">#</span><span class="bash"> note: Different protocols and encryption methods correspond to different ports, when SSL/TLS is enabled, make sure the port is correct.</span>
+mailServerPort="25"
+<span class="hljs-meta">
+#</span><span class="bash"> mail sender</span>
+mailSender="xxx@qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> mail user</span>
+mailUser="xxx@qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> mail sender password</span>
+<span class="hljs-meta">#</span><span class="bash"> note: The mail.passwd is email service authorization code, not the email login password.</span>
+mailPassword="xxx"
+<span class="hljs-meta">
+#</span><span class="bash"> Whether TLS mail protocol is supported,<span class="hljs-literal">true</span> is supported and <span class="hljs-literal">false</span> is not supported</span>
+starttlsEnable="true"
+<span class="hljs-meta">
+#</span><span class="bash"> Whether TLS mail protocol is supported,<span class="hljs-literal">true</span> is supported and <span class="hljs-literal">false</span> is not supported。</span>
+<span class="hljs-meta">#</span><span class="bash"> note: only one of TLS and SSL can be <span class="hljs-keyword">in</span> the <span class="hljs-literal">true</span> state.</span>
+sslEnable="false"
+<span class="hljs-meta">
+#</span><span class="bash"> note: sslTrust is the same as mailServerHost</span>
+sslTrust="smtp.qq.com"
+<span class="hljs-meta">
+
+#</span><span class="bash"> resource storage <span class="hljs-built_in">type</span>:HDFS,S3,NONE</span>
+resourceStorageType="HDFS"
+<span class="hljs-meta">
+#</span><span class="bash"> here is an example of saving to a <span class="hljs-built_in">local</span> file system</span>
+<span class="hljs-meta">#</span><span class="bash"> Note: If you want to upload to HDFS and the NameNode has HA enabled, you need to put core-site.xml and hdfs-site.xml <span class="hljs-keyword">in</span> the conf directory. In this example, it is placed under /opt/dolphinscheduler/conf, and Configure the namenode cluster name; <span class="hljs-keyword">if</span> the NameNode is not HA, modify it to a specific IP or host name.</span>
+defaultFS="file:///data/dolphinscheduler"
+<span class="hljs-meta">
+
+#</span><span class="bash"> <span class="hljs-keyword">if</span> not use hadoop resourcemanager, please keep default value; <span class="hljs-keyword">if</span> resourcemanager HA <span class="hljs-built_in">enable</span>, please <span class="hljs-built_in">type</span> the HA ips ; <span class="hljs-keyword">if</span> resourcemanager is single, make this value empty</span>
+yarnHaIps="192.168.xx.xx,192.168.xx.xx"
+<span class="hljs-meta">
+#</span><span class="bash"> <span class="hljs-keyword">if</span> resourcemanager HA <span class="hljs-built_in">enable</span> or not use resourcemanager, please skip this value setting; If resourcemanager is single, you only need to replace yarnIp1 to actual resourcemanager hostname.</span>
+singleYarnIp="yarnIp1"
+<span class="hljs-meta">
+#</span><span class="bash"> resource store on HDFS/S3 path, resource file will store to this hadoop hdfs path, self configuration, please make sure the directory exists on hdfs and have <span class="hljs-built_in">read</span> write permissions。/dolphinscheduler is recommended</span>
+resourceUploadPath="/data/dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> specify the user who have permissions to create directory under HDFS/S3 root path</span>
+hdfsRootUser="hdfs"
+<span class="hljs-meta">
+
+
+#</span><span class="bash"> On <span class="hljs-built_in">which</span> machines to deploy the DS service, choose localhost <span class="hljs-keyword">for</span> this machine</span>
+ips="localhost"
+<span class="hljs-meta">
+#</span><span class="bash"> ssh port, default 22</span>
+<span class="hljs-meta">#</span><span class="bash"> Note: <span class="hljs-keyword">if</span> ssh port is not default, modify here</span>
+sshPort="22"
+<span class="hljs-meta">
+#</span><span class="bash"> run master machine</span>
+masters="localhost"
+<span class="hljs-meta">
+#</span><span class="bash"> run worker machine</span>
+workers="localhost"
+<span class="hljs-meta">
+#</span><span class="bash"> run alert machine</span>
+alertServer="localhost"
+<span class="hljs-meta">
+#</span><span class="bash"> run api machine</span>
+apiServers="localhost"
+
+</code></pre>
+<p><em>Attention:</em></p>
+<ul>
+<li>If you need to upload resources to the Hadoop cluster, and the NameNode of the Hadoop cluster is configured with HA, you need to enable HDFS resource upload, and you need to copy the core-site.xml and hdfs-site.xml in the Hadoop cluster to /opt/ dolphinscheduler/conf. Non-NameNode HA skips the next step.</li>
+</ul>
+</li>
+</ul>
+<h1>7、Automated Deployment</h1>
+<ul>
+<li>
+<p>Switch to the deployment user and execute the one-click deployment script</p>
+<p><code>sh install.sh</code></p>
+<pre><code>Note:
+For the first deployment, the following message appears in step 3 of `3, stop server` during operation. This message can be ignored.
+sh: bin/dolphinscheduler-daemon.sh: No such file or directory
+</code></pre>
+</li>
+<li>
+<p>After the script is completed, the following 5 services will be started. Use the <code>jps</code> command to check whether the services are started (<code>jps</code> comes with <code>java JDK</code>)</p>
+</li>
+</ul>
+<pre><code class="language-aidl">    MasterServer         ----- master service
+    WorkerServer         ----- worker service
+    LoggerServer         ----- logger service
+    ApiApplicationServer ----- api service
+    AlertServer          ----- alert service
+</code></pre>
+<p>If the above services are started normally, the automatic deployment is successful.</p>
+<p>After the deployment is successful, you can view the logs. The logs are stored in the logs folder.</p>
+<pre><code class="language-log"> logs/
+    ├── dolphinscheduler-alert-server.log
+    ├── dolphinscheduler-master-server.log
+    |—— dolphinscheduler-worker-server.log
+    |—— dolphinscheduler-api-server.log
+    |—— dolphinscheduler-logger-server.log
+</code></pre>
+<h1>8、login</h1>
+<ul>
+<li>
+<p>Access the address of the front page, interface IP (self-modified)
+<a href="http://192.168.xx.xx:12345/dolphinscheduler">http://192.168.xx.xx:12345/dolphinscheduler</a></p>
+ <p align="center">
+   <img src="/img/login.png" width="60%" />
+ </p>
+</li>
+</ul>
+<h1>9、Start and stop service</h1>
+<ul>
+<li>
+<p>Stop all services</p>
+<p><code>sh ./bin/stop-all.sh</code></p>
+</li>
+<li>
+<p>Start all services</p>
+<p><code>sh ./bin/start-all.sh</code></p>
+</li>
+<li>
+<p>Start and stop master service</p>
+</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start master-server
+sh ./bin/dolphinscheduler-daemon.sh stop master-server
+</code></pre>
+<ul>
+<li>Start and stop worker Service</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start worker-server
+sh ./bin/dolphinscheduler-daemon.sh stop worker-server
+</code></pre>
+<ul>
+<li>Start and stop api Service</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start api-server
+sh ./bin/dolphinscheduler-daemon.sh stop api-server
+</code></pre>
+<ul>
+<li>Start and stop logger Service</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start logger-server
+sh ./bin/dolphinscheduler-daemon.sh stop logger-server
+</code></pre>
+<ul>
+<li>Start and stop alert service</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start alert-server
+sh ./bin/dolphinscheduler-daemon.sh stop alert-server
+</code></pre>
+<p><code>Note: Please refer to the &quot;Architecture Design&quot; section for service usage</code></p>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>Documentation</dt><dd><a href="/en-us/docs/development/architecture-design.html" target="_self">Overview</a></dd><dd><a href="/en-us/docs/1.2.0/user_doc/quick-start.html" target="_self">Quick start</a></dd><dd><a href="/en-us/docs/development/backend-development.html" target="_self">Developer guide</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http:/ [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/en-us/docs/1.3.2/user_doc/standalone-deployment.json b/en-us/docs/1.3.2/user_doc/standalone-deployment.json
new file mode 100644
index 0000000..77fff4a
--- /dev/null
+++ b/en-us/docs/1.3.2/user_doc/standalone-deployment.json
@@ -0,0 +1,6 @@
+{
+  "filename": "standalone-deployment.md",
+  "__html": "<h1>Standalone Deployment</h1>\n<h1>1、Before you begin (please install requirement basic software by yourself)</h1>\n<ul>\n<li>PostgreSQL (8.2.15+) or MySQL (5.7)  :  Choose One</li>\n<li><a href=\"https://www.oracle.com/technetwork/java/javase/downloads/index.html\">JDK</a> (1.8+) :  Required. Double-check configure JAVA_HOME and PATH environment variables in /etc/profile</li>\n<li>ZooKeeper (3.4.6+) :Required</li>\n<li>Hadoop (2.6+) or MinIO :Optional. If you need to uploa [...]
+  "link": "/en-us/docs/1.3.2/user_doc/standalone-deployment.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/architecture-design.html b/zh-cn/docs/1.3.2/user_doc/architecture-design.html
new file mode 100644
index 0000000..53af66e
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/architecture-design.html
@@ -0,0 +1,353 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="architecture-design" />
+	<meta name="description" content="architecture-design" />
+	<!-- 网页标签标题 -->
+	<title>architecture-design</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/zh-cn/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">En</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass an [...]
+<p>在对调度系统架构说明之前,我们先来认识一下调度系统常用的名词</p>
+<h3>1.名词解释</h3>
+<p><strong>DAG:</strong> 全称Directed Acyclic Graph,简称DAG。工作流中的Task任务以有向无环图的形式组装起来,从入度为零的节点进行拓扑遍历,直到无后继节点为止。举例如下图:</p>
+<p align="center">
+  <img src="/img/dag_examples_cn.jpg" alt="dag示例"  width="60%" />
+  <p align="center">
+        <em>dag示例</em>
+  </p>
+</p>
+<p><strong>流程定义</strong>:通过拖拽任务节点并建立任务节点的关联所形成的可视化<strong>DAG</strong></p>
+<p><strong>流程实例</strong>:流程实例是流程定义的实例化,可以通过手动启动或定时调度生成,流程定义每运行一次,产生一个流程实例</p>
+<p><strong>任务实例</strong>:任务实例是流程定义中任务节点的实例化,标识着具体的任务执行状态</p>
+<p><strong>任务类型</strong>: 目前支持有SHELL、SQL、SUB_PROCESS(子流程)、PROCEDURE、MR、SPARK、PYTHON、DEPENDENT(依赖)、,同时计划支持动态插件扩展,注意:其中子 <strong>SUB_PROCESS</strong>  也是一个单独的流程定义,是可以单独启动执行的</p>
+<p><strong>调度方式:</strong> 系统支持基于cron表达式的定时调度和手动调度。命令类型支持:启动工作流、从当前节点开始执行、恢复被容错的工作流、恢复暂停流程、从失败节点开始执行、补数、定时、重跑、暂停、停止、恢复等待线程。其中 <strong>恢复被容错的工作流</strong> 和 <strong>恢复等待线程</strong> 两种命令类型是由调度内部控制使用,外部无法调用</p>
+<p><strong>定时调度</strong>:系统采用 <strong>quartz</strong> 分布式调度器,并同时支持cron表达式可视化的生成</p>
+<p><strong>依赖</strong>:系统不单单支持 <strong>DAG</strong> 简单的前驱和后继节点之间的依赖,同时还提供<strong>任务依赖</strong>节点,支持<strong>流程间的自定义任务依赖</strong></p>
+<p><strong>优先级</strong> :支持流程实例和任务实例的优先级,如果流程实例和任务实例的优先级不设置,则默认是先进先出</p>
+<p><strong>邮件告警</strong>:支持 <strong>SQL任务</strong> 查询结果邮件发送,流程实例运行结果邮件告警及容错告警通知</p>
+<p><strong>失败策略</strong>:对于并行运行的任务,如果有任务失败,提供两种失败策略处理方式,<strong>继续</strong>是指不管并行运行任务的状态,直到流程失败结束。<strong>结束</strong>是指一旦发现失败任务,则同时Kill掉正在运行的并行任务,流程失败结束</p>
+<p><strong>补数</strong>:补历史数据,支持<strong>区间并行和串行</strong>两种补数方式</p>
+<h3>2.系统架构</h3>
+<h4>2.1 系统架构图</h4>
+<p align="center">
+  <img src="/img/architecture-1.3.0.jpg" alt="系统架构图"  width="70%" />
+  <p align="center">
+        <em>系统架构图</em>
+  </p>
+</p>
+<h4>2.2 启动流程活动图</h4>
+<p align="center">
+  <img src="/img/process-start-flow-1.3.0.png" alt="启动流程活动图"  width="70%" />
+  <p align="center">
+        <em>启动流程活动图</em>
+  </p>
+</p>
+<h4>2.3 架构说明</h4>
+<ul>
+<li>
+<p><strong>MasterServer</strong></p>
+<p>MasterServer采用分布式无中心设计理念,MasterServer主要负责 DAG 任务切分、任务提交监控,并同时监听其它MasterServer和WorkerServer的健康状态。
+MasterServer服务启动时向Zookeeper注册临时节点,通过监听Zookeeper临时节点变化来进行容错处理。
+MasterServer基于netty提供监听服务。</p>
+<h5>该服务内主要包含:</h5>
+<ul>
+<li>
+<p><strong>Distributed Quartz</strong>分布式调度组件,主要负责定时任务的启停操作,当quartz调起任务后,Master内部会有线程池具体负责处理任务的后续操作</p>
+</li>
+<li>
+<p><strong>MasterSchedulerThread</strong>是一个扫描线程,定时扫描数据库中的 <strong>command</strong> 表,根据不同的<strong>命令类型</strong>进行不同的业务操作</p>
+</li>
+<li>
+<p><strong>MasterExecThread</strong>主要是负责DAG任务切分、任务提交监控、各种不同命令类型的逻辑处理</p>
+</li>
+<li>
+<p><strong>MasterTaskExecThread</strong>主要负责任务的持久化</p>
+</li>
+</ul>
+</li>
+<li>
+<p><strong>WorkerServer</strong></p>
+<p>WorkerServer也采用分布式无中心设计理念,WorkerServer主要负责任务的执行和提供日志服务。
+WorkerServer服务启动时向Zookeeper注册临时节点,并维持心跳。
+Server基于netty提供监听服务。Worker</p>
+<h5>该服务包含:</h5>
+<ul>
+<li>
+<p><strong>FetchTaskThread</strong>主要负责不断从<strong>Task Queue</strong>中领取任务,并根据不同任务类型调用<strong>TaskScheduleThread</strong>对应执行器。</p>
+</li>
+<li>
+<p><strong>LoggerServer</strong>是一个RPC服务,提供日志分片查看、刷新和下载等功能</p>
+</li>
+</ul>
+</li>
+<li>
+<p><strong>ZooKeeper</strong></p>
+<p>ZooKeeper服务,系统中的MasterServer和WorkerServer节点都通过ZooKeeper来进行集群管理和容错。另外系统还基于ZooKeeper进行事件监听和分布式锁。
+我们也曾经基于Redis实现过队列,不过我们希望DolphinScheduler依赖到的组件尽量地少,所以最后还是去掉了Redis实现。</p>
+</li>
+<li>
+<p><strong>Task Queue</strong></p>
+<p>提供任务队列的操作,目前队列也是基于Zookeeper来实现。由于队列中存的信息较少,不必担心队列里数据过多的情况,实际上我们压测过百万级数据存队列,对系统稳定性和性能没影响。</p>
+</li>
+<li>
+<p><strong>Alert</strong></p>
+<p>提供告警相关接口,接口主要包括<strong>告警</strong>两种类型的告警数据的存储、查询和通知功能。其中通知功能又有<strong>邮件通知</strong>和**SNMP(暂未实现)**两种。</p>
+</li>
+<li>
+<p><strong>API</strong></p>
+<p>API接口层,主要负责处理前端UI层的请求。该服务统一提供RESTful api向外部提供请求服务。
+接口包括工作流的创建、定义、查询、修改、发布、下线、手工启动、停止、暂停、恢复、从该节点开始执行等等。</p>
+</li>
+<li>
+<p><strong>UI</strong></p>
+<p>系统的前端页面,提供系统的各种可视化操作界面,详见<a href="/zh-cn/docs/user_doc/system-manual.html" target="_self">系统使用手册</a>部分。</p>
+</li>
+</ul>
+<h4>2.3 架构设计思想</h4>
+<h5>一、去中心化vs中心化</h5>
+<h6>中心化思想</h6>
+<p>中心化的设计理念比较简单,分布式集群中的节点按照角色分工,大体上分为两种角色:</p>
+<p align="center">
+   <img src="https://analysys.github.io/easyscheduler_docs_cn/images/master_slave.png" alt="master-slave角色"  width="50%" />
+ </p>
+<ul>
+<li>Master的角色主要负责任务分发并监督Slave的健康状态,可以动态的将任务均衡到Slave上,以致Slave节点不至于“忙死”或”闲死”的状态。</li>
+<li>Worker的角色主要负责任务的执行工作并维护和Master的心跳,以便Master可以分配任务给Slave。</li>
+</ul>
+<p>中心化思想设计存在的问题:</p>
+<ul>
+<li>一旦Master出现了问题,则群龙无首,整个集群就会崩溃。为了解决这个问题,大多数Master/Slave架构模式都采用了主备Master的设计方案,可以是热备或者冷备,也可以是自动切换或手动切换,而且越来越多的新系统都开始具备自动选举切换Master的能力,以提升系统的可用性。</li>
+<li>另外一个问题是如果Scheduler在Master上,虽然可以支持一个DAG中不同的任务运行在不同的机器上,但是会产生Master的过负载。如果Scheduler在Slave上,则一个DAG中所有的任务都只能在某一台机器上进行作业提交,则并行任务比较多的时候,Slave的压力可能会比较大。</li>
+</ul>
+<h6>去中心化</h6>
+ <p align="center"
+   <img src="https://analysys.github.io/easyscheduler_docs_cn/images/decentralization.png" alt="去中心化"  width="50%" />
+ </p>
+<ul>
+<li>
+<p>在去中心化设计里,通常没有Master/Slave的概念,所有的角色都是一样的,地位是平等的,全球互联网就是一个典型的去中心化的分布式系统,联网的任意节点设备down机,都只会影响很小范围的功能。</p>
+</li>
+<li>
+<p>去中心化设计的核心设计在于整个分布式系统中不存在一个区别于其他节点的”管理者”,因此不存在单点故障问题。但由于不存在” 管理者”节点所以每个节点都需要跟其他节点通信才得到必须要的机器信息,而分布式系统通信的不可靠性,则大大增加了上述功能的实现难度。</p>
+</li>
+<li>
+<p>实际上,真正去中心化的分布式系统并不多见。反而动态中心化分布式系统正在不断涌出。在这种架构下,集群中的管理者是被动态选择出来的,而不是预置的,并且集群在发生故障的时候,集群的节点会自发的举行&quot;会议&quot;来选举新的&quot;管理者&quot;去主持工作。最典型的案例就是ZooKeeper及Go语言实现的Etcd。</p>
+</li>
+<li>
+<p>DolphinScheduler的去中心化是Master/Worker注册到Zookeeper中,实现Master集群和Worker集群无中心,并使用Zookeeper分布式锁来选举其中的一台Master或Worker为“管理者”来执行任务。</p>
+</li>
+</ul>
+<h5>二、分布式锁实践</h5>
+<p>DolphinScheduler使用ZooKeeper分布式锁来实现同一时刻只有一台Master执行Scheduler,或者只有一台Worker执行任务的提交。</p>
+<ol>
+<li>获取分布式锁的核心流程算法如下</li>
+</ol>
+ <p align="center">
+   <img src="https://analysys.github.io/easyscheduler_docs_cn/images/distributed_lock.png" alt="获取分布式锁流程"  width="50%" />
+ </p>
+<ol start="2">
+<li>DolphinScheduler中Scheduler线程分布式锁实现流程图:</li>
+</ol>
+ <p align="center">
+   <img src="/img/distributed_lock_procss.png" alt="获取分布式锁流程"  width="50%" />
+ </p>
+<h5>三、线程不足循环等待问题</h5>
+<ul>
+<li>如果一个DAG中没有子流程,则如果Command中的数据条数大于线程池设置的阈值,则直接流程等待或失败。</li>
+<li>如果一个大的DAG中嵌套了很多子流程,如下图则会产生“死等”状态:</li>
+</ul>
+ <p align="center">
+   <img src="https://analysys.github.io/easyscheduler_docs_cn/images/lack_thread.png" alt="线程不足循环等待问题"  width="50%" />
+ </p>
+上图中MainFlowThread等待SubFlowThread1结束,SubFlowThread1等待SubFlowThread2结束, SubFlowThread2等待SubFlowThread3结束,而SubFlowThread3等待线程池有新线程,则整个DAG流程不能结束,从而其中的线程也不能释放。这样就形成的子父流程循环等待的状态。此时除非启动新的Master来增加线程来打破这样的”僵局”,否则调度集群将不能再使用。
+<p>对于启动新Master来打破僵局,似乎有点差强人意,于是我们提出了以下三种方案来降低这种风险:</p>
+<ol>
+<li>计算所有Master的线程总和,然后对每一个DAG需要计算其需要的线程数,也就是在DAG流程执行之前做预计算。因为是多Master线程池,所以总线程数不太可能实时获取。</li>
+<li>对单Master线程池进行判断,如果线程池已经满了,则让线程直接失败。</li>
+<li>增加一种资源不足的Command类型,如果线程池不足,则将主流程挂起。这样线程池就有了新的线程,可以让资源不足挂起的流程重新唤醒执行。</li>
+</ol>
+<p>注意:Master Scheduler线程在获取Command的时候是FIFO的方式执行的。</p>
+<p>于是我们选择了第三种方式来解决线程不足的问题。</p>
+<h5>四、容错设计</h5>
+<p>容错分为服务宕机容错和任务重试,服务宕机容错又分为Master容错和Worker容错两种情况</p>
+<h6>1. 宕机容错</h6>
+<p>服务容错设计依赖于ZooKeeper的Watcher机制,实现原理如图:</p>
+ <p align="center">
+   <img src="https://analysys.github.io/easyscheduler_docs_cn/images/fault-tolerant.png" alt="DolphinScheduler容错设计"  width="40%" />
+ </p>
+其中Master监控其他Master和Worker的目录,如果监听到remove事件,则会根据具体的业务逻辑进行流程实例容错或者任务实例容错。
+<ul>
+<li>Master容错流程图:</li>
+</ul>
+ <p align="center">
+   <img src="https://analysys.github.io/easyscheduler_docs_cn/images/fault-tolerant_master.png" alt="Master容错流程图"  width="40%" />
+ </p>
+ZooKeeper Master容错完成之后则重新由DolphinScheduler中Scheduler线程调度,遍历 DAG 找到”正在运行”和“提交成功”的任务,对”正在运行”的任务监控其任务实例的状态,对”提交成功”的任务需要判断Task Queue中是否已经存在,如果存在则同样监控任务实例的状态,如果不存在则重新提交任务实例。
+<ul>
+<li>Worker容错流程图:</li>
+</ul>
+ <p align="center">
+   <img src="https://analysys.github.io/easyscheduler_docs_cn/images/fault-tolerant_worker.png" alt="Worker容错流程图"  width="40%" />
+ </p>
+<p>Master Scheduler线程一旦发现任务实例为” 需要容错”状态,则接管任务并进行重新提交。</p>
+<p>注意:由于” 网络抖动”可能会使得节点短时间内失去和ZooKeeper的心跳,从而发生节点的remove事件。对于这种情况,我们使用最简单的方式,那就是节点一旦和ZooKeeper发生超时连接,则直接将Master或Worker服务停掉。</p>
+<h6>2.任务失败重试</h6>
+<p>这里首先要区分任务失败重试、流程失败恢复、流程失败重跑的概念:</p>
+<ul>
+<li>任务失败重试是任务级别的,是调度系统自动进行的,比如一个Shell任务设置重试次数为3次,那么在Shell任务运行失败后会自己再最多尝试运行3次</li>
+<li>流程失败恢复是流程级别的,是手动进行的,恢复是从只能<strong>从失败的节点开始执行</strong>或<strong>从当前节点开始执行</strong></li>
+<li>流程失败重跑也是流程级别的,是手动进行的,重跑是从开始节点进行</li>
+</ul>
+<p>接下来说正题,我们将工作流中的任务节点分了两种类型。</p>
+<ul>
+<li>
+<p>一种是业务节点,这种节点都对应一个实际的脚本或者处理语句,比如Shell节点,MR节点、Spark节点、依赖节点等。</p>
+</li>
+<li>
+<p>还有一种是逻辑节点,这种节点不做实际的脚本或语句处理,只是整个流程流转的逻辑处理,比如子流程节等。</p>
+</li>
+</ul>
+<p>每一个<strong>业务节点</strong>都可以配置失败重试的次数,当该任务节点失败,会自动重试,直到成功或者超过配置的重试次数。<strong>逻辑节点</strong>不支持失败重试。但是逻辑节点里的任务支持重试。</p>
+<p>如果工作流中有任务失败达到最大重试次数,工作流就会失败停止,失败的工作流可以手动进行重跑操作或者流程恢复操作</p>
+<h5>五、任务优先级设计</h5>
+<p>在早期调度设计中,如果没有优先级设计,采用公平调度设计的话,会遇到先行提交的任务可能会和后继提交的任务同时完成的情况,而不能做到设置流程或者任务的优先级,因此我们对此进行了重新设计,目前我们设计如下:</p>
+<ul>
+<li>按照<strong>不同流程实例优先级</strong>优先于<strong>同一个流程实例优先级</strong>优先于<strong>同一流程内任务优先级</strong>优先于<strong>同一流程内任务</strong>提交顺序依次从高到低进行任务处理。
+<ul>
+<li>
+<p>具体实现是根据任务实例的json解析优先级,然后把<strong>流程实例优先级_流程实例id_任务优先级_任务id</strong>信息保存在ZooKeeper任务队列中,当从任务队列获取的时候,通过字符串比较即可得出最需要优先执行的任务</p>
+<ul>
+<li>
+<p>其中流程定义的优先级是考虑到有些流程需要先于其他流程进行处理,这个可以在流程启动或者定时启动时配置,共有5级,依次为HIGHEST、HIGH、MEDIUM、LOW、LOWEST。如下图</p>
+  <p align="center">
+     <img src="https://analysys.github.io/easyscheduler_docs_cn/images/process_priority.png" alt="流程优先级配置"  width="40%" />
+   </p>
+</li>
+<li>
+<p>任务的优先级也分为5级,依次为HIGHEST、HIGH、MEDIUM、LOW、LOWEST。如下图</p>
+  <p align="center">
+     <img src="https://analysys.github.io/easyscheduler_docs_cn/images/task_priority.png" alt="任务优先级配置"  width="35%" />
+   </p>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+<h5>六、Logback和netty实现日志访问</h5>
+<ul>
+<li>
+<p>由于Web(UI)和Worker不一定在同一台机器上,所以查看日志不能像查询本地文件那样。有两种方案:</p>
+</li>
+<li>
+<p>将日志放到ES搜索引擎上</p>
+</li>
+<li>
+<p>通过netty通信获取远程日志信息</p>
+</li>
+<li>
+<p>介于考虑到尽可能的DolphinScheduler的轻量级性,所以选择了gRPC实现远程访问日志信息。</p>
+</li>
+</ul>
+ <p align="center">
+   <img src="https://analysys.github.io/easyscheduler_docs_cn/images/grpc.png" alt="grpc远程访问"  width="50%" />
+ </p>
+<ul>
+<li>我们使用自定义Logback的FileAppender和Filter功能,实现每个任务实例生成一个日志文件。</li>
+<li>FileAppender主要实现如下:</li>
+</ul>
+<pre><code class="language-java"><span class="hljs-comment">/**
+ * task log appender
+ */</span>
+<span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">TaskLogAppender</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">FileAppender</span>&lt;<span class="hljs-title">ILoggingEvent</span>&gt; </span>{
+
+    ...
+
+   <span class="hljs-meta">@Override</span>
+   <span class="hljs-function"><span class="hljs-keyword">protected</span> <span class="hljs-keyword">void</span> <span class="hljs-title">append</span><span class="hljs-params">(ILoggingEvent event)</span> </span>{
+
+       <span class="hljs-keyword">if</span> (currentlyActiveFile == <span class="hljs-keyword">null</span>){
+           currentlyActiveFile = getFile();
+       }
+       String activeFile = currentlyActiveFile;
+       <span class="hljs-comment">// thread name: taskThreadName-processDefineId_processInstanceId_taskInstanceId</span>
+       String threadName = event.getThreadName();
+       String[] threadNameArr = threadName.split(<span class="hljs-string">"-"</span>);
+       <span class="hljs-comment">// logId = processDefineId_processInstanceId_taskInstanceId</span>
+       String logId = threadNameArr[<span class="hljs-number">1</span>];
+       ...
+       <span class="hljs-keyword">super</span>.subAppend(event);
+   }
+}
+</code></pre>
+<p>以/流程定义id/流程实例id/任务实例id.log的形式生成日志</p>
+<ul>
+<li>
+<p>过滤匹配以TaskLogInfo开始的线程名称:</p>
+</li>
+<li>
+<p>TaskLogFilter实现如下:</p>
+</li>
+</ul>
+<pre><code class="language-java"><span class="hljs-comment">/**
+*  task log filter
+*/</span>
+<span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">TaskLogFilter</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">Filter</span>&lt;<span class="hljs-title">ILoggingEvent</span>&gt; </span>{
+
+   <span class="hljs-meta">@Override</span>
+   <span class="hljs-function"><span class="hljs-keyword">public</span> FilterReply <span class="hljs-title">decide</span><span class="hljs-params">(ILoggingEvent event)</span> </span>{
+       <span class="hljs-keyword">if</span> (event.getThreadName().startsWith(<span class="hljs-string">"TaskLogInfo-"</span>)){
+           <span class="hljs-keyword">return</span> FilterReply.ACCEPT;
+       }
+       <span class="hljs-keyword">return</span> FilterReply.DENY;
+   }
+}
+</code></pre>
+<h3>3.模块介绍</h3>
+<ul>
+<li>
+<p>dolphinscheduler-alert 告警模块,提供AlertServer服务。</p>
+</li>
+<li>
+<p>dolphinscheduler-api   web应用模块,提供ApiServer服务。</p>
+</li>
+<li>
+<p>dolphinscheduler-common 通用的常量枚举、工具类、数据结构或者基类</p>
+</li>
+<li>
+<p>dolphinscheduler-dao 提供数据库访问等操作。</p>
+</li>
+<li>
+<p>dolphinscheduler-remote 基于netty的客户端、服务端</p>
+</li>
+<li>
+<p>dolphinscheduler-server MasterServer和WorkerServer服务</p>
+</li>
+<li>
+<p>dolphinscheduler-service service模块,包含Quartz、Zookeeper、日志客户端访问服务,便于server模块和api模块调用</p>
+</li>
+<li>
+<p>dolphinscheduler-ui 前端模块</p>
+</li>
+</ul>
+<h3>总结</h3>
+<p>本文从调度出发,初步介绍了大数据分布式工作流调度系统--DolphinScheduler的架构原理及实现思路。未完待续</p>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>文档</dt><dd><a href="/zh-cn/docs/development/architecture-design.html" target="_self">概览</a></dd><dd><a href="/zh-cn/docs/1.3.1/user_doc/quick-start.html" target="_self">快速开始</a></dd><dd><a href="/zh-cn/docs/development/backend-development.html" target="_self">开发者指南</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http://www.apache.org" target="_self">基金 [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/architecture-design.json b/zh-cn/docs/1.3.2/user_doc/architecture-design.json
new file mode 100644
index 0000000..eddfb71
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/architecture-design.json
@@ -0,0 +1,6 @@
+{
+  "filename": "architecture-design.md",
+  "__html": "<h2>系统架构设计</h2>\n<p>在对调度系统架构说明之前,我们先来认识一下调度系统常用的名词</p>\n<h3>1.名词解释</h3>\n<p><strong>DAG:</strong> 全称Directed Acyclic Graph,简称DAG。工作流中的Task任务以有向无环图的形式组装起来,从入度为零的节点进行拓扑遍历,直到无后继节点为止。举例如下图:</p>\n<p align=\"center\">\n  <img src=\"/img/dag_examples_cn.jpg\" alt=\"dag示例\"  width=\"60%\" />\n  <p align=\"center\">\n        <em>dag示例</em>\n  </p>\n</p>\n<p><strong>流程定义</strong>:通过拖拽任务节点并建立任务节点的关联所形成的可视化<strong>DAG</strong></p>\n<p><strong>流程实例</strong>:流程实例是流程定义的实例化,可以通过手动启动或定时调度生成, [...]
+  "link": "/zh-cn/docs/1.3.2/user_doc/architecture-design.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/cluster-deployment.html b/zh-cn/docs/1.3.2/user_doc/cluster-deployment.html
new file mode 100644
index 0000000..8e91b8c
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/cluster-deployment.html
@@ -0,0 +1,429 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="cluster-deployment" />
+	<meta name="description" content="cluster-deployment" />
+	<!-- 网页标签标题 -->
+	<title>cluster-deployment</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/zh-cn/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">En</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass an [...]
+<h1>1、基础软件安装(必装项请自行安装)</h1>
+<ul>
+<li>PostgreSQL (8.2.15+) or MySQL (5.7系列)  :  两者任选其一即可</li>
+<li><a href="https://www.oracle.com/technetwork/java/javase/downloads/index.html">JDK</a> (1.8+) :  必装,请安装好后在/etc/profile下配置 JAVA_HOME 及 PATH 变量</li>
+<li>ZooKeeper (3.4.6+) :必装</li>
+<li>Hadoop (2.6+) or MinIO :选装,如果需要用到资源上传功能,可以选择上传到Hadoop or MinIO上</li>
+</ul>
+<pre><code class="language-markdown"> 注意:DolphinScheduler本身不依赖Hadoop、Hive、Spark,仅是会调用他们的Client,用于对应任务的提交。
+</code></pre>
+<h1>2、下载二进制tar.gz包</h1>
+<ul>
+<li>请下载最新版本的后端安装包至服务器部署目录,比如创建 /opt/dolphinscheduler 做为安装部署目录,下载地址: <a href="https://dolphinscheduler.apache.org/zh-cn/docs/release/download.html">下载</a>,下载后上传tar包到该目录中,并进行解压</li>
+</ul>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> 创建部署目录,部署目录请不要创建在/root、/home等高权限目录 </span>
+mkdir -p /opt/dolphinscheduler;
+cd /opt/dolphinscheduler;
+<span class="hljs-meta">#</span><span class="bash"> 解压缩</span>
+tar -zxvf apache-dolphinscheduler-incubating-1.3.1-dolphinscheduler-bin.tar.gz -C /opt/dolphinscheduler;
+
+mv apache-dolphinscheduler-incubating-1.3.1-dolphinscheduler-bin  dolphinscheduler-bin
+</code></pre>
+<h1>3、创建部署用户和hosts映射</h1>
+<ul>
+<li>在<strong>所有</strong>部署调度的机器上创建部署用户,并且一定要配置sudo免密。假如我们计划在ds1,ds2,ds3,ds4这4台机器上部署调度,首先需要在每台机器上都创建部署用户</li>
+</ul>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> 创建用户需使用root登录,设置部署用户名,请自行修改,后面以dolphinscheduler为例</span>
+useradd dolphinscheduler;
+<span class="hljs-meta">
+#</span><span class="bash"> 设置用户密码,请自行修改,后面以dolphinscheduler123为例</span>
+echo "dolphinscheduler123" | passwd --stdin dolphinscheduler
+<span class="hljs-meta">
+#</span><span class="bash"> 配置sudo免密</span>
+echo 'dolphinscheduler  ALL=(ALL)  NOPASSWD: NOPASSWD: ALL' &gt;&gt; /etc/sudoers
+sed -i 's/Defaults    requirett/#Defaults    requirett/g' /etc/sudoers
+
+</code></pre>
+<pre><code> 注意:
+ - 因为是以 sudo -u {linux-user} 切换不同linux用户的方式来实现多租户运行作业,所以部署用户需要有 sudo 权限,而且是免密的。
+ - 如果发现/etc/sudoers文件中有&quot;Default requiretty&quot;这行,也请注释掉
+ - 如果用到资源上传的话,还需要在`HDFS或者MinIO`上给该部署用户分配读写的权限
+</code></pre>
+<h1>4、配置hosts映射和ssh打通及修改目录权限</h1>
+<ul>
+<li>
+<p>以第一台机器(hostname为ds1)作为部署机,在ds1上配置所有待部署机器的hosts, 在ds1以root登录</p>
+<pre><code class="language-shell">vi /etc/hosts
+<span class="hljs-meta">
+#</span><span class="bash">add ip hostname</span>
+192.168.xxx.xxx ds1
+192.168.xxx.xxx ds2
+192.168.xxx.xxx ds3
+192.168.xxx.xxx ds4
+</code></pre>
+<p><em>注意:请删掉或者注释掉127.0.0.1这行</em></p>
+</li>
+<li>
+<p>同步ds1上的/etc/hosts到所有部署机器</p>
+<pre><code class="language-shell">for ip in ds2 ds3;     #请将此处ds2 ds3替换为自己要部署的机器的hostname
+do
+    sudo scp -r /etc/hosts  $ip:/etc/          #在运行中需要输入root密码
+done
+</code></pre>
+<p><em>备注:当然 通过<code>sshpass -p xxx sudo scp -r /etc/hosts $ip:/etc/</code>就可以省去输入密码了</em></p>
+<blockquote>
+<p>centos下sshpass的安装:</p>
+<ol>
+<li>
+<p>先安装epel</p>
+<p>yum install -y epel-release</p>
+<p>yum repolist</p>
+</li>
+<li>
+<p>安装完成epel之后,就可以按照sshpass了</p>
+<p>yum install -y sshpass</p>
+</li>
+</ol>
+</blockquote>
+</li>
+<li>
+<p>在ds1上,切换到部署用户并配置ssh本机免密登录</p>
+<pre><code class="language-shell"> su dolphinscheduler;
+
+ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa
+cat ~/.ssh/id_rsa.pub &gt;&gt; ~/.ssh/authorized_keys
+chmod 600 ~/.ssh/authorized_keys
+</code></pre>
+</li>
+</ul>
+<p>​      注意:<em>正常设置后,dolphinscheduler用户在执行命令<code>ssh localhost</code> 是不需要再输入密码的</em></p>
+<ul>
+<li>
+<p>在ds1上,配置部署用户dolphinscheduler ssh打通到其他待部署的机器</p>
+<pre><code class="language-shell">su dolphinscheduler;
+for ip in ds2 ds3;     #请将此处ds2 ds3替换为自己要部署的机器的hostname
+do
+    ssh-copy-id  $ip   #该操作执行过程中需要手动输入dolphinscheduler用户的密码
+done
+<span class="hljs-meta">#</span><span class="bash"> 当然 通过 sshpass -p xxx ssh-copy-id <span class="hljs-variable">$ip</span> 就可以省去输入密码了</span>
+</code></pre>
+</li>
+<li>
+<p>在ds1上,修改目录权限,使得部署用户对dolphinscheduler-bin目录有操作权限</p>
+<pre><code class="language-shell">sudo chown -R dolphinscheduler:dolphinscheduler dolphinscheduler-bin
+</code></pre>
+</li>
+</ul>
+<h1>5、数据库初始化</h1>
+<ul>
+<li>进入数据库,默认数据库是PostgreSQL,如选择MySQL的话,后续需要添加mysql-connector-java驱动包到DolphinScheduler的lib目录下,这里以MySQL为例</li>
+</ul>
+<pre><code>mysql -h192.168.xx.xx -P3306 -uroot -p
+</code></pre>
+<ul>
+<li>进入数据库命令行窗口后,执行数据库初始化命令,设置访问账号和密码。<strong>注: {user} 和 {password} 需要替换为具体的数据库用户名和密码</strong></li>
+</ul>
+<pre><code class="language-mysql">   mysql&gt; CREATE DATABASE dolphinscheduler DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_general_ci;
+   mysql&gt; GRANT ALL PRIVILEGES ON dolphinscheduler.* TO '{user}'@'%' IDENTIFIED BY '{password}';
+   mysql&gt; GRANT ALL PRIVILEGES ON dolphinscheduler.* TO '{user}'@'localhost' IDENTIFIED BY '{password}';
+   mysql&gt; flush privileges;
+</code></pre>
+<ul>
+<li>
+<p>创建表和导入基础数据</p>
+<ul>
+<li>修改 conf 目录下 datasource.properties 中的下列配置</li>
+</ul>
+<pre><code class="language-shell">  vi conf/datasource.properties
+</code></pre>
+<ul>
+<li>如果选择 MySQL,请注释掉 PostgreSQL 相关配置(反之同理), 还需要手动添加 [<a href="https://downloads.mysql.com/archives/c-j/"> mysql-connector-java 驱动 jar </a>] 包到 lib 目录下,这里下载的是mysql-connector-java-5.1.47.jar,然后正确配置数据库连接相关信息</li>
+</ul>
+<pre><code class="language-properties"><span class="hljs-comment">  #postgre</span>
+<span class="hljs-comment">  #spring.datasource.driver-class-name=org.postgresql.Driver</span>
+<span class="hljs-comment">  #spring.datasource.url=jdbc:postgresql://localhost:5432/dolphinscheduler</span>
+<span class="hljs-comment">  # mysql</span>
+  <span class="hljs-meta">spring.datasource.driver-class-name</span>=<span class="hljs-string">com.mysql.jdbc.Driver</span>
+  <span class="hljs-meta">spring.datasource.url</span>=<span class="hljs-string">jdbc:mysql://xxx:3306/dolphinscheduler?useUnicode=true&amp;characterEncoding=UTF-8&amp;allowMultiQueries=true     需要修改ip</span>
+  <span class="hljs-meta">spring.datasource.username</span>=<span class="hljs-string">xxx						需要修改为上面的{user}值</span>
+  <span class="hljs-meta">spring.datasource.password</span>=<span class="hljs-string">xxx						需要修改为上面的{password}值</span>
+</code></pre>
+<ul>
+<li>修改并保存完后,执行 script 目录下的创建表及导入基础数据脚本</li>
+</ul>
+<pre><code class="language-shell">sh script/create-dolphinscheduler.sh
+</code></pre>
+</li>
+</ul>
+<p>​       <em>注意: 如果执行上述脚本报 ”/bin/java: No such file or directory“ 错误,请在/etc/profile下配置  JAVA_HOME 及 PATH 变量</em></p>
+<h1>6、修改运行参数</h1>
+<ul>
+<li>
+<p>修改 conf/env 目录下的 <code>dolphinscheduler_env.sh</code> 环境变量(以相关用到的软件都安装在/opt/soft下为例)</p>
+<pre><code class="language-shell">    export HADOOP_HOME=/opt/soft/hadoop
+    export HADOOP_CONF_DIR=/opt/soft/hadoop/etc/hadoop
+    #export SPARK_HOME1=/opt/soft/spark1
+    export SPARK_HOME2=/opt/soft/spark2
+    export PYTHON_HOME=/opt/soft/python
+    export JAVA_HOME=/opt/soft/java
+    export HIVE_HOME=/opt/soft/hive
+    export FLINK_HOME=/opt/soft/flink
+    export DATAX_HOME=/opt/soft/datax/bin/datax.py
+    export PATH=$HADOOP_HOME/bin:$SPARK_HOME2/bin:$PYTHON_HOME:$JAVA_HOME/bin:$HIVE_HOME/bin:$PATH:$FLINK_HOME/bin:$DATAX_HOME:$PATH
+
+    ```
+
+ `注: 这一步非常重要,例如 JAVA_HOME 和 PATH 是必须要配置的,没有用到的可以忽略或者注释掉`
+
+
+
+</code></pre>
+</li>
+<li>
+<p>将jdk软链到/usr/bin/java下(仍以 JAVA_HOME=/opt/soft/java 为例)</p>
+<pre><code class="language-shell">sudo ln -s /opt/soft/java/bin/java /usr/bin/java
+</code></pre>
+</li>
+<li>
+<p>修改一键部署配置文件 <code>conf/config/install_config.conf</code>中的各参数,特别注意以下参数的配置</p>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> 这里填 mysql or postgresql</span>
+dbtype="mysql"
+<span class="hljs-meta">
+#</span><span class="bash"> 数据库连接地址</span>
+dbhost="192.168.xx.xx:3306"
+<span class="hljs-meta">
+#</span><span class="bash"> 数据库名</span>
+dbname="dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> 数据库用户名,此处需要修改为上面设置的{user}具体值</span>
+username="xxx"
+<span class="hljs-meta">
+#</span><span class="bash"> 数据库密码, 如果有特殊字符,请使用\转义,需要修改为上面设置的{password}具体值</span>
+password="xxx"
+<span class="hljs-meta">
+#</span><span class="bash">Zookeeper地址</span>
+zkQuorum="192.168.xx.xx:2181,192.168.xx.xx:2181,192.168.xx.xx:2181"
+<span class="hljs-meta">
+#</span><span class="bash">将DS安装到哪个目录,如: /opt/soft/dolphinscheduler,不同于现在的目录</span>
+installPath="/opt/soft/dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash">使用哪个用户部署,使用第3节创建的用户</span>
+deployUser="dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> 邮件配置,以qq邮箱为例</span>
+<span class="hljs-meta">#</span><span class="bash"> 邮件协议</span>
+mailProtocol="SMTP"
+<span class="hljs-meta">
+#</span><span class="bash"> 邮件服务地址</span>
+mailServerHost="smtp.qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> 邮件服务端口</span>
+mailServerPort="25"
+<span class="hljs-meta">
+#</span><span class="bash"> mailSender和mailUser配置成一样即可</span>
+<span class="hljs-meta">#</span><span class="bash"> 发送者</span>
+mailSender="xxx@qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> 发送用户</span>
+mailUser="xxx@qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> 邮箱密码</span>
+mailPassword="xxx"
+<span class="hljs-meta">
+#</span><span class="bash"> TLS协议的邮箱设置为<span class="hljs-literal">true</span>,否则设置为<span class="hljs-literal">false</span></span>
+starttlsEnable="true"
+<span class="hljs-meta">
+#</span><span class="bash"> 开启SSL协议的邮箱配置为<span class="hljs-literal">true</span>,否则为<span class="hljs-literal">false</span>。注意: starttlsEnable和sslEnable不能同时为<span class="hljs-literal">true</span></span>
+sslEnable="false"
+<span class="hljs-meta">
+#</span><span class="bash"> 邮件服务地址值,参考上面 mailServerHost</span>
+sslTrust="smtp.qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> 业务用到的比如sql等资源文件上传到哪里,可以设置:HDFS,S3,NONE,单机如果想使用本地文件系统,请配置为HDFS,因为HDFS支持本地文件系统;如果不需要资源上传功能请选择NONE。强调一点:使用本地文件系统不需要部署hadoop</span>
+resourceStorageType="HDFS"
+<span class="hljs-meta">
+#</span><span class="bash">如果上传资源保存想保存在hadoop上,hadoop集群的NameNode启用了HA的话,需要将hadoop的配置文件core-site.xml和hdfs-site.xml放到conf目录下,本例即是放到/opt/dolphinscheduler/conf下面,并配置namenode cluster名称;如果NameNode不是HA,则只需要将mycluster修改为具体的ip或者主机名即可</span>
+defaultFS="hdfs://mycluster:8020"
+<span class="hljs-meta">
+
+#</span><span class="bash"> 如果没有使用到Yarn,保持以下默认值即可;如果ResourceManager是HA,则配置为ResourceManager节点的主备ip或者hostname,比如<span class="hljs-string">"192.168.xx.xx,192.168.xx.xx"</span>;如果是单ResourceManager请配置yarnHaIps=<span class="hljs-string">""</span>即可</span>
+yarnHaIps="192.168.xx.xx,192.168.xx.xx"
+<span class="hljs-meta">
+#</span><span class="bash"> 如果ResourceManager是HA或者没有使用到Yarn保持默认值即可;如果是单ResourceManager,请配置真实的ResourceManager主机名或者ip</span>
+singleYarnIp="yarnIp1"
+<span class="hljs-meta">
+#</span><span class="bash"> 资源上传根路径,主持HDFS和S3,由于hdfs支持本地文件系统,需要确保本地文件夹存在且有读写权限</span>
+resourceUploadPath="/data/dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> 具备权限创建resourceUploadPath的用户</span>
+hdfsRootUser="hdfs"
+<span class="hljs-meta">
+
+
+#</span><span class="bash">在哪些机器上部署DS服务,本机选localhost</span>
+ips="ds1,ds2,ds3,ds4"
+<span class="hljs-meta">
+#</span><span class="bash">ssh端口,默认22</span>
+sshPort="22"
+<span class="hljs-meta">
+#</span><span class="bash">master服务部署在哪台机器上</span>
+masters="ds1,ds2"
+<span class="hljs-meta">
+#</span><span class="bash">worker服务部署在哪台机器上,并指定此worker属于哪一个worker组,下面示例的default即为组名</span>
+workers="ds3:default,ds4:default"
+<span class="hljs-meta">
+#</span><span class="bash">报警服务部署在哪台机器上</span>
+alertServer="ds2"
+<span class="hljs-meta">
+#</span><span class="bash">后端api服务部署在在哪台机器上</span>
+apiServers="ds1"
+
+</code></pre>
+<p><em>特别注意:</em></p>
+<ul>
+<li>如果需要用资源上传到Hadoop集群功能, 并且Hadoop集群的NameNode 配置了 HA的话 ,需要开启 HDFS类型的资源上传,同时需要将Hadoop集群下的core-site.xml和hdfs-site.xml复制到/opt/dolphinscheduler/conf,非NameNode HA跳过次步骤</li>
+</ul>
+</li>
+</ul>
+<h1>7、一键部署</h1>
+<ul>
+<li>
+<p>切换到部署用户dolphinscheduler,然后执行一键部署脚本</p>
+<p><code>sh install.sh</code></p>
+<pre><code>注意:
+第一次部署的话,在运行中第3步`3,stop server`出现5次以下信息,此信息可以忽略
+sh: bin/dolphinscheduler-daemon.sh: No such file or directory
+</code></pre>
+</li>
+<li>
+<p>脚本完成后,会启动以下5个服务,使用<code>jps</code>命令查看服务是否启动(<code>jps</code>为<code>java JDK</code>自带)</p>
+</li>
+</ul>
+<pre><code class="language-aidl">    MasterServer         ----- master服务
+    WorkerServer         ----- worker服务
+    LoggerServer         ----- logger服务
+    ApiApplicationServer ----- api服务
+    AlertServer          ----- alert服务
+</code></pre>
+<p>如果以上服务都正常启动,说明自动部署成功</p>
+<p>部署成功后,可以进行日志查看,日志统一存放于logs文件夹内</p>
+<pre><code class="language-日志路径"> logs/
+    ├── dolphinscheduler-alert-server.log
+    ├── dolphinscheduler-master-server.log
+    |—— dolphinscheduler-worker-server.log
+    |—— dolphinscheduler-api-server.log
+    |—— dolphinscheduler-logger-server.log
+</code></pre>
+<h1>8、登录系统</h1>
+<ul>
+<li>
+<p>访问前端页面地址,接口ip(自行修改)
+<a href="http://192.168.xx.xx:12345/dolphinscheduler">http://192.168.xx.xx:12345/dolphinscheduler</a></p>
+ <p align="center">
+   <img src="/img/login.png" width="60%" />
+ </p>
+</li>
+</ul>
+<h1>9、启停服务</h1>
+<ul>
+<li>
+<p>一键停止集群所有服务</p>
+<p><code>sh ./bin/stop-all.sh</code></p>
+</li>
+<li>
+<p>一键开启集群所有服务</p>
+<p><code>sh ./bin/start-all.sh</code></p>
+</li>
+<li>
+<p>启停Master</p>
+</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start master-server
+sh ./bin/dolphinscheduler-daemon.sh stop master-server
+</code></pre>
+<ul>
+<li>启停Worker</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start worker-server
+sh ./bin/dolphinscheduler-daemon.sh stop worker-server
+</code></pre>
+<ul>
+<li>启停Api</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start api-server
+sh ./bin/dolphinscheduler-daemon.sh stop api-server
+</code></pre>
+<ul>
+<li>启停Logger</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start logger-server
+sh ./bin/dolphinscheduler-daemon.sh stop logger-server
+</code></pre>
+<ul>
+<li>启停Alert</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start alert-server
+sh ./bin/dolphinscheduler-daemon.sh stop alert-server
+</code></pre>
+<p><code>注:服务用途请具体参见《系统架构设计》小节</code></p>
+<hr>
+<h3>附录:</h3>
+<ul>
+<li>
+<p>如果您需要使用到企业微信进行告警,请在安装完成后,修改 alert.properties 文件,然后重启 alert 服务即可:</p>
+<pre><code># 设置企业微信告警功能是否开启:开启为 true,否则为 false。
+enterprise.wechat.enable=&quot;true&quot;
+</code></pre>
+<pre><code># 设置 corpid,每个企业都拥有唯一的 corpid,获取此信息可在管理后台“我的企业”-“企业信息”下查看“企业 ID”(需要有管理员权限)
+enterprise.wechat.corp.id=&quot;xxx&quot;
+</code></pre>
+ <p align="center">
+   <img src="/img/alert/corpid.png" width="60%" />
+ </p>
+<pre><code># 设置 secret,secret 是企业应用里面用于保障数据安全的“钥匙”,每一个应用都有一个独立的访问密钥。
+enterprise.wechat.secret=&quot;xxx&quot;
+</code></pre>
+ <p align="center">
+  <img src="/img/alert/secret.png" width="60%" />
+ </p>
+<pre><code># 设置 agentid,每个应用都有唯一的 agentid。在管理后台-&gt;“应用与小程序”-&gt;“应用”,点进某个应用,即可看到 agentid。
+enterprise.wechat.agent.id=&quot;xxxx&quot;
+</code></pre>
+<p align="center">
+ <img src="/img/alert/agentid.png" width="60%" />
+</p>
+<pre><code># 设置 userid,多个用逗号分隔。每个成员都有唯一的 userid,即所谓“帐号”。在管理后台-&gt;“通讯录”-&gt;点进某个成员的详情页,可以看到。
+enterprise.wechat.users=zhangsan,lisi
+</code></pre>
+   <p align="center">
+    <img src="/img/alert/userid.png" width="60%" />
+   </p>
+<pre><code># 获取 access_token 的地址,使用如下例子无需修改。
+enterprise.wechat.token.url=https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid={corpId}&amp;corpsecret={secret}
+
+# 发送应用消息地址,使用如下例子无需改动。
+enterprise.wechat.push.url=https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token={token}
+
+#发送消息格式,无需改动
+enterprise.wechat.user.send.msg={\&quot;touser\&quot;:\&quot;{toUser}\&quot;,\&quot;agentid\&quot;:\&quot;{agentId}\&quot;,\&quot;msgtype\&quot;:\&quot;markdown\&quot;,\&quot;markdown\&quot;:{\&quot;content\&quot;:\&quot;{msg}\&quot;}}
+</code></pre>
+</li>
+</ul>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>文档</dt><dd><a href="/zh-cn/docs/development/architecture-design.html" target="_self">概览</a></dd><dd><a href="/zh-cn/docs/1.3.1/user_doc/quick-start.html" target="_self">快速开始</a></dd><dd><a href="/zh-cn/docs/development/backend-development.html" target="_self">开发者指南</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http://www.apache.org" target="_self">基金 [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/cluster-deployment.json b/zh-cn/docs/1.3.2/user_doc/cluster-deployment.json
new file mode 100644
index 0000000..a4966b6
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/cluster-deployment.json
@@ -0,0 +1,6 @@
+{
+  "filename": "cluster-deployment.md",
+  "__html": "<h1>集群部署(Cluster)</h1>\n<h1>1、基础软件安装(必装项请自行安装)</h1>\n<ul>\n<li>PostgreSQL (8.2.15+) or MySQL (5.7系列)  :  两者任选其一即可</li>\n<li><a href=\"https://www.oracle.com/technetwork/java/javase/downloads/index.html\">JDK</a> (1.8+) :  必装,请安装好后在/etc/profile下配置 JAVA_HOME 及 PATH 变量</li>\n<li>ZooKeeper (3.4.6+) :必装</li>\n<li>Hadoop (2.6+) or MinIO :选装,如果需要用到资源上传功能,可以选择上传到Hadoop or MinIO上</li>\n</ul>\n<pre><code class=\"language-markdown\"> 注意:DolphinScheduler本身不依赖Hadoop、Hive、Spark,仅是会调用他们的Cl [...]
+  "link": "/zh-cn/docs/1.3.2/user_doc/cluster-deployment.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/configuration-file.html b/zh-cn/docs/1.3.2/user_doc/configuration-file.html
new file mode 100644
index 0000000..76444c6
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/configuration-file.html
@@ -0,0 +1,993 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="configuration-file" />
+	<meta name="description" content="configuration-file" />
+	<!-- 网页标签标题 -->
+	<title>configuration-file</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/zh-cn/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">En</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass an [...]
+<p>本文档为dolphinscheduler配置文件说明文档,针对版本为 dolphinscheduler-1.3.x 版本.</p>
+<h1>目录结构</h1>
+<p>目前dolphinscheduler 所有的配置文件都在 [conf ] 目录中.
+为了更直观的了解[conf]目录所在的位置以及包含的配置文件,请查看下面dolphinscheduler安装目录的简化说明.
+本文主要讲述dolphinscheduler的配置文件.其他部分先不做赘述.</p>
+<p>[注:以下 dolphinscheduler 简称为DS.]</p>
+<pre><code>
+├─bin                               DS命令存放目录
+│  ├─dolphinscheduler-daemon.sh         启动/关闭DS服务脚本
+│  ├─start-all.sh                       根据配置文件启动所有DS服务
+│  ├─stop-all.sh                        根据配置文件关闭所有DS服务
+├─conf                              配置文件目录
+│  ├─application-api.properties         api服务配置文件
+│  ├─datasource.properties              数据库配置文件
+│  ├─zookeeper.properties               zookeeper配置文件
+│  ├─master.properties                  master服务配置文件
+│  ├─worker.properties                  worker服务配置文件
+│  ├─quartz.properties                  quartz服务配置文件
+│  ├─common.properties                  公共服务[存储]配置文件
+│  ├─alert.properties                   alert服务配置文件
+│  ├─config                             环境变量配置文件夹
+│      ├─install_config.conf                DS环境变量配置脚本[用于DS安装/启动]
+│  ├─env                                运行脚本环境变量配置目录
+│      ├─dolphinscheduler_env.sh            运行脚本加载环境变量配置文件[如: JAVA_HOME,HADOOP_HOME, HIVE_HOME ...]
+│  ├─org                                mybatis mapper文件目录
+│  ├─i18n                               i18n配置文件目录
+│  ├─logback-api.xml                    api服务日志配置文件
+│  ├─logback-master.xml                 master服务日志配置文件
+│  ├─logback-worker.xml                 worker服务日志配置文件
+│  ├─logback-alert.xml                  alert服务日志配置文件
+├─sql                               DS的元数据创建升级sql文件
+│  ├─create                             创建SQL脚本目录
+│  ├─upgrade                            升级SQL脚本目录
+│  ├─dolphinscheduler-postgre.sql       postgre数据库初始化脚本
+│  ├─dolphinscheduler_mysql.sql         mysql数据库初始化版本
+│  ├─soft_version                       当前DS版本标识文件
+├─script                            DS服务部署,数据库创建/升级脚本目录
+│  ├─create-dolphinscheduler.sh         DS数据库初始化脚本      
+│  ├─upgrade-dolphinscheduler.sh        DS数据库升级脚本                
+│  ├─monitor-server.sh                  DS服务监控启动脚本               
+│  ├─scp-hosts.sh                       安装文件传输脚本                                                    
+│  ├─remove-zk-node.sh                  清理zookeeper缓存文件脚本       
+├─ui                                前端WEB资源目录
+├─lib                               DS依赖的jar存放目录
+├─install.sh                        自动安装DS服务脚本
+
+
+</code></pre>
+<h1>配置文件详解</h1>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>服务分类</th>
+<th>配置文件</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>启动/关闭DS服务脚本</td>
+<td><a href="http://dolphinscheduler-daemon.sh">dolphinscheduler-daemon.sh</a></td>
+</tr>
+<tr>
+<td>2</td>
+<td>数据库连接配置</td>
+<td>datasource.properties</td>
+</tr>
+<tr>
+<td>3</td>
+<td>zookeeper连接配置</td>
+<td>zookeeper.properties</td>
+</tr>
+<tr>
+<td>4</td>
+<td>公共[存储]配置</td>
+<td>common.properties</td>
+</tr>
+<tr>
+<td>5</td>
+<td>API服务配置</td>
+<td>application-api.properties</td>
+</tr>
+<tr>
+<td>6</td>
+<td>Master服务配置</td>
+<td>master.properties</td>
+</tr>
+<tr>
+<td>7</td>
+<td>Worker服务配置</td>
+<td>worker.properties</td>
+</tr>
+<tr>
+<td>8</td>
+<td>Alert 服务配置</td>
+<td>alert.properties</td>
+</tr>
+<tr>
+<td>9</td>
+<td>Quartz配置</td>
+<td>quartz.properties</td>
+</tr>
+<tr>
+<td>10</td>
+<td>DS环境变量配置脚本[用于DS安装/启动]</td>
+<td>install_config.conf</td>
+</tr>
+<tr>
+<td>11</td>
+<td>运行脚本加载环境变量配置文件 <br />[如: JAVA_HOME,HADOOP_HOME, HIVE_HOME ...</td>
+<td>dolphinscheduler_env.sh</td>
+</tr>
+<tr>
+<td>12</td>
+<td>各服务日志配置文件</td>
+<td>api服务日志配置文件 : logback-api.xml  <br /> master服务日志配置文件  : logback-master.xml    <br /> worker服务日志配置文件 : logback-worker.xml  <br /> alert服务日志配置文件 : logback-alert.xml</td>
+</tr>
+</tbody>
+</table>
+<h2><a href="http://1.dolphinscheduler-daemon.sh">1.dolphinscheduler-daemon.sh</a> [启动/关闭DS服务脚本]</h2>
+<p>dolphinscheduler-daemon.sh脚本负责DS的启动&amp;关闭.
+<a href="http://start-all.sh/stop-all.sh%E6%9C%80%E7%BB%88%E4%B9%9F%E6%98%AF%E9%80%9A%E8%BF%87dolphinscheduler-daemon.sh%E5%AF%B9%E9%9B%86%E7%BE%A4%E8%BF%9B%E8%A1%8C%E5%90%AF%E5%8A%A8/%E5%85%B3%E9%97%AD%E6%93%8D%E4%BD%9C">start-all.sh/stop-all.sh最终也是通过dolphinscheduler-daemon.sh对集群进行启动/关闭操作</a>.
+目前DS只是做了一个基本的设置,JVM参数请根据各自资源的实际情况自行设置.</p>
+<p>默认简化参数如下:</p>
+<pre><code class="language-bash"><span class="hljs-built_in">export</span> DOLPHINSCHEDULER_OPTS=<span class="hljs-string">"
+-server 
+-Xmx16g 
+-Xms1g 
+-Xss512k 
+-XX:+UseConcMarkSweepGC 
+-XX:+CMSParallelRemarkEnabled 
+-XX:+UseFastAccessorMethods 
+-XX:+UseCMSInitiatingOccupancyOnly 
+-XX:CMSInitiatingOccupancyFraction=70
+"</span>
+</code></pre>
+<blockquote>
+<p>不建议设置&quot;-XX:DisableExplicitGC&quot; , DS使用Netty进行通讯,设置该参数,可能会导致内存泄漏.</p>
+</blockquote>
+<h2>2.datasource.properties [数据库连接]</h2>
+<p>在DS中使用Druid对数据库连接进行管理,默认简化配置如下.</p>
+<table>
+<thead>
+<tr>
+<th>参数</th>
+<th>默认值</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>spring.datasource.driver-class-name</td>
+<td></td>
+<td>数据库驱动</td>
+</tr>
+<tr>
+<td>spring.datasource.url</td>
+<td></td>
+<td>数据库连接地址</td>
+</tr>
+<tr>
+<td>spring.datasource.username</td>
+<td></td>
+<td>数据库用户名</td>
+</tr>
+<tr>
+<td>spring.datasource.password</td>
+<td></td>
+<td>数据库密码</td>
+</tr>
+<tr>
+<td>spring.datasource.initialSize</td>
+<td>5</td>
+<td>初始连接池数量</td>
+</tr>
+<tr>
+<td>spring.datasource.minIdle</td>
+<td>5</td>
+<td>最小连接池数量</td>
+</tr>
+<tr>
+<td>spring.datasource.maxActive</td>
+<td>5</td>
+<td>最大连接池数量</td>
+</tr>
+<tr>
+<td>spring.datasource.maxWait</td>
+<td>60000</td>
+<td>最大等待时长</td>
+</tr>
+<tr>
+<td>spring.datasource.timeBetweenEvictionRunsMillis</td>
+<td>60000</td>
+<td>连接检测周期</td>
+</tr>
+<tr>
+<td>spring.datasource.timeBetweenConnectErrorMillis</td>
+<td>60000</td>
+<td>重试间隔</td>
+</tr>
+<tr>
+<td>spring.datasource.minEvictableIdleTimeMillis</td>
+<td>300000</td>
+<td>连接保持空闲而不被驱逐的最小时间</td>
+</tr>
+<tr>
+<td>spring.datasource.validationQuery</td>
+<td>SELECT 1</td>
+<td>检测连接是否有效的sql</td>
+</tr>
+<tr>
+<td>spring.datasource.validationQueryTimeout</td>
+<td>3</td>
+<td>检测连接是否有效的超时时间[seconds]</td>
+</tr>
+<tr>
+<td>spring.datasource.testWhileIdle</td>
+<td>true</td>
+<td>申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。</td>
+</tr>
+<tr>
+<td>spring.datasource.testOnBorrow</td>
+<td>true</td>
+<td>申请连接时执行validationQuery检测连接是否有效</td>
+</tr>
+<tr>
+<td>spring.datasource.testOnReturn</td>
+<td>false</td>
+<td>归还连接时执行validationQuery检测连接是否有效</td>
+</tr>
+<tr>
+<td>spring.datasource.defaultAutoCommit</td>
+<td>true</td>
+<td>是否开启自动提交</td>
+</tr>
+<tr>
+<td>spring.datasource.keepAlive</td>
+<td>true</td>
+<td>连接池中的minIdle数量以内的连接,空闲时间超过minEvictableIdleTimeMillis,则会执行keepAlive操作。</td>
+</tr>
+<tr>
+<td>spring.datasource.poolPreparedStatements</td>
+<td>true</td>
+<td>开启PSCache</td>
+</tr>
+<tr>
+<td>spring.datasource.maxPoolPreparedStatementPerConnectionSize</td>
+<td>20</td>
+<td>要启用PSCache,必须配置大于0,当大于0时,poolPreparedStatements自动触发修改为true。</td>
+</tr>
+</tbody>
+</table>
+<h2>3.zookeeper.properties [zookeeper连接配置]</h2>
+<table>
+<thead>
+<tr>
+<th>参数</th>
+<th>默认值</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>zookeeper.quorum</td>
+<td>localhost:2181</td>
+<td>zk集群连接信息</td>
+</tr>
+<tr>
+<td>zookeeper.dolphinscheduler.root</td>
+<td>/dolphinscheduler</td>
+<td>DS在zookeeper存储根目录</td>
+</tr>
+<tr>
+<td>zookeeper.session.timeout</td>
+<td>60000</td>
+<td>session 超时</td>
+</tr>
+<tr>
+<td>zookeeper.connection.timeout</td>
+<td>30000</td>
+<td>连接超时</td>
+</tr>
+<tr>
+<td>zookeeper.retry.base.sleep</td>
+<td>100</td>
+<td>基本重试时间差</td>
+</tr>
+<tr>
+<td>zookeeper.retry.max.sleep</td>
+<td>30000</td>
+<td>最大重试时间</td>
+</tr>
+<tr>
+<td>zookeeper.retry.maxtime</td>
+<td>10</td>
+<td>最大重试次数</td>
+</tr>
+</tbody>
+</table>
+<h2>4.common.properties [hadoop、s3、yarn配置]</h2>
+<p>common.properties配置文件目前主要是配置hadoop/s3a相关的配置.</p>
+<table>
+<thead>
+<tr>
+<th>参数</th>
+<th>默认值</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>resource.storage.type</td>
+<td>NONE</td>
+<td>资源文件存储类型: HDFS,S3,NONE</td>
+</tr>
+<tr>
+<td>resource.upload.path</td>
+<td>/dolphinscheduler</td>
+<td>资源文件存储路径</td>
+</tr>
+<tr>
+<td>data.basedir.path</td>
+<td>/tmp/dolphinscheduler</td>
+<td>本地工作目录,用于存放临时文件</td>
+</tr>
+<tr>
+<td>hadoop.security.authentication.startup.state</td>
+<td>false</td>
+<td>hadoop是否开启kerberos权限</td>
+</tr>
+<tr>
+<td>java.security.krb5.conf.path</td>
+<td>/opt/krb5.conf</td>
+<td>kerberos配置目录</td>
+</tr>
+<tr>
+<td>login.user.keytab.username</td>
+<td><a href="mailto:hdfs-mycluster@ESZ.COM">hdfs-mycluster@ESZ.COM</a></td>
+<td>kerberos登录用户</td>
+</tr>
+<tr>
+<td>login.user.keytab.path</td>
+<td>/opt/hdfs.headless.keytab</td>
+<td>kerberos登录用户keytab</td>
+</tr>
+<tr>
+<td>resource.view.suffixs</td>
+<td>txt,log,sh,conf,cfg,py,java,sql,hql,xml,properties</td>
+<td>资源中心支持的文件格式</td>
+</tr>
+<tr>
+<td>hdfs.root.user</td>
+<td>hdfs</td>
+<td>如果存储类型为HDFS,需要配置拥有对应操作权限的用户</td>
+</tr>
+<tr>
+<td>fs.defaultFS</td>
+<td>hdfs://mycluster:8020</td>
+<td>请求地址如果resource.storage.type=S3 ,该值类似为: s3a://dolphinscheduler. 如果resource.storage.type=HDFS, 如果 hadoop 配置了 HA ,需要复制core-site.xml 和 hdfs-site.xml 文件到conf目录</td>
+</tr>
+<tr>
+<td>fs.s3a.endpoint</td>
+<td></td>
+<td>s3 endpoint地址</td>
+</tr>
+<tr>
+<td>fs.s3a.access.key</td>
+<td></td>
+<td>s3 access key</td>
+</tr>
+<tr>
+<td>fs.s3a.secret.key</td>
+<td></td>
+<td>s3 secret key</td>
+</tr>
+<tr>
+<td>yarn.resourcemanager.ha.rm.ids</td>
+<td></td>
+<td>yarn resourcemanager 地址, 如果resourcemanager开启了HA, 输入HA的IP地址(以逗号分隔),如果resourcemanager为单节点, 该值为空即可.</td>
+</tr>
+<tr>
+<td>yarn.application.status.address</td>
+<td><a href="http://ds1:8088/ws/v1/cluster/apps/%25s">http://ds1:8088/ws/v1/cluster/apps/%s</a></td>
+<td>如果resourcemanager开启了HA或者没有使用resourcemanager,保持默认值即可. 如果resourcemanager为单节点,你需要将ds1 配置为resourcemanager对应的hostname</td>
+</tr>
+<tr>
+<td>dolphinscheduler.env.path</td>
+<td>env/dolphinscheduler_env.sh</td>
+<td>运行脚本加载环境变量配置文件[如: JAVA_HOME,HADOOP_HOME, HIVE_HOME ...]</td>
+</tr>
+<tr>
+<td>development.state</td>
+<td>false</td>
+<td>是否处于开发模式</td>
+</tr>
+<tr>
+<td>kerberos.expire.time</td>
+<td>7</td>
+<td>kerberos过期时间 [小时]</td>
+</tr>
+</tbody>
+</table>
+<h2>5.application-api.properties [API服务配置]</h2>
+<table>
+<thead>
+<tr>
+<th>参数</th>
+<th>默认值</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>server.port</td>
+<td>12345</td>
+<td>api服务通讯端口</td>
+</tr>
+<tr>
+<td>server.servlet.session.timeout</td>
+<td>7200</td>
+<td>session超时时间</td>
+</tr>
+<tr>
+<td>server.servlet.context-path</td>
+<td>/dolphinscheduler</td>
+<td>请求路径</td>
+</tr>
+<tr>
+<td>spring.servlet.multipart.max-file-size</td>
+<td>1024MB</td>
+<td>最大上传文件大小</td>
+</tr>
+<tr>
+<td>spring.servlet.multipart.max-request-size</td>
+<td>1024MB</td>
+<td>最大请求大小</td>
+</tr>
+<tr>
+<td>server.jetty.max-http-post-size</td>
+<td>5000000</td>
+<td>jetty服务最大发送请求大小</td>
+</tr>
+<tr>
+<td>spring.messages.encoding</td>
+<td>UTF-8</td>
+<td>请求编码</td>
+</tr>
+<tr>
+<td>spring.jackson.time-zone</td>
+<td>GMT+8</td>
+<td>设置时区</td>
+</tr>
+<tr>
+<td>spring.messages.basename</td>
+<td>i18n/messages</td>
+<td>i18n配置</td>
+</tr>
+<tr>
+<td>security.authentication.type</td>
+<td>PASSWORD</td>
+<td>权限校验类型</td>
+</tr>
+</tbody>
+</table>
+<h2>6.master.properties [Master服务配置]</h2>
+<table>
+<thead>
+<tr>
+<th>参数</th>
+<th>默认值</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>master.listen.port</td>
+<td>5678</td>
+<td>master通讯端口</td>
+</tr>
+<tr>
+<td>master.exec.threads</td>
+<td>100</td>
+<td>工作线程数量</td>
+</tr>
+<tr>
+<td>master.exec.task.num</td>
+<td>20</td>
+<td>并行任务数量</td>
+</tr>
+<tr>
+<td>master.dispatch.task.num</td>
+<td>3</td>
+<td>分发任务数量</td>
+</tr>
+<tr>
+<td>master.heartbeat.interval</td>
+<td>10</td>
+<td>心跳间隔</td>
+</tr>
+<tr>
+<td>master.task.commit.retryTimes</td>
+<td>5</td>
+<td>任务重试次数</td>
+</tr>
+<tr>
+<td>master.task.commit.interval</td>
+<td>1000</td>
+<td>任务提交间隔</td>
+</tr>
+<tr>
+<td>master.max.cpuload.avg</td>
+<td>-1</td>
+<td>cpu小于该配置时,master 服务才能工作.默认值为-1 :  cpu cores * 2</td>
+</tr>
+<tr>
+<td>master.reserved.memory</td>
+<td>0.3</td>
+<td>内存阈值限制,可用内存大于该值,master 服务才能工作.</td>
+</tr>
+</tbody>
+</table>
+<h2>7.worker.properties [Worker服务配置]</h2>
+<table>
+<thead>
+<tr>
+<th>参数</th>
+<th>默认值</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>worker.listen.port</td>
+<td>1234</td>
+<td>worker通讯端口</td>
+</tr>
+<tr>
+<td>worker.exec.threads</td>
+<td>100</td>
+<td>工作线程数量</td>
+</tr>
+<tr>
+<td>worker.heartbeat.interval</td>
+<td>10</td>
+<td>心跳间隔</td>
+</tr>
+<tr>
+<td>worker.max.cpuload.avg</td>
+<td>-1</td>
+<td>cpu小于该配置时,worker 服务才能工作. 默认值为-1 :  cpu cores * 2</td>
+</tr>
+<tr>
+<td>worker.reserved.memory</td>
+<td>0.3</td>
+<td>内存阈值限制,可用内存大于该值,worker 服务才能工作.</td>
+</tr>
+<tr>
+<td>worker.group</td>
+<td>default</td>
+<td>workgroup分组配置. <br> worker启动时会根据该配置自动加入对应的分组.</td>
+</tr>
+</tbody>
+</table>
+<h2>8.alert.properties [Alert 告警服务配置]</h2>
+<table>
+<thead>
+<tr>
+<th>参数</th>
+<th>默认值</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>alert.type</td>
+<td>EMAIL</td>
+<td>告警类型</td>
+</tr>
+<tr>
+<td>mail.protocol</td>
+<td>SMTP</td>
+<td>邮件服务器协议</td>
+</tr>
+<tr>
+<td>mail.server.host</td>
+<td><a href="http://xxx.xxx.com">xxx.xxx.com</a></td>
+<td>邮件服务器地址</td>
+</tr>
+<tr>
+<td>mail.server.port</td>
+<td>25</td>
+<td>邮件服务器端口</td>
+</tr>
+<tr>
+<td>mail.sender</td>
+<td><a href="mailto:xxx@xxx.com">xxx@xxx.com</a></td>
+<td>发送人邮箱</td>
+</tr>
+<tr>
+<td>mail.user</td>
+<td><a href="mailto:xxx@xxx.com">xxx@xxx.com</a></td>
+<td>发送人邮箱名称</td>
+</tr>
+<tr>
+<td>mail.passwd</td>
+<td>111111</td>
+<td>发送人邮箱密码</td>
+</tr>
+<tr>
+<td>mail.smtp.starttls.enable</td>
+<td>true</td>
+<td>邮箱是否开启tls</td>
+</tr>
+<tr>
+<td>mail.smtp.ssl.enable</td>
+<td>false</td>
+<td>邮箱是否开启ssl</td>
+</tr>
+<tr>
+<td>mail.smtp.ssl.trust</td>
+<td><a href="http://xxx.xxx.com">xxx.xxx.com</a></td>
+<td>邮箱ssl白名单</td>
+</tr>
+<tr>
+<td>xls.file.path</td>
+<td>/tmp/xls</td>
+<td>邮箱附件临时工作目录</td>
+</tr>
+<tr>
+<td></td>
+<td>以下为企业微信配置[选填]</td>
+<td></td>
+</tr>
+<tr>
+<td>enterprise.wechat.enable</td>
+<td>false</td>
+<td>企业微信是否启用</td>
+</tr>
+<tr>
+<td><a href="http://enterprise.wechat.corp.id">enterprise.wechat.corp.id</a></td>
+<td>xxxxxxx</td>
+<td></td>
+</tr>
+<tr>
+<td>enterprise.wechat.secret</td>
+<td>xxxxxxx</td>
+<td></td>
+</tr>
+<tr>
+<td><a href="http://enterprise.wechat.agent.id">enterprise.wechat.agent.id</a></td>
+<td>xxxxxxx</td>
+<td></td>
+</tr>
+<tr>
+<td>enterprise.wechat.users</td>
+<td>xxxxxxx</td>
+<td></td>
+</tr>
+<tr>
+<td>enterprise.wechat.token.url</td>
+<td><a href="https://qyapi.weixin.qq.com/cgi-bin/gettoken">https://qyapi.weixin.qq.com/cgi-bin/gettoken</a>?  <br /> corpid=corpId&corpsecret=secret</td>
+<td></td>
+</tr>
+<tr>
+<td>enterprise.wechat.push.url</td>
+<td><a href="https://qyapi.weixin.qq.com/cgi-bin/message/send">https://qyapi.weixin.qq.com/cgi-bin/message/send</a>?  <br /> access_token=$token</td>
+<td></td>
+</tr>
+<tr>
+<td>enterprise.wechat.user.send.msg</td>
+<td></td>
+<td>发送消息格式</td>
+</tr>
+<tr>
+<td>enterprise.wechat.team.send.msg</td>
+<td></td>
+<td>群发消息格式</td>
+</tr>
+<tr>
+<td>plugin.dir</td>
+<td>/Users/xx/your/path/to/plugin/dir</td>
+<td>插件目录</td>
+</tr>
+</tbody>
+</table>
+<h2>9.quartz.properties [Quartz配置]</h2>
+<p>这里面主要是quartz配置,请结合实际业务场景&amp;资源进行配置,本文暂时不做展开.</p>
+<table>
+<thead>
+<tr>
+<th>参数</th>
+<th>默认值</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>org.quartz.jobStore.driverDelegateClass</td>
+<td>org.quartz.impl.jdbcjobstore.StdJDBCDelegate</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.jobStore.driverDelegateClass</td>
+<td>org.quartz.impl.jdbcjobstore.PostgreSQLDelegate</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.scheduler.instanceName</td>
+<td>DolphinScheduler</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.scheduler.instanceId</td>
+<td>AUTO</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.scheduler.makeSchedulerThreadDaemon</td>
+<td>true</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.jobStore.useProperties</td>
+<td>false</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.threadPool.class</td>
+<td>org.quartz.simpl.SimpleThreadPool</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.threadPool.makeThreadsDaemons</td>
+<td>true</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.threadPool.threadCount</td>
+<td>25</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.threadPool.threadPriority</td>
+<td>5</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.jobStore.class</td>
+<td>org.quartz.impl.jdbcjobstore.JobStoreTX</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.jobStore.tablePrefix</td>
+<td>QRTZ_</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.jobStore.isClustered</td>
+<td>true</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.jobStore.misfireThreshold</td>
+<td>60000</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.jobStore.clusterCheckinInterval</td>
+<td>5000</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.jobStore.acquireTriggersWithinLock</td>
+<td>true</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.jobStore.dataSource</td>
+<td>myDs</td>
+<td></td>
+</tr>
+<tr>
+<td>org.quartz.dataSource.myDs.connectionProvider.class</td>
+<td>org.apache.dolphinscheduler.service.quartz.DruidConnectionProvider</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<h2>10.install_config.conf [DS环境变量配置脚本[用于DS安装/启动]]</h2>
+<p>install_config.conf这个配置文件比较繁琐,这个文件主要有两个地方会用到.</p>
+<ul>
+<li>1.DS集群的自动安装.</li>
+</ul>
+<blockquote>
+<p>调用install.sh脚本会自动加载该文件中的配置.并根据该文件中的内容自动配置上述的配置文件中的内容.
+比如:dolphinscheduler-daemon.sh、datasource.properties、zookeeper.properties、common.properties、application-api.properties、master.properties、worker.properties、alert.properties、quartz.properties 等文件.</p>
+</blockquote>
+<ul>
+<li>2.DS集群的启动&amp;关闭.</li>
+</ul>
+<blockquote>
+<p>DS集群在启动&amp;关闭的时候,会加载该配置文件中的masters,workers,alertServer,apiServers等参数,启动/关闭DS集群.</p>
+</blockquote>
+<p>文件内容如下:</p>
+<pre><code class="language-bash">
+<span class="hljs-comment"># 注意: 该配置文件中如果包含特殊字符,如: `.*[]^${}\+?|()@#&amp;`, 请转义,</span>
+<span class="hljs-comment">#      示例: `[` 转义为 `\[`</span>
+
+<span class="hljs-comment"># 数据库类型, 目前仅支持 postgresql 或者 mysql</span>
+dbtype=<span class="hljs-string">"mysql"</span>
+
+<span class="hljs-comment"># 数据库 地址 &amp; 端口</span>
+dbhost=<span class="hljs-string">"192.168.xx.xx:3306"</span>
+
+<span class="hljs-comment"># 数据库 名称</span>
+dbname=<span class="hljs-string">"dolphinscheduler"</span>
+
+
+<span class="hljs-comment"># 数据库 用户名</span>
+username=<span class="hljs-string">"xx"</span>
+
+<span class="hljs-comment"># 数据库 密码</span>
+password=<span class="hljs-string">"xx"</span>
+
+<span class="hljs-comment"># Zookeeper地址</span>
+zkQuorum=<span class="hljs-string">"192.168.xx.xx:2181,192.168.xx.xx:2181,192.168.xx.xx:2181"</span>
+
+<span class="hljs-comment"># 将DS安装到哪个目录,如: /data1_1T/dolphinscheduler,</span>
+installPath=<span class="hljs-string">"/data1_1T/dolphinscheduler"</span>
+
+<span class="hljs-comment"># 使用哪个用户部署</span>
+<span class="hljs-comment"># 注意: 部署用户需要sudo 权限, 并且可以操作 hdfs .</span>
+<span class="hljs-comment">#     如果使用hdfs的话,根目录必须使用该用户进行创建.否则会有权限相关的问题.</span>
+deployUser=<span class="hljs-string">"dolphinscheduler"</span>
+
+
+<span class="hljs-comment"># 以下为告警服务配置</span>
+<span class="hljs-comment"># 邮件服务器地址</span>
+mailServerHost=<span class="hljs-string">"smtp.exmail.qq.com"</span>
+
+<span class="hljs-comment"># 邮件服务器 端口</span>
+mailServerPort=<span class="hljs-string">"25"</span>
+
+<span class="hljs-comment"># 发送者</span>
+mailSender=<span class="hljs-string">"xxxxxxxxxx"</span>
+
+<span class="hljs-comment"># 发送用户</span>
+mailUser=<span class="hljs-string">"xxxxxxxxxx"</span>
+
+<span class="hljs-comment"># 邮箱密码</span>
+mailPassword=<span class="hljs-string">"xxxxxxxxxx"</span>
+
+<span class="hljs-comment"># TLS协议的邮箱设置为true,否则设置为false</span>
+starttlsEnable=<span class="hljs-string">"true"</span>
+
+<span class="hljs-comment"># 开启SSL协议的邮箱配置为true,否则为false。注意: starttlsEnable和sslEnable不能同时为true</span>
+sslEnable=<span class="hljs-string">"false"</span>
+
+<span class="hljs-comment"># 邮件服务地址值,同 mailServerHost</span>
+sslTrust=<span class="hljs-string">"smtp.exmail.qq.com"</span>
+
+<span class="hljs-comment">#业务用到的比如sql等资源文件上传到哪里,可以设置:HDFS,S3,NONE。如果想上传到HDFS,请配置为HDFS;如果不需要资源上传功能请选择NONE。</span>
+resourceStorageType=<span class="hljs-string">"NONE"</span>
+
+<span class="hljs-comment"># if S3,write S3 address,HA,for example :s3a://dolphinscheduler,</span>
+<span class="hljs-comment"># Note,s3 be sure to create the root directory /dolphinscheduler</span>
+defaultFS=<span class="hljs-string">"hdfs://mycluster:8020"</span>
+
+<span class="hljs-comment"># 如果resourceStorageType 为S3 需要配置的参数如下:</span>
+s3Endpoint=<span class="hljs-string">"http://192.168.xx.xx:9010"</span>
+s3AccessKey=<span class="hljs-string">"xxxxxxxxxx"</span>
+s3SecretKey=<span class="hljs-string">"xxxxxxxxxx"</span>
+
+<span class="hljs-comment"># 如果ResourceManager是HA,则配置为ResourceManager节点的主备ip或者hostname,比如"192.168.xx.xx,192.168.xx.xx",否则如果是单ResourceManager或者根本没用到yarn,请配置yarnHaIps=""即可,如果没用到yarn,配置为""</span>
+yarnHaIps=<span class="hljs-string">"192.168.xx.xx,192.168.xx.xx"</span>
+
+<span class="hljs-comment"># 如果是单ResourceManager,则配置为ResourceManager节点ip或主机名,否则保持默认值即可。</span>
+singleYarnIp=<span class="hljs-string">"yarnIp1"</span>
+
+<span class="hljs-comment"># 资源文件在 HDFS/S3  存储路径</span>
+resourceUploadPath=<span class="hljs-string">"/dolphinscheduler"</span>
+
+
+<span class="hljs-comment"># HDFS/S3  操作用户</span>
+hdfsRootUser=<span class="hljs-string">"hdfs"</span>
+
+<span class="hljs-comment"># 以下为 kerberos 配置</span>
+
+<span class="hljs-comment"># kerberos是否开启</span>
+kerberosStartUp=<span class="hljs-string">"false"</span>
+<span class="hljs-comment"># kdc krb5 config file path</span>
+krb5ConfPath=<span class="hljs-string">"<span class="hljs-variable">$installPath</span>/conf/krb5.conf"</span>
+<span class="hljs-comment"># keytab username</span>
+keytabUserName=<span class="hljs-string">"hdfs-mycluster@ESZ.COM"</span>
+<span class="hljs-comment"># username keytab path</span>
+keytabPath=<span class="hljs-string">"<span class="hljs-variable">$installPath</span>/conf/hdfs.headless.keytab"</span>
+
+
+<span class="hljs-comment"># api 服务端口</span>
+apiServerPort=<span class="hljs-string">"12345"</span>
+
+
+<span class="hljs-comment"># 部署DS的所有主机hostname</span>
+ips=<span class="hljs-string">"ds1,ds2,ds3,ds4,ds5"</span>
+
+<span class="hljs-comment"># ssh 端口 , 默认 22</span>
+sshPort=<span class="hljs-string">"22"</span>
+
+<span class="hljs-comment"># 部署master服务主机</span>
+masters=<span class="hljs-string">"ds1,ds2"</span>
+
+<span class="hljs-comment"># 部署 worker服务的主机</span>
+<span class="hljs-comment"># 注意: 每一个worker都需要设置一个worker 分组的名称,默认值为 "default"</span>
+workers=<span class="hljs-string">"ds1:default,ds2:default,ds3:default,ds4:default,ds5:default"</span>
+
+<span class="hljs-comment">#  部署alert服务主机</span>
+alertServer=<span class="hljs-string">"ds3"</span>
+
+<span class="hljs-comment"># 部署api服务主机 </span>
+apiServers=<span class="hljs-string">"ds1"</span>
+</code></pre>
+<h2>11.dolphinscheduler_env.sh [环境变量配置]</h2>
+<p>通过类似shell方式提交任务的的时候,会加载该配置文件中的环境变量到主机中.
+涉及到的任务类型有: Shell任务、Python任务、Spark任务、Flink任务、Datax任务等等</p>
+<pre><code class="language-bash"><span class="hljs-built_in">export</span> HADOOP_HOME=/opt/soft/hadoop
+<span class="hljs-built_in">export</span> HADOOP_CONF_DIR=/opt/soft/hadoop/etc/hadoop
+<span class="hljs-built_in">export</span> SPARK_HOME1=/opt/soft/spark1
+<span class="hljs-built_in">export</span> SPARK_HOME2=/opt/soft/spark2
+<span class="hljs-built_in">export</span> PYTHON_HOME=/opt/soft/python
+<span class="hljs-built_in">export</span> JAVA_HOME=/opt/soft/java
+<span class="hljs-built_in">export</span> HIVE_HOME=/opt/soft/hive
+<span class="hljs-built_in">export</span> FLINK_HOME=/opt/soft/flink
+<span class="hljs-built_in">export</span> DATAX_HOME=/opt/soft/datax/bin/datax.py
+
+<span class="hljs-built_in">export</span> PATH=<span class="hljs-variable">$HADOOP_HOME</span>/bin:<span class="hljs-variable">$SPARK_HOME1</span>/bin:<span class="hljs-variable">$SPARK_HOME2</span>/bin:<span class="hljs-variable">$PYTHON_HOME</span>:<span class="hljs-variable">$JAVA_HOME</span>/bin:<span class="hljs-variable">$HIVE_HOME</span>/bin:<span class="hljs-variable">$PATH</span>:<span class="hljs-variable">$FLINK_HOME</span>/bin:<span class="hljs-variable">$DATAX_HOME</span>:<s [...]
+
+</code></pre>
+<h2>12.各服务日志配置文件</h2>
+<table>
+<thead>
+<tr>
+<th>对应服务服务名成</th>
+<th>日志文件名</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>api服务日志配置文件</td>
+<td>logback-api.xml</td>
+</tr>
+<tr>
+<td>master服务日志配置文件</td>
+<td>logback-master.xml</td>
+</tr>
+<tr>
+<td>worker服务日志配置文件</td>
+<td>logback-worker.xml</td>
+</tr>
+<tr>
+<td>alert服务日志配置文件</td>
+<td>logback-alert.xml</td>
+</tr>
+</tbody>
+</table>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>文档</dt><dd><a href="/zh-cn/docs/development/architecture-design.html" target="_self">概览</a></dd><dd><a href="/zh-cn/docs/1.3.1/user_doc/quick-start.html" target="_self">快速开始</a></dd><dd><a href="/zh-cn/docs/development/backend-development.html" target="_self">开发者指南</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http://www.apache.org" target="_self">基金 [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/configuration-file.json b/zh-cn/docs/1.3.2/user_doc/configuration-file.json
new file mode 100644
index 0000000..eb621af
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/configuration-file.json
@@ -0,0 +1,6 @@
+{
+  "filename": "configuration-file.md",
+  "__html": "<h1>前言</h1>\n<p>本文档为dolphinscheduler配置文件说明文档,针对版本为 dolphinscheduler-1.3.x 版本.</p>\n<h1>目录结构</h1>\n<p>目前dolphinscheduler 所有的配置文件都在 [conf ] 目录中.\n为了更直观的了解[conf]目录所在的位置以及包含的配置文件,请查看下面dolphinscheduler安装目录的简化说明.\n本文主要讲述dolphinscheduler的配置文件.其他部分先不做赘述.</p>\n<p>[注:以下 dolphinscheduler 简称为DS.]</p>\n<pre><code>\n├─bin                               DS命令存放目录\n│  ├─dolphinscheduler-daemon.sh         启动/关闭DS服务脚本\n│  ├─start-all.sh                       根据配置文件启动所有DS服务\n│  ├─stop-all.sh     [...]
+  "link": "/zh-cn/docs/1.3.2/user_doc/configuration-file.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/hardware-environment.html b/zh-cn/docs/1.3.2/user_doc/hardware-environment.html
new file mode 100644
index 0000000..53db6bc
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/hardware-environment.html
@@ -0,0 +1,127 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="hardware-environment" />
+	<meta name="description" content="hardware-environment" />
+	<!-- 网页标签标题 -->
+	<title>hardware-environment</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/zh-cn/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">En</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass an [...]
+<p>DolphinScheduler 作为一款开源分布式工作流任务调度系统,可以很好的部署和运行在 Intel 架构服务器环境及主流虚拟化环境下,并支持主流的Linux操作系统环境。</p>
+<h2>1. Linux 操作系统版本要求</h2>
+<table>
+<thead>
+<tr>
+<th style="text-align:left">操作系统</th>
+<th style="text-align:center">版本</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td style="text-align:left">Red Hat Enterprise Linux</td>
+<td style="text-align:center">7.0 及以上</td>
+</tr>
+<tr>
+<td style="text-align:left">CentOS</td>
+<td style="text-align:center">7.0 及以上</td>
+</tr>
+<tr>
+<td style="text-align:left">Oracle Enterprise Linux</td>
+<td style="text-align:center">7.0 及以上</td>
+</tr>
+<tr>
+<td style="text-align:left">Ubuntu LTS</td>
+<td style="text-align:center">16.04 及以上</td>
+</tr>
+</tbody>
+</table>
+<blockquote>
+<p><strong>注意:</strong>
+以上 Linux 操作系统可运行在物理服务器以及 VMware、KVM、XEN 主流虚拟化环境上。</p>
+</blockquote>
+<h2>2. 服务器建议配置</h2>
+<p>DolphinScheduler 支持运行在 Intel x86-64 架构的 64 位通用硬件服务器平台。对生产环境的服务器硬件配置有以下建议:</p>
+<h3>生产环境</h3>
+<table>
+<thead>
+<tr>
+<th><strong>CPU</strong></th>
+<th><strong>内存</strong></th>
+<th><strong>硬盘类型</strong></th>
+<th><strong>网络</strong></th>
+<th><strong>实例数量</strong></th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>4核+</td>
+<td>8 GB+</td>
+<td>SAS</td>
+<td>千兆网卡</td>
+<td>1+</td>
+</tr>
+</tbody>
+</table>
+<blockquote>
+<p><strong>注意:</strong></p>
+<ul>
+<li>以上建议配置为部署 DolphinScheduler 的最低配置,生产环境强烈推荐使用更高的配置。</li>
+<li>硬盘大小配置建议 50GB+ ,系统盘和数据盘分开。</li>
+</ul>
+</blockquote>
+<h2>3. 网络要求</h2>
+<p>DolphinScheduler正常运行提供如下的网络端口配置:</p>
+<table>
+<thead>
+<tr>
+<th>组件</th>
+<th>默认端口</th>
+<th>说明</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>MasterServer</td>
+<td>5678</td>
+<td>非通信端口,只需本机端口不冲突即可</td>
+</tr>
+<tr>
+<td>WorkerServer</td>
+<td>1234</td>
+<td>非通信端口,只需本机端口不冲突即可</td>
+</tr>
+<tr>
+<td>ApiApplicationServer</td>
+<td>12345</td>
+<td>提供后端通信端口</td>
+</tr>
+</tbody>
+</table>
+<blockquote>
+<p><strong>注意:</strong></p>
+<ul>
+<li>MasterServer 和 WorkerServer 不需要开启网络间通信,只需本机端口不冲突即可</li>
+<li>管理员可根据实际环境中 DolphinScheduler 组件部署方案,在网络侧和主机侧开放相关端口</li>
+</ul>
+</blockquote>
+<h2>4. 客户端 Web 浏览器要求</h2>
+<p>DolphinScheduler 推荐 Chrome 以及使用 Chrome 内核的较新版本浏览器访问前端可视化操作界面。</p>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>文档</dt><dd><a href="/zh-cn/docs/development/architecture-design.html" target="_self">概览</a></dd><dd><a href="/zh-cn/docs/1.3.1/user_doc/quick-start.html" target="_self">快速开始</a></dd><dd><a href="/zh-cn/docs/development/backend-development.html" target="_self">开发者指南</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http://www.apache.org" target="_self">基金 [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/hardware-environment.json b/zh-cn/docs/1.3.2/user_doc/hardware-environment.json
new file mode 100644
index 0000000..cd41872
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/hardware-environment.json
@@ -0,0 +1,6 @@
+{
+  "filename": "hardware-environment.md",
+  "__html": "<h1>软硬件环境建议配置</h1>\n<p>DolphinScheduler 作为一款开源分布式工作流任务调度系统,可以很好的部署和运行在 Intel 架构服务器环境及主流虚拟化环境下,并支持主流的Linux操作系统环境。</p>\n<h2>1. Linux 操作系统版本要求</h2>\n<table>\n<thead>\n<tr>\n<th style=\"text-align:left\">操作系统</th>\n<th style=\"text-align:center\">版本</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td style=\"text-align:left\">Red Hat Enterprise Linux</td>\n<td style=\"text-align:center\">7.0 及以上</td>\n</tr>\n<tr>\n<td style=\"text-align:left\">CentOS</td>\n<td style=\"text-align:center\"> [...]
+  "link": "/zh-cn/docs/1.3.2/user_doc/hardware-environment.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/metadata-1.3.html b/zh-cn/docs/1.3.2/user_doc/metadata-1.3.html
new file mode 100644
index 0000000..25aaa6d
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/metadata-1.3.html
@@ -0,0 +1,743 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="metadata-1.3" />
+	<meta name="description" content="metadata-1.3" />
+	<!-- 网页标签标题 -->
+	<title>metadata-1.3</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/zh-cn/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">En</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass an [...]
+<p><a name="25Ald"></a></p>
+<h3>表概览</h3>
+<table>
+<thead>
+<tr>
+<th style="text-align:center">表名</th>
+<th style="text-align:center">表信息</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td style="text-align:center">t_ds_access_token</td>
+<td style="text-align:center">访问ds后端的token</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_alert</td>
+<td style="text-align:center">告警信息</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_alertgroup</td>
+<td style="text-align:center">告警组</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_command</td>
+<td style="text-align:center">执行命令</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_datasource</td>
+<td style="text-align:center">数据源</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_error_command</td>
+<td style="text-align:center">错误命令</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_process_definition</td>
+<td style="text-align:center">流程定义</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_process_instance</td>
+<td style="text-align:center">流程实例</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_project</td>
+<td style="text-align:center">项目</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_queue</td>
+<td style="text-align:center">队列</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_datasource_user</td>
+<td style="text-align:center">用户关联数据源</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_process_instance</td>
+<td style="text-align:center">子流程</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_project_user</td>
+<td style="text-align:center">用户关联项目</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_resources_user</td>
+<td style="text-align:center">用户关联资源</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_udfs_user</td>
+<td style="text-align:center">用户关联UDF函数</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_relation_user_alertgroup</td>
+<td style="text-align:center">用户关联告警组</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_resources</td>
+<td style="text-align:center">资源文件</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_schedules</td>
+<td style="text-align:center">流程定时调度</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_session</td>
+<td style="text-align:center">用户登录的session</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_task_instance</td>
+<td style="text-align:center">任务实例</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_tenant</td>
+<td style="text-align:center">租户</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_udfs</td>
+<td style="text-align:center">UDF资源</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_user</td>
+<td style="text-align:center">用户</td>
+</tr>
+<tr>
+<td style="text-align:center">t_ds_version</td>
+<td style="text-align:center">ds版本信息</td>
+</tr>
+</tbody>
+</table>
+<p><a name="VNVGr"></a></p>
+<h3>用户	队列	数据源</h3>
+<p><img src="/img/metadata-erd/user-queue-datasource.png" alt="image.png"></p>
+<ul>
+<li>一个租户下可以有多个用户<br /></li>
+<li>t_ds_user中的queue字段存储的是队列表中的queue_name信息,t_ds_tenant下存的是queue_id,在流程定义执行过程中,用户队列优先级最高,用户队列为空则采用租户队列<br /></li>
+<li>t_ds_datasource表中的user_id字段表示创建该数据源的用户,t_ds_relation_datasource_user中的user_id表示,对数据源有权限的用户<br />
+<a name="HHyGV"></a></li>
+</ul>
+<h3>项目	资源	告警</h3>
+<p><img src="/img/metadata-erd/project-resource-alert.png" alt="image.png"></p>
+<ul>
+<li>一个用户可以有多个项目,用户项目授权通过t_ds_relation_project_user表完成project_id和user_id的关系绑定<br /></li>
+<li>t_ds_projcet表中的user_id表示创建该项目的用户,t_ds_relation_project_user表中的user_id表示对项目有权限的用户<br /></li>
+<li>t_ds_resources表中的user_id表示创建该资源的用户,t_ds_relation_resources_user中的user_id表示对资源有权限的用户<br /></li>
+<li>t_ds_udfs表中的user_id表示创建该UDF的用户,t_ds_relation_udfs_user表中的user_id表示对UDF有权限的用户<br />
+<a name="Bg2Sn"></a></li>
+</ul>
+<h3>命令	流程	任务</h3>
+<p><img src="/img/metadata-erd/command.png" alt="image.png"><br /><img src="/img/metadata-erd/process-task.png" alt="image.png"></p>
+<ul>
+<li>一个项目有多个流程定义,一个流程定义可以生成多个流程实例,一个流程实例可以生成多个任务实例<br /></li>
+<li>t_ds_schedulers表存放流程定义的定时调度信息<br /></li>
+<li>t_ds_relation_process_instance表存放的数据用于处理流程定义中含有子流程的情况,parent_process_instance_id表示含有子流程的主流程实例id,process_instance_id表示子流程实例的id,parent_task_instance_id表示子流程节点的任务实例id,流程实例表和任务实例表分别对应t_ds_process_instance表和t_ds_task_instance表
+<a name="Pv25P"></a></li>
+</ul>
+<h3>核心表Schema</h3>
+<p><a name="32Jzd"></a></p>
+<h4>t_ds_process_definition</h4>
+<table>
+<thead>
+<tr>
+<th>字段</th>
+<th>类型</th>
+<th>注释</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>id</td>
+<td>int</td>
+<td>主键</td>
+</tr>
+<tr>
+<td>name</td>
+<td>varchar</td>
+<td>流程定义名称</td>
+</tr>
+<tr>
+<td>version</td>
+<td>int</td>
+<td>流程定义版本</td>
+</tr>
+<tr>
+<td>release_state</td>
+<td>tinyint</td>
+<td>流程定义的发布状态:0 未上线  1已上线</td>
+</tr>
+<tr>
+<td>project_id</td>
+<td>int</td>
+<td>项目id</td>
+</tr>
+<tr>
+<td>user_id</td>
+<td>int</td>
+<td>流程定义所属用户id</td>
+</tr>
+<tr>
+<td>process_definition_json</td>
+<td>longtext</td>
+<td>流程定义json串</td>
+</tr>
+<tr>
+<td>description</td>
+<td>text</td>
+<td>流程定义描述</td>
+</tr>
+<tr>
+<td>global_params</td>
+<td>text</td>
+<td>全局参数</td>
+</tr>
+<tr>
+<td>flag</td>
+<td>tinyint</td>
+<td>流程是否可用:0 不可用,1 可用</td>
+</tr>
+<tr>
+<td>locations</td>
+<td>text</td>
+<td>节点坐标信息</td>
+</tr>
+<tr>
+<td>connects</td>
+<td>text</td>
+<td>节点连线信息</td>
+</tr>
+<tr>
+<td>receivers</td>
+<td>text</td>
+<td>收件人</td>
+</tr>
+<tr>
+<td>receivers_cc</td>
+<td>text</td>
+<td>抄送人</td>
+</tr>
+<tr>
+<td>create_time</td>
+<td>datetime</td>
+<td>创建时间</td>
+</tr>
+<tr>
+<td>timeout</td>
+<td>int</td>
+<td>超时时间</td>
+</tr>
+<tr>
+<td>tenant_id</td>
+<td>int</td>
+<td>租户id</td>
+</tr>
+<tr>
+<td>update_time</td>
+<td>datetime</td>
+<td>更新时间</td>
+</tr>
+<tr>
+<td>modify_by</td>
+<td>varchar</td>
+<td>修改用户</td>
+</tr>
+<tr>
+<td>resource_ids</td>
+<td>varchar</td>
+<td>资源id集</td>
+</tr>
+</tbody>
+</table>
+<p><a name="e6jfz"></a></p>
+<h4>t_ds_process_instance</h4>
+<table>
+<thead>
+<tr>
+<th>字段</th>
+<th>类型</th>
+<th>注释</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>id</td>
+<td>int</td>
+<td>主键</td>
+</tr>
+<tr>
+<td>name</td>
+<td>varchar</td>
+<td>流程实例名称</td>
+</tr>
+<tr>
+<td>process_definition_id</td>
+<td>int</td>
+<td>流程定义id</td>
+</tr>
+<tr>
+<td>state</td>
+<td>tinyint</td>
+<td>流程实例状态:0 提交成功,1 正在运行,2 准备暂停,3 暂停,4 准备停止,5 停止,6 失败,7 成功,8 需要容错,9 kill,10 等待线程,11 等待依赖完成</td>
+</tr>
+<tr>
+<td>recovery</td>
+<td>tinyint</td>
+<td>流程实例容错标识:0 正常,1 需要被容错重启</td>
+</tr>
+<tr>
+<td>start_time</td>
+<td>datetime</td>
+<td>流程实例开始时间</td>
+</tr>
+<tr>
+<td>end_time</td>
+<td>datetime</td>
+<td>流程实例结束时间</td>
+</tr>
+<tr>
+<td>run_times</td>
+<td>int</td>
+<td>流程实例运行次数</td>
+</tr>
+<tr>
+<td>host</td>
+<td>varchar</td>
+<td>流程实例所在的机器</td>
+</tr>
+<tr>
+<td>command_type</td>
+<td>tinyint</td>
+<td>命令类型:0 启动工作流,1 从当前节点开始执行,2 恢复被容错的工作流,3 恢复暂停流程,4 从失败节点开始执行,5 补数,6 调度,7 重跑,8 暂停,9 停止,10 恢复等待线程</td>
+</tr>
+<tr>
+<td>command_param</td>
+<td>text</td>
+<td>命令的参数(json格式)</td>
+</tr>
+<tr>
+<td>task_depend_type</td>
+<td>tinyint</td>
+<td>节点依赖类型:0 当前节点,1 向前执行,2 向后执行</td>
+</tr>
+<tr>
+<td>max_try_times</td>
+<td>tinyint</td>
+<td>最大重试次数</td>
+</tr>
+<tr>
+<td>failure_strategy</td>
+<td>tinyint</td>
+<td>失败策略 0 失败后结束,1 失败后继续</td>
+</tr>
+<tr>
+<td>warning_type</td>
+<td>tinyint</td>
+<td>告警类型:0 不发,1 流程成功发,2 流程失败发,3 成功失败都发</td>
+</tr>
+<tr>
+<td>warning_group_id</td>
+<td>int</td>
+<td>告警组id</td>
+</tr>
+<tr>
+<td>schedule_time</td>
+<td>datetime</td>
+<td>预期运行时间</td>
+</tr>
+<tr>
+<td>command_start_time</td>
+<td>datetime</td>
+<td>开始命令时间</td>
+</tr>
+<tr>
+<td>global_params</td>
+<td>text</td>
+<td>全局参数(固化流程定义的参数)</td>
+</tr>
+<tr>
+<td>process_instance_json</td>
+<td>longtext</td>
+<td>流程实例json(copy的流程定义的json)</td>
+</tr>
+<tr>
+<td>flag</td>
+<td>tinyint</td>
+<td>是否可用,1 可用,0不可用</td>
+</tr>
+<tr>
+<td>update_time</td>
+<td>timestamp</td>
+<td>更新时间</td>
+</tr>
+<tr>
+<td>is_sub_process</td>
+<td>int</td>
+<td>是否是子工作流 1 是,0 不是</td>
+</tr>
+<tr>
+<td>executor_id</td>
+<td>int</td>
+<td>命令执行用户</td>
+</tr>
+<tr>
+<td>locations</td>
+<td>text</td>
+<td>节点坐标信息</td>
+</tr>
+<tr>
+<td>connects</td>
+<td>text</td>
+<td>节点连线信息</td>
+</tr>
+<tr>
+<td>history_cmd</td>
+<td>text</td>
+<td>历史命令,记录所有对流程实例的操作</td>
+</tr>
+<tr>
+<td>dependence_schedule_times</td>
+<td>text</td>
+<td>依赖节点的预估时间</td>
+</tr>
+<tr>
+<td>process_instance_priority</td>
+<td>int</td>
+<td>流程实例优先级:0 Highest,1 High,2 Medium,3 Low,4 Lowest</td>
+</tr>
+<tr>
+<td>worker_group</td>
+<td>varchar</td>
+<td>任务指定运行的worker分组</td>
+</tr>
+<tr>
+<td>timeout</td>
+<td>int</td>
+<td>超时时间</td>
+</tr>
+<tr>
+<td>tenant_id</td>
+<td>int</td>
+<td>租户id</td>
+</tr>
+</tbody>
+</table>
+<p><a name="IvHEc"></a></p>
+<h4>t_ds_task_instance</h4>
+<table>
+<thead>
+<tr>
+<th>字段</th>
+<th>类型</th>
+<th>注释</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>id</td>
+<td>int</td>
+<td>主键</td>
+</tr>
+<tr>
+<td>name</td>
+<td>varchar</td>
+<td>任务名称</td>
+</tr>
+<tr>
+<td>task_type</td>
+<td>varchar</td>
+<td>任务类型</td>
+</tr>
+<tr>
+<td>process_definition_id</td>
+<td>int</td>
+<td>流程定义id</td>
+</tr>
+<tr>
+<td>process_instance_id</td>
+<td>int</td>
+<td>流程实例id</td>
+</tr>
+<tr>
+<td>task_json</td>
+<td>longtext</td>
+<td>任务节点json</td>
+</tr>
+<tr>
+<td>state</td>
+<td>tinyint</td>
+<td>任务实例状态:0 提交成功,1 正在运行,2 准备暂停,3 暂停,4 准备停止,5 停止,6 失败,7 成功,8 需要容错,9 kill,10 等待线程,11 等待依赖完成</td>
+</tr>
+<tr>
+<td>submit_time</td>
+<td>datetime</td>
+<td>任务提交时间</td>
+</tr>
+<tr>
+<td>start_time</td>
+<td>datetime</td>
+<td>任务开始时间</td>
+</tr>
+<tr>
+<td>end_time</td>
+<td>datetime</td>
+<td>任务结束时间</td>
+</tr>
+<tr>
+<td>host</td>
+<td>varchar</td>
+<td>执行任务的机器</td>
+</tr>
+<tr>
+<td>execute_path</td>
+<td>varchar</td>
+<td>任务执行路径</td>
+</tr>
+<tr>
+<td>log_path</td>
+<td>varchar</td>
+<td>任务日志路径</td>
+</tr>
+<tr>
+<td>alert_flag</td>
+<td>tinyint</td>
+<td>是否告警</td>
+</tr>
+<tr>
+<td>retry_times</td>
+<td>int</td>
+<td>重试次数</td>
+</tr>
+<tr>
+<td>pid</td>
+<td>int</td>
+<td>进程pid</td>
+</tr>
+<tr>
+<td>app_link</td>
+<td>varchar</td>
+<td>yarn app id</td>
+</tr>
+<tr>
+<td>flag</td>
+<td>tinyint</td>
+<td>是否可用:0 不可用,1 可用</td>
+</tr>
+<tr>
+<td>retry_interval</td>
+<td>int</td>
+<td>重试间隔</td>
+</tr>
+<tr>
+<td>max_retry_times</td>
+<td>int</td>
+<td>最大重试次数</td>
+</tr>
+<tr>
+<td>task_instance_priority</td>
+<td>int</td>
+<td>任务实例优先级:0 Highest,1 High,2 Medium,3 Low,4 Lowest</td>
+</tr>
+<tr>
+<td>worker_group</td>
+<td>varchar</td>
+<td>任务指定运行的worker分组</td>
+</tr>
+</tbody>
+</table>
+<p><a name="pPQkU"></a></p>
+<h4>t_ds_schedules</h4>
+<table>
+<thead>
+<tr>
+<th>字段</th>
+<th>类型</th>
+<th>注释</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>id</td>
+<td>int</td>
+<td>主键</td>
+</tr>
+<tr>
+<td>process_definition_id</td>
+<td>int</td>
+<td>流程定义id</td>
+</tr>
+<tr>
+<td>start_time</td>
+<td>datetime</td>
+<td>调度开始时间</td>
+</tr>
+<tr>
+<td>end_time</td>
+<td>datetime</td>
+<td>调度结束时间</td>
+</tr>
+<tr>
+<td>crontab</td>
+<td>varchar</td>
+<td>crontab 表达式</td>
+</tr>
+<tr>
+<td>failure_strategy</td>
+<td>tinyint</td>
+<td>失败策略: 0 结束,1 继续</td>
+</tr>
+<tr>
+<td>user_id</td>
+<td>int</td>
+<td>用户id</td>
+</tr>
+<tr>
+<td>release_state</td>
+<td>tinyint</td>
+<td>状态:0 未上线,1 上线</td>
+</tr>
+<tr>
+<td>warning_type</td>
+<td>tinyint</td>
+<td>告警类型:0 不发,1 流程成功发,2 流程失败发,3 成功失败都发</td>
+</tr>
+<tr>
+<td>warning_group_id</td>
+<td>int</td>
+<td>告警组id</td>
+</tr>
+<tr>
+<td>process_instance_priority</td>
+<td>int</td>
+<td>流程实例优先级:0 Highest,1 High,2 Medium,3 Low,4 Lowest</td>
+</tr>
+<tr>
+<td>worker_group</td>
+<td>varchar</td>
+<td>任务指定运行的worker分组</td>
+</tr>
+<tr>
+<td>create_time</td>
+<td>datetime</td>
+<td>创建时间</td>
+</tr>
+<tr>
+<td>update_time</td>
+<td>datetime</td>
+<td>更新时间</td>
+</tr>
+</tbody>
+</table>
+<p><a name="TkQzn"></a></p>
+<h4>t_ds_command</h4>
+<table>
+<thead>
+<tr>
+<th>字段</th>
+<th>类型</th>
+<th>注释</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>id</td>
+<td>int</td>
+<td>主键</td>
+</tr>
+<tr>
+<td>command_type</td>
+<td>tinyint</td>
+<td>命令类型:0 启动工作流,1 从当前节点开始执行,2 恢复被容错的工作流,3 恢复暂停流程,4 从失败节点开始执行,5 补数,6 调度,7 重跑,8 暂停,9 停止,10 恢复等待线程</td>
+</tr>
+<tr>
+<td>process_definition_id</td>
+<td>int</td>
+<td>流程定义id</td>
+</tr>
+<tr>
+<td>command_param</td>
+<td>text</td>
+<td>命令的参数(json格式)</td>
+</tr>
+<tr>
+<td>task_depend_type</td>
+<td>tinyint</td>
+<td>节点依赖类型:0 当前节点,1 向前执行,2 向后执行</td>
+</tr>
+<tr>
+<td>failure_strategy</td>
+<td>tinyint</td>
+<td>失败策略:0结束,1继续</td>
+</tr>
+<tr>
+<td>warning_type</td>
+<td>tinyint</td>
+<td>告警类型:0 不发,1 流程成功发,2 流程失败发,3 成功失败都发</td>
+</tr>
+<tr>
+<td>warning_group_id</td>
+<td>int</td>
+<td>告警组</td>
+</tr>
+<tr>
+<td>schedule_time</td>
+<td>datetime</td>
+<td>预期运行时间</td>
+</tr>
+<tr>
+<td>start_time</td>
+<td>datetime</td>
+<td>开始时间</td>
+</tr>
+<tr>
+<td>executor_id</td>
+<td>int</td>
+<td>执行用户id</td>
+</tr>
+<tr>
+<td>dependence</td>
+<td>varchar</td>
+<td>依赖字段</td>
+</tr>
+<tr>
+<td>update_time</td>
+<td>datetime</td>
+<td>更新时间</td>
+</tr>
+<tr>
+<td>process_instance_priority</td>
+<td>int</td>
+<td>流程实例优先级:0 Highest,1 High,2 Medium,3 Low,4 Lowest</td>
+</tr>
+<tr>
+<td>worker_group</td>
+<td>varchar</td>
+<td>任务指定运行的worker分组</td>
+</tr>
+</tbody>
+</table>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>文档</dt><dd><a href="/zh-cn/docs/development/architecture-design.html" target="_self">概览</a></dd><dd><a href="/zh-cn/docs/1.3.1/user_doc/quick-start.html" target="_self">快速开始</a></dd><dd><a href="/zh-cn/docs/development/backend-development.html" target="_self">开发者指南</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http://www.apache.org" target="_self">基金 [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/metadata-1.3.json b/zh-cn/docs/1.3.2/user_doc/metadata-1.3.json
new file mode 100644
index 0000000..b1f3f11
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/metadata-1.3.json
@@ -0,0 +1,6 @@
+{
+  "filename": "metadata-1.3.md",
+  "__html": "<h1>Dolphin Scheduler 1.3元数据文档</h1>\n<p><a name=\"25Ald\"></a></p>\n<h3>表概览</h3>\n<table>\n<thead>\n<tr>\n<th style=\"text-align:center\">表名</th>\n<th style=\"text-align:center\">表信息</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td style=\"text-align:center\">t_ds_access_token</td>\n<td style=\"text-align:center\">访问ds后端的token</td>\n</tr>\n<tr>\n<td style=\"text-align:center\">t_ds_alert</td>\n<td style=\"text-align:center\">告警信息</td>\n</tr>\n<tr>\n<td style=\"text-align:center\">t [...]
+  "link": "/zh-cn/docs/1.3.2/user_doc/metadata-1.3.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/quick-start.html b/zh-cn/docs/1.3.2/user_doc/quick-start.html
new file mode 100644
index 0000000..9acb846
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/quick-start.html
@@ -0,0 +1,97 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="quick-start" />
+	<meta name="description" content="quick-start" />
+	<!-- 网页标签标题 -->
+	<title>quick-start</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/zh-cn/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">En</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass an [...]
+<ul>
+<li>管理员用户登录
+<blockquote>
+<p>地址:192.168.xx.xx:8888 用户名密码:admin/dolphinscheduler123</p>
+</blockquote>
+</li>
+</ul>
+<p align="center">
+   <img src="/img/login.png" width="60%" />
+ </p>
+<ul>
+<li>创建队列</li>
+</ul>
+<p align="center">
+   <img src="/img/create-queue.png" width="60%" />
+ </p>
+<ul>
+<li>创建租户</li>
+</ul>
+   <p align="center">
+    <img src="/img/addtenant.png" width="60%" />
+  </p>
+<ul>
+<li>创建普通用户</li>
+</ul>
+<p align="center">
+   <img src="/img/useredit2.png" width="60%" />
+ </p>
+<ul>
+<li>创建告警组</li>
+</ul>
+ <p align="center">
+    <img src="/img/mail_edit.png" width="60%" />
+  </p>
+<ul>
+<li>创建Worker分组</li>
+</ul>
+ <p align="center">
+    <img src="/img/worker_group.png" width="60%" />
+  </p>
+<ul>
+<li>创建token令牌</li>
+</ul>
+ <p align="center">
+    <img src="/img/creat_token.png" width="60%" />
+  </p>
+<ul>
+<li>使用普通用户登录</li>
+</ul>
+<blockquote>
+<p>点击右上角用户名“退出”,重新使用普通用户登录。</p>
+</blockquote>
+<ul>
+<li>项目管理-&gt;创建项目-&gt;点击项目名称</li>
+</ul>
+<p align="center">
+   <img src="/img/project.png" width="60%" />
+ </p>
+<ul>
+<li>点击工作流定义-&gt;创建工作流定义-&gt;上线工作流定义</li>
+</ul>
+<p align="center">
+   <img src="/img/dag1.png" width="60%" />
+ </p>
+<ul>
+<li>运行工作流定义-&gt;点击工作流实例-&gt;点击工作流实例名称-&gt;双击任务节点-&gt;查看任务执行日志</li>
+</ul>
+ <p align="center">
+   <img src="/img/task-log.png" width="60%" />
+</p></div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>文档</dt><dd><a href="/zh-cn/docs/development/architecture-design.html" target="_self">概览</a></dd><dd><a href="/zh-cn/docs/1.3.1/user_doc/quick-start.html" target="_self">快速开始</a></dd><dd><a href="/zh-cn/docs/development/backend-development.html" target="_self">开发者指南</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http://www.apache.org" target="_self">基金 [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/quick-start.json b/zh-cn/docs/1.3.2/user_doc/quick-start.json
new file mode 100644
index 0000000..1e41205
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/quick-start.json
@@ -0,0 +1,6 @@
+{
+  "filename": "quick-start.md",
+  "__html": "<h1>快速上手</h1>\n<ul>\n<li>管理员用户登录\n<blockquote>\n<p>地址:192.168.xx.xx:8888 用户名密码:admin/dolphinscheduler123</p>\n</blockquote>\n</li>\n</ul>\n<p align=\"center\">\n   <img src=\"/img/login.png\" width=\"60%\" />\n </p>\n<ul>\n<li>创建队列</li>\n</ul>\n<p align=\"center\">\n   <img src=\"/img/create-queue.png\" width=\"60%\" />\n </p>\n<ul>\n<li>创建租户</li>\n</ul>\n   <p align=\"center\">\n    <img src=\"/img/addtenant.png\" width=\"60%\" />\n  </p>\n<ul>\n<li>创建普通用户</li>\n</ul>\n<p a [...]
+  "link": "/zh-cn/docs/1.3.2/user_doc/quick-start.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/standalone-deployment.html b/zh-cn/docs/1.3.2/user_doc/standalone-deployment.html
new file mode 100644
index 0000000..57e839c
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/standalone-deployment.html
@@ -0,0 +1,332 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="standalone-deployment" />
+	<meta name="description" content="standalone-deployment" />
+	<!-- 网页标签标题 -->
+	<title>standalone-deployment</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/zh-cn/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">En</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass an [...]
+<h1>1、基础软件安装(必装项请自行安装)</h1>
+<ul>
+<li>PostgreSQL (8.2.15+) or MySQL (5.7系列)  :  两者任选其一即可</li>
+<li><a href="https://www.oracle.com/technetwork/java/javase/downloads/index.html">JDK</a> (1.8+) :  必装,请安装好后在/etc/profile下配置 JAVA_HOME 及 PATH 变量</li>
+<li>ZooKeeper (3.4.6+) :必装</li>
+<li>Hadoop (2.6+) or MinIO :选装, 如果需要用到资源上传功能,针对单机可以选择本地文件目录作为上传文件夹(此操作不需要部署Hadoop);当然也可以选择上传到Hadoop or MinIO集群上</li>
+</ul>
+<pre><code class="language-markdown"> 注意:DolphinScheduler本身不依赖Hadoop、Hive、Spark,仅是会调用他们的Client,用于对应任务的运行。
+</code></pre>
+<h1>2、下载二进制tar.gz包</h1>
+<ul>
+<li>请下载最新版本的后端安装包至服务器部署目录,比如创建 /opt/dolphinscheduler 做为安装部署目录,下载地址: <a href="https://dolphinscheduler.apache.org/zh-cn/docs/release/download.html">下载</a>,下载后上传tar包到该目录中,并进行解压</li>
+</ul>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> 创建部署目录,部署目录请不要创建在/root、/home等高权限目录 </span>
+mkdir -p /opt/dolphinscheduler;
+cd /opt/dolphinscheduler;
+<span class="hljs-meta">#</span><span class="bash"> 解压缩</span>
+tar -zxvf apache-dolphinscheduler-incubating-1.3.1-dolphinscheduler-bin.tar.gz -C /opt/dolphinscheduler;
+ 
+mv apache-dolphinscheduler-incubating-1.3.1-dolphinscheduler-bin  dolphinscheduler-bin
+</code></pre>
+<h1>3、创建部署用户并赋予目录操作权限</h1>
+<ul>
+<li>创建部署用户,并且一定要配置sudo免密。以创建dolphinscheduler用户为例</li>
+</ul>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> 创建用户需使用root登录</span>
+useradd dolphinscheduler;
+<span class="hljs-meta">
+#</span><span class="bash"> 添加密码</span>
+echo "dolphinscheduler" | passwd --stdin dolphinscheduler
+<span class="hljs-meta">
+#</span><span class="bash"> 配置sudo免密</span>
+sed -i '$adolphinscheduler  ALL=(ALL)  NOPASSWD: NOPASSWD: ALL' /etc/sudoers
+sed -i 's/Defaults    requirett/#Defaults    requirett/g' /etc/sudoers
+<span class="hljs-meta">
+#</span><span class="bash"> 修改目录权限,使得部署用户对dolphinscheduler-bin目录有操作权限</span>
+chown -R dolphinscheduler:dolphinscheduler dolphinscheduler-bin
+</code></pre>
+<pre><code> 注意:
+ - 因为任务执行服务是以 sudo -u {linux-user} 切换不同linux用户的方式来实现多租户运行作业,所以部署用户需要有 sudo 权限,而且是免密的。初学习者不理解的话,完全可以暂时忽略这一点
+ - 如果发现/etc/sudoers文件中有&quot;Default requiretty&quot;这行,也请注释掉
+ - 如果用到资源上传的话,还需要给该部署用户分配操作`本地文件系统或者HDFS或者MinIO`的权限
+</code></pre>
+<h1>4、ssh免密配置</h1>
+<ul>
+<li>切换到部署用户并配置ssh本机免密登录</li>
+</ul>
+<pre><code class="language-shell">su dolphinscheduler;
+
+ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa
+cat ~/.ssh/id_rsa.pub &gt;&gt; ~/.ssh/authorized_keys
+chmod 600 ~/.ssh/authorized_keys
+</code></pre>
+<p>注意:<em>正常设置后,dolphinscheduler用户在执行命令<code>ssh localhost</code> 是不需要再输入密码的</em></p>
+<h1>5、数据库初始化</h1>
+<ul>
+<li>进入数据库,默认数据库是PostgreSQL,如选择MySQL的话,后续需要添加mysql-connector-java驱动包到DolphinScheduler的lib目录下</li>
+</ul>
+<pre><code>mysql -uroot -p
+</code></pre>
+<ul>
+<li>
+<p>进入数据库命令行窗口后,执行数据库初始化命令,设置访问账号和密码。<strong>注: {user} 和 {password} 需要替换为具体的数据库用户名和密码</strong></p>
+<pre><code class="language-mysql">mysql&gt; CREATE DATABASE dolphinscheduler DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_general_ci;
+mysql&gt; GRANT ALL PRIVILEGES ON dolphinscheduler.* TO '{user}'@'%' IDENTIFIED BY '{password}';
+mysql&gt; GRANT ALL PRIVILEGES ON dolphinscheduler.* TO '{user}'@'localhost' IDENTIFIED BY '{password}';
+mysql&gt; flush privileges;
+</code></pre>
+</li>
+<li>
+<p>创建表和导入基础数据</p>
+<ul>
+<li>
+<p>修改 conf 目录下 datasource.properties 中的下列配置</p>
+<ul>
+<li>
+<pre><code class="language-shell">vi conf/datasource.properties
+</code></pre>
+</li>
+</ul>
+</li>
+<li>
+<p>如果选择 MySQL,请注释掉 PostgreSQL 相关配置(反之同理), 还需要手动添加 [<a href="https://downloads.MySQL.com/archives/c-j/"> mysql-connector-java 驱动 jar </a>] 包到 lib 目录下,这里下载的是mysql-connector-java-5.1.47.jar,然后正确配置数据库连接相关信息</p>
+</li>
+</ul>
+<pre><code class="language-properties"><span class="hljs-comment">  # postgre</span>
+<span class="hljs-comment">  #spring.datasource.driver-class-name=org.postgresql.Driver</span>
+<span class="hljs-comment">  #spring.datasource.url=jdbc:postgresql://localhost:5432/dolphinscheduler</span>
+<span class="hljs-comment">  # mysql</span>
+  <span class="hljs-meta">spring.datasource.driver-class-name</span>=<span class="hljs-string">com.mysql.jdbc.Driver</span>
+  <span class="hljs-meta">spring.datasource.url</span>=<span class="hljs-string">jdbc:mysql://xxx:3306/dolphinscheduler?useUnicode=true&amp;characterEncoding=UTF-8&amp;allowMultiQueries=true     需要修改ip,本机localhost即可</span>
+  <span class="hljs-meta">spring.datasource.username</span>=<span class="hljs-string">xxx						需要修改为上面的{user}值</span>
+  <span class="hljs-meta">spring.datasource.password</span>=<span class="hljs-string">xxx						需要修改为上面的{password}值</span>
+</code></pre>
+<ul>
+<li>修改并保存完后,执行 script 目录下的创建表及导入基础数据脚本</li>
+</ul>
+<pre><code class="language-shell">sh script/create-dolphinscheduler.sh
+</code></pre>
+</li>
+</ul>
+<p>​       <em>注意: 如果执行上述脚本报 ”/bin/java: No such file or directory“ 错误,请在/etc/profile下配置  JAVA_HOME 及 PATH 变量</em></p>
+<h1>6、修改运行参数</h1>
+<ul>
+<li>
+<p>修改 conf/env 目录下的 <code>dolphinscheduler_env.sh</code> 环境变量(以相关用到的软件都安装在/opt/soft下为例)</p>
+<pre><code class="language-shell">export HADOOP_HOME=/opt/soft/hadoop
+export HADOOP_CONF_DIR=/opt/soft/hadoop/etc/hadoop
+<span class="hljs-meta">#</span><span class="bash"><span class="hljs-built_in">export</span> SPARK_HOME1=/opt/soft/spark1</span>
+export SPARK_HOME2=/opt/soft/spark2
+export PYTHON_HOME=/opt/soft/python
+export JAVA_HOME=/opt/soft/java
+export HIVE_HOME=/opt/soft/hive
+export FLINK_HOME=/opt/soft/flink
+export DATAX_HOME=/opt/soft/datax/bin/datax.py
+export PATH=$HADOOP_HOME/bin:$SPARK_HOME2/bin:$PYTHON_HOME:$JAVA_HOME/bin:$HIVE_HOME/bin:$PATH:$FLINK_HOME/bin:$DATAX_HOME:$PATH
+</code></pre>
+<p><code>注: 这一步非常重要,例如 JAVA_HOME 和 PATH 是必须要配置的,没有用到的可以忽略或者注释掉;如果找不到dolphinscheduler_env.sh, 请运行 ls -a</code></p>
+</li>
+<li>
+<p>将jdk软链到/usr/bin/java下(仍以 JAVA_HOME=/opt/soft/java 为例)</p>
+<pre><code class="language-shell">sudo ln -s /opt/soft/java/bin/java /usr/bin/java
+</code></pre>
+</li>
+<li>
+<p>修改一键部署配置文件 <code>conf/config/install_config.conf</code>中的各参数,特别注意以下参数的配置</p>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash"> 这里填 mysql or postgresql</span>
+dbtype="mysql"
+<span class="hljs-meta">
+#</span><span class="bash"> 数据库连接地址</span>
+dbhost="localhost:3306"
+<span class="hljs-meta">
+#</span><span class="bash"> 数据库名</span>
+dbname="dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> 数据库用户名,此处需要修改为上面设置的{user}具体值</span>
+username="xxx"    
+<span class="hljs-meta">
+#</span><span class="bash"> 数据库密码, 如果有特殊字符,请使用\转义,需要修改为上面设置的{password}具体值</span>
+password="xxx"
+<span class="hljs-meta">
+#</span><span class="bash">Zookeeper地址,单机本机是localhost:2181,记得把2181端口带上</span>
+zkQuorum="localhost:2181"
+<span class="hljs-meta">
+#</span><span class="bash">将DS安装到哪个目录,如: /opt/soft/dolphinscheduler,不同于现在的目录</span>
+installPath="/opt/soft/dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash">使用哪个用户部署,使用第3节创建的用户</span>
+deployUser="dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> 邮件配置,以qq邮箱为例</span>
+<span class="hljs-meta">#</span><span class="bash"> 邮件协议</span>
+mailProtocol="SMTP"
+<span class="hljs-meta">
+#</span><span class="bash"> 邮件服务地址</span>
+mailServerHost="smtp.qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> 邮件服务端口</span>
+mailServerPort="25"
+<span class="hljs-meta">
+#</span><span class="bash"> mailSender和mailUser配置成一样即可</span>
+<span class="hljs-meta">#</span><span class="bash"> 发送者</span>
+mailSender="xxx@qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> 发送用户</span>
+mailUser="xxx@qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> 邮箱密码</span>
+mailPassword="xxx"
+<span class="hljs-meta">
+#</span><span class="bash"> TLS协议的邮箱设置为<span class="hljs-literal">true</span>,否则设置为<span class="hljs-literal">false</span></span>
+starttlsEnable="true"
+<span class="hljs-meta">
+#</span><span class="bash"> 开启SSL协议的邮箱配置为<span class="hljs-literal">true</span>,否则为<span class="hljs-literal">false</span>。注意: starttlsEnable和sslEnable不能同时为<span class="hljs-literal">true</span></span>
+sslEnable="false"
+<span class="hljs-meta">
+#</span><span class="bash"> 邮件服务地址值,参考上面 mailServerHost</span>
+sslTrust="smtp.qq.com"
+<span class="hljs-meta">
+#</span><span class="bash"> 业务用到的比如sql等资源文件上传到哪里,可以设置:HDFS,S3,NONE,单机如果想使用本地文件系统,请配置为HDFS,因为HDFS支持本地文件系统;如果不需要资源上传功能请选择NONE。强调一点:使用本地文件系统不需要部署hadoop</span>
+resourceStorageType="HDFS"
+<span class="hljs-meta">
+#</span><span class="bash"> 这里以保存到本地文件系统为例</span>
+<span class="hljs-meta">#</span><span class="bash">注:但是如果你想上传到HDFS的话,NameNode启用了HA,则需要将hadoop的配置文件core-site.xml和hdfs-site.xml放到conf目录下,本例即是放到/opt/dolphinscheduler/conf下面,并配置namenode cluster名称;如果NameNode不是HA,则修改为具体的ip或者主机名即可</span>
+defaultFS="file:///data/dolphinscheduler"    #hdfs://{具体的ip/主机名}:8020
+<span class="hljs-meta">
+#</span><span class="bash"> 如果没有使用到Yarn,保持以下默认值即可;如果ResourceManager是HA,则配置为ResourceManager节点的主备ip或者hostname,比如<span class="hljs-string">"192.168.xx.xx,192.168.xx.xx"</span>;如果是单ResourceManager请配置yarnHaIps=<span class="hljs-string">""</span>即可</span>
+yarnHaIps="192.168.xx.xx,192.168.xx.xx"
+<span class="hljs-meta">
+#</span><span class="bash"> 如果ResourceManager是HA或者没有使用到Yarn保持默认值即可;如果是单ResourceManager,请配置真实的ResourceManager主机名或者ip</span>
+singleYarnIp="yarnIp1"
+<span class="hljs-meta">
+#</span><span class="bash"> 资源上传根路径,支持HDFS和S3,由于hdfs支持本地文件系统,需要确保本地文件夹存在且有读写权限</span>
+resourceUploadPath="/data/dolphinscheduler"
+<span class="hljs-meta">
+#</span><span class="bash"> 具备权限创建resourceUploadPath的用户</span>
+hdfsRootUser="hdfs"
+<span class="hljs-meta">
+#</span><span class="bash">在哪些机器上部署DS服务,本机选localhost</span>
+ips="localhost"
+<span class="hljs-meta">
+#</span><span class="bash">ssh端口,默认22</span>
+sshPort="22"
+<span class="hljs-meta">
+#</span><span class="bash">master服务部署在哪台机器上</span>
+masters="localhost"
+<span class="hljs-meta">
+#</span><span class="bash">worker服务部署在哪台机器上,并指定此worker属于哪一个worker组,下面示例的default即为组名</span>
+workers="localhost:default"
+<span class="hljs-meta">
+#</span><span class="bash">报警服务部署在哪台机器上</span>
+alertServer="localhost"
+<span class="hljs-meta">
+#</span><span class="bash">后端api服务部署在在哪台机器上</span>
+apiServers="localhost"
+
+</code></pre>
+<p><em>注:如果打算用到<code>资源中心</code>功能,请执行以下命令:</em></p>
+<pre><code class="language-shell">sudo mkdir /data/dolphinscheduler
+sudo chown -R dolphinscheduler:dolphinscheduler /data/dolphinscheduler
+</code></pre>
+</li>
+</ul>
+<h1>7、一键部署</h1>
+<ul>
+<li>
+<p>切换到部署用户,执行一键部署脚本</p>
+<p><code>sh install.sh</code></p>
+<pre><code>注意:
+第一次部署的话,在运行中第3步`3,stop server`出现5次以下信息,此信息可以忽略
+sh: bin/dolphinscheduler-daemon.sh: No such file or directory
+</code></pre>
+</li>
+<li>
+<p>脚本完成后,会启动以下5个服务,使用<code>jps</code>命令查看服务是否启动(<code>jps</code>为<code>java JDK</code>自带)</p>
+</li>
+</ul>
+<pre><code class="language-aidl">    MasterServer         ----- master服务
+    WorkerServer         ----- worker服务
+    LoggerServer         ----- logger服务
+    ApiApplicationServer ----- api服务
+    AlertServer          ----- alert服务
+</code></pre>
+<p>如果以上服务都正常启动,说明自动部署成功</p>
+<p>部署成功后,可以进行日志查看,日志统一存放于logs文件夹内</p>
+<pre><code class="language-日志路径"> logs/
+    ├── dolphinscheduler-alert-server.log
+    ├── dolphinscheduler-master-server.log
+    |—— dolphinscheduler-worker-server.log
+    |—— dolphinscheduler-api-server.log
+    |—— dolphinscheduler-logger-server.log
+</code></pre>
+<h1>8、登录系统</h1>
+<ul>
+<li>
+<p>访问前端页面地址,接口ip(自行修改)
+<a href="http://192.168.xx.xx:12345/dolphinscheduler">http://192.168.xx.xx:12345/dolphinscheduler</a></p>
+ <p align="center">
+   <img src="/img/login.png" width="60%" />
+ </p>
+</li>
+</ul>
+<h1>9、启停服务</h1>
+<ul>
+<li>
+<p>一键停止集群所有服务</p>
+<p><code>sh ./bin/stop-all.sh</code></p>
+</li>
+<li>
+<p>一键开启集群所有服务</p>
+<p><code>sh ./bin/start-all.sh</code></p>
+</li>
+<li>
+<p>启停Master</p>
+</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start master-server
+sh ./bin/dolphinscheduler-daemon.sh stop master-server
+</code></pre>
+<ul>
+<li>启停Worker</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start worker-server
+sh ./bin/dolphinscheduler-daemon.sh stop worker-server
+</code></pre>
+<ul>
+<li>启停Api</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start api-server
+sh ./bin/dolphinscheduler-daemon.sh stop api-server
+</code></pre>
+<ul>
+<li>启停Logger</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start logger-server
+sh ./bin/dolphinscheduler-daemon.sh stop logger-server
+</code></pre>
+<ul>
+<li>启停Alert</li>
+</ul>
+<pre><code class="language-shell">sh ./bin/dolphinscheduler-daemon.sh start alert-server
+sh ./bin/dolphinscheduler-daemon.sh stop alert-server
+</code></pre>
+<p><code>注:服务用途请具体参见《系统架构设计》小节</code></p>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>文档</dt><dd><a href="/zh-cn/docs/development/architecture-design.html" target="_self">概览</a></dd><dd><a href="/zh-cn/docs/1.3.1/user_doc/quick-start.html" target="_self">快速开始</a></dd><dd><a href="/zh-cn/docs/development/backend-development.html" target="_self">开发者指南</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http://www.apache.org" target="_self">基金 [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/standalone-deployment.json b/zh-cn/docs/1.3.2/user_doc/standalone-deployment.json
new file mode 100644
index 0000000..c737496
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/standalone-deployment.json
@@ -0,0 +1,6 @@
+{
+  "filename": "standalone-deployment.md",
+  "__html": "<h1>单机部署(Standalone)</h1>\n<h1>1、基础软件安装(必装项请自行安装)</h1>\n<ul>\n<li>PostgreSQL (8.2.15+) or MySQL (5.7系列)  :  两者任选其一即可</li>\n<li><a href=\"https://www.oracle.com/technetwork/java/javase/downloads/index.html\">JDK</a> (1.8+) :  必装,请安装好后在/etc/profile下配置 JAVA_HOME 及 PATH 变量</li>\n<li>ZooKeeper (3.4.6+) :必装</li>\n<li>Hadoop (2.6+) or MinIO :选装, 如果需要用到资源上传功能,针对单机可以选择本地文件目录作为上传文件夹(此操作不需要部署Hadoop);当然也可以选择上传到Hadoop or MinIO集群上</li>\n</ul>\n<pre><code class=\"language-markdown\"> 注意:Do [...]
+  "link": "/zh-cn/docs/1.3.2/user_doc/standalone-deployment.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/system-manual.html b/zh-cn/docs/1.3.2/user_doc/system-manual.html
new file mode 100644
index 0000000..57aa8e7
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/system-manual.html
@@ -0,0 +1,986 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="system-manual" />
+	<meta name="description" content="system-manual" />
+	<!-- 网页标签标题 -->
+	<title>system-manual</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/zh-cn/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">En</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass an [...]
+<h2>快速上手</h2>
+<blockquote>
+<p>请参照<a href="quick-start.html">快速上手</a></p>
+</blockquote>
+<h2>操作指南</h2>
+<h3>1. 首页</h3>
+<p>首页包含用户所有项目的任务状态统计、流程状态统计、工作流定义统计。
+<p align="center">
+<img src="/img/home.png" width="80%" />
+</p></p>
+<h3>2. 项目管理</h3>
+<h4>2.1 创建项目</h4>
+<ul>
+<li>
+<p>点击&quot;项目管理&quot;进入项目管理页面,点击“创建项目”按钮,输入项目名称,项目描述,点击“提交”,创建新的项目。</p>
+<p align="center">
+    <img src="/img/project.png" width="80%" />
+</p>
+</li>
+</ul>
+<h4>2.2 项目首页</h4>
+<ul>
+<li>
+<p>在项目管理页面点击项目名称链接,进入项目首页,如下图所示,项目首页包含该项目的任务状态统计、流程状态统计、工作流定义统计。</p>
+<p align="center">
+   <img src="/img/project-home.png" width="80%" />
+</p>
+</li>
+<li>
+<p>任务状态统计:在指定时间范围内,统计任务实例中状态为提交成功、正在运行、准备暂停、暂停、准备停止、停止、失败、成功、需要容错、kill、等待线程的个数</p>
+</li>
+<li>
+<p>流程状态统计:在指定时间范围内,统计工作流实例中状态为提交成功、正在运行、准备暂停、暂停、准备停止、停止、失败、成功、需要容错、kill、等待线程的个数</p>
+</li>
+<li>
+<p>工作流定义统计:统计用户创建的工作流定义及管理员授予该用户的工作流定义</p>
+</li>
+</ul>
+<h4>2.3 工作流定义</h4>
+<h4><span id=creatDag>2.3.1 创建工作流定义</span></h4>
+<ul>
+<li>点击项目管理-&gt;工作流-&gt;工作流定义,进入工作流定义页面,点击“创建工作流”按钮,进入<strong>工作流DAG编辑</strong>页面,如下图所示:<p align="center">
+    <img src="/img/dag0.png" width="80%" />
+</p>  
+</li>
+<li>工具栏中拖拽<img src="/img/shell.png" width="35"/>到画板中,新增一个Shell任务,如下图所示:<p align="center">
+    <img src="/img/shell_dag.png" width="80%" />
+</p>  
+</li>
+<li><strong>添加shell任务的参数设置:</strong></li>
+</ul>
+<ol>
+<li>填写“节点名称”,“描述”,“脚本”字段;</li>
+<li>“运行标志”勾选“正常”,若勾选“禁止执行”,运行工作流不会执行该任务;</li>
+<li>选择“任务优先级”:当worker线程数不足时,级别高的任务在执行队列中会优先执行,相同优先级的任务按照先进先出的顺序执行;</li>
+<li>超时告警(非必选):勾选超时告警、超时失败,填写“超时时长”,当任务执行时间超过<strong>超时时长</strong>,会发送告警邮件并且任务超时失败;</li>
+<li>资源(非必选)。资源文件是资源中心-&gt;文件管理页面创建或上传的文件,如文件名为<code>test.sh</code>,脚本中调用资源命令为<code>sh test.sh</code>;</li>
+<li>自定义参数(非必填),参考<a href="#UserDefinedParameters">自定义参数</a>;</li>
+<li>点击&quot;确认添加&quot;按钮,保存任务设置。</li>
+</ol>
+<ul>
+<li>
+<p><strong>增加任务执行的先后顺序:</strong> 点击右上角图标<img src="/img/line.png" width="35"/>连接任务;如下图所示,任务2和任务3并行执行,当任务1执行完,任务2、3会同时执行。</p>
+<p align="center">
+   <img src="/img/dag2.png" width="80%" />
+</p>
+</li>
+<li>
+<p><strong>删除依赖关系:</strong> 点击右上角&quot;箭头&quot;图标<img src="/img/arrow.png" width="35"/>,选中连接线,点击右上角&quot;删除&quot;图标<img src="/img/delete.png" width="35"/>,删除任务间的依赖关系。</p>
+<p align="center">
+   <img src="/img/dag3.png" width="80%" />
+</p>
+</li>
+<li>
+<p><strong>保存工作流定义:</strong> 点击”保存“按钮,弹出&quot;设置DAG图名称&quot;弹框,如下图所示,输入工作流定义名称,工作流定义描述,设置全局参数(选填,参考<a href="#UserDefinedParameters">自定义参数</a>),点击&quot;添加&quot;按钮,工作流定义创建成功。</p>
+<p align="center">
+   <img src="/img/dag4.png" width="80%" />
+ </p>
+</li>
+</ul>
+<blockquote>
+<p>其他类型任务,请参考 <a href="#TaskParamers">任务节点类型和参数设置</a>。</p>
+</blockquote>
+<h4>2.3.2  工作流定义操作功能</h4>
+<p>点击项目管理-&gt;工作流-&gt;工作流定义,进入工作流定义页面,如下图所示:
+<p align="center">
+<img src="/img/work_list.png" width="80%" />
+</p>
+工作流定义列表的操作功能如下:</p>
+<ul>
+<li><strong>编辑:</strong> 只能编辑&quot;下线&quot;的工作流定义。工作流DAG编辑同<a href="#creatDag">创建工作流定义</a>。</li>
+<li><strong>上线:</strong> 工作流状态为&quot;下线&quot;时,上线工作流,只有&quot;上线&quot;状态的工作流能运行,但不能编辑。</li>
+<li><strong>下线:</strong> 工作流状态为&quot;上线&quot;时,下线工作流,下线状态的工作流可以编辑,但不能运行。</li>
+<li><strong>运行:</strong> 只有上线的工作流能运行。运行操作步骤见<a href="#runWorkflow">2.3.3 运行工作流</a></li>
+<li><strong>定时:</strong> 只有上线的工作流能设置定时,系统自动定时调度工作流运行。创建定时后的状态为&quot;下线&quot;,需在定时管理页面上线定时才生效。定时操作步骤见<a href="#creatTiming">2.3.4 工作流定时</a>。</li>
+<li><strong>定时管理:</strong> 定时管理页面可编辑、上线/下线、删除定时。</li>
+<li><strong>删除:</strong> 删除工作流定义。</li>
+<li><strong>下载:</strong> 下载工作流定义到本地。</li>
+<li><strong>树形图:</strong> 以树形结构展示任务节点的类型及任务状态,如下图所示:<p align="center">
+    <img src="/img/tree.png" width="80%" />
+</p>  
+</li>
+</ul>
+<h4><span id=runWorkflow>2.3.3 运行工作流</span></h4>
+<ul>
+<li>
+<p>点击项目管理-&gt;工作流-&gt;工作流定义,进入工作流定义页面,如下图所示,点击&quot;上线&quot;按钮<img src="/img/online.png" width="35"/>,上线工作流。</p>
+<p align="center">
+    <img src="/img/work_list.png" width="80%" />
+</p>
+</li>
+<li>
+<p>点击”运行“按钮,弹出启动参数设置弹框,如下图所示,设置启动参数,点击弹框中的&quot;运行&quot;按钮,工作流开始运行,工作流实例页面生成一条工作流实例。</p>
+ <p align="center">
+   <img src="/img/run-work.png" width="80%" />
+ </p>  
+</li>
+</ul>
+<p><span id=runParamers>工作流运行参数说明:</span></p>
+<pre><code>* 失败策略:当某一个任务节点执行失败时,其他并行的任务节点需要执行的策略。”继续“表示:某一任务失败后,其他任务节点正常执行;”结束“表示:终止所有正在执行的任务,并终止整个流程。
+* 通知策略:当流程结束,根据流程状态发送流程执行信息通知邮件,包含任何状态都不发,成功发,失败发,成功或失败都发。
+* 流程优先级:流程运行的优先级,分五个等级:最高(HIGHEST),高(HIGH),中(MEDIUM),低(LOW),最低(LOWEST)。当master线程数不足时,级别高的流程在执行队列中会优先执行,相同优先级的流程按照先进先出的顺序执行。
+* worker分组:该流程只能在指定的worker机器组里执行。默认是Default,可以在任一worker上执行。
+* 通知组:选择通知策略||超时报警||发生容错时,会发送流程信息或邮件到通知组里的所有成员。
+* 收件人:选择通知策略||超时报警||发生容错时,会发送流程信息或告警邮件到收件人列表。
+* 抄送人:选择通知策略||超时报警||发生容错时,会抄送流程信息或告警邮件到抄送人列表。
+* 补数:包括串行补数、并行补数2种模式。串行补数:指定时间范围内,从开始日期至结束日期依次执行补数,只生成一条流程实例;并行补数:指定时间范围内,多天同时进行补数,生成N条流程实例。 
+</code></pre>
+<ul>
+<li>
+<p>补数: 执行指定日期的工作流定义,可以选择补数时间范围(目前只支持针对连续的天进行补数),比如需要补5月1号到5月10号的数据,如下图所示:</p>
+<p align="center">
+    <img src="/img/complement.png" width="80%" />
+</p>
+<blockquote>
+<p>串行模式:补数从5月1号到5月10号依次执行,流程实例页面生成一条流程实例;</p>
+</blockquote>
+<blockquote>
+<p>并行模式:同时执行5月1号到5月10号的任务,流程实例页面生成十条流程实例。</p>
+</blockquote>
+</li>
+</ul>
+<h4><span id=creatTiming>2.3.4 工作流定时</span></h4>
+<ul>
+<li>创建定时:点击项目管理-&gt;工作流-&gt;工作流定义,进入工作流定义页面,上线工作流,点击&quot;定时&quot;按钮<img src="/img/timing.png" width="35"/>,弹出定时参数设置弹框,如下图所示:<p align="center">
+    <img src="/img/time-schedule.png" width="80%" />
+</p>
+</li>
+<li>选择起止时间。在起止时间范围内,定时运行工作流;不在起止时间范围内,不再产生定时工作流实例。</li>
+<li>添加一个每天凌晨5点执行一次的定时,如下图所示:<p align="center">
+    <img src="/img/time-schedule2.png" width="80%" />
+</p>
+</li>
+<li>失败策略、通知策略、流程优先级、Worker分组、通知组、收件人、抄送人同<a href="#runParamers">工作流运行参数</a>。</li>
+<li>点击&quot;创建&quot;按钮,创建定时成功,此时定时状态为&quot;<strong>下线</strong>&quot;,定时需<strong>上线</strong>才生效。</li>
+<li>定时上线:点击&quot;定时管理&quot;按钮<img src="/img/timeManagement.png" width="35"/>,进入定时管理页面,点击&quot;上线&quot;按钮,定时状态变为&quot;上线&quot;,如下图所示,工作流定时生效。<p align="center">
+    <img src="/img/time-schedule3.png" width="80%" />
+</p>
+</li>
+</ul>
+<h4>2.3.5 导入工作流</h4>
+<p>点击项目管理-&gt;工作流-&gt;工作流定义,进入工作流定义页面,点击&quot;导入工作流&quot;按钮,导入本地工作流文件,工作流定义列表显示导入的工作流,状态为下线。</p>
+<h4>2.4 工作流实例</h4>
+<h4>2.4.1 查看工作流实例</h4>
+<ul>
+<li>点击项目管理-&gt;工作流-&gt;工作流实例,进入工作流实例页面,如下图所示:   <p align="center">
+      <img src="/img/instance-list.png" width="80%" />
+   </p>           
+</li>
+<li>点击工作流名称,进入DAG查看页面,查看任务执行状态,如下图所示。<p align="center">
+  <img src="/img/instance-detail.png" width="80%" />
+</p>
+</li>
+</ul>
+<h4>2.4.2 查看任务日志</h4>
+<ul>
+<li>进入工作流实例页面,点击工作流名称,进入DAG查看页面,双击任务节点,如下图所示: <p align="center">
+   <img src="/img/instanceViewLog.png" width="80%" />
+ </p>
+</li>
+<li>点击&quot;查看日志&quot;,弹出日志弹框,如下图所示,任务实例页面也可查看任务日志,参考<a href="#taskLog">任务查看日志</a>。 <p align="center">
+   <img src="/img/task-log.png" width="80%" />
+ </p>
+</li>
+</ul>
+<h4>2.4.3 查看任务历史记录</h4>
+<ul>
+<li>点击项目管理-&gt;工作流-&gt;工作流实例,进入工作流实例页面,点击工作流名称,进入工作流DAG页面;</li>
+<li>双击任务节点,如下图所示,点击&quot;查看历史&quot;,跳转到任务实例页面,并展示该工作流实例运行的任务实例列表 <p align="center">
+   <img src="/img/task_history.png" width="80%" />
+ </p>
+</li>
+</ul>
+<h4>2.4.4 查看运行参数</h4>
+<ul>
+<li>点击项目管理-&gt;工作流-&gt;工作流实例,进入工作流实例页面,点击工作流名称,进入工作流DAG页面;</li>
+<li>点击左上角图标<img src="/img/run_params_button.png" width="35"/>,查看工作流实例的启动参数;点击图标<img src="/img/global_param.png" width="35"/>,查看工作流实例的全局参数和局部参数,如下图所示: <p align="center">
+   <img src="/img/run_params.png" width="80%" />
+ </p>      
+</li>
+</ul>
+<h4>2.4.4 工作流实例操作功能</h4>
+<p>点击项目管理-&gt;工作流-&gt;工作流实例,进入工作流实例页面,如下图所示:<br>
+<p align="center">
+<img src="/img/instance-list.png" width="80%" />
+</p></p>
+<ul>
+<li><strong>编辑:</strong> 只能编辑已终止的流程。点击&quot;编辑&quot;按钮或工作流实例名称进入DAG编辑页面,编辑后点击&quot;保存&quot;按钮,弹出保存DAG弹框,如下图所示,在弹框中勾选&quot;是否更新到工作流定义&quot;,保存后则更新工作流定义;若不勾选,则不更新工作流定义。   <p align="center">
+     <img src="/img/editDag.png" width="80%" />
+   </p>
+</li>
+<li><strong>重跑:</strong> 重新执行已经终止的流程。</li>
+<li><strong>恢复失败:</strong> 针对失败的流程,可以执行恢复失败操作,从失败的节点开始执行。</li>
+<li><strong>停止:</strong> 对正在运行的流程进行<strong>停止</strong>操作,后台会先<code>kill</code>worker进程,再执行<code>kill -9</code>操作</li>
+<li><strong>暂停:</strong> 对正在运行的流程进行<strong>暂停</strong>操作,系统状态变为<strong>等待执行</strong>,会等待正在执行的任务结束,暂停下一个要执行的任务。</li>
+<li><strong>恢复暂停:</strong> 对暂停的流程恢复,直接从<strong>暂停的节点</strong>开始运行</li>
+<li><strong>删除:</strong> 删除工作流实例及工作流实例下的任务实例</li>
+<li><strong>甘特图:</strong> Gantt图纵轴是某个工作流实例下的任务实例的拓扑排序,横轴是任务实例的运行时间,如图示:   <p align="center">
+       <img src="/img/gant-pic.png" width="80%" />
+   </p>
+</li>
+</ul>
+<h4>2.5 任务实例</h4>
+<ul>
+<li>
+<p>点击项目管理-&gt;工作流-&gt;任务实例,进入任务实例页面,如下图所示,点击工作流实例名称,可跳转到工作流实例DAG图查看任务状态。</p>
+   <p align="center">
+      <img src="/img/task-list.png" width="80%" />
+   </p>
+</li>
+<li>
+<p><span id=taskLog>查看日志:</span>点击操作列中的“查看日志”按钮,可以查看任务执行的日志情况。</p>
+   <p align="center">
+      <img src="/img/task-log2.png" width="80%" />
+   </p>
+</li>
+</ul>
+<h3>3. 资源中心</h3>
+<h4>3.1 hdfs资源配置</h4>
+<ul>
+<li>上传资源文件和udf函数,所有上传的文件和资源都会被存储到hdfs上,所以需要以下配置项:</li>
+</ul>
+<pre><code>conf/common/common.properties  
+    # Users who have permission to create directories under the HDFS root path
+    hdfs.root.user=hdfs
+    # data base dir, resource file will store to this hadoop hdfs path, self configuration, please make sure the directory exists on hdfs and have read write permissions。&quot;/escheduler&quot; is recommended
+    data.store2hdfs.basepath=/dolphinscheduler
+    # resource upload startup type : HDFS,S3,NONE
+    res.upload.startup.type=HDFS
+    # whether kerberos starts
+    hadoop.security.authentication.startup.state=false
+    # java.security.krb5.conf path
+    java.security.krb5.conf.path=/opt/krb5.conf
+    # loginUserFromKeytab user
+    login.user.keytab.username=hdfs-mycluster@ESZ.COM
+    # loginUserFromKeytab path
+    login.user.keytab.path=/opt/hdfs.headless.keytab
+    
+conf/common/hadoop.properties      
+    # ha or single namenode,If namenode ha needs to copy core-site.xml and hdfs-site.xml
+    # to the conf directory,support s3,for example : s3a://dolphinscheduler
+    fs.defaultFS=hdfs://mycluster:8020    
+    #resourcemanager ha note this need ips , this empty if single
+    yarn.resourcemanager.ha.rm.ids=192.168.xx.xx,192.168.xx.xx    
+    # If it is a single resourcemanager, you only need to configure one host name. If it is resourcemanager HA, the default configuration is fine
+    yarn.application.status.address=http://xxxx:8088/ws/v1/cluster/apps/%s
+
+</code></pre>
+<ul>
+<li>yarn.resourcemanager.ha.rm.ids与yarn.application.status.address只需配置其中一个地址,另一个地址配置为空。</li>
+<li>需要从Hadoop集群的conf目录下复制core-site.xml、hdfs-site.xml到dolphinscheduler项目的conf目录下,重启api-server服务。</li>
+</ul>
+<h4>3.2 文件管理</h4>
+<blockquote>
+<p>是对各种资源文件的管理,包括创建基本的txt/log/sh/conf/py/java等文件、上传jar包等各种类型文件,可进行编辑、重命名、下载、删除等操作。</p>
+</blockquote>
+  <p align="center">
+   <img src="/img/file-manage.png" width="80%" />
+ </p>
+<ul>
+<li>创建文件</li>
+</ul>
+<blockquote>
+<p>文件格式支持以下几种类型:txt、log、sh、conf、cfg、py、java、sql、xml、hql、properties</p>
+</blockquote>
+<p align="center">
+   <img src="/img/file_create.png" width="80%" />
+ </p>
+<ul>
+<li>上传文件</li>
+</ul>
+<blockquote>
+<p>上传文件:点击&quot;上传文件&quot;按钮进行上传,将文件拖拽到上传区域,文件名会自动以上传的文件名称补全</p>
+</blockquote>
+<p align="center">
+   <img src="/img/file_upload.png" width="80%" />
+ </p>
+<ul>
+<li>文件查看</li>
+</ul>
+<blockquote>
+<p>对可查看的文件类型,点击文件名称,可查看文件详情</p>
+</blockquote>
+<p align="center">
+   <img src="/img/file_detail.png" width="80%" />
+ </p>
+<ul>
+<li>下载文件</li>
+</ul>
+<blockquote>
+<p>点击文件列表的&quot;下载&quot;按钮下载文件或者在文件详情中点击右上角&quot;下载&quot;按钮下载文件</p>
+</blockquote>
+<ul>
+<li>文件重命名</li>
+</ul>
+<p align="center">
+   <img src="/img/file_rename.png" width="80%" />
+ </p>
+<ul>
+<li>删除</li>
+</ul>
+<blockquote>
+<p>文件列表-&gt;点击&quot;删除&quot;按钮,删除指定文件</p>
+</blockquote>
+<h4>3.3 UDF管理</h4>
+<h4>3.3.1 资源管理</h4>
+<blockquote>
+<p>资源管理和文件管理功能类似,不同之处是资源管理是上传的UDF函数,文件管理上传的是用户程序,脚本及配置文件
+操作功能:重命名、下载、删除。</p>
+</blockquote>
+<ul>
+<li>上传udf资源</li>
+</ul>
+<blockquote>
+<p>和上传文件相同。</p>
+</blockquote>
+<h4>3.3.2 函数管理</h4>
+<ul>
+<li>创建udf函数</li>
+</ul>
+<blockquote>
+<p>点击“创建UDF函数”,输入udf函数参数,选择udf资源,点击“提交”,创建udf函数。</p>
+</blockquote>
+<blockquote>
+<p>目前只支持HIVE的临时UDF函数</p>
+</blockquote>
+<ul>
+<li>UDF函数名称:输入UDF函数时的名称</li>
+<li>包名类名:输入UDF函数的全路径</li>
+<li>UDF资源:设置创建的UDF对应的资源文件</li>
+</ul>
+<p align="center">
+   <img src="/img/udf_edit.png" width="80%" />
+ </p>
+<h3>4. 创建数据源</h3>
+<blockquote>
+<p>数据源中心支持MySQL、POSTGRESQL、HIVE/IMPALA、SPARK、CLICKHOUSE、ORACLE、SQLSERVER等数据源</p>
+</blockquote>
+<h4>4.1 创建/编辑MySQL数据源</h4>
+<ul>
+<li>
+<p>点击“数据源中心-&gt;创建数据源”,根据需求创建不同类型的数据源。</p>
+</li>
+<li>
+<p>数据源:选择MYSQL</p>
+</li>
+<li>
+<p>数据源名称:输入数据源的名称</p>
+</li>
+<li>
+<p>描述:输入数据源的描述</p>
+</li>
+<li>
+<p>IP主机名:输入连接MySQL的IP</p>
+</li>
+<li>
+<p>端口:输入连接MySQL的端口</p>
+</li>
+<li>
+<p>用户名:设置连接MySQL的用户名</p>
+</li>
+<li>
+<p>密码:设置连接MySQL的密码</p>
+</li>
+<li>
+<p>数据库名:输入连接MySQL的数据库名称</p>
+</li>
+<li>
+<p>Jdbc连接参数:用于MySQL连接的参数设置,以JSON形式填写</p>
+</li>
+</ul>
+<p align="center">
+   <img src="/img/mysql_edit.png" width="80%" />
+ </p>
+<blockquote>
+<p>点击“测试连接”,测试数据源是否可以连接成功。</p>
+</blockquote>
+<h4>4.2 创建/编辑POSTGRESQL数据源</h4>
+<ul>
+<li>数据源:选择POSTGRESQL</li>
+<li>数据源名称:输入数据源的名称</li>
+<li>描述:输入数据源的描述</li>
+<li>IP/主机名:输入连接POSTGRESQL的IP</li>
+<li>端口:输入连接POSTGRESQL的端口</li>
+<li>用户名:设置连接POSTGRESQL的用户名</li>
+<li>密码:设置连接POSTGRESQL的密码</li>
+<li>数据库名:输入连接POSTGRESQL的数据库名称</li>
+<li>Jdbc连接参数:用于POSTGRESQL连接的参数设置,以JSON形式填写</li>
+</ul>
+<p align="center">
+   <img src="/img/postgresql_edit.png" width="80%" />
+ </p>
+<h4>4.3 创建/编辑HIVE数据源</h4>
+<p>1.使用HiveServer2方式连接</p>
+ <p align="center">
+    <img src="/img/hive_edit.png" width="80%" />
+  </p>
+<ul>
+<li>数据源:选择HIVE</li>
+<li>数据源名称:输入数据源的名称</li>
+<li>描述:输入数据源的描述</li>
+<li>IP/主机名:输入连接HIVE的IP</li>
+<li>端口:输入连接HIVE的端口</li>
+<li>用户名:设置连接HIVE的用户名</li>
+<li>密码:设置连接HIVE的密码</li>
+<li>数据库名:输入连接HIVE的数据库名称</li>
+<li>Jdbc连接参数:用于HIVE连接的参数设置,以JSON形式填写</li>
+</ul>
+<p>2.使用HiveServer2 HA Zookeeper方式连接</p>
+ <p align="center">
+    <img src="/img/hive_edit2.png" width="80%" />
+  </p>
+<p>注意:如果开启了<strong>kerberos</strong>,则需要填写 <strong>Principal</strong></p>
+<p align="center">
+    <img src="/img/hive_kerberos.png" width="80%" />
+  </p>
+<h4>4.4 创建/编辑Spark数据源</h4>
+<p align="center">
+   <img src="/img/spark_datesource.png" width="80%" />
+ </p>
+<ul>
+<li>数据源:选择Spark</li>
+<li>数据源名称:输入数据源的名称</li>
+<li>描述:输入数据源的描述</li>
+<li>IP/主机名:输入连接Spark的IP</li>
+<li>端口:输入连接Spark的端口</li>
+<li>用户名:设置连接Spark的用户名</li>
+<li>密码:设置连接Spark的密码</li>
+<li>数据库名:输入连接Spark的数据库名称</li>
+<li>Jdbc连接参数:用于Spark连接的参数设置,以JSON形式填写</li>
+</ul>
+<p>注意:如果开启了<strong>kerberos</strong>,则需要填写 <strong>Principal</strong></p>
+<p align="center">
+    <img src="/img/sparksql_kerberos.png" width="80%" />
+  </p>
+<h3>5. 安全中心(权限系统)</h3>
+<pre><code> * 安全中心只有管理员账户才有权限操作,分别有队列管理、租户管理、用户管理、告警组管理、worker分组管理、令牌管理等功能,在用户管理模块可以对资源、数据源、项目等授权
+ * 管理员登录,默认用户名密码:admin/dolphinscheduler123
+</code></pre>
+<h4>5.1 创建队列</h4>
+<ul>
+<li>队列是在执行spark、mapreduce等程序,需要用到“队列”参数时使用的。</li>
+<li>管理员进入安全中心-&gt;队列管理页面,点击“创建队列”按钮,创建队列。</li>
+</ul>
+ <p align="center">
+    <img src="/img/create-queue.png" width="80%" />
+  </p>
+<h4>5.2 添加租户</h4>
+<ul>
+<li>租户对应的是Linux的用户,用于worker提交作业所使用的用户。如果linux没有这个用户,worker会在执行脚本的时候创建这个用户。</li>
+<li>租户编码:<strong>租户编码是Linux上的用户,唯一,不能重复</strong></li>
+<li>管理员进入安全中心-&gt;租户管理页面,点击“创建租户”按钮,创建租户。</li>
+</ul>
+ <p align="center">
+    <img src="/img/addtenant.png" width="80%" />
+  </p>
+<h4>5.3 创建普通用户</h4>
+<ul>
+<li>用户分为<strong>管理员用户</strong>和<strong>普通用户</strong></li>
+</ul>
+<pre><code>* 管理员有授权和用户管理等权限,没有创建项目和工作流定义的操作的权限。
+* 普通用户可以创建项目和对工作流定义的创建,编辑,执行等操作。
+* 注意:如果该用户切换了租户,则该用户所在租户下所有资源将复制到切换的新租户下。
+</code></pre>
+<ul>
+<li>管理员进入安全中心-&gt;用户管理页面,点击“创建用户”按钮,创建用户。</li>
+</ul>
+<p align="center">
+   <img src="/img/useredit2.png" width="80%" />
+ </p>
+<blockquote>
+<p><strong>编辑用户信息</strong></p>
+</blockquote>
+<ul>
+<li>管理员进入安全中心-&gt;用户管理页面,点击&quot;编辑&quot;按钮,编辑用户信息。</li>
+<li>普通用户登录后,点击用户名下拉框中的用户信息,进入用户信息页面,点击&quot;编辑&quot;按钮,编辑用户信息。</li>
+</ul>
+<blockquote>
+<p><strong>修改用户密码</strong></p>
+</blockquote>
+<ul>
+<li>管理员进入安全中心-&gt;用户管理页面,点击&quot;编辑&quot;按钮,编辑用户信息时,输入新密码修改用户密码。</li>
+<li>普通用户登录后,点击用户名下拉框中的用户信息,进入修改密码页面,输入密码并确认密码后点击&quot;编辑&quot;按钮,则修改密码成功。</li>
+</ul>
+<h4>5.4 创建告警组</h4>
+<ul>
+<li>告警组是在启动时设置的参数,在流程结束以后会将流程的状态和其他信息以邮件形式发送给告警组。</li>
+</ul>
+<ul>
+<li>管理员进入安全中心-&gt;告警组管理页面,点击“创建告警组”按钮,创建告警组。</li>
+</ul>
+  <p align="center">
+    <img src="/img/mail_edit.png" width="80%" />
+  </p>
+<h4>5.5 令牌管理</h4>
+<blockquote>
+<p>由于后端接口有登录检查,令牌管理提供了一种可以通过调用接口的方式对系统进行各种操作。</p>
+</blockquote>
+<ul>
+<li>管理员进入安全中心-&gt;令牌管理页面,点击“创建令牌”按钮,选择失效时间与用户,点击&quot;生成令牌&quot;按钮,点击&quot;提交&quot;按钮,则选择用户的token创建成功。</li>
+</ul>
+  <p align="center">
+      <img src="/img/creat_token.png" width="80%" />
+   </p>
+<ul>
+<li>
+<p>普通用户登录后,点击用户名下拉框中的用户信息,进入令牌管理页面,选择失效时间,点击&quot;生成令牌&quot;按钮,点击&quot;提交&quot;按钮,则该用户创建token成功。</p>
+</li>
+<li>
+<p>调用示例:</p>
+</li>
+</ul>
+<pre><code class="language-令牌调用示例">    /**
+     * test token
+     */
+    public  void doPOSTParam()throws Exception{
+        // create HttpClient
+        CloseableHttpClient httpclient = HttpClients.createDefault();
+
+        // create http post request
+        HttpPost httpPost = new HttpPost(&quot;http://127.0.0.1:12345/escheduler/projects/create&quot;);
+        httpPost.setHeader(&quot;token&quot;, &quot;123&quot;);
+        // set parameters
+        List&lt;NameValuePair&gt; parameters = new ArrayList&lt;NameValuePair&gt;();
+        parameters.add(new BasicNameValuePair(&quot;projectName&quot;, &quot;qzw&quot;));
+        parameters.add(new BasicNameValuePair(&quot;desc&quot;, &quot;qzw&quot;));
+        UrlEncodedFormEntity formEntity = new UrlEncodedFormEntity(parameters);
+        httpPost.setEntity(formEntity);
+        CloseableHttpResponse response = null;
+        try {
+            // execute
+            response = httpclient.execute(httpPost);
+            // response status code 200
+            if (response.getStatusLine().getStatusCode() == 200) {
+                String content = EntityUtils.toString(response.getEntity(), &quot;UTF-8&quot;);
+                System.out.println(content);
+            }
+        } finally {
+            if (response != null) {
+                response.close();
+            }
+            httpclient.close();
+        }
+    }
+</code></pre>
+<h4>5.6 授予权限</h4>
+<pre><code>* 授予权限包括项目权限,资源权限,数据源权限,UDF函数权限。
+* 管理员可以对普通用户进行非其创建的项目、资源、数据源和UDF函数进行授权。因为项目、资源、数据源和UDF函数授权方式都是一样的,所以以项目授权为例介绍。
+* 注意:对于用户自己创建的项目,该用户拥有所有的权限。则项目列表和已选项目列表中不会显示。
+</code></pre>
+<ul>
+<li>管理员进入安全中心-&gt;用户管理页面,点击需授权用户的“授权”按钮,如下图所示:</li>
+</ul>
+  <p align="center">
+   <img src="/img/auth_user.png" width="80%" />
+ </p>
+<ul>
+<li>选择项目,进行项目授权。</li>
+</ul>
+<p align="center">
+   <img src="/img/auth_project.png" width="80%" />
+ </p>
+<ul>
+<li>资源、数据源、UDF函数授权同项目授权。</li>
+</ul>
+<h3>6. 监控中心</h3>
+<h4>6.1 服务管理</h4>
+<ul>
+<li>服务管理主要是对系统中的各个服务的健康状况和基本信息的监控和显示</li>
+</ul>
+<h4>6.1.1 master监控</h4>
+<ul>
+<li>主要是master的相关信息。</li>
+</ul>
+<p align="center">
+   <img src="/img/master-jk.png" width="80%" />
+ </p>
+<h4>6.1.2 worker监控</h4>
+<ul>
+<li>主要是worker的相关信息。</li>
+</ul>
+<p align="center">
+   <img src="/img/worker-jk.png" width="80%" />
+ </p>
+<h4>6.1.3 Zookeeper监控</h4>
+<ul>
+<li>主要是zookpeeper中各个worker和master的相关配置信息。</li>
+</ul>
+<p align="center">
+   <img src="/img/zk-jk.png" width="80%" />
+ </p>
+<h4>6.1.4 DB监控</h4>
+<ul>
+<li>主要是DB的健康状况</li>
+</ul>
+<p align="center">
+   <img src="/img/mysql-jk.png" width="80%" />
+ </p>
+<h4>6.2 统计管理</h4>
+<p align="center">
+   <img src="/img/Statistics.png" width="80%" />
+ </p>
+<ul>
+<li>待执行命令数:统计t_ds_command表的数据</li>
+<li>执行失败的命令数:统计t_ds_error_command表的数据</li>
+<li>待运行任务数:统计Zookeeper中task_queue的数据</li>
+<li>待杀死任务数:统计Zookeeper中task_kill的数据</li>
+</ul>
+<h3>7. <span id=TaskParamers>任务节点类型和参数设置</span></h3>
+<h4>7.1 Shell节点</h4>
+<blockquote>
+<p>shell节点,在worker执行的时候,会生成一个临时shell脚本,使用租户同名的linux用户执行这个脚本。</p>
+</blockquote>
+<ul>
+<li>
+<p>点击项目管理-项目名称-工作流定义,点击&quot;创建工作流&quot;按钮,进入DAG编辑页面。</p>
+</li>
+<li>
+<p>工具栏中拖动<img src="/img/shell.png" width="35"/>到画板中,如下图所示:</p>
+<p align="center">
+    <img src="/img/shell_dag.png" width="80%" />
+</p> 
+</li>
+<li>
+<p>节点名称:一个工作流定义中的节点名称是唯一的。</p>
+</li>
+<li>
+<p>运行标志:标识这个节点是否能正常调度,如果不需要执行,可以打开禁止执行开关。</p>
+</li>
+<li>
+<p>描述信息:描述该节点的功能。</p>
+</li>
+<li>
+<p>任务优先级:worker线程数不足时,根据优先级从高到低依次执行,优先级一样时根据先进先出原则执行。</p>
+</li>
+<li>
+<p>Worker分组:任务分配给worker组的机器机执行,选择Default,会随机选择一台worker机执行。</p>
+</li>
+<li>
+<p>失败重试次数:任务失败重新提交的次数,支持下拉和手填。</p>
+</li>
+<li>
+<p>失败重试间隔:任务失败重新提交任务的时间间隔,支持下拉和手填。</p>
+</li>
+<li>
+<p>超时告警:勾选超时告警、超时失败,当任务超过&quot;超时时长&quot;后,会发送告警邮件并且任务执行失败.</p>
+</li>
+<li>
+<p>脚本:用户开发的SHELL程序。</p>
+</li>
+<li>
+<p>资源:是指脚本中需要调用的资源文件列表,资源中心-文件管理上传或创建的文件。</p>
+</li>
+<li>
+<p>自定义参数:是SHELL局部的用户自定义参数,会替换脚本中以${变量}的内容。</p>
+</li>
+</ul>
+<h4>7.2 子流程节点</h4>
+<ul>
+<li>子流程节点,就是把外部的某个工作流定义当做一个任务节点去执行。</li>
+</ul>
+<blockquote>
+<p>拖动工具栏中的<img src="https://analysys.github.io/easyscheduler_docs_cn/images/toolbar_SUB_PROCESS.png" alt="PNG">任务节点到画板中,如下图所示:</p>
+</blockquote>
+<p align="center">
+   <img src="/img/subprocess_edit.png" width="80%" />
+ </p>
+<ul>
+<li>节点名称:一个工作流定义中的节点名称是唯一的</li>
+<li>运行标志:标识这个节点是否能正常调度</li>
+<li>描述信息:描述该节点的功能</li>
+<li>超时告警:勾选超时告警、超时失败,当任务超过&quot;超时时长&quot;后,会发送告警邮件并且任务执行失败.</li>
+<li>子节点:是选择子流程的工作流定义,右上角进入该子节点可以跳转到所选子流程的工作流定义</li>
+</ul>
+<h4>7.3 依赖(DEPENDENT)节点</h4>
+<ul>
+<li>依赖节点,就是<strong>依赖检查节点</strong>。比如A流程依赖昨天的B流程执行成功,依赖节点会去检查B流程在昨天是否有执行成功的实例。</li>
+</ul>
+<blockquote>
+<p>拖动工具栏中的<img src="https://analysys.github.io/easyscheduler_docs_cn/images/toolbar_DEPENDENT.png" alt="PNG">任务节点到画板中,如下图所示:</p>
+</blockquote>
+<p align="center">
+   <img src="/img/dependent_edit.png" width="80%" />
+ </p>
+<blockquote>
+<p>依赖节点提供了逻辑判断功能,比如检查昨天的B流程是否成功,或者C流程是否执行成功。</p>
+</blockquote>
+  <p align="center">
+   <img src="/img/depend-node.png" width="80%" />
+ </p>
+<blockquote>
+<p>例如,A流程为周报任务,B、C流程为天任务,A任务需要B、C任务在上周的每一天都执行成功,如图示:</p>
+</blockquote>
+ <p align="center">
+   <img src="/img/depend-node2.png" width="80%" />
+ </p>
+<blockquote>
+<p>假如,周报A同时还需要自身在上周二执行成功:</p>
+</blockquote>
+ <p align="center">
+   <img src="/img/depend-node3.png" width="80%" />
+ </p>
+<h4>7.4 存储过程节点</h4>
+<ul>
+<li>根据选择的数据源,执行存储过程。</li>
+</ul>
+<blockquote>
+<p>拖动工具栏中的<img src="https://analysys.github.io/easyscheduler_docs_cn/images/toolbar_PROCEDURE.png" alt="PNG">任务节点到画板中,如下图所示:</p>
+</blockquote>
+<p align="center">
+   <img src="/img/procedure_edit.png" width="80%" />
+ </p>
+<ul>
+<li>数据源:存储过程的数据源类型支持MySQL和POSTGRESQL两种,选择对应的数据源</li>
+<li>方法:是存储过程的方法名称</li>
+<li>自定义参数:存储过程的自定义参数类型支持IN、OUT两种,数据类型支持VARCHAR、INTEGER、LONG、FLOAT、DOUBLE、DATE、TIME、TIMESTAMP、BOOLEAN九种数据类型</li>
+</ul>
+<h4>7.5 SQL节点</h4>
+<ul>
+<li>拖动工具栏中的<img src="https://analysys.github.io/easyscheduler_docs_cn/images/toolbar_SQL.png" alt="PNG">任务节点到画板中</li>
+<li>非查询SQL功能:编辑非查询SQL任务信息,sql类型选择非查询,如下图所示:</li>
+</ul>
+  <p align="center">
+   <img src="/img/sql-node.png" width="80%" />
+ </p>
+<ul>
+<li>查询SQL功能:编辑查询SQL任务信息,sql类型选择查询,选择表格或附件形式发送邮件到指定的收件人,如下图所示。</li>
+</ul>
+<p align="center">
+   <img src="/img/sql-node2.png" width="80%" />
+ </p>
+<ul>
+<li>数据源:选择对应的数据源</li>
+<li>sql类型:支持查询和非查询两种,查询是select类型的查询,是有结果集返回的,可以指定邮件通知为表格、附件或表格附件三种模板。非查询是没有结果集返回的,是针对update、delete、insert三种类型的操作。</li>
+<li>sql参数:输入参数格式为key1=value1;key2=value2…</li>
+<li>sql语句:SQL语句</li>
+<li>UDF函数:对于HIVE类型的数据源,可以引用资源中心中创建的UDF函数,其他类型的数据源暂不支持UDF函数。</li>
+<li>自定义参数:SQL任务类型,而存储过程是自定义参数顺序的给方法设置值自定义参数类型和数据类型同存储过程任务类型一样。区别在于SQL任务类型自定义参数会替换sql语句中${变量}。</li>
+<li>前置sql:前置sql在sql语句之前执行。</li>
+<li>后置sql:后置sql在sql语句之后执行。</li>
+</ul>
+<h4>7.6 SPARK节点</h4>
+<ul>
+<li>通过SPARK节点,可以直接直接执行SPARK程序,对于spark节点,worker会使用<code>spark-submit</code>方式提交任务</li>
+</ul>
+<blockquote>
+<p>拖动工具栏中的<img src="https://analysys.github.io/easyscheduler_docs_cn/images/toolbar_SPARK.png" alt="PNG">任务节点到画板中,如下图所示:</p>
+</blockquote>
+<p align="center">
+   <img src="/img/spark_edit.png" width="80%" />
+ </p>
+<ul>
+<li>程序类型:支持JAVA、Scala和Python三种语言</li>
+<li>主函数的class:是Spark程序的入口Main Class的全路径</li>
+<li>主jar包:是Spark的jar包</li>
+<li>部署方式:支持yarn-cluster、yarn-client和local三种模式</li>
+<li>Driver内核数:可以设置Driver内核数及内存数</li>
+<li>Executor数量:可以设置Executor数量、Executor内存数和Executor内核数</li>
+<li>命令行参数:是设置Spark程序的输入参数,支持自定义参数变量的替换。</li>
+<li>其他参数:支持 --jars、--files、--archives、--conf格式</li>
+<li>资源:如果其他参数中引用了资源文件,需要在资源中选择指定</li>
+<li>自定义参数:是MR局部的用户自定义参数,会替换脚本中以${变量}的内容</li>
+</ul>
+<p>注意:JAVA和Scala只是用来标识,没有区别,如果是Python开发的Spark则没有主函数的class,其他都是一样</p>
+<h4>7.7 MapReduce(MR)节点</h4>
+<ul>
+<li>使用MR节点,可以直接执行MR程序。对于mr节点,worker会使用<code>hadoop jar</code>方式提交任务</li>
+</ul>
+<blockquote>
+<p>拖动工具栏中的<img src="https://analysys.github.io/easyscheduler_docs_cn/images/toolbar_MR.png" alt="PNG">任务节点到画板中,如下图所示:</p>
+</blockquote>
+<ol>
+<li>JAVA程序</li>
+</ol>
+ <p align="center">
+   <img src="/img/mr_java.png" width="80%" />
+ </p>
+<ul>
+<li>主函数的class:是MR程序的入口Main Class的全路径</li>
+<li>程序类型:选择JAVA语言</li>
+<li>主jar包:是MR的jar包</li>
+<li>命令行参数:是设置MR程序的输入参数,支持自定义参数变量的替换</li>
+<li>其他参数:支持 –D、-files、-libjars、-archives格式</li>
+<li>资源: 如果其他参数中引用了资源文件,需要在资源中选择指定</li>
+<li>自定义参数:是MR局部的用户自定义参数,会替换脚本中以${变量}的内容</li>
+</ul>
+<ol start="2">
+<li>Python程序</li>
+</ol>
+<p align="center">
+   <img src="/img/mr_edit.png" width="80%" />
+ </p>
+<ul>
+<li>程序类型:选择Python语言</li>
+<li>主jar包:是运行MR的Python jar包</li>
+<li>其他参数:支持 –D、-mapper、-reducer、-input  -output格式,这里可以设置用户自定义参数的输入,比如:</li>
+<li>-mapper  &quot;<a href="http://mapper.py">mapper.py</a> 1&quot;  -file <a href="http://mapper.py">mapper.py</a>   -reducer <a href="http://reducer.py">reducer.py</a>  -file <a href="http://reducer.py">reducer.py</a> –input /journey/words.txt -output /journey/out/mr/${currentTimeMillis}</li>
+<li>其中 -mapper 后的 <a href="http://mapper.py">mapper.py</a> 1是两个参数,<a href="http://xn--mapper-9m7iglm85bf76bbzbb87i.py">第一个参数是mapper.py</a>,第二个参数是1</li>
+<li>资源: 如果其他参数中引用了资源文件,需要在资源中选择指定</li>
+<li>自定义参数:是MR局部的用户自定义参数,会替换脚本中以${变量}的内容</li>
+</ul>
+<h4>7.8 Python节点</h4>
+<ul>
+<li>使用python节点,可以直接执行python脚本,对于python节点,worker会使用<code>python **</code>方式提交任务。</li>
+</ul>
+<blockquote>
+<p>拖动工具栏中的<img src="https://analysys.github.io/easyscheduler_docs_cn/images/toolbar_PYTHON.png" alt="PNG">任务节点到画板中,如下图所示:</p>
+</blockquote>
+<p align="center">
+   <img src="/img/python_edit.png" width="80%" />
+ </p>
+<ul>
+<li>脚本:用户开发的Python程序</li>
+<li>资源:是指脚本中需要调用的资源文件列表</li>
+<li>自定义参数:是Python局部的用户自定义参数,会替换脚本中以${变量}的内容</li>
+</ul>
+<h4>7.9 Flink节点</h4>
+<ul>
+<li>拖动工具栏中的<img src="/img/flink.png" width="35"/>任务节点到画板中,如下图所示:</li>
+</ul>
+<p align="center">
+  <img src="/img/flink_edit.png" width="80%" />
+</p>
+<ul>
+<li>程序类型:支持JAVA、Scala和Python三种语言</li>
+<li>主函数的class:是Flink程序的入口Main Class的全路径</li>
+<li>主jar包:是Flink的jar包</li>
+<li>部署方式:支持cluster、local三种模式</li>
+<li>slot数量:可以设置slot数</li>
+<li>taskManage数量:可以设置taskManage数</li>
+<li>jobManager内存数:可以设置jobManager内存数</li>
+<li>taskManager内存数:可以设置taskManager内存数</li>
+<li>命令行参数:是设置Spark程序的输入参数,支持自定义参数变量的替换。</li>
+<li>其他参数:支持 --jars、--files、--archives、--conf格式</li>
+<li>资源:如果其他参数中引用了资源文件,需要在资源中选择指定</li>
+<li>自定义参数:是Flink局部的用户自定义参数,会替换脚本中以${变量}的内容</li>
+</ul>
+<p>注意:JAVA和Scala只是用来标识,没有区别,如果是Python开发的Flink则没有主函数的class,其他都是一样</p>
+<h4>7.10 http节点</h4>
+<ul>
+<li>拖动工具栏中的<img src="/img/http.png" width="35"/>任务节点到画板中,如下图所示:</li>
+</ul>
+<p align="center">
+   <img src="/img/http_edit.png" width="80%" />
+ </p>
+<ul>
+<li>节点名称:一个工作流定义中的节点名称是唯一的。</li>
+<li>运行标志:标识这个节点是否能正常调度,如果不需要执行,可以打开禁止执行开关。</li>
+<li>描述信息:描述该节点的功能。</li>
+<li>任务优先级:worker线程数不足时,根据优先级从高到低依次执行,优先级一样时根据先进先出原则执行。</li>
+<li>Worker分组:任务分配给worker组的机器机执行,选择Default,会随机选择一台worker机执行。</li>
+<li>失败重试次数:任务失败重新提交的次数,支持下拉和手填。</li>
+<li>失败重试间隔:任务失败重新提交任务的时间间隔,支持下拉和手填。</li>
+<li>超时告警:勾选超时告警、超时失败,当任务超过&quot;超时时长&quot;后,会发送告警邮件并且任务执行失败.</li>
+<li>请求地址:http请求URL。</li>
+<li>请求类型:支持GET、POSt、HEAD、PUT、DELETE。</li>
+<li>请求参数:支持Parameter、Body、Headers。</li>
+<li>校验条件:支持默认响应码、自定义响应码、内容包含、内容不包含。</li>
+<li>校验内容:当校验条件选择自定义响应码、内容包含、内容不包含时,需填写校验内容。</li>
+<li>自定义参数:是http局部的用户自定义参数,会替换脚本中以${变量}的内容。</li>
+</ul>
+<h4>7.11 DATAX节点</h4>
+<ul>
+<li>拖动工具栏中的<img src="/img/datax.png" width="35"/>任务节点到画板中</li>
+</ul>
+  <p align="center">
+   <img src="/img/datax_edit.png" width="80%" />
+  </p>
+<ul>
+<li>自定义模板:打开自定义模板开关时,可以自定义datax节点的json配置文件内容(适用于控件配置不满足需求时)</li>
+<li>数据源:选择抽取数据的数据源</li>
+<li>sql语句:目标库抽取数据的sql语句,节点执行时自动解析sql查询列名,映射为目标表同步列名,源表和目标表列名不一致时,可以通过列别名(as)转换</li>
+<li>目标库:选择数据同步的目标库</li>
+<li>目标表:数据同步的目标表名</li>
+<li>前置sql:前置sql在sql语句之前执行(目标库执行)。</li>
+<li>后置sql:后置sql在sql语句之后执行(目标库执行)。</li>
+<li>json:datax同步的json配置文件</li>
+<li>自定义参数:SQL任务类型,而存储过程是自定义参数顺序的给方法设置值自定义参数类型和数据类型同存储过程任务类型一样。区别在于SQL任务类型自定义参数会替换sql语句中${变量}。</li>
+</ul>
+<h4>8. 参数</h4>
+<h4>8.1 系统参数</h4>
+<table>
+    <tr><th>变量</th><th>含义</th></tr>
+    <tr>
+        <td>${system.biz.date}</td>
+        <td>日常调度实例定时的定时时间前一天,格式为 yyyyMMdd,补数据时,该日期 +1</td>
+    </tr>
+    <tr>
+        <td>${system.biz.curdate}</td>
+        <td>日常调度实例定时的定时时间,格式为 yyyyMMdd,补数据时,该日期 +1</td>
+    </tr>
+    <tr>
+        <td>${system.datetime}</td>
+        <td>日常调度实例定时的定时时间,格式为 yyyyMMddHHmmss,补数据时,该日期 +1</td>
+    </tr>
+</table>
+<h4>8.2 时间自定义参数</h4>
+<ul>
+<li>
+<p>支持代码中自定义变量名,声明方式:${变量名}。可以是引用 &quot;系统参数&quot; 或指定 &quot;常量&quot;。</p>
+</li>
+<li>
+<p>我们定义这种基准变量为 [...] 格式的,[yyyyMMddHHmmss] 是可以任意分解组合的,比如:$[yyyyMMdd], $[HHmmss], $[yyyy-MM-dd] 等</p>
+</li>
+<li>
+<p>也可以使用以下格式:</p>
+<pre><code>* 后 N 年:$[add_months(yyyyMMdd,12*N)]
+* 前 N 年:$[add_months(yyyyMMdd,-12*N)]
+* 后 N 月:$[add_months(yyyyMMdd,N)]
+* 前 N 月:$[add_months(yyyyMMdd,-N)]
+* 后 N 周:$[yyyyMMdd+7*N]
+* 前 N 周:$[yyyyMMdd-7*N]
+* 后 N 天:$[yyyyMMdd+N]
+* 前 N 天:$[yyyyMMdd-N]
+* 后 N 小时:$[HHmmss+N/24]
+* 前 N 小时:$[HHmmss-N/24]
+* 后 N 分钟:$[HHmmss+N/24/60]
+* 前 N 分钟:$[HHmmss-N/24/60]
+</code></pre>
+</li>
+</ul>
+<h4>8.3 <span id=UserDefinedParameters>用户自定义参数</span></h4>
+<ul>
+<li>用户自定义参数分为全局参数和局部参数。全局参数是保存工作流定义和工作流实例的时候传递的全局参数,全局参数可以在整个流程中的任何一个任务节点的局部参数引用。
+例如:</li>
+</ul>
+<p align="center">
+   <img src="/img/local_parameter.png" width="80%" />
+ </p>
+<ul>
+<li>global_bizdate为全局参数,引用的是系统参数。</li>
+</ul>
+<p align="center">
+   <img src="/img/global_parameter.png" width="80%" />
+ </p>
+<ul>
+<li>任务中local_param_bizdate通过${global_bizdate}来引用全局参数,对于脚本可以通过${local_param_bizdate}来引全局变量global_bizdate的值,或通过JDBC直接将local_param_bizdate的值set进去</li>
+</ul>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>文档</dt><dd><a href="/zh-cn/docs/development/architecture-design.html" target="_self">概览</a></dd><dd><a href="/zh-cn/docs/1.3.1/user_doc/quick-start.html" target="_self">快速开始</a></dd><dd><a href="/zh-cn/docs/development/backend-development.html" target="_self">开发者指南</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http://www.apache.org" target="_self">基金 [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/system-manual.json b/zh-cn/docs/1.3.2/user_doc/system-manual.json
new file mode 100644
index 0000000..122c2d5
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/system-manual.json
@@ -0,0 +1,6 @@
+{
+  "filename": "system-manual.md",
+  "__html": "<h1>系统使用手册</h1>\n<h2>快速上手</h2>\n<blockquote>\n<p>请参照<a href=\"quick-start.html\">快速上手</a></p>\n</blockquote>\n<h2>操作指南</h2>\n<h3>1. 首页</h3>\n<p>首页包含用户所有项目的任务状态统计、流程状态统计、工作流定义统计。\n<p align=\"center\">\n<img src=\"/img/home.png\" width=\"80%\" />\n</p></p>\n<h3>2. 项目管理</h3>\n<h4>2.1 创建项目</h4>\n<ul>\n<li>\n<p>点击&quot;项目管理&quot;进入项目管理页面,点击“创建项目”按钮,输入项目名称,项目描述,点击“提交”,创建新的项目。</p>\n<p align=\"center\">\n    <img src=\"/img/project.png\" width=\"80%\" />\n</p>\n</li>\n</ul>\n<h4>2.2 [...]
+  "link": "/zh-cn/docs/1.3.2/user_doc/system-manual.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/task-structure.html b/zh-cn/docs/1.3.2/user_doc/task-structure.html
new file mode 100644
index 0000000..548a7bf
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/task-structure.html
@@ -0,0 +1,3282 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="task-structure" />
+	<meta name="description" content="task-structure" />
+	<!-- 网页标签标题 -->
+	<title>task-structure</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/zh-cn/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">En</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass an [...]
+<p>在dolphinscheduler中创建的所有任务都保存在t_ds_process_definition 表中.</p>
+<p>该数据库表结构如下表所示:</p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>字段</th>
+<th>类型</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td>int(11)</td>
+<td>主键</td>
+</tr>
+<tr>
+<td>2</td>
+<td>name</td>
+<td>varchar(255)</td>
+<td>流程定义名称</td>
+</tr>
+<tr>
+<td>3</td>
+<td>version</td>
+<td>int(11)</td>
+<td>流程定义版本</td>
+</tr>
+<tr>
+<td>4</td>
+<td>release_state</td>
+<td>tinyint(4)</td>
+<td>流程定义的发布状态:0 未上线 ,  1已上线</td>
+</tr>
+<tr>
+<td>5</td>
+<td>project_id</td>
+<td>int(11)</td>
+<td>项目id</td>
+</tr>
+<tr>
+<td>6</td>
+<td>user_id</td>
+<td>int(11)</td>
+<td>流程定义所属用户id</td>
+</tr>
+<tr>
+<td>7</td>
+<td>process_definition_json</td>
+<td>longtext</td>
+<td>流程定义JSON</td>
+</tr>
+<tr>
+<td>8</td>
+<td>description</td>
+<td>text</td>
+<td>流程定义描述</td>
+</tr>
+<tr>
+<td>9</td>
+<td>global_params</td>
+<td>text</td>
+<td>全局参数</td>
+</tr>
+<tr>
+<td>10</td>
+<td>flag</td>
+<td>tinyint(4)</td>
+<td>流程是否可用:0 不可用,1 可用</td>
+</tr>
+<tr>
+<td>11</td>
+<td>locations</td>
+<td>text</td>
+<td>节点坐标信息</td>
+</tr>
+<tr>
+<td>12</td>
+<td>connects</td>
+<td>text</td>
+<td>节点连线信息</td>
+</tr>
+<tr>
+<td>13</td>
+<td>receivers</td>
+<td>text</td>
+<td>收件人</td>
+</tr>
+<tr>
+<td>14</td>
+<td>receivers_cc</td>
+<td>text</td>
+<td>抄送人</td>
+</tr>
+<tr>
+<td>15</td>
+<td>create_time</td>
+<td>datetime</td>
+<td>创建时间</td>
+</tr>
+<tr>
+<td>16</td>
+<td>timeout</td>
+<td>int(11)</td>
+<td>超时时间</td>
+</tr>
+<tr>
+<td>17</td>
+<td>tenant_id</td>
+<td>int(11)</td>
+<td>租户id</td>
+</tr>
+<tr>
+<td>18</td>
+<td>update_time</td>
+<td>datetime</td>
+<td>更新时间</td>
+</tr>
+<tr>
+<td>19</td>
+<td>modify_by</td>
+<td>varchar(36)</td>
+<td>修改用户</td>
+</tr>
+<tr>
+<td>20</td>
+<td>resource_ids</td>
+<td>varchar(255)</td>
+<td>资源ids</td>
+</tr>
+</tbody>
+</table>
+<p>其中process_definition_json 字段为核心字段, 定义了 DAG 图中的任务信息.该数据以JSON 的方式进行存储.</p>
+<p>公共的数据结构如下表.</p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>字段</th>
+<th>类型</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>globalParams</td>
+<td>Array</td>
+<td>全局参数</td>
+</tr>
+<tr>
+<td>2</td>
+<td>tasks</td>
+<td>Array</td>
+<td>流程中的任务集合  [ 各个类型的结构请参考如下章节]</td>
+</tr>
+<tr>
+<td>3</td>
+<td>tenantId</td>
+<td>int</td>
+<td>租户id</td>
+</tr>
+<tr>
+<td>4</td>
+<td>timeout</td>
+<td>int</td>
+<td>超时时间</td>
+</tr>
+</tbody>
+</table>
+<p>数据示例:</p>
+<pre><code class="language-bash">{
+    <span class="hljs-string">"globalParams"</span>:[
+        {
+            <span class="hljs-string">"prop"</span>:<span class="hljs-string">"golbal_bizdate"</span>,
+            <span class="hljs-string">"direct"</span>:<span class="hljs-string">"IN"</span>,
+            <span class="hljs-string">"type"</span>:<span class="hljs-string">"VARCHAR"</span>,
+            <span class="hljs-string">"value"</span>:<span class="hljs-string">"<span class="hljs-variable">${system.biz.date}</span>"</span>
+        }
+    ],
+    <span class="hljs-string">"tasks"</span>:Array[1],
+    <span class="hljs-string">"tenantId"</span>:0,
+    <span class="hljs-string">"timeout"</span>:0
+}
+</code></pre>
+<h1>各任务类型存储结构详解</h1>
+<h2>Shell节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>SHELL</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>Json 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>rawScript</td>
+<td>String</td>
+<td>Shell脚本</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td></td>
+<td>localParams</td>
+<td>Array</td>
+<td>自定义参数</td>
+<td></td>
+</tr>
+<tr>
+<td>7</td>
+<td></td>
+<td>resourceList</td>
+<td>Array</td>
+<td>资源文件</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>9</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>10</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>11</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>14</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>15</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>17</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>18</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>19</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+    <span class="hljs-string">"type"</span>:<span class="hljs-string">"SHELL"</span>,
+    <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-80760"</span>,
+    <span class="hljs-string">"name"</span>:<span class="hljs-string">"Shell Task"</span>,
+    <span class="hljs-string">"params"</span>:{
+        <span class="hljs-string">"resourceList"</span>:[
+            {
+                <span class="hljs-string">"id"</span>:3,
+                <span class="hljs-string">"name"</span>:<span class="hljs-string">"run.sh"</span>,
+                <span class="hljs-string">"res"</span>:<span class="hljs-string">"run.sh"</span>
+            }
+        ],
+        <span class="hljs-string">"localParams"</span>:[
+
+        ],
+        <span class="hljs-string">"rawScript"</span>:<span class="hljs-string">"echo "</span>This is a shell script<span class="hljs-string">""</span>
+    },
+    <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+    <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+    <span class="hljs-string">"conditionResult"</span>:{
+        <span class="hljs-string">"successNode"</span>:[
+            <span class="hljs-string">""</span>
+        ],
+        <span class="hljs-string">"failedNode"</span>:[
+            <span class="hljs-string">""</span>
+        ]
+    },
+    <span class="hljs-string">"dependence"</span>:{
+
+    },
+    <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+    <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+    <span class="hljs-string">"timeout"</span>:{
+        <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"interval"</span>:null,
+        <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+    },
+    <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+    <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+    <span class="hljs-string">"preTasks"</span>:[
+
+    ]
+}
+
+</code></pre>
+<h2>SQL节点</h2>
+<p>通过 SQL对指定的数据源进行数据查询、更新操作.</p>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>SQL</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>Json 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>type</td>
+<td>String</td>
+<td>数据库类型</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td></td>
+<td>datasource</td>
+<td>Int</td>
+<td>数据源id</td>
+<td></td>
+</tr>
+<tr>
+<td>7</td>
+<td></td>
+<td>sql</td>
+<td>String</td>
+<td>查询SQL语句</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td></td>
+<td>udfs</td>
+<td>String</td>
+<td>udf函数</td>
+<td>UDF函数id,以逗号分隔.</td>
+</tr>
+<tr>
+<td>9</td>
+<td></td>
+<td>sqlType</td>
+<td>String</td>
+<td>SQL节点类型</td>
+<td>0 查询  , 1 非查询</td>
+</tr>
+<tr>
+<td>10</td>
+<td></td>
+<td>title</td>
+<td>String</td>
+<td>邮件标题</td>
+<td></td>
+</tr>
+<tr>
+<td>11</td>
+<td></td>
+<td>receivers</td>
+<td>String</td>
+<td>收件人</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td></td>
+<td>receiversCc</td>
+<td>String</td>
+<td>抄送人</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td></td>
+<td>showType</td>
+<td>String</td>
+<td>邮件显示类型</td>
+<td>TABLE 表格  ,  ATTACHMENT附件</td>
+</tr>
+<tr>
+<td>14</td>
+<td></td>
+<td>connParams</td>
+<td>String</td>
+<td>连接参数</td>
+<td></td>
+</tr>
+<tr>
+<td>15</td>
+<td></td>
+<td>preStatements</td>
+<td>Array</td>
+<td>前置SQL</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td></td>
+<td>postStatements</td>
+<td>Array</td>
+<td>后置SQL</td>
+<td></td>
+</tr>
+<tr>
+<td>17</td>
+<td></td>
+<td>localParams</td>
+<td>Array</td>
+<td>自定义参数</td>
+<td></td>
+</tr>
+<tr>
+<td>18</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>19</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>20</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>21</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>22</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>23</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>24</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>25</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>26</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>27</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>28</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>29</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+    <span class="hljs-string">"type"</span>:<span class="hljs-string">"SQL"</span>,
+    <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-95648"</span>,
+    <span class="hljs-string">"name"</span>:<span class="hljs-string">"SqlTask-Query"</span>,
+    <span class="hljs-string">"params"</span>:{
+        <span class="hljs-string">"type"</span>:<span class="hljs-string">"MYSQL"</span>,
+        <span class="hljs-string">"datasource"</span>:1,
+        <span class="hljs-string">"sql"</span>:<span class="hljs-string">"select id , namge , age from emp where id =  <span class="hljs-variable">${id}</span>"</span>,
+        <span class="hljs-string">"udfs"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"sqlType"</span>:<span class="hljs-string">"0"</span>,
+        <span class="hljs-string">"title"</span>:<span class="hljs-string">"xxxx@xxx.com"</span>,
+        <span class="hljs-string">"receivers"</span>:<span class="hljs-string">"xxxx@xxx.com"</span>,
+        <span class="hljs-string">"receiversCc"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"showType"</span>:<span class="hljs-string">"TABLE"</span>,
+        <span class="hljs-string">"localParams"</span>:[
+            {
+                <span class="hljs-string">"prop"</span>:<span class="hljs-string">"id"</span>,
+                <span class="hljs-string">"direct"</span>:<span class="hljs-string">"IN"</span>,
+                <span class="hljs-string">"type"</span>:<span class="hljs-string">"INTEGER"</span>,
+                <span class="hljs-string">"value"</span>:<span class="hljs-string">"1"</span>
+            }
+        ],
+        <span class="hljs-string">"connParams"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"preStatements"</span>:[
+            <span class="hljs-string">"insert into emp ( id,name ) value (1,'Li' )"</span>
+        ],
+        <span class="hljs-string">"postStatements"</span>:[
+
+        ]
+    },
+    <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+    <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+    <span class="hljs-string">"conditionResult"</span>:{
+        <span class="hljs-string">"successNode"</span>:[
+            <span class="hljs-string">""</span>
+        ],
+        <span class="hljs-string">"failedNode"</span>:[
+            <span class="hljs-string">""</span>
+        ]
+    },
+    <span class="hljs-string">"dependence"</span>:{
+
+    },
+    <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+    <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+    <span class="hljs-string">"timeout"</span>:{
+        <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"interval"</span>:null,
+        <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+    },
+    <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+    <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+    <span class="hljs-string">"preTasks"</span>:[
+
+    ]
+}
+</code></pre>
+<h2>PROCEDURE[存储过程]节点</h2>
+<p><strong>节点数据结构如下:</strong>
+<strong>节点数据样例:</strong></p>
+<h2>SPARK节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>SPARK</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>Json 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>mainClass</td>
+<td>String</td>
+<td>运行主类</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td></td>
+<td>mainArgs</td>
+<td>String</td>
+<td>运行参数</td>
+<td></td>
+</tr>
+<tr>
+<td>7</td>
+<td></td>
+<td>others</td>
+<td>String</td>
+<td>其他参数</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td></td>
+<td>mainJar</td>
+<td>Object</td>
+<td>程序 jar 包</td>
+<td></td>
+</tr>
+<tr>
+<td>9</td>
+<td></td>
+<td>deployMode</td>
+<td>String</td>
+<td>部署模式</td>
+<td>local,client,cluster</td>
+</tr>
+<tr>
+<td>10</td>
+<td></td>
+<td>driverCores</td>
+<td>String</td>
+<td>driver核数</td>
+<td></td>
+</tr>
+<tr>
+<td>11</td>
+<td></td>
+<td>driverMemory</td>
+<td>String</td>
+<td>driver 内存数</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td></td>
+<td>numExecutors</td>
+<td>String</td>
+<td>executor数量</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td></td>
+<td>executorMemory</td>
+<td>String</td>
+<td>executor内存</td>
+<td></td>
+</tr>
+<tr>
+<td>14</td>
+<td></td>
+<td>executorCores</td>
+<td>String</td>
+<td>executor核数</td>
+<td></td>
+</tr>
+<tr>
+<td>15</td>
+<td></td>
+<td>programType</td>
+<td>String</td>
+<td>程序类型</td>
+<td>JAVA,SCALA,PYTHON</td>
+</tr>
+<tr>
+<td>16</td>
+<td></td>
+<td>sparkVersion</td>
+<td>String</td>
+<td>Spark 版本</td>
+<td>SPARK1 , SPARK2</td>
+</tr>
+<tr>
+<td>17</td>
+<td></td>
+<td>localParams</td>
+<td>Array</td>
+<td>自定义参数</td>
+<td></td>
+</tr>
+<tr>
+<td>18</td>
+<td></td>
+<td>resourceList</td>
+<td>Array</td>
+<td>资源文件</td>
+<td></td>
+</tr>
+<tr>
+<td>19</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>20</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>21</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>22</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>23</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>24</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>25</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>26</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>27</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>28</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>29</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>30</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+    <span class="hljs-string">"type"</span>:<span class="hljs-string">"SPARK"</span>,
+    <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-87430"</span>,
+    <span class="hljs-string">"name"</span>:<span class="hljs-string">"SparkTask"</span>,
+    <span class="hljs-string">"params"</span>:{
+        <span class="hljs-string">"mainClass"</span>:<span class="hljs-string">"org.apache.spark.examples.SparkPi"</span>,
+        <span class="hljs-string">"mainJar"</span>:{
+            <span class="hljs-string">"id"</span>:4
+        },
+        <span class="hljs-string">"deployMode"</span>:<span class="hljs-string">"cluster"</span>,
+        <span class="hljs-string">"resourceList"</span>:[
+            {
+                <span class="hljs-string">"id"</span>:3,
+                <span class="hljs-string">"name"</span>:<span class="hljs-string">"run.sh"</span>,
+                <span class="hljs-string">"res"</span>:<span class="hljs-string">"run.sh"</span>
+            }
+        ],
+        <span class="hljs-string">"localParams"</span>:[
+
+        ],
+        <span class="hljs-string">"driverCores"</span>:1,
+        <span class="hljs-string">"driverMemory"</span>:<span class="hljs-string">"512M"</span>,
+        <span class="hljs-string">"numExecutors"</span>:2,
+        <span class="hljs-string">"executorMemory"</span>:<span class="hljs-string">"2G"</span>,
+        <span class="hljs-string">"executorCores"</span>:2,
+        <span class="hljs-string">"mainArgs"</span>:<span class="hljs-string">"10"</span>,
+        <span class="hljs-string">"others"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"programType"</span>:<span class="hljs-string">"SCALA"</span>,
+        <span class="hljs-string">"sparkVersion"</span>:<span class="hljs-string">"SPARK2"</span>
+    },
+    <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+    <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+    <span class="hljs-string">"conditionResult"</span>:{
+        <span class="hljs-string">"successNode"</span>:[
+            <span class="hljs-string">""</span>
+        ],
+        <span class="hljs-string">"failedNode"</span>:[
+            <span class="hljs-string">""</span>
+        ]
+    },
+    <span class="hljs-string">"dependence"</span>:{
+
+    },
+    <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+    <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+    <span class="hljs-string">"timeout"</span>:{
+        <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"interval"</span>:null,
+        <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+    },
+    <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+    <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+    <span class="hljs-string">"preTasks"</span>:[
+
+    ]
+}
+</code></pre>
+<h2>MapReduce(MR)节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>MR</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>Json 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>mainClass</td>
+<td>String</td>
+<td>运行主类</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td></td>
+<td>mainArgs</td>
+<td>String</td>
+<td>运行参数</td>
+<td></td>
+</tr>
+<tr>
+<td>7</td>
+<td></td>
+<td>others</td>
+<td>String</td>
+<td>其他参数</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td></td>
+<td>mainJar</td>
+<td>Object</td>
+<td>程序 jar 包</td>
+<td></td>
+</tr>
+<tr>
+<td>9</td>
+<td></td>
+<td>programType</td>
+<td>String</td>
+<td>程序类型</td>
+<td>JAVA,PYTHON</td>
+</tr>
+<tr>
+<td>10</td>
+<td></td>
+<td>localParams</td>
+<td>Array</td>
+<td>自定义参数</td>
+<td></td>
+</tr>
+<tr>
+<td>11</td>
+<td></td>
+<td>resourceList</td>
+<td>Array</td>
+<td>资源文件</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>14</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>15</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>17</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>18</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>19</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>20</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>21</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>22</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>23</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+    <span class="hljs-string">"type"</span>:<span class="hljs-string">"MR"</span>,
+    <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-28997"</span>,
+    <span class="hljs-string">"name"</span>:<span class="hljs-string">"MRTask"</span>,
+    <span class="hljs-string">"params"</span>:{
+        <span class="hljs-string">"mainClass"</span>:<span class="hljs-string">"wordcount"</span>,
+        <span class="hljs-string">"mainJar"</span>:{
+            <span class="hljs-string">"id"</span>:5
+        },
+        <span class="hljs-string">"resourceList"</span>:[
+            {
+                <span class="hljs-string">"id"</span>:3,
+                <span class="hljs-string">"name"</span>:<span class="hljs-string">"run.sh"</span>,
+                <span class="hljs-string">"res"</span>:<span class="hljs-string">"run.sh"</span>
+            }
+        ],
+        <span class="hljs-string">"localParams"</span>:[
+
+        ],
+        <span class="hljs-string">"mainArgs"</span>:<span class="hljs-string">"/tmp/wordcount/input /tmp/wordcount/output/"</span>,
+        <span class="hljs-string">"others"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"programType"</span>:<span class="hljs-string">"JAVA"</span>
+    },
+    <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+    <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+    <span class="hljs-string">"conditionResult"</span>:{
+        <span class="hljs-string">"successNode"</span>:[
+            <span class="hljs-string">""</span>
+        ],
+        <span class="hljs-string">"failedNode"</span>:[
+            <span class="hljs-string">""</span>
+        ]
+    },
+    <span class="hljs-string">"dependence"</span>:{
+
+    },
+    <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+    <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+    <span class="hljs-string">"timeout"</span>:{
+        <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"interval"</span>:null,
+        <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+    },
+    <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+    <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+    <span class="hljs-string">"preTasks"</span>:[
+
+    ]
+}
+</code></pre>
+<h2>Python节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>PYTHON</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>Json 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>rawScript</td>
+<td>String</td>
+<td>Python脚本</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td></td>
+<td>localParams</td>
+<td>Array</td>
+<td>自定义参数</td>
+<td></td>
+</tr>
+<tr>
+<td>7</td>
+<td></td>
+<td>resourceList</td>
+<td>Array</td>
+<td>资源文件</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>9</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>10</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>11</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>14</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>15</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>17</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>18</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>19</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+    <span class="hljs-string">"type"</span>:<span class="hljs-string">"PYTHON"</span>,
+    <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-5463"</span>,
+    <span class="hljs-string">"name"</span>:<span class="hljs-string">"Python Task"</span>,
+    <span class="hljs-string">"params"</span>:{
+        <span class="hljs-string">"resourceList"</span>:[
+            {
+                <span class="hljs-string">"id"</span>:3,
+                <span class="hljs-string">"name"</span>:<span class="hljs-string">"run.sh"</span>,
+                <span class="hljs-string">"res"</span>:<span class="hljs-string">"run.sh"</span>
+            }
+        ],
+        <span class="hljs-string">"localParams"</span>:[
+
+        ],
+        <span class="hljs-string">"rawScript"</span>:<span class="hljs-string">"print("</span>This is a python script<span class="hljs-string">")"</span>
+    },
+    <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+    <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+    <span class="hljs-string">"conditionResult"</span>:{
+        <span class="hljs-string">"successNode"</span>:[
+            <span class="hljs-string">""</span>
+        ],
+        <span class="hljs-string">"failedNode"</span>:[
+            <span class="hljs-string">""</span>
+        ]
+    },
+    <span class="hljs-string">"dependence"</span>:{
+
+    },
+    <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+    <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+    <span class="hljs-string">"timeout"</span>:{
+        <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"interval"</span>:null,
+        <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+    },
+    <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+    <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+    <span class="hljs-string">"preTasks"</span>:[
+
+    ]
+}
+</code></pre>
+<h2>Flink节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>FLINK</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>Json 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>mainClass</td>
+<td>String</td>
+<td>运行主类</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td></td>
+<td>mainArgs</td>
+<td>String</td>
+<td>运行参数</td>
+<td></td>
+</tr>
+<tr>
+<td>7</td>
+<td></td>
+<td>others</td>
+<td>String</td>
+<td>其他参数</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td></td>
+<td>mainJar</td>
+<td>Object</td>
+<td>程序 jar 包</td>
+<td></td>
+</tr>
+<tr>
+<td>9</td>
+<td></td>
+<td>deployMode</td>
+<td>String</td>
+<td>部署模式</td>
+<td>local,client,cluster</td>
+</tr>
+<tr>
+<td>10</td>
+<td></td>
+<td>slot</td>
+<td>String</td>
+<td>slot数量</td>
+<td></td>
+</tr>
+<tr>
+<td>11</td>
+<td></td>
+<td>taskManager</td>
+<td>String</td>
+<td>taskManage数量</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td></td>
+<td>taskManagerMemory</td>
+<td>String</td>
+<td>taskManager内存数</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td></td>
+<td>jobManagerMemory</td>
+<td>String</td>
+<td>jobManager内存数</td>
+<td></td>
+</tr>
+<tr>
+<td>14</td>
+<td></td>
+<td>programType</td>
+<td>String</td>
+<td>程序类型</td>
+<td>JAVA,SCALA,PYTHON</td>
+</tr>
+<tr>
+<td>15</td>
+<td></td>
+<td>localParams</td>
+<td>Array</td>
+<td>自定义参数</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td></td>
+<td>resourceList</td>
+<td>Array</td>
+<td>资源文件</td>
+<td></td>
+</tr>
+<tr>
+<td>17</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>18</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>19</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>20</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>21</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>22</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>23</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>24</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>25</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>26</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>27</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>38</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+    <span class="hljs-string">"type"</span>:<span class="hljs-string">"FLINK"</span>,
+    <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-17135"</span>,
+    <span class="hljs-string">"name"</span>:<span class="hljs-string">"FlinkTask"</span>,
+    <span class="hljs-string">"params"</span>:{
+        <span class="hljs-string">"mainClass"</span>:<span class="hljs-string">"com.flink.demo"</span>,
+        <span class="hljs-string">"mainJar"</span>:{
+            <span class="hljs-string">"id"</span>:6
+        },
+        <span class="hljs-string">"deployMode"</span>:<span class="hljs-string">"cluster"</span>,
+        <span class="hljs-string">"resourceList"</span>:[
+            {
+                <span class="hljs-string">"id"</span>:3,
+                <span class="hljs-string">"name"</span>:<span class="hljs-string">"run.sh"</span>,
+                <span class="hljs-string">"res"</span>:<span class="hljs-string">"run.sh"</span>
+            }
+        ],
+        <span class="hljs-string">"localParams"</span>:[
+
+        ],
+        <span class="hljs-string">"slot"</span>:1,
+        <span class="hljs-string">"taskManager"</span>:<span class="hljs-string">"2"</span>,
+        <span class="hljs-string">"jobManagerMemory"</span>:<span class="hljs-string">"1G"</span>,
+        <span class="hljs-string">"taskManagerMemory"</span>:<span class="hljs-string">"2G"</span>,
+        <span class="hljs-string">"executorCores"</span>:2,
+        <span class="hljs-string">"mainArgs"</span>:<span class="hljs-string">"100"</span>,
+        <span class="hljs-string">"others"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"programType"</span>:<span class="hljs-string">"SCALA"</span>
+    },
+    <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+    <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+    <span class="hljs-string">"conditionResult"</span>:{
+        <span class="hljs-string">"successNode"</span>:[
+            <span class="hljs-string">""</span>
+        ],
+        <span class="hljs-string">"failedNode"</span>:[
+            <span class="hljs-string">""</span>
+        ]
+    },
+    <span class="hljs-string">"dependence"</span>:{
+
+    },
+    <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+    <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+    <span class="hljs-string">"timeout"</span>:{
+        <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"interval"</span>:null,
+        <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+    },
+    <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+    <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+    <span class="hljs-string">"preTasks"</span>:[
+
+    ]
+}
+</code></pre>
+<h2>HTTP节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>HTTP</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>Json 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>url</td>
+<td>String</td>
+<td>请求地址</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td></td>
+<td>httpMethod</td>
+<td>String</td>
+<td>请求方式</td>
+<td>GET,POST,HEAD,PUT,DELETE</td>
+</tr>
+<tr>
+<td>7</td>
+<td></td>
+<td>httpParams</td>
+<td>Array</td>
+<td>请求参数</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td></td>
+<td>httpCheckCondition</td>
+<td>String</td>
+<td>校验条件</td>
+<td>默认响应码200</td>
+</tr>
+<tr>
+<td>9</td>
+<td></td>
+<td>condition</td>
+<td>String</td>
+<td>校验内容</td>
+<td></td>
+</tr>
+<tr>
+<td>10</td>
+<td></td>
+<td>localParams</td>
+<td>Array</td>
+<td>自定义参数</td>
+<td></td>
+</tr>
+<tr>
+<td>11</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>14</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>15</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>17</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>18</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>19</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>20</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>21</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>22</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+    <span class="hljs-string">"type"</span>:<span class="hljs-string">"HTTP"</span>,
+    <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-60499"</span>,
+    <span class="hljs-string">"name"</span>:<span class="hljs-string">"HttpTask"</span>,
+    <span class="hljs-string">"params"</span>:{
+        <span class="hljs-string">"localParams"</span>:[
+
+        ],
+        <span class="hljs-string">"httpParams"</span>:[
+            {
+                <span class="hljs-string">"prop"</span>:<span class="hljs-string">"id"</span>,
+                <span class="hljs-string">"httpParametersType"</span>:<span class="hljs-string">"PARAMETER"</span>,
+                <span class="hljs-string">"value"</span>:<span class="hljs-string">"1"</span>
+            },
+            {
+                <span class="hljs-string">"prop"</span>:<span class="hljs-string">"name"</span>,
+                <span class="hljs-string">"httpParametersType"</span>:<span class="hljs-string">"PARAMETER"</span>,
+                <span class="hljs-string">"value"</span>:<span class="hljs-string">"Bo"</span>
+            }
+        ],
+        <span class="hljs-string">"url"</span>:<span class="hljs-string">"https://www.xxxxx.com:9012"</span>,
+        <span class="hljs-string">"httpMethod"</span>:<span class="hljs-string">"POST"</span>,
+        <span class="hljs-string">"httpCheckCondition"</span>:<span class="hljs-string">"STATUS_CODE_DEFAULT"</span>,
+        <span class="hljs-string">"condition"</span>:<span class="hljs-string">""</span>
+    },
+    <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+    <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+    <span class="hljs-string">"conditionResult"</span>:{
+        <span class="hljs-string">"successNode"</span>:[
+            <span class="hljs-string">""</span>
+        ],
+        <span class="hljs-string">"failedNode"</span>:[
+            <span class="hljs-string">""</span>
+        ]
+    },
+    <span class="hljs-string">"dependence"</span>:{
+
+    },
+    <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+    <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+    <span class="hljs-string">"timeout"</span>:{
+        <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"interval"</span>:null,
+        <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+    },
+    <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+    <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+    <span class="hljs-string">"preTasks"</span>:[
+
+    ]
+}
+</code></pre>
+<h2>DataX节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>DATAX</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>Json 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>customConfig</td>
+<td>Int</td>
+<td>自定义类型</td>
+<td>0定制 , 1自定义</td>
+</tr>
+<tr>
+<td>6</td>
+<td></td>
+<td>dsType</td>
+<td>String</td>
+<td>源数据库类型</td>
+<td></td>
+</tr>
+<tr>
+<td>7</td>
+<td></td>
+<td>dataSource</td>
+<td>Int</td>
+<td>源数据库ID</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td></td>
+<td>dtType</td>
+<td>String</td>
+<td>目标数据库类型</td>
+<td></td>
+</tr>
+<tr>
+<td>9</td>
+<td></td>
+<td>dataTarget</td>
+<td>Int</td>
+<td>目标数据库ID</td>
+<td></td>
+</tr>
+<tr>
+<td>10</td>
+<td></td>
+<td>sql</td>
+<td>String</td>
+<td>SQL语句</td>
+<td></td>
+</tr>
+<tr>
+<td>11</td>
+<td></td>
+<td>targetTable</td>
+<td>String</td>
+<td>目标表</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td></td>
+<td>jobSpeedByte</td>
+<td>Int</td>
+<td>限流(字节数)</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td></td>
+<td>jobSpeedRecord</td>
+<td>Int</td>
+<td>限流(记录数)</td>
+<td></td>
+</tr>
+<tr>
+<td>14</td>
+<td></td>
+<td>preStatements</td>
+<td>Array</td>
+<td>前置SQL</td>
+<td></td>
+</tr>
+<tr>
+<td>15</td>
+<td></td>
+<td>postStatements</td>
+<td>Array</td>
+<td>后置SQL</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td></td>
+<td>json</td>
+<td>String</td>
+<td>自定义配置</td>
+<td>customConfig=1时生效</td>
+</tr>
+<tr>
+<td>17</td>
+<td></td>
+<td>localParams</td>
+<td>Array</td>
+<td>自定义参数</td>
+<td>customConfig=1时生效</td>
+</tr>
+<tr>
+<td>18</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>19</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>20</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>21</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>22</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>23</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>24</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>25</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>26</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>27</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>28</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>29</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+    <span class="hljs-string">"type"</span>:<span class="hljs-string">"DATAX"</span>,
+    <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-91196"</span>,
+    <span class="hljs-string">"name"</span>:<span class="hljs-string">"DataxTask-DB"</span>,
+    <span class="hljs-string">"params"</span>:{
+        <span class="hljs-string">"customConfig"</span>:0,
+        <span class="hljs-string">"dsType"</span>:<span class="hljs-string">"MYSQL"</span>,
+        <span class="hljs-string">"dataSource"</span>:1,
+        <span class="hljs-string">"dtType"</span>:<span class="hljs-string">"MYSQL"</span>,
+        <span class="hljs-string">"dataTarget"</span>:1,
+        <span class="hljs-string">"sql"</span>:<span class="hljs-string">"select id, name ,age from user "</span>,
+        <span class="hljs-string">"targetTable"</span>:<span class="hljs-string">"emp"</span>,
+        <span class="hljs-string">"jobSpeedByte"</span>:524288,
+        <span class="hljs-string">"jobSpeedRecord"</span>:500,
+        <span class="hljs-string">"preStatements"</span>:[
+            <span class="hljs-string">"truncate table emp "</span>
+        ],
+        <span class="hljs-string">"postStatements"</span>:[
+            <span class="hljs-string">"truncate table user"</span>
+        ]
+    },
+    <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+    <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+    <span class="hljs-string">"conditionResult"</span>:{
+        <span class="hljs-string">"successNode"</span>:[
+            <span class="hljs-string">""</span>
+        ],
+        <span class="hljs-string">"failedNode"</span>:[
+            <span class="hljs-string">""</span>
+        ]
+    },
+    <span class="hljs-string">"dependence"</span>:{
+
+    },
+    <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+    <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+    <span class="hljs-string">"timeout"</span>:{
+        <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"interval"</span>:null,
+        <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+    },
+    <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+    <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+    <span class="hljs-string">"preTasks"</span>:[
+
+    ]
+}
+</code></pre>
+<h2>Sqoop节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>SQOOP</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>JSON 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>concurrency</td>
+<td>Int</td>
+<td>并发度</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td></td>
+<td>modelType</td>
+<td>String</td>
+<td>流向</td>
+<td>import,export</td>
+</tr>
+<tr>
+<td>7</td>
+<td></td>
+<td>sourceType</td>
+<td>String</td>
+<td>数据源类型</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td></td>
+<td>sourceParams</td>
+<td>String</td>
+<td>数据源参数</td>
+<td>JSON格式</td>
+</tr>
+<tr>
+<td>9</td>
+<td></td>
+<td>targetType</td>
+<td>String</td>
+<td>目标数据类型</td>
+<td></td>
+</tr>
+<tr>
+<td>10</td>
+<td></td>
+<td>targetParams</td>
+<td>String</td>
+<td>目标数据参数</td>
+<td>JSON格式</td>
+</tr>
+<tr>
+<td>11</td>
+<td></td>
+<td>localParams</td>
+<td>Array</td>
+<td>自定义参数</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>14</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>15</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>17</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>18</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>19</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>20</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>21</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>22</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>23</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+            <span class="hljs-string">"type"</span>:<span class="hljs-string">"SQOOP"</span>,
+            <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-82041"</span>,
+            <span class="hljs-string">"name"</span>:<span class="hljs-string">"Sqoop Task"</span>,
+            <span class="hljs-string">"params"</span>:{
+                <span class="hljs-string">"concurrency"</span>:1,
+                <span class="hljs-string">"modelType"</span>:<span class="hljs-string">"import"</span>,
+                <span class="hljs-string">"sourceType"</span>:<span class="hljs-string">"MYSQL"</span>,
+                <span class="hljs-string">"targetType"</span>:<span class="hljs-string">"HDFS"</span>,
+                <span class="hljs-string">"sourceParams"</span>:<span class="hljs-string">"{"</span>srcType<span class="hljs-string">":"</span>MYSQL<span class="hljs-string">","</span>srcDatasource<span class="hljs-string">":1,"</span>srcTable<span class="hljs-string">":"</span><span class="hljs-string">","</span>srcQueryType<span class="hljs-string">":"</span>1<span class="hljs-string">","</span>srcQuerySql<span class="hljs-string">":"</span>selec id , name from user<span class="hljs-st [...]
+                <span class="hljs-string">"targetParams"</span>:<span class="hljs-string">"{"</span>targetPath<span class="hljs-string">":"</span>/user/hive/warehouse/ods.db/user<span class="hljs-string">","</span>deleteTargetDir<span class="hljs-string">":false,"</span>fileType<span class="hljs-string">":"</span>--as-avrodatafile<span class="hljs-string">","</span>compressionCodec<span class="hljs-string">":"</span>snappy<span class="hljs-string">","</span>fieldsTerminated<span class="h [...]
+                <span class="hljs-string">"localParams"</span>:[
+
+                ]
+            },
+            <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+            <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+            <span class="hljs-string">"conditionResult"</span>:{
+                <span class="hljs-string">"successNode"</span>:[
+                    <span class="hljs-string">""</span>
+                ],
+                <span class="hljs-string">"failedNode"</span>:[
+                    <span class="hljs-string">""</span>
+                ]
+            },
+            <span class="hljs-string">"dependence"</span>:{
+
+            },
+            <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+            <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+            <span class="hljs-string">"timeout"</span>:{
+                <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+                <span class="hljs-string">"interval"</span>:null,
+                <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+            },
+            <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+            <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+            <span class="hljs-string">"preTasks"</span>:[
+
+            ]
+        }
+</code></pre>
+<h2>条件分支节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>SHELL</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>null</td>
+</tr>
+<tr>
+<td>5</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>7</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>9</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>10</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>11</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>14</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>15</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+    <span class="hljs-string">"type"</span>:<span class="hljs-string">"CONDITIONS"</span>,
+    <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-96189"</span>,
+    <span class="hljs-string">"name"</span>:<span class="hljs-string">"条件"</span>,
+    <span class="hljs-string">"params"</span>:{
+
+    },
+    <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+    <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+    <span class="hljs-string">"conditionResult"</span>:{
+        <span class="hljs-string">"successNode"</span>:[
+            <span class="hljs-string">"test04"</span>
+        ],
+        <span class="hljs-string">"failedNode"</span>:[
+            <span class="hljs-string">"test05"</span>
+        ]
+    },
+    <span class="hljs-string">"dependence"</span>:{
+        <span class="hljs-string">"relation"</span>:<span class="hljs-string">"AND"</span>,
+        <span class="hljs-string">"dependTaskList"</span>:[
+
+        ]
+    },
+    <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+    <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+    <span class="hljs-string">"timeout"</span>:{
+        <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+        <span class="hljs-string">"interval"</span>:null,
+        <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+    },
+    <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+    <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+    <span class="hljs-string">"preTasks"</span>:[
+        <span class="hljs-string">"test01"</span>,
+        <span class="hljs-string">"test02"</span>
+    ]
+}
+</code></pre>
+<h2>子流程节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>SHELL</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>Json 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>processDefinitionId</td>
+<td>Int</td>
+<td>流程定义id</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>7</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>9</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>10</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>11</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>12</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>14</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>15</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>17</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+            <span class="hljs-string">"type"</span>:<span class="hljs-string">"SUB_PROCESS"</span>,
+            <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-14806"</span>,
+            <span class="hljs-string">"name"</span>:<span class="hljs-string">"SubProcessTask"</span>,
+            <span class="hljs-string">"params"</span>:{
+                <span class="hljs-string">"processDefinitionId"</span>:2
+            },
+            <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+            <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+            <span class="hljs-string">"conditionResult"</span>:{
+                <span class="hljs-string">"successNode"</span>:[
+                    <span class="hljs-string">""</span>
+                ],
+                <span class="hljs-string">"failedNode"</span>:[
+                    <span class="hljs-string">""</span>
+                ]
+            },
+            <span class="hljs-string">"dependence"</span>:{
+
+            },
+            <span class="hljs-string">"timeout"</span>:{
+                <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+                <span class="hljs-string">"interval"</span>:null,
+                <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+            },
+            <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+            <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+            <span class="hljs-string">"preTasks"</span>:[
+
+            ]
+        }
+</code></pre>
+<h2>依赖(DEPENDENT)节点</h2>
+<p><strong>节点数据结构如下:</strong></p>
+<p><strong>节点数据结构如下:</strong></p>
+<table>
+<thead>
+<tr>
+<th>序号</th>
+<th>参数名</th>
+<th></th>
+<th>类型</th>
+<th>描述</th>
+<th>描述</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td>1</td>
+<td>id</td>
+<td></td>
+<td>String</td>
+<td>任务编码</td>
+<td></td>
+</tr>
+<tr>
+<td>2</td>
+<td>type</td>
+<td></td>
+<td>String</td>
+<td>类型</td>
+<td>DEPENDENT</td>
+</tr>
+<tr>
+<td>3</td>
+<td>name</td>
+<td></td>
+<td>String</td>
+<td>名称</td>
+<td></td>
+</tr>
+<tr>
+<td>4</td>
+<td>params</td>
+<td></td>
+<td>Object</td>
+<td>自定义参数</td>
+<td>Json 格式</td>
+</tr>
+<tr>
+<td>5</td>
+<td></td>
+<td>rawScript</td>
+<td>String</td>
+<td>Shell脚本</td>
+<td></td>
+</tr>
+<tr>
+<td>6</td>
+<td></td>
+<td>localParams</td>
+<td>Array</td>
+<td>自定义参数</td>
+<td></td>
+</tr>
+<tr>
+<td>7</td>
+<td></td>
+<td>resourceList</td>
+<td>Array</td>
+<td>资源文件</td>
+<td></td>
+</tr>
+<tr>
+<td>8</td>
+<td>description</td>
+<td></td>
+<td>String</td>
+<td>描述</td>
+<td></td>
+</tr>
+<tr>
+<td>9</td>
+<td>runFlag</td>
+<td></td>
+<td>String</td>
+<td>运行标识</td>
+<td></td>
+</tr>
+<tr>
+<td>10</td>
+<td>conditionResult</td>
+<td></td>
+<td>Object</td>
+<td>条件分支</td>
+<td></td>
+</tr>
+<tr>
+<td>11</td>
+<td></td>
+<td>successNode</td>
+<td>Array</td>
+<td>成功跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>12</td>
+<td></td>
+<td>failedNode</td>
+<td>Array</td>
+<td>失败跳转节点</td>
+<td></td>
+</tr>
+<tr>
+<td>13</td>
+<td>dependence</td>
+<td></td>
+<td>Object</td>
+<td>任务依赖</td>
+<td>与params互斥</td>
+</tr>
+<tr>
+<td>14</td>
+<td></td>
+<td>relation</td>
+<td>String</td>
+<td>关系</td>
+<td>AND,OR</td>
+</tr>
+<tr>
+<td>15</td>
+<td></td>
+<td>dependTaskList</td>
+<td>Array</td>
+<td>依赖任务清单</td>
+<td></td>
+</tr>
+<tr>
+<td>16</td>
+<td>maxRetryTimes</td>
+<td></td>
+<td>String</td>
+<td>最大重试次数</td>
+<td></td>
+</tr>
+<tr>
+<td>17</td>
+<td>retryInterval</td>
+<td></td>
+<td>String</td>
+<td>重试间隔</td>
+<td></td>
+</tr>
+<tr>
+<td>18</td>
+<td>timeout</td>
+<td></td>
+<td>Object</td>
+<td>超时控制</td>
+<td></td>
+</tr>
+<tr>
+<td>19</td>
+<td>taskInstancePriority</td>
+<td></td>
+<td>String</td>
+<td>任务优先级</td>
+<td></td>
+</tr>
+<tr>
+<td>20</td>
+<td>workerGroup</td>
+<td></td>
+<td>String</td>
+<td>Worker 分组</td>
+<td></td>
+</tr>
+<tr>
+<td>21</td>
+<td>preTasks</td>
+<td></td>
+<td>Array</td>
+<td>前置任务</td>
+<td></td>
+</tr>
+</tbody>
+</table>
+<p><strong>节点数据样例:</strong></p>
+<pre><code class="language-bash">{
+            <span class="hljs-string">"type"</span>:<span class="hljs-string">"DEPENDENT"</span>,
+            <span class="hljs-string">"id"</span>:<span class="hljs-string">"tasks-57057"</span>,
+            <span class="hljs-string">"name"</span>:<span class="hljs-string">"DenpendentTask"</span>,
+            <span class="hljs-string">"params"</span>:{
+
+            },
+            <span class="hljs-string">"description"</span>:<span class="hljs-string">""</span>,
+            <span class="hljs-string">"runFlag"</span>:<span class="hljs-string">"NORMAL"</span>,
+            <span class="hljs-string">"conditionResult"</span>:{
+                <span class="hljs-string">"successNode"</span>:[
+                    <span class="hljs-string">""</span>
+                ],
+                <span class="hljs-string">"failedNode"</span>:[
+                    <span class="hljs-string">""</span>
+                ]
+            },
+            <span class="hljs-string">"dependence"</span>:{
+                <span class="hljs-string">"relation"</span>:<span class="hljs-string">"AND"</span>,
+                <span class="hljs-string">"dependTaskList"</span>:[
+                    {
+                        <span class="hljs-string">"relation"</span>:<span class="hljs-string">"AND"</span>,
+                        <span class="hljs-string">"dependItemList"</span>:[
+                            {
+                                <span class="hljs-string">"projectId"</span>:1,
+                                <span class="hljs-string">"definitionId"</span>:7,
+                                <span class="hljs-string">"definitionList"</span>:[
+                                    {
+                                        <span class="hljs-string">"value"</span>:8,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"MRTask"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:7,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"FlinkTask"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:6,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"SparkTask"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:5,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"SqlTask-Update"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:4,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"SqlTask-Query"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:3,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"SubProcessTask"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:2,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"Python Task"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:1,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"Shell Task"</span>
+                                    }
+                                ],
+                                <span class="hljs-string">"depTasks"</span>:<span class="hljs-string">"ALL"</span>,
+                                <span class="hljs-string">"cycle"</span>:<span class="hljs-string">"day"</span>,
+                                <span class="hljs-string">"dateValue"</span>:<span class="hljs-string">"today"</span>
+                            }
+                        ]
+                    },
+                    {
+                        <span class="hljs-string">"relation"</span>:<span class="hljs-string">"AND"</span>,
+                        <span class="hljs-string">"dependItemList"</span>:[
+                            {
+                                <span class="hljs-string">"projectId"</span>:1,
+                                <span class="hljs-string">"definitionId"</span>:5,
+                                <span class="hljs-string">"definitionList"</span>:[
+                                    {
+                                        <span class="hljs-string">"value"</span>:8,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"MRTask"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:7,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"FlinkTask"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:6,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"SparkTask"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:5,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"SqlTask-Update"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:4,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"SqlTask-Query"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:3,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"SubProcessTask"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:2,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"Python Task"</span>
+                                    },
+                                    {
+                                        <span class="hljs-string">"value"</span>:1,
+                                        <span class="hljs-string">"label"</span>:<span class="hljs-string">"Shell Task"</span>
+                                    }
+                                ],
+                                <span class="hljs-string">"depTasks"</span>:<span class="hljs-string">"SqlTask-Update"</span>,
+                                <span class="hljs-string">"cycle"</span>:<span class="hljs-string">"day"</span>,
+                                <span class="hljs-string">"dateValue"</span>:<span class="hljs-string">"today"</span>
+                            }
+                        ]
+                    }
+                ]
+            },
+            <span class="hljs-string">"maxRetryTimes"</span>:<span class="hljs-string">"0"</span>,
+            <span class="hljs-string">"retryInterval"</span>:<span class="hljs-string">"1"</span>,
+            <span class="hljs-string">"timeout"</span>:{
+                <span class="hljs-string">"strategy"</span>:<span class="hljs-string">""</span>,
+                <span class="hljs-string">"interval"</span>:null,
+                <span class="hljs-string">"enable"</span>:<span class="hljs-literal">false</span>
+            },
+            <span class="hljs-string">"taskInstancePriority"</span>:<span class="hljs-string">"MEDIUM"</span>,
+            <span class="hljs-string">"workerGroup"</span>:<span class="hljs-string">"default"</span>,
+            <span class="hljs-string">"preTasks"</span>:[
+
+            ]
+        }
+</code></pre>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>文档</dt><dd><a href="/zh-cn/docs/development/architecture-design.html" target="_self">概览</a></dd><dd><a href="/zh-cn/docs/1.3.1/user_doc/quick-start.html" target="_self">快速开始</a></dd><dd><a href="/zh-cn/docs/development/backend-development.html" target="_self">开发者指南</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http://www.apache.org" target="_self">基金 [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/task-structure.json b/zh-cn/docs/1.3.2/user_doc/task-structure.json
new file mode 100644
index 0000000..8703844
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/task-structure.json
@@ -0,0 +1,6 @@
+{
+  "filename": "task-structure.md",
+  "__html": "<h1>任务总体存储结构</h1>\n<p>在dolphinscheduler中创建的所有任务都保存在t_ds_process_definition 表中.</p>\n<p>该数据库表结构如下表所示:</p>\n<table>\n<thead>\n<tr>\n<th>序号</th>\n<th>字段</th>\n<th>类型</th>\n<th>描述</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>1</td>\n<td>id</td>\n<td>int(11)</td>\n<td>主键</td>\n</tr>\n<tr>\n<td>2</td>\n<td>name</td>\n<td>varchar(255)</td>\n<td>流程定义名称</td>\n</tr>\n<tr>\n<td>3</td>\n<td>version</td>\n<td>int(11)</td>\n<td>流程定义版本</td>\n</tr>\n<tr>\n<td>4</td>\n<td>release_state</td>\n<t [...]
+  "link": "/zh-cn/docs/1.3.2/user_doc/task-structure.html",
+  "meta": {}
+}
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/upgrade.html b/zh-cn/docs/1.3.2/user_doc/upgrade.html
new file mode 100644
index 0000000..c1b1891
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/upgrade.html
@@ -0,0 +1,126 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+	<meta charset="UTF-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
+	<meta name="keywords" content="upgrade" />
+	<meta name="description" content="upgrade" />
+	<!-- 网页标签标题 -->
+	<title>upgrade</title>
+	<link rel="shortcut icon" href="/img/docsite.ico"/>
+	<link rel="stylesheet" href="/build/documentation.css" />
+</head>
+<body>
+	<div id="root"><div class="documentation-page" data-reactroot=""><header class="header-container header-container-normal"><div class="header-body"><a href="/zh-cn/index.html"><img class="logo" src="/img/hlogo_colorful.svg"/></a><div class="search search-normal"><span class="icon-search"></span></div><span class="language-switch language-switch-normal">En</span><div class="header-menu"><img class="header-menu-toggle" src="/img/system/menu_gray.png"/><div><ul class="ant-menu blackClass an [...]
+<h2>1. 备份上一版本文件和数据库</h2>
+<h2>2. 停止dolphinscheduler所有服务</h2>
+<p><code>sh ./script/stop-all.sh</code></p>
+<h2>3. 下载新版本的安装包</h2>
+<ul>
+<li><a href="https://dolphinscheduler.apache.org/en-us/docs/user_doc/download.html">下载</a>, 下载最新版本的二进制安装包</li>
+<li>以下升级操作都需要在新版本的目录进行</li>
+</ul>
+<h2>4. 数据库升级</h2>
+<ul>
+<li>
+<p>修改conf/datasource.properties中的下列属性</p>
+</li>
+<li>
+<p>如果选择 MySQL,请注释掉 PostgreSQL 相关配置(反之同理), 还需要手动添加 [<a href="https://downloads.MySQL.com/archives/c-j/"> mysql-connector-java 驱动 jar </a>] 包到 lib 目录下,这里下载的是mysql-connector-java-5.1.47.jar,然后正确配置数据库连接相关信息</p>
+<pre><code class="language-properties"><span class="hljs-comment">  # postgre</span>
+<span class="hljs-comment">  #spring.datasource.driver-class-name=org.postgresql.Driver</span>
+<span class="hljs-comment">  #spring.datasource.url=jdbc:postgresql://localhost:5432/dolphinscheduler</span>
+<span class="hljs-comment">  # mysql</span>
+  <span class="hljs-meta">spring.datasource.driver-class-name</span>=<span class="hljs-string">com.mysql.jdbc.Driver</span>
+  <span class="hljs-meta">spring.datasource.url</span>=<span class="hljs-string">jdbc:mysql://xxx:3306/dolphinscheduler?useUnicode=true&amp;characterEncoding=UTF-8&amp;allowMultiQueries=true     需要修改ip,本机localhost即可</span>
+  <span class="hljs-meta">spring.datasource.username</span>=<span class="hljs-string">xxx						需要修改为上面的{user}值</span>
+  <span class="hljs-meta">spring.datasource.password</span>=<span class="hljs-string">xxx						需要修改为上面的{password}值</span>
+</code></pre>
+</li>
+<li>
+<p>执行数据库升级脚本</p>
+</li>
+</ul>
+<p><code>sh ./script/upgrade-escheduler.sh</code></p>
+<h2>5. 服务升级</h2>
+<h3>5.1 修改<code>conf/config/install_config.conf</code>配置内容</h3>
+<p>单机部署请参照<a href="https://dolphinscheduler.apache.org/zh-cn/docs/1.3.1/user_doc/standalone-deployment.html">单机部署(Standalone)</a>中的<code>6.修改运行参数部分</code>
+集群部署请参照<a href="https://dolphinscheduler.apache.org/zh-cn/docs/1.3.1/user_doc/cluster-deployment.html">集群部署(Cluster)</a>中的<code>6.修改运行参数部分</code></p>
+<h3>注意事项</h3>
+<p>创建worker分组在1.3.1版本和之前版本有了不同的设计</p>
+<ul>
+<li>worker分组在1.3.1版本之前是通过UI界面创建</li>
+<li>worker分组在1.3.1版本是修改worker配置指定</li>
+</ul>
+<h3>1.3.1之前的版本升级1.3.2时如何设置worker分组与之前一致</h3>
+<p>1、查询已备份的数据库,查看t_ds_worker_group表记录,重点看下id、name和ip_list三个字段</p>
+<table>
+<thead>
+<tr>
+<th style="text-align:left">id</th>
+<th style="text-align:center">name</th>
+<th style="text-align:right">ip_list</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td style="text-align:left">1</td>
+<td style="text-align:center">service1</td>
+<td style="text-align:right">192.168.xx.10</td>
+</tr>
+<tr>
+<td style="text-align:left">2</td>
+<td style="text-align:center">service2</td>
+<td style="text-align:right">192.168.xx.11,192.168.xx.12</td>
+</tr>
+</tbody>
+</table>
+<p>2、修改conf/config/install_config.conf中的workers参数</p>
+<p>假设以下为要部署的worker主机名和ip的对应关系</p>
+<table>
+<thead>
+<tr>
+<th style="text-align:left">主机名</th>
+<th style="text-align:center">ip</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td style="text-align:left">ds1</td>
+<td style="text-align:center">192.168.xx.10</td>
+</tr>
+<tr>
+<td style="text-align:left">ds2</td>
+<td style="text-align:center">192.168.xx.11</td>
+</tr>
+<tr>
+<td style="text-align:left">ds3</td>
+<td style="text-align:center">192.168.xx.12</td>
+</tr>
+</tbody>
+</table>
+<p>那么为了保持与之前版本worker分组一致,则需要把workers参数改为如下</p>
+<pre><code class="language-shell"><span class="hljs-meta">#</span><span class="bash">worker服务部署在哪台机器上,并指定此worker属于哪一个worker组</span>
+workers="ds1:service1,ds2:service2,ds3:service2"
+</code></pre>
+<h3>1.3.2的worker分组进行了增强</h3>
+<p>1.3.1版本的worker不能同时属于多个worker分组,1.3.2是可以支持的
+所以在1.3.1里面的workers=&quot;ds1:service1,ds1:service2&quot;是不支持的,
+在1.3.2可以设置workers=&quot;ds1:service1,ds1:service2&quot;</p>
+<h3>5.2 执行部署脚本</h3>
+<pre><code class="language-shell">`sh install.sh`
+</code></pre>
+</div></section><footer class="footer-container"><div class="footer-body"><img src="/img/ds_gray.svg"/><div class="cols-container"><div class="col col-12"><h3>Disclaimer</h3><p>Apache DolphinScheduler (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by Incubator. 
+Incubation is required of all newly accepted projects until a further review indicates 
+that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. 
+While incubation status is not necessarily a reflection of the completeness or stability of the code, 
+it does indicate that the project has yet to be fully endorsed by the ASF.</p></div><div class="col col-6"><dl><dt>文档</dt><dd><a href="/zh-cn/docs/development/architecture-design.html" target="_self">概览</a></dd><dd><a href="/zh-cn/docs/1.3.1/user_doc/quick-start.html" target="_self">快速开始</a></dd><dd><a href="/zh-cn/docs/development/backend-development.html" target="_self">开发者指南</a></dd></dl></div><div class="col col-6"><dl><dt>ASF</dt><dd><a href="http://www.apache.org" target="_self">基金 [...]
+	<script src="https://f.alicdn.com/react/15.4.1/react-with-addons.min.js"></script>
+	<script src="https://f.alicdn.com/react/15.4.1/react-dom.min.js"></script>
+	<script>
+		window.rootPath = '';
+  </script>
+	<script src="/build/documentation.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/zh-cn/docs/1.3.2/user_doc/upgrade.json b/zh-cn/docs/1.3.2/user_doc/upgrade.json
new file mode 100644
index 0000000..9ebbbab
--- /dev/null
+++ b/zh-cn/docs/1.3.2/user_doc/upgrade.json
@@ -0,0 +1,6 @@
+{
+  "filename": "upgrade.md",
+  "__html": "<h1>DolphinScheduler升级文档</h1>\n<h2>1. 备份上一版本文件和数据库</h2>\n<h2>2. 停止dolphinscheduler所有服务</h2>\n<p><code>sh ./script/stop-all.sh</code></p>\n<h2>3. 下载新版本的安装包</h2>\n<ul>\n<li><a href=\"https://dolphinscheduler.apache.org/en-us/docs/user_doc/download.html\">下载</a>, 下载最新版本的二进制安装包</li>\n<li>以下升级操作都需要在新版本的目录进行</li>\n</ul>\n<h2>4. 数据库升级</h2>\n<ul>\n<li>\n<p>修改conf/datasource.properties中的下列属性</p>\n</li>\n<li>\n<p>如果选择 MySQL,请注释掉 PostgreSQL 相关配置(反之同理), 还需要手动添加 [<a href=\"https://downlo [...]
+  "link": "/zh-cn/docs/1.3.2/user_doc/upgrade.html",
+  "meta": {}
+}
\ No newline at end of file