From 3de698becc78c7a99a547a5b4d8ebcefa72ee4f1 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Tue, 16 Jan 2024 05:17:57 +0000 Subject: [PATCH] deploy: 772885d63dfe8ebe617021cab308a8880814fd2b --- 404.html | 4 ++-- ...upport-2c611b3527dfbaf5fc109185d28f38ac.jpeg | Bin 0 -> 81009 bytes assets/js/935f2afb.3fb9cbef.js | 1 + assets/js/935f2afb.6db62b48.js | 1 - assets/js/a1c7e5e9.7d2436e8.js | 1 - assets/js/a1c7e5e9.dd649570.js | 1 + ...ain.6707881b.js => runtime~main.4848967e.js} | 2 +- docs/FAQ/intro/index.html | 4 ++-- docs/FAQ/whichdatabase/index.html | 4 ++-- docs/SUMMARY/index.html | 4 ++-- docs/deploy-manual/Docker/index.html | 4 ++-- docs/deploy-manual/DockerCompose/index.html | 4 ++-- docs/deploy-manual/config/index.html | 4 ++-- docs/deploy-manual/intro/index.html | 4 ++-- docs/deploy-manual/rpm/index.html | 4 ++-- docs/deploy-manual/source/index.html | 4 ++-- docs/dev-manual/intro/index.html | 4 ++-- docs/dev-manual/plugins/howtodev/index.html | 4 ++-- docs/dev-manual/plugins/howtouse/index.html | 4 ++-- docs/dev-manual/plugins/intro/index.html | 4 ++-- docs/guide/index.html | 4 ++-- docs/intro/index.html | 4 ++-- docs/online-demo/index.html | 4 ++-- docs/quick-usage/index.html | 4 ++-- docs/support/commercial-support/index.html | 8 ++++---- docs/support/community-support/index.html | 4 ++-- docs/support/compare/index.html | 4 ++-- docs/user-manual/customrule/index.html | 4 ++-- docs/user-manual/intro/index.html | 4 ++-- docs/user-manual/jetbrains/index.html | 4 ++-- docs/user-manual/knowledgebase/index.html | 4 ++-- docs/user-manual/project/analysis/index.html | 4 ++-- .../project/audit_task/SQLfile_audit/index.html | 4 ++-- .../project/audit_task/baiduyunrds/index.html | 4 ++-- .../project/audit_task/huaweiyunrds/index.html | 4 ++-- .../project/audit_task/intro/index.html | 4 ++-- .../audit_task/java_agent_audit/index.html | 4 ++-- .../java_application_audit/index.html | 4 ++-- .../audit_task/metadata_audit/index.html | 4 ++-- .../project/audit_task/mybatis/index.html | 4 ++-- .../audit_task/processlist_audit/index.html | 4 ++-- .../project/audit_task/slowlog_audit/index.html | 4 ++-- .../project/audit_task/topsql/index.html | 4 ++-- .../authorization_list/index.html | 4 ++-- .../data_access_control/intro/index.html | 4 ++-- .../permission_template/index.html | 4 ++-- .../user-manual/project/group_member/index.html | 4 ++-- .../project/instance-manager/index.html | 4 ++-- .../user-manual/project/instance_syn/index.html | 4 ++-- docs/user-manual/project/intro/index.html | 4 ++-- .../project/operation_records/index.html | 4 ++-- .../project/project_create/index.html | 4 ++-- docs/user-manual/project/quick_audit/index.html | 4 ++-- .../project/rule-template-manager/index.html | 4 ++-- docs/user-manual/project/sqlmanage/index.html | 4 ++-- .../project/whitelist-manager/index.html | 4 ++-- .../workflow-template-manager/index.html | 4 ++-- .../project/workflow/audit-workflow/index.html | 4 ++-- .../project/workflow/create-workflow/index.html | 4 ++-- .../project/workflow/exec-workflow/index.html | 4 ++-- .../project/workflow/intro/index.html | 4 ++-- .../sql-workbench/how-to-configure/index.html | 4 ++-- .../how-to-quick-deploy/index.html | 4 ++-- .../sql-workbench/how-to-use/index.html | 4 ++-- .../sql-workbench/introduction/index.html | 4 ++-- .../sys-configuration/configuration/index.html | 4 ++-- .../sys-configuration/customize/index.html | 4 ++-- .../sys-configuration/intro/index.html | 4 ++-- .../sys-configuration/login_syn/index.html | 4 ++-- .../sys-configuration/message_syn/index.html | 4 ++-- .../sys-configuration/process_syn/index.html | 4 ++-- .../sys-configuration/webhook/index.html | 4 ++-- docs/user-manual/user-manager/intro/index.html | 4 ++-- docs/user-manual/user-manager/role/index.html | 4 ++-- docs/user-manual/user-manager/user/index.html | 4 ++-- docs/v2/FAQ/intro/index.html | 4 ++-- docs/v2/FAQ/whichdatabase/index.html | 4 ++-- docs/v2/SUMMARY/index.html | 4 ++-- docs/v2/deploy-manual/cluster/index.html | 4 ++-- docs/v2/deploy-manual/config/index.html | 4 ++-- docs/v2/deploy-manual/docker-compose/index.html | 4 ++-- docs/v2/deploy-manual/docker/index.html | 4 ++-- docs/v2/deploy-manual/intro/index.html | 4 ++-- docs/v2/deploy-manual/rpm/index.html | 4 ++-- docs/v2/deploy-manual/source/index.html | 4 ++-- docs/v2/dev-manual/intro/index.html | 4 ++-- docs/v2/dev-manual/plugins/howtodev/index.html | 4 ++-- docs/v2/dev-manual/plugins/howtouse/index.html | 4 ++-- docs/v2/dev-manual/plugins/intro/index.html | 4 ++-- docs/v2/guide/index.html | 4 ++-- docs/v2/intro/index.html | 4 ++-- docs/v2/online-demo/index.html | 4 ++-- docs/v2/quick-usage/index.html | 4 ++-- docs/v2/support/commercial-support/index.html | 4 ++-- docs/v2/support/community-support/index.html | 4 ++-- docs/v2/support/compare/index.html | 4 ++-- docs/v2/user-manual/customrule/index.html | 4 ++-- docs/v2/user-manual/intro/index.html | 4 ++-- docs/v2/user-manual/jetbrains/index.html | 4 ++-- .../v2/user-manual/operation_records/index.html | 4 ++-- docs/v2/user-manual/project/analysis/index.html | 4 ++-- .../project/audit_task/SQLfile_audit/index.html | 4 ++-- .../project/audit_task/baiduyunrds/index.html | 4 ++-- .../project/audit_task/intro/index.html | 4 ++-- .../audit_task/java_agent_audit/index.html | 4 ++-- .../java_application_audit/index.html | 4 ++-- .../audit_task/metadata_audit/index.html | 4 ++-- .../project/audit_task/mybatis/index.html | 4 ++-- .../audit_task/processlist_audit/index.html | 4 ++-- .../project/audit_task/slowlog_audit/index.html | 4 ++-- .../project/audit_task/topsql/index.html | 4 ++-- .../user-manual/project/group_member/index.html | 4 ++-- .../project/instance-manager/index.html | 4 ++-- docs/v2/user-manual/project/intro/index.html | 4 ++-- .../project/project_create/index.html | 4 ++-- .../project/rule-template-manager/index.html | 4 ++-- .../project/whitelist-manager/index.html | 4 ++-- .../workflow-template-manager/index.html | 4 ++-- .../project/workflow/audit-workflow/index.html | 4 ++-- .../project/workflow/create-workflow/index.html | 4 ++-- .../project/workflow/exec-workflow/index.html | 4 ++-- .../project/workflow/intro/index.html | 4 ++-- .../sql-workbench/how-to-configure/index.html | 4 ++-- .../how-to-quick-deploy/index.html | 4 ++-- .../sql-workbench/how-to-use/index.html | 4 ++-- .../sql-workbench/introduction/index.html | 4 ++-- .../sys-configuration/configuration/index.html | 4 ++-- .../sys-configuration/customize/index.html | 4 ++-- .../sys-configuration/instance_syn/index.html | 4 ++-- .../sys-configuration/intro/index.html | 4 ++-- .../sys-configuration/login_syn/index.html | 4 ++-- .../sys-configuration/message_syn/index.html | 4 ++-- .../sys-configuration/process_syn/index.html | 4 ++-- .../sys-configuration/webhook/index.html | 4 ++-- .../user-manual/user-manager/intro/index.html | 4 ++-- .../v2/user-manual/user-manager/role/index.html | 4 ++-- .../user-manager/user-group/index.html | 4 ++-- .../v2/user-manual/user-manager/user/index.html | 4 ++-- index.html | 4 ++-- markdown-page/index.html | 4 ++-- search/index.html | 4 ++-- 141 files changed, 275 insertions(+), 275 deletions(-) create mode 100644 assets/images/commercial-support-2c611b3527dfbaf5fc109185d28f38ac.jpeg create mode 100644 assets/js/935f2afb.3fb9cbef.js delete mode 100644 assets/js/935f2afb.6db62b48.js delete mode 100644 assets/js/a1c7e5e9.7d2436e8.js create mode 100644 assets/js/a1c7e5e9.dd649570.js rename assets/js/{runtime~main.6707881b.js => runtime~main.4848967e.js} (76%) diff --git a/404.html b/404.html index 7d4298c9..140943cd 100644 --- a/404.html +++ b/404.html @@ -4,13 +4,13 @@ 找不到页面 | SQLE 文档 - +
跳到主要内容

找不到页面

我们找不到您要找的页面。

请联系原始链接来源网站的所有者,并告知他们链接已损坏。

- + \ No newline at end of file diff --git a/assets/images/commercial-support-2c611b3527dfbaf5fc109185d28f38ac.jpeg b/assets/images/commercial-support-2c611b3527dfbaf5fc109185d28f38ac.jpeg new file mode 100644 index 0000000000000000000000000000000000000000..439ad41437a02f2da486231e1e5d27797eab9f6c GIT binary patch literal 81009 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%0AXqe|xOY{np8$(kTkK$_#+` z7!Vxi`M-iE|AUg&E$><_KZ?5u4q6pk$0-+nX5qRF8}w4NR@O2rpSMrF=Q1BEH4xd| ze=?r@DIrRb1ClZb=K8`{*(q+Da54dlQ91h>^g)vDen0T4&F$)S$$!UvwARW!(MTP$ z*Y=9dl3`MT8bY1H!IQ1@?l*V4F{Wy=Jkf_mi8?z=e{zM|86IGk$p6fgtD6`qHvoq46 zTQTWl)bEWnOt8^wa{3xox3KkW+`TWB>o3MoKXkw&)^?AJC?l{d07z}|0Y#Q;S@)ii zKLxCcwoHX6GO|;4=uL^J(_GTUWNMxHRS3OcNo*KuH(lDuUO0SwDzrMx;Ib3U;Z> z6}m+fX1aap?`>7x@rV$!)%Lp99Pv7Sf9TIsnT>VO-;$FY)Gy>U_?l|p!*VnXPx*Qb zUG9cJz&ufop)?Z2t2(}w=bB#bdg^a(xIdPU#TU}+dNsSeW`R{VY3w91x`9oOu1 z@Z?Bb>-98In@)=y81>wD<0<uBA8TNu}PujcWQIK`4_PlGX1p?y3ooL`U9bGP7YZx5O;n*rIB6% zv;8P#3ayb6Bi(n}vKc>M!Aa8JJYM&O>ZQJ6^q_j7>)-?jCaO*26s|_UCZ+Q zUb)LXDc>Y)bg|-L)jR8SGM5!k?9ZxQ7EOhr(rpvH~V1Vvm&pIBoeW=2cctFra#?^_r@%SsQSC;NIczf zxr!7Bnh+#kpVDiq&K?cfo2_2%7+eWg^Z(77HCBHnFvs5&hk8{z8L9$Fj!B8U>e&E} zvR*MEgQxcu9s_~2!hEM-rJUUtZxbdpWk#uzZOEfB?G5P>cLXNMG7VF3-jPiIUDYk- z1%$JM&wkHzDkx}a+$+q*RW&ztL^#p7JV9{LFh|*QZJs*zrJd?xV+1;Gu3$jWPz=|o z*4FE0K5s0EzRqSsdQ;EnG@V7}lD8%E-VvvL>MWFenr@mO`!XKNkUwQ&8Q!f$s3d(1 zX<#fOyDY@pI_F=`4gM3x$RpDAO)J;QGRFVS6jXkp4Tjf9xO{gYtuMyvizdl*rWOthleqR~?9ET+I%p_e*m~;fevU@%^?1TeW&F|dZ?P^z zx+dPqmM(LSORAJ3J@MctiIQx%YkH&xrFxVqC<*X&DPUgQ8tcdRY)=z7OYKVdH_=E8<6OwD(tCukwN+K74v$hT z4Ag@=AfDwbKp(thJtWv^hXM`@{tRrf4X@$w)Ku`1Pi$8B+v4g8 zKwO>H0eCC0b^xZmc%Xbfctm<8DRcxywXtfA90C4^*{$`*{f2udea_^{p+;S!e(e<> zZQGyRvqlwF`N*lB)_#qbx4|hl=1Kq1sF9Eli%aG%Ik0+ml2e#S$$BS3*zD5iOVe^I zOiwF#v~w8oI+FQkmh%<0^ES1tiSv9KKz?~cuBDfnFHKdb3=GGyJ2b1qz{D=yDRBJA z2ZR{kTmzglKoJQj34R|?VeWTzq1XBwGPKr6q&H~s9a+XRr);&E!b&G`SJz_aO?*%| zK(Jv(jWhA56KaJ~HP_nfFzG`r#d2BYG?kV$I)W3ROx{CqCS};;{%2D-Jn$!JPwEMi z>}$ISssXKiJN^B)h^;kj4~>`3*)Id5mW*N!Ey_1VQtKV-%V{|(`e>)Op56u+N4d#S zF3*}byVUne`L9da%oZsm^YLD%%tqS6>kegdqHW&^%y&R$k!dL7GEA>YuyL*7gz+A5 z8eepn4PX!@%zWyirNiM~A226Rn@2>M3B=y}ubb`a@u$)o^dwbql8@6T4Q&uwe^4Sc zK-i(2nW@v@M%Z`J1TMavkm?hUwwwS_DX&&0AT0SsO!O_0A80`btbcE9}u zak`>#G3)&~CSlg+DnopJ@AaAFKFG2wdC#9Z`E+gcI3RA_mFm{8hBo{3&b!G`E>;lbFxc9$zJ+-0<^ukMS%V9ewy_n*to?#MQCmr*l=YJ$*>KNKN4pLmq{ z3o0xNsQli|5iM2~zNzE?xJ-KXvAC{*k-N;q*cp}-F$FNF)rnG&cUCw9k{z{=e21|f z6CwlBMUszQMSz3Z8~|gV?;K0rBjEuUVDk3K%R&soa&^6U`v;>isy zYv%;~JI^`|*W9LqhvgnP9&tE8nta(Z-!={JCvHw>Fu19O&prg5;sK zR?4jSnew{751ix1`c@;@W#-FcLJ(Agsko1X>0` z84dTZ&-mYTF^n%Ac>BAwBB&2)mohVw)Nq$vM9mXg7`JT}k@z@SeiG&N@~2! z4q*?|3=;~2g|XuNZ$kVbK=R?RY#K|9cgwXs3r19fY8t!fJiwD(+DQ~^pn1eF` zr%hoWU1P4|yxI?+MMi)2MwN}Ol{QT-uTbs_UL4xds?cC>cD^-D=h)Jli>Y06EbT8> z$?ZJgcv_lxobJ%{bG2V5Fct6b^JnzYx+o|ZP8X1+IcjjUqw8S0y61hp2ekDJKL-0a z-a0tWvz;Qi_BKOkH51aFgn{Q@^9>s2p(PHg(ua|U%yZ=0z68x~NlWqE)?OY}hIr4_ zztMU0H?-*Ezx;Y^9a%05JI@$525EWNpwrNLkn7JctX#c8NWZd0NW7mXfS_dgbc58awaREao<1gP^%Dq}1=Ww$NibuY=;dyhgNlGb+QW zgTBMkUpy!Ktub5hBY#)$q%TDjq2`$a4fAZ#vcOjpagv9rzjTm$;_sBWNqakWPQ)5H z-r@Kd`Md%hfzWVUi7(v0gO09$B&o>`k1!d1OzX2lC!@R3EO8eRVnqK{4b}N3aN8>+ zp8Hm<`>arWF>4~eb6w+7vNTd0gCzgx>3*u-iR>W;&0;j_<6ge(+g%N#{67L*&frAi zTNgE68qA3;5Y*NjQaIt^OH%J^TJ@{NYi;3!vcU6N)kAD?%HF`N;xJ;8X!(A%C9rkC z6ev7t%Z5N0AxeglvpL7Ij($RfgaLkypkzSk@|GA71P4KkAGEhg~} zn(*ciAPF-qV1Wur73aekkAiu`Ph_>vZi>l!n9O|Z5AiQ|t7E@UdcUsx)qM0jf1aMu zEX##UxnMe?#%P`MT))Xu-8vCZUW-L-=>3np=Y;85cKMMX)rbmoa;NvVkVDVx?;oWX z)O%f2cdWed%5}|;>x)bcViE-m)qfF^>gayKnMZpu_%~X6Y|PoskQrPh%|-e3X|cS5 zW{uVewMlyQsJwA^SaP`%JmuAcSHdT?5HYs2l%cO9F)WdcgHNvXiiWHQ=EdVmmB6Cv z9`T;SX05fetL-rY-1F3A1&zE-ksgeKZ%Rr9#WuJWeYc1raZ{==2dptv%SS?Aex<^J z9R0D$mL&}P>8YQBIxB{g$@}EGWEBJCIKD~-3&rwTbI)2U8)xsfSGszgv+L_Z$kP)w zCDpgqr61OLP;~oLpie)^2OP8ih|lINx-vcfO4-x56%?uoVR_#g?Vosc5VY$z2C}CJVYGUFXBBb^_MR?zI*Pc-QDRBmxKQ3 zzN44mnU|Fm?=>Igtd@m=q@{7Q!RMPgqazaiktKi`d+q{DwG<8T{VaTXiKP8x?A>M9 zcv$+H2SF6*JW|x%s=UHNSC+&Iq0@DMB^kfMu2J%&`>1J;x8y-d2vbf37q%m!GV51p zR`y(?F0&oI%YCFdR@-JLokjqDqyW|;%XmT}J}G_|I=wt5JJGoZKOG!1N$r)j2+)%u zcgVlI@Xhn-e#o3?>)=bq$+)kpt+LJ{ChE_U`ct~{ z$Q6vV_lA?QeXp+z{SbrtT35$f-W6d5)W!~SVFG$~LJ>hO#h=2`u>4wVzFCi2YvD#` z#FJb`Db{1f+|o-FG|0|qaOAL+mV#B><7ecs5M7=9|Stf%%aTD5OGqls5@9=lqcfGn7lmLlNELH2f*42cwwW0sqH50u|e~RP+hUhIV(C27xWH>ZhE-)h?Cc(-)GQ)D(Gibr8uC}3^9JlKOj z=9$iFZ5ENjt&uVKRSF}tE1hk>@uA&UYGsfwE_HQvbUd8?byVojo@H;bcD}?#`korT zk8}KgHr4<)@to}&F@`}cUWAH2H~%zY)9WrXwpPK-9+q}mXU~0M(LFZ>xVG!0Kr+em zOC21tB$*%b2J5)gaH}Y0c4p0_-XVoQ6+tSPag}XmMckU~SnxlzOk6@*%m+fjCxU!1SWde>W$I!! ze7x}(@_>Vym)wMe~Rz^=%Iec{y%n^tNHYj#oqg`T*g`YC93 z`4~)WZ|kEt!%WQd^pu~xQ(h;heoRv4TdR#>|FBKpQ_(^1=kL=9>BQNoefyDS zLuZ+P$Oa~v6c>cZbU3_mmsKD(khu)hu+I65#Cr7(Ex3K3l6{?Dzr%tLL6yFXx z$0Ki@;k_dr$H?^Y;CB)~R-CeWE3X~Dh^y3NfeLc`>q@s~Sqt|5Q1Y^9yp#NDowwDG zhm;-q8OQpN5SJ49{V7-8j`90%(jsP=<+Le0GkxA&D&DyHC6)EMl!c5o^Ka&STcR>q z9Lng}?m@tPtsZnxCUA|%aVtU(88LBu*~BI`2*%Dird^SnH{$%2 z=f)UIN$x>sMqSMg!gzTVB^4>Ab>~$Z8x>q)64rJu1)1|dDzIe7GtDWIR3sCoZ$>5l zh)`ds_Z<|McJ=NU|3ga#R;ujMSL?R%4@Ljb>iw{4-_&%T4WMMY2IR~4zx^yeV0$^x zySD5l2pPrh3i$F5ZL6q55_$=n5L0VV)M#}jC07PtS-Mh(G!ua#!m(Ri@HoCxyEj&`itS3%_F#X zEmhaIU-YRcfr(N~i^PSnR;9n*zf3JJ^snwtCbb?*4uXoN(3;P>cq-q;CnM%BVu6vu z!uD}a=^_qRrC9?@UY3Iu7oxI{6 z7~$N+i*&N-M~__@bfm?q*}!QKL#&wvIq$rbN~edZ*gCqD8&RjHE{Z!G^U85GY=*$Z zSBij%@t0h~bdnS5DpURtU6TP3BM+WZWLllQlNN+gq5 zPQGg&9#sj zP<{lqcVsmuFTYD(Q7DLm-^t)&bWox}5hFcH)jtHicv} zYI0b2e$`W%Z8_yX+q$IplC@|Kr2slFX5A6sAz2Dff{~7&JIlB>59r3z_-NSvs8?@uX?3dUq1QFnozgjzj;|^<=~^wKL_d1!7YU(jP0cy+?hoVs?`OS z?@cT^$n6F1ioXe4$sP{~jCQeo1%nSR?Xm0CGb)VBNj8+-3uYY+-R>i(0;KIQ2D1kQ zfGk36FalV~q)7+gb+n`g8XmDA_e@(#AAR4h6Flvlu1N7!H1%uxM8PpY)!S=f_#pa1 z_)O`{(&DK=E@XtKF_phU2lf3Hehf%d8rP_<;@e=8|GePl(xQU5WYm*qhYETziH>ep zckOp^zQCDY*;v<%$xno%`YPdaxj?K&PqyMmlpNfb^f=0ePdFeLlwP`QVE~&-jd9d= z;LlBQ)sjs7b?ND*yU<7%!C>Z7{J1w0*jDkQ44Unx|3$&s`$Hg)9NYJAW_)4IN~O2V z{I#4O(tie{pv6}yuO=sK_XeCEY7fug$Fy5O+rvLJ|ExoMvh1LydU=zQc?z-qEP|qu zxQr<7U!&Bsz%rM=ffL6o^*+GdVzx38F`Vt&m}jVNd#&QT*eA&=5{Il{cGA09*OGEd znPCja_i{!qVP=!j{ke&wAGHu=WRQAy>mdp*qL8gwc32zzhbI3}4LLyAZX7ta2u1SD z%;!}V3biI}dKuKy?^O$v`0sMPcvFD}iC z#V1VR{9usMcbhFPc3l}zr$sF1ny`^h7602u6^^3ihRJ~Gq=G44|L7<#%+~Bhb;3?8| z9~^w|@6juA{b);j{uq1&gd3!aN;T`vDhN}>0$vrS!TGf<ItPN%Vw_G-gmlLyR> zKp^7ijY!XH1^%X2VOAXdsbZ|_@eC~)&biAl`JC?xPZOi&xZ1wbTSDRe+v!g1?GG$? zt|E%#TmjpBsfEh)z2Ku|Kr2dXKmFCtSL}53p-vT+t~XYJT;xf2_9hLvm(@H(J*B?j z8g5^Z^?B%zQn)hXI9U)n8=vECUhVAvrKp+PI;>D`7;eZ|4?=Yq`Y1O1{4vi*i~FpW z(0JOM!ap4r8DcHre!2a<8?OY>(9FYBT12o@->Z|K)9aArYp-rR8k&neHJ2OQ5T4Jq z{aeyyuPA$OOvEp~v@C|?XhwQ;f+&T=vNmlwxZS$1JPswp12X4=_2`6Psk?~F8kf7I zomHoay2|gyyElzO_4_viPsf|1@*)vU7N0JiBR-?6eNx62FbsM?MuR zD#x({o%cX}ceD zBMw)q1Ib8^7mcu4Yx06TRwJDx&^8HPH)Z>1%NvJ=BFUp7;eZRnqW{V!7B7`cN>C>eT7~aei?rmrO(XrY-z^6%t_p`*{Z|S2AB+uZOLH?W za0h%s)yE?5kh#%-@R^4LG>@0Nhypz^GS$5YLXM33KXK{Po%Wte^-91IAg`oHT>F*zimH8FXVz_Hp!>_4i zU!0@ux?Vv!EmbOwCk{=t`gUNw`aOkR4VKs>)zqZZBUk=Jp(B!u@0W(&q8%vjUFq3Y zgxvPSYvNaN1?e^XLmXX)g)s z^F1kTDoxhf%s*n?4|Go8e2IxMmdh|{xdkVPZcaBl@WWazmO0=y^(uD~x~E*iuMwOPto8*3=^2>3wUJ3vYJdRb?D(_Y<&G|6fgz z@se!^+nu}VM#74Aurz$XxI(tNYx^GzHRGUdcXXmzCrlM3Bl6LLi}LmNPtxZj2$bWR z?=gnI%}`hOLzJK~WWwHXWep2q13LV%Qmn z`jcR^&Y^wO3*^2y+79pMhnA}i))M1t87;o;2a12Z%u3NzXAYs+(;e}LSbK>0_O!%|d($)U-8r@` zPOlPC6}_xpuZk48c}=a_L(cH3`Opp(*yn5^=o?SkJ15p+?>F{sPih1a{NyZBq11$G zMal{IWRZNd!tSr^Eon9O|9VD6eRih?sc5U?{zL2U8^6|XC;42m$AQ7BdvUBkvV`%V zTXfi%{~H0@dPR3olWds0h_7BtDz{{>(GkV_6FzdBRJ3T{l(I%B$b4B1r}euJvO>S? zD$6dne{pB*L44AXsma03zkd{;gxx$^|61PyDkjRN1x+6a9AHFHjNn@c7hU}E^SL*i z;u)%LqlWW0RUf!Dh=VxIcm3v4RMoCjTJUII#YG$no6%)0u7^@a6ZBSx({rppYwe4E zSvOe$yF}z$G19*y<)INF&-i8dZe39!N(2o{T)D^iljc+BJUFNUi6f^50}hM2_N6FrSlGkmi$bECV(NfFP=~_ z(28ulO2eeyNlEc2zbjuEFZS^(=Jwu8yI#0&?J(#4d`~>PnouPK?iF4L+q23NE|8 z6j{|1KAQG%Tox~H+dF4Zrct15DzDcPWJ z1j;$r(}mggM@+9Gn&7S)S6w#fY?AAK(}FnrXA@*6)*uLzJkxWkAGGoOGRgJ53_`sO zj83o_7G;UF1Vk|D6rq%82WOC!pSrdDKQwTZ2KZV{^8@s0jDs9D7Oa|FyxCKWvo-JQ z=7uSo7c)NHh;?e-{Hi)NAv!1dRek7(x4j?gMx5(Lxbup#>~WlnvYbWaoMFqnDfBR4 z0gJ89`(OPz(9wd3%ANT?^$bvn15C;93<_95BBFM_7BsjDLhrm)Uvy(Te~=PoY)@_2 zSBF*P*%`T~vH~McwP-va)b={wrShP3dO4>Y2Gg(VV>YG626=+$Q&YdteZ{5=m`I(S zOV(|^C1IZZ9cS8Tkhfpg^wf~rz^|_Eib9DlbSjnaOd5%9B~QlP;^}E$ZxkE3D(2U~ zLB*qL4w~C?k(ehw|2#ZES{UdWpm(7s#hsiA36sds8<*@t0@onDi|V=pmZGSG9V^Y# z^`QtQ*4XZ^`nqXhEBxrYzrdUf6H@f%6pZ#zG+7lCncF;1RD!J0u;$@Hbxl z*rlbX6(kDBPHA;)-qt%6tp2XIt4&fn6)yH(h$OYu#MoXtF={x6>^Y&RlRw{`&0Uqr zRP`SkwQ-#>T1R5Jp);pl_tstZ?&ZamC&@P|9#rA&cZH~?OVFIvrSb*DrL_Jb6e&U4 zWHK;XxkEJ|JOAn79+6#DsSoQvUOF6jXB2|aqpX^v6Zrld-YNMHZ3cCGzHC5kt9+~pqtCtHZhR#(ZMhuMN zZAoG}x(BtEerV{*($NFlQmeQBv4erC51_k__S%Ye_i(gl&qq<%)zzsogwR+%DN+>R8{45T3Ei!NW4G5BefFDZ6X3qRpaZ4A6W|7+AfKeYw8&! ze4BUXwldf;KV{tN_MzP!)a^@t*;8kBp7Lo)Elb|{m8)=HW#HB#okYwi4@XQN1hQjQR!!IM z?YUx-b`R8eD!WwG5RrT&I48UdoXlaICC4%@?QN0{;IZz&;@bi}cT}iCCt9lRbNbZ@nGXLb1~ZSaVyMI8tD2d6)X z-Vax8N+kP_00Zu-a^vW4=W{0^>+S8|3r3?F{|{+z71vhRc6(E3Deh3*-8IE2?i6=- zNpN>7?(VL|-Jxi3x1hxx3X}i^dVjf}_kH%!w~zKZ$U2%yewkTo&NZ%U{D+y&W?OyP ztB$gL+j1W>HHU=gQjrJ8 z54Ok8XT2%?-`fVAQ-IoA&efc@zy0yea_ooZNH)_gKH|W6NUKf^4n$_nHCg-9HZ`{# zAWaEZqaAL~G_Dct*C^aXw5bim`4Vds;g88V-Cgk#i!P4Kc0#+8FEf%vg@=tpn8D&r@aHX|6X2mo*?y8F{tvt!`IK?s^y{dyd^29$w3!vHlu%xOaGr-*SsY~?SLA#oZZcdbo~eY)SOlxTGXf_TCA<*zdn^my z3`8t(SxF!o=VdW0wdCJ5QNjS0O$?Ka3}Mt!{2E4ym2f5>1 zmQ9El9i8YixZfplSGaSZzJcxk1+fC1%M$oRw`X=#fD{ETr#?6|O5oUgcDW{|q3y)x z2Prz;y*KDGy9r%QY-{t^EPJuxXA;`)02}2tv3U*!Rd$Q&G_p;bkJrT+3Cm*A&xew* z)#xn*v3`-$&t@x2n~7V`JSO3Q?X{nc=PbmY{!c2$e~EejIVUq6%Fa|K&Jkt(MQzNr z;m*~}dKj0n6S2l%_hZd)U8=!`=q|{S11hNM+cRX@*H|zjo%c=5Fq^({;HllApWobk zw!*e4_Ta{#sUrTatP)C>Kz9gvY`Rq#u4A(_LXn_iZphh~Z=XwIkHkicL?Uq@T%BQ(9s_(JkhD#_C zGt#ruG9^cj#N=99if)Clg~e;NfZm#R;mh ze^*xq@}*l`vVxNcOr``PxnZ3tr0vs%^vU)M3gI4B7X7q$Y$BlA z~i;&iml?8R)J5+0KB&Wkql=rT# zHEhYbpfVA@ely`8XB=4F++9sjI(q{vV0<l_Bi~+n z6mhsVCO$+tfMQzGfFg=vd4g2h5w!p3&^v))CaEnmFlED1@_OI`G;Gv5b0fbswV>q^ z=hEwx`RLC|q*&`FrjfWV8A_d9j>j0G+QYpIg@ z?RR!)@?G@v@8_4;RuX!_TFm7;=CrCunUwWh46Qcq4YMd2XtXl{0t2$1rDUY7kO3s{j}w#8=(^%tjnkE1Ss2&CI1MJ=IxCKTZbaqc zMQ|zgh-B0r6AC#7rPKklx=UJ;!L0CAZ!gQAuWSZ---E3EvqC<9S(_F4WKrqi(vWAh zbBaT1J4Uv7RP)n=9;x^9?_?$XiaKt1vAlwSpv~I}sV2#067+5^qs1-w}R9a| zk6j+<1xIZ47k*!jbUA*Zm1R##(XDpCto3FJ>YTsx-H8~EhMW%b$`xq=i?9?A9~I3) zca@3%-jz=3pRPm~*FDOFm#WoCK_lh1>I8Y^^6ENqd-5v9> zLdzR`XZiBX=qz3iNrcq#37?AMPEh@yw4Kuit}73gBDsq*4H>dMB8|+T8B^1BAmOPf zbyzyZN*e!Cluq+}`$}B7oiS%w4bf23&6_7bTWe=tx$YQjZ%(A*5_cd9tJA_{?7#g_ zu*Z==*^J#=uVu0YSLR2{qEuY7WDfcnA&uOm24r5v>}SE>!S7h$nNC&`voRCKZ+d&H z9ReJf$GJ9(}0Saz|r_k65AIuq5)q#hUH}* z36CB}PyKy94oxkzJT65iZthr#vEX2Qg)su)^7o~uLGB%%n~1b>9GRd_9!!px-nLzN zf0J{S+PDwxv*WoWPDkOLZxwP<^??3A3yF=swPu7a)B!%vG~7PvhSdfP_5;l&- z?jvEn6?dtYXS~X(qfd79En(9AxnylYi2)VTvc(!O|D6(_^Q0#Dv1DK8oYcz%liZJxG zlate%;r&4z%tU#TEF4tL@b>j^A{g%9!yWGR9jObLF9$}g_#Y}av@>9I@Qo@{jlm+B+j1iW4j%scn`Zc6z z0Vy*}#gBlZ#;v1=X~g9<9zVo)NUomoxSn<6n|qrEF?P(U^&e?}|KNYo$hd!|>bP}- zpp4;_9SFDG8#-*4!(ZuGtJ%GvG`~dooWJdKVA_3iIlj#U+?CP~^9%Rya5vQLR$j{X z2eN?sy`xPi6eF#B+%}wuJA0rzgTQ`8ok#TU!Wt;(43<7+?6GC2!A(pcELT-EzpjEcUL*^@ z^e%!&ZVYD$p?OmoCLO53q=URlY*Lp=2j3q(A={3Pb}Ds09_n9$mj3kEZg?V*I9NE? z`7mFeEvYUva%eJE>QVQH?U^5jvJZ1)ND14}@5HNKpWF_*q^MC1tnlpf^vrpg0KJaC zed&PNl7OB1b_~<%Bg_k8RVLLM`z)@i?J?69mo33o?$$)p#fgI?0it1m{3^00? zEqy}{F}sZ3^>=ulAK&)bM{6TH;c6w%x}R&sBM7Cl3vNqh4QfqPa5v;S$S-8G2Ibr_ zA&6Wa)60&XeCHU)R5(GXbMlj#b88h~=ijRP4AM2>Fqh=jm{3F11VkUm&+dUbG8>~5 z0X9@*L%){Tz!nsq>_TD(V#8}yv9<1wXNw+X5#{ZdKWEfP6g9apB_O{(Be~|qH?IIJ z83)HTuI?IBYCE}P6r~C51`jRvkF&8BwkPS~y>lKsb$W1{8AaS~#u~#`*0w`TBPy1> z0vjg=F35|B2~+LzI4}k>UmbNa)&&XRw}5URauIOFSIX6Y*Q|6ZjZ?n+mX?Dep@?J~xlHOb z!!*Y6Bb=_4u9X2<0w;}%AKVUW%!loZ6YpR;yanMua7r$?Qwc6^Zb@xb(JUVljJe?v z38`tzk1G-h*y-7YWtMMc<;HU^;NKI@(5dvxa{#84%N1ShRCo&9tz)miI(~vZs79Wb zI_lBJTR+*(vljR>5>?)h2x4tw;bSc-&QbQs`c^8lp_DTHvIQ| z60;hySV^j{3S+hCuh!Bb!R%;E3hFJea)Amrj8qN#t~LU5?E*)WEPp0m1~%C!KkNOO ztE%%-HYj@}Q@I7LuTHv0H_`#+tK?P9^wuiYsdr4FduA5sQX{RXmI>2C$3NVUV@Uz( z;fmOv8gq%!vz3=RZ8BR|+Z>p?jdUuI z;8GRncHC}Z+^%xNrStmFJTwck-u53}PnHhsK9=Oa7>!_Qg<;vgWY z8N(Wm@~MjLVKq z>vCsp6{o+N_TsM|PA6b6qqS2wKp&{mu9G3!d-04h<^+0F+JruT=`f-&+hO(6?`hS( zXfB&IFvc)@rgCsv&LOpvJ0ol_o!{Jx#H+26aOQ5Wy2a@a^y{S*IHoYMTRS7MrcrfN z#`CDt@-Yx5y7yp__T8UWv8rjwilM9KuhbJnLpZSdMy!ZdLl^f81z6iZ?d!eqJJiFW zE_DyMbGG zXul0k;HTx6eF{R}N1dJxy?Y`GW930Ey3hozpXC|h2L;dAz@>i{tUVksqmBpPNkB`O%yf=Ck`w!)v_m_8g zYl)r&wC@$x+D7O+DLA$GzfTtaCFWX^&N9uk&}8 zWwY4Csx^SaAk!jNX~k;9Xf zgSK|L4P$cZDkfqe>z{zuf^A}+>a;AQl&#$6Mt~w~e9F@UXQaMMxp@lNtT_;678}~# zPM(0@BCDVJ8*hV<2yIH#?f;sE9(Y#{V{tIN^pxh?FL$Fh;DQ$#0-6F}h=A)0r76?f z4tknH--ulSrTm*SpRvuGb1iX1p5JZy%825(WRMi$sg}Foet47pTM9kB+7U#UCmAB^ z77RPzj=1F0{ax3c>Yx~^zvOMrhl#W+m!J^g2)36uu- zY;m^Z&ZV8U>F|=#;N7=rk&~Hhj-dBryxDpvwG)qCC+!EU%NR&xG9f%)naNCv>cjpo zQOAhytiklv3{Z}DpJMdOuVNttELWM04u zFP8ErYTc5)4zH1~QTgxo9loG8c$}6PJks^b-FF1u2#QnyKTRR9`QMX}q`xH&shLr@ z96Pj)8Bb!x)hozbDWr)LNoC9mgzm`qjB4FZERoG^_E_20RBa5=b6~YL&M9d?d$dv< zMLP__G`~j(VV9(`&<{rz!ota2F4O)X`hd!bf=xd5R~Y=;PdfD=>G1&lPd_P%(XO7} zDIofP`bkM4DEXlPZ zA=_OCini0$BehUzC>bjy(l66NPv)vDZzu1yPUIEFu-*F>{pYXTPvO4WEq<9tdAn^_Q<5Jr3H=#G^#l!qYqGuKJ zAGjwvB-3v^u+%>c-SdCoPT;X&vCGdG0vJ2ULjS<|+{qs#s(Vt{$FK-lGC62BLn38H z1+cMATNh~6F@OtUR$y5LAl9MO!~_6mp0LGfB8qb;VOXic+&k(-?S>4s!jG-4^7r4j z)wH*^+RH1du5Qo{p?s(L>a1&VtmOM*MGPqhp3LCX4})cJL4^L?x?Y6FLT(AvYM*<_ zV}1E9%rf0iGtEPmJeVL1Fdt@a0=45dx)!iRwVX?#b6B|Rv1G&!+{|l~C6AjFp>L)A zu|EiK^>JSV%;q&(sc5^c5z*b%bWDB1x~4dDrKT4~KH=Iyno?F6AEjs0LxxLEd3(z> z-EVQz$xq1iTD-5lT-`TAy)^YtG%y%CGQuLp5hLj&jilLJ5ZVLy^arlu?-R(jI_*- zr8-y68OYyhn!&=HA=GQQgqHf+YUW7yv#m@cvk}ZZQwTYRLW;UYeM-Zr|7I zN7Q_8_{}tb-7pF!YO%2yk0oI4e~i+ZOiI-_x_7ehFHwX# z<6ak57dU4~)Q2^&E4|2QOQ z@>zPj_lo>@wCt1DL40)`%5ts){BmUJU&A_NL%qOAuj|kXNfxeSEB+xdMmmhY8gUHl zeino$9xfv)HOqpZl|24_j{(H52;Qh_a>aH$7p%{`YF->+OjYHG1 zlgnktucV`WJ=@p$wk-Zy2%gYL$@AP12s|p0TK^Ssfcc1GW%=lbbSZ@?G~3Jch?NLr zrVJUE>Glnysf5<_5(}He8@xB7Tci5;j}7|g+yp*Yu<*cEvI`$)qWDs~_)ioQay^z^ zf{X*;FO9_mJWu?d)J3o^^Q~9bx;&9-%ZuHrrO_Z8A!Ul?0HdzUaG)Yxh!!(lgm0K> z$XYJqe5RZomWQ8sorM77N@AK+ANPBH*K7Vw?8AP^THebspuUHnhrPonT(xwU*2c!4 z3AI3bxZg((p*=crQHFWENeN7C)n6toi%`v0T8{%OvC7*UwlTYT{tX2%@q4N606<`& z02voM(HjqSA5I2r(*nUOd{RQPDX4lS5L1u_ z=kQrd(CgKb7m@AHa7I=8-*_HZ&afh9*%TRb%nD<2gRBWbuCQz>(QfBEod=PL-pm z$cVBH^O=3B1Dj^4NR-W2>i|$LrgLsxX}bxFbzszHb{4j>&YZrbKIN0^#NhsfZ)5}Aek9XS4>y^@|S$Uwv4jSvT-HT*J-R~{X|zeU2&B+;W2_} zOUK2B)URHj8#Y<${5C###;diPa(%Q;L|XwDWaP5y@lWXL$#8a9l<(8QBWlx&=dno= zvtYa$%HVyI_KFkxS}6Of1IktTy?96R)eL0!MC2Q;TxmZiph{Y20NLv}T%B#TMPkuHj>i{hwFIUlG@1F6 zU^q1{Thx9JxU(-s+jb7qPh{XSRqAgC%P3GDwz!K@TRhqe303~FD+1V9JlSmc8m&3~P9us|@_0C~ie4WH8I0$`Q?bzw;TbtSOu_ z+{PruF=53&{x{g|0S98moCcVSj-6(k=fq`xQ(rO2O>EXa!N)5RA4w`z7~_QeG+n^6 z^c&?2)ia1Tru;N`Q(+I@e{8*bYuFA5t-9I-vdOH;t!l-f8#|KI^W~~XqDVkYQwmt_ z$WjbR-ow)}n%25}qJ6nmz-ro*SYQK#1slAt6&Q?puV;69L^Ym_{Hji&A|cMHii!aX zrZw2%lN3+G9p41i5_v^skz~{>W7t+@t(aYw8F;(S5^Du@n)*&x|6rPXsMj>Kik?B7 z^~ZAEqWh-hckPZhthrG2^4mEr4X}8`30+*Kr#}!23zls93}tbSBvceg^{$b+AqsIF zf{R7?dsjUQtzR^%eqa6FS|1tK1ZB{+2}Ip%9+*u{!Q;{knS5hg&6r=p?Mz4r7->LD z=>=S?M(4e{MKnP?cT zZB)9mzW=~^-WUn2UO9<%Jg!bwo*P-|fHD~zJF<%@i-OhI&5}Q=NwW!19+1xx!t+as zx{NTfA_>hgG43+}U8Z%;8@vSbx6kw1U~>#=~?C_y-% zs#;IDiCN1!4o(Qe89v8%GRx#H_`Uu(j&9K4WWc?A5vT2OB|72R*gMI2Ff+7LJe`}W z!S-^1Ard_3ckXl)$2J!eaC>tz^0oCK&E_nqmffV8?0j_t!Sq3)L43iW!CKq_#cGWF zo`)r%?(7A_@U0cw@ngHe+TCf)j-1 zBW<~CfhUF`9V_%SwS2Ks!l2L|5iA3SQKccpsOfOaGMCc2!AYc_yOzmOR`#IPJc-5H z1O7SQ-+!WgO&rcL(=ouZ^1%{}Jv$J#b&wu+SU>Q;QUg3!vUHC5~ODXqs?CBr>#-u8rhL9 z4x|>E5A6Q^YR9NhfIs>o_DKj2>XQCJ$T;0nph|LcmJ~w?yAa%uRmP$umg+>l=`g0_ z2>7H6O;sTt;Ua8wFz8|J-_jmlO?{8m-B-_bB1^;)0BpXrJiYAr72gC_0PiWvjl0<9 z_7ZzkZh(#rLC3}*jMfW9#dyJ`=%G!Q4s4j<*BQ4b_ir?^z)))5f#_=_ta|W7dka2H zxnp0s1e9f<0-ISi?KXMz^vi5BYTippCRo}|0mS98?oZ{etLP8QN(yrcdC@pifEX-n z^dut8{WkhnD!HgdMiH$r=u#R%L~X)YL19jc9Zs&F>Ik4BJ7!G517m#ip;OKjUY`gv znM&Q1Nu9eHE{)2IWS?HxL+5)pPq{C5>Kc2Ox@^(8FVZpJhxZE+6B%c&)&q1Lu!H`Y zoBJN;j<(gW0T$MD_g+9Y@8?btp|6f?$*hvhAZYBD6Efcvf{5>Xs zVl3O6C{VqXx}eXjMg;MZAnZ0Gl$7F%gVn(`&0=xp8fPwNi|hg(#F zjvdJZ0|7lmcg=;1txs_NeF?G-Mh>@^R|}_}aHknmlGq8a#fN_x_Ei}2r@B0y$A-o< zjM>?&420}*CdcB?1JH(VEVsn}mUJhHto6CCUUwC4kiVT8*A=hl@=mqq2Uql)Urc5m z$bapKBq3Tw%5$-7BGX4+ohFRP%VxEpMbH?LkexbICzc|-n&TuZ>=S(-Xr|8X z>PjaH437(Gs7+PjU(`OM%hF@-6qm+2NKAT(^;oGJt=4-Gi1qaEvB{avn)^cPPIx4JdVD~}z%t8`>#s1R}lzlP!V`0O7qfhi_>G8ED zyWTkSK(868fW<%Y-G~ovPQ~W#Ko)=B?nd;jBJ8xt+9ek zP9b!x!J(8vB|vht-Lc5#oTA$c2G@t~h!1A_#xA-FL}qQ>=PP+H7RZuzuw({U0O&dx z7N%1C7WiYG_03wX6;t&eIN!xLuiYxqoo%oCwV=X+GCR_L;Kqpr&T{ew(oLF0%6(Y6 zApI7IuA|z6Ng%5HSggvDk<>dsZlmwL&7Mmp!a@Lp_XI279FXn47*a{0NLOgwKK@8e zkJwXC6PR?nqqoZLt-%ob)>R76t4PHmRoHDp!Y4!cWY^|p& zo61snJcZ!h1YO1Zcvf!%qI1QYk8r1<{fZtAPSV$r!6P;LHKtv}Wo9D6*;YC^@Ota;h=dVn6|spKDI3*jCVqt7L-C@+7VX z>74|GO?2q*7goJ=d2eGZF$%cmC(L*y0pD{By?pwDIY}OzVgMG?CJ(rkQNeX(=@71r z=W4jV5bzMlFtGmIoWU=Y7c&bYV6&_fUEPhzZ|LWXDTXx!{V+HJ) zeHVt1{?{0Kk_bca8teFh#Zn+^5o%3K$KgbZB0XXzseoI5L-@{V#Bol)&2Z~@2D?- zm(K-$sGMAsu5BZc9^&|~^ z%6v3*h(HpN&edzrixe$CWjI?Ki|C%mzicUFDVP5N*HPM0`v>QcSRNV+-9Q>5k**64 zgYcwpdx_oQrr^o`Q&x}gy>j+Po2#^>!d#;$COy@P#7fhzX6Pz;^y+uSJ=5Hmk29J)E?&N(jEYWZpfk~wv5+@g#`Q5Cv2 zrX|NpY0^>?Y>sf{O^lCxyXPYjc-8aPJ6nsf2fSZeDL3kny0i@gV*D`vfHifL49)es zgAY|uZDPXr@0Le4haY&by6ulskyFl?MVn*@cxqh8wWt#n@(n8K$ZJx6F)^@12?#tb zm3wWbrcI%ab^PAkl9Bg6|)i>O9_j!kb1=4Jri73jS-olxPj1Lo0W7cm5dTy)eZF^WwfQQ|W0)DNYJPtoD2~ zi|wRRjbN%H&mEs{a}qRkmH4CNQntVYOi$E4gq9a2@jxj(txs&q4yZ}}kp2|7sPT19 zo5sOHe}GJEmGyj1wL(+qPO(+T@AxKWOy7iCa3GSMlBaoP!ka<5F@C#MCSk>w659T$H2#aS+;SAGum%cdMJ#MiF+B+tl9 z0uGeiY*LAoy5k&Je8)6Y@UtX9=YQaahhuJLe|RsRirLz!x3aA*_YpaSXNZe&gV)+N zjxvNx=FUgA3>82`8kmuoK9>_Z_Vt8fA@oQ43SYv6j_gIUV%(H6?)Ni zAHUaP@uYF7-M;0Exb2d4F*7+k8mR!{)@EGovuM7k>=B)T2mT~`q}E1LL&&UKH$(%R z9OP1AG?tc@arT85APZ;o9HADqf@XlP+Mlfu<=+(h!m!!6Cv?u|;Y4FiLz|b-QPB6X zPB*C$&C*cNLR?)etUzG@=IG@|0}k;w&cM%OGoE#gm3#+&=#(RaTr{5qS|7=GyWbz& z%I=NwaULA3C>1Q4x=fJ`EVBk6-Q5n()7P}dUvlD=yf;tckR}z zZ>*Z59N;%T9D~DS2;3*@+G&Xxr!70xCqGns%iB(9SR9oudUNn^Kxoa^8MSqy=5CAk zUQ~R2cp039T--OCNghoxD~?$`AzRubB|{PmZDsy#eOiL8es}j$RTsQ9)RYhbBFxmA zXhQztggoKQ1=^PJ!mR74r#@wSq1Ie(Ig*+24^t~`@x+}0V=pWy5cY_}gXEB-U~{t+ z19r5q1(_Bxa+oB>~AL)^XPZxUPTr z;NI*<;?VF9oMXF4{U*{%ExLt5lFP3PxOXUf2jM;6(r=ZLW$)qhD6y0Pjy%ZPZ z4Za%&3y(XZbuQ{50lQCT$4I5>F~5V|b@?zO(IG@emU9EH#(WWl>HL~q58ySM+Nk`z z36)Y5N#Mi>eNB3Gs3@knvND~#hjI<^9}$slN3WK@M%`XteMN>ZmW@L4A&yV2m4xJ| zs=?9=-#(@7$$vRow=gZahf)DM&#t)d0xPx4u4b=vwA^hxc&#?;jpEA^1D7B7hV4C( zm(b(bN)FJ?6{wA=jk#{i%;~9VWlVoyqC>YpV|SZb?lvZ7TkN+pd$A>=?6i(h(Ykq7 zNn-$#ZB)~419bS>vrUIkh#P*@0)?qbJSxIAkN4sV3~n@xt>rw-wzi7kT%@gaQ|!pU z8ldVC?)K_lw=6qMYTVqJt1reD-Pcw!WN(?mGb=#=brjlqC+&u^aK*Lv`o)}+dmvGr zq{c4@FF5UzlogC!pEx;bC?WFJHMEcn*^5U(w}AvPJeCkr5BT<%x$X#!yca5V;r*t> z^WK+RT;N)z*3`=mksvE{H07_h-nI>A6}Rh)RObr*=Nb)7&U}wn8ZpZNway~f&4JI5 zVPvZ{QVkz%vy;_U<3Wq!084VD6rwd7PZy<2L}G7k2)ACoj}?8~f-;*fZ^VX2E)jZ> zd#$DDl1gTrU~qc$+pj^nPexBAw=ddA`?RtSH97TeAMiFoBAK8EDBEGvF9!kHRU)4H zh@rl}DxAZP0+;*g2^Nu6LSxtCcOD1FPKsyJ(mmZ(1~`=+d}T_9JNYTtQDHdFo6lvkv+6chNkD#rzAv!?cCqJbPaB}=+jbTd=8EUKVglHfOyA6>& z*s6G&nHv@>oY&r4Hg3ygAWx`IFgGqcsc?7Fj2)kI@7$y=doj&nqQwkK=KU2R@@ByrcQ=qWXL&$L8ixo#KpD+778DB6H_Z74s7D+z@t z)I@EzSum^l6Eo4d$$b+4X6N|qUw?|lZ*4H8)z zTx^;2hVFZ^8soOHRyx^7PYtA`y)3MY;P+Vo zRj8`gxhkDwl6^GPzx6%_;qs7h6B_|(CuHhQk8|*UHxAJ=!ki^=1+(s07>mm^Q7pFZ zld3iH%J3{@$vl3;kG5w>wJ`f#e0s70n-8E;L+I=fv-nwhGm(R4&4O(**>Zl zadBpc)Ukb6$s#@*&J!kY1nMm>FIXooQ?UCum1No_|!01>E|MIM9qde4E+ ze!#8%t0tTC?JDtT3Aw_6c}OO9>VAb8-H5NK3cD0F*3YB&&Q85tG`-&d7bxbI5fU#|Srux&>K@|6K2!PnUmoC(!iduVu?^mUD zoF#mOY38z9Z9)Y$>$h>5`-^?%t|P^&J4#JhvEhm!gINEl_(}z32swwXD9_hKYigWn zPcw>Sh|to^nC(RRTcM+<9;+1-2gd9Psnh~yH8kP=?5hQHk6?@?w07qYs%Zx$F(y{k zv;N!n2I{7=qRM@_VT^8?bK6db_f+Go_vk@AOW4h7 zKQ?zKtXEr=B*g@-*2fTo8jJfC(aKIMjTr5`Ek0^ovC}I7^8M(V6|hYTg~+pnJ_bE5 z^mUz;Z|YwtH@U&lf5zzPZ(%^z>0gIak+FWkHxG`_&@@ULKOV(!*F*A(%=Xu|)S_i# zrs9~!40R$P;J_v0;gQ<)d@ni*S*uItYrVN!aXP|Qj!jFA3JXOX&~r3OMuY9yI;jS@ zb%WsoHBSn>s2hbOS~ut|y>40=&yOQ=TBN!s8=#pk>T9804-H6#DTL`g{E8TH295~& z38r0{M3hz^DQy>ih4->sZBXI;OioG4N)pu9J)om2M`M;zQIV>gNlH%Qdq}YZ6Dw@f zwxH6jAu*Pay4+E?ICi&nwy|)R9wRu4`Ch*GK1XgD0t)I7up&fP_`%SGRsIaS7G3b8 zzKl_HU=#TtgQ2y^675W*$&`$bF{0+=M$N$O)B_gW#873VqJsGC#QsBf%)o;ysHlj8 zI;PR1l$e32-pn0lCLqs^glRMW7faoOsd;G!B%oZ1{RA*7g5Wcy5kd0EREbkk`N+l2 ze^8(;skg2V%d&qY|51D4t14D#-YVA)2Rac@MCiE6MCI>*fnbUT@iEdA3m}vFcDf3h zz2yS!U>!lWvOj}5NTX6?x=!*$%{Ckv??%0+@gq_*7d|~RYB(=kv7AI~kT7}J4!Nqm zXJXQ(Iv6_A=Qi-WL}da}9n|0@LE`n7z6B8FrE6I6C;HnU8ymz+1_}GIAnPy1y)fy{ zT0UoPJqptIt?6IaFdOp1LJ9&rUB3h@C@=$%t1kKQA6v^B-ep~;EIWA5iXJ8`In3%A z)O96!{}m-~QTBYHPfm7bWmbRp8|6IqY@JFk@3o8Udtxy1DP&;j)2E;POuuxf|0Evy zGW)O}P|(oF)3ZIS*$&sob$fJP#IYN&l+v)6*}Xul$R}Oq1BxNei}YU|x*O4s?MEGr zbcOd##$#e#myE@cX^wuqdbFi-rS+u;d9c+G8oOP=7_W1wm!DL5#q8{*j?Gc1a3c^h zDLK-Q!|g3Utt8ds z)^CezLeGXD*X#!{z9|%RQ-q4#MD^G5QK^yilkHoY6z zdt)ZvuPDCt_Ij0{_bjA;dB$p3N2dT@%q})Npt|W!%$L1}B!N)AEOBwXd>2)9$`JY6 ztOuRUopsAFR*YwXDMfjZ&!b+z_+8)Nd>_vg_qX(_+=Li_+&!LVd_|c#nPZ2jWCQQ! zs61-$L};Fm$~fLF_MY-2St_fp9pTsGofaIv!mkE|l5&}%qOOF!rO3mHh&&=H^N62%t+pqo4cRfe`tk}4EzS?_650GhaeSH%N(IXSTdJrj# z49jA}-sicGO!;tXd+4~U7gAe85$ zb3oT0<3FA2&NH3?bweFOy~+f`#G8bx-81_Oo(!`- z-bysKQhEQ4RnSU&g2BYaZcZ|})4IP%!pV+PVg=17jKDw}$`=3ig8%QCAqFdAF^!5z z0yoZ#QNlTmf$(qEzqWBg@bkZXjyZPzeLBlNLv5e#f8Zi!;?M+e5HKCKeI>eti~8d* zUfF>o%8UYHZ6jSzP7{(cb%bOch7)n9cSA(O3G}=oSj+l7#F)JXZ0}_2&*(b%+9T8VhGKM} zm#OwelV4~E7PE=-gb;mo2KoA>t`fK0I^~)Duhb?g&TC|eDS^BqohU`ZQMx|bzshH1 zf>#71=j6B9(i%q4`SZ@-Q)u58NtI2!S2KWyy#Duxox|9s+tjosp{`#VEE5Gt;8_MV zqGV4fSxn^30*r9qc!RA{|@Ksow$z)FeAix~qJ$zHHOHh_2>+6Ujs3#8P+!8N^V1p|X8&NbeS9oK;H%x;- zDlEOpl9w*eY~aUVM!l8@2$wAORVJqjEhfC6$iR}K1&s`>H)||ULH)+%&yatissk}I z%~(cjBj)GUcHp*#sgvdy7KB>;Va8GXEN9eM?RH0>xM`yfd!hMSsy_}3jZ~5zE8>=o zyv?hl)SyaRnQNhM7*Z2Qr3!|YT8-_ehUwF~((+~0z)KKwTcLHz=&7o=cTG9{6bsIB zxgC;6rYx2tK`Sx*n(x)YXT{@vJ`-C3>bkvjT%I&Gf8} z!Yu|QC&o0V)+IZ~T=Oi_?H>euM)FU|yTZ5&xeK67(N_ustyjxADmYOE1(~gh(|PQ)j)C*U7qaRB42mZuq@=fT?UBXQyZCj#pAygD>JWq z|EJmie_vqeZ;D#j^?gAIL-Gr}fU$+OYl~5}vC5B_)EmS7{MXVB1fCd<(kc%doGf3{ z(q2x;pU1@f7s(FqeXkNA&jeS-^AN5S{&nrTE63_+P2i_r{=5MSE*o@!99nzMTNHX` z90Gc(riDjgc~G_dRK3V`-HtyjQWd{n@Nzrap&j>4WZ|wa#LyZIYNZ?V~+$7WwDLHvR($J$}@Kba?=Ra_60GZy4nE{*5y3)>y z>t^J*vySd%-lH$5U2ttZtc%d`2?FYHfRZ-{YkD4{E#Mj+m22 z4@ljMy(5J&_+z_Tg=}VmJxtzj-cMBYkympa0!U)uexm1(Y}~x$KRuJ2sn#EO)9Hh9 zwDrr`xNE6TOC=PZz3TJ1yW6^|V8eN?28m68P!SOnNGP67X`=|@Ud~^?wdd5-HQyQd zEZ0x;#|8*A*@>X;z8KH8AeJ}=JZB|^E8jF_l!Y`4ZSS|Cqtc2als#OHd7)1XR z8l0xFMA-VX(NnsUpsKf_gzxm8!XP09Z~#p z(S1P?@^o`@Z6;BTVh8NGJaAA*>NV4y6-W{OeGqC75GFjvYvUm&EatA{iR-NRW`zc* za0tZg0S2aUb%MSIi$xXx_qx{jviIz)Gfpu#it>Xsr4cukl;a zm&+@)fDctK%7C${dayh%ml8SdgtM0{Cr{}dp2b1gJ6a2IPEUCvXg-K}jMd#?G*a5% zg?|50&D~O^HEUq60<@Y!U#s0?IAUAgX^Z8!&ZgeHh%hMIe{4v=C@YJ5r65oB9zSj% zO=a@RD@f2`;RlO4S<|IV$0BkUR?~UW7Cqk9@?RpK3RHG>c#*J*nD|7P(~ORBohSj} zI1f)lK^><)`Q~##aqCT-@!;eC*VF=Jm|EbAR9OCzq<~wN_TK#TAv;c(r3% z8Hh8I`QNT%b;*q2siBlqpv637`3gCUmMwwgW4Sn|6I2%>%Xjv*XZ*=u{iFmhb0hz> zscrYX9kd1s=wpym4M;T&QGZMra#TUJ3)5?QFaI#Fkr!CTk$IAfHP)_hC)UcXxkBFh zBZ#fZm3q-HeWQdP%G4wu{DUdM3cYen zQF1sX+sis?U0MC6)_M-3@iH}TN^e#$>fD^Nzhu0`di+*O%gPre&$29S7(b1mrzA2& zR?1Fr!FOq+n_wg19!-U=U`jgMbciAffG(Ee3c*3GbVdOUZ9vcXkAGVd znP}X^ExTU*2|Qdrmz<~(LHNZyHxbHPeE{5N$qfANGC|&!l7Bqe8A9A7m=BQ zI{37nd$qWlN|i|uFA|nbs#5IJ;1|jPqPv(pVXvLL_0<1WFq>c&^uVI#kPwB z7&rd@O!Hxn!5tO*PiF~vMfGiN2MJeD0q-+VKiGegcKE>w{i^$gWl};|A7VWu zEv_Dm6wAN83)95#UTG)-bWJ?|aP+lr&Zy!F*L#k_Y<&VB=7kozAz$5KSvSzAP|4Qk znjzaAEyin++lkG!guQjw~H5tnw#?ow0_R|L!u+*{2!gN=R z+Z~Q@-&X?XIEdH{wI(;^zexNGzXNMc591E zDW;o_+3p<+o5B|z&j08a*m4&%y&zR*szwgMy z_-H_n@vB19F*Kg=B_;u_T)-s3U=p1)2i7Cdw3RYBo#tPHCTaX8)6l-jSlOy|WXrrFng&Hk1<@u0)i3^hZC@>!=MKOVI<7F>?m)U>?EEU!Vfb?^M|A9q+sUcR zug>oF#=gpZwwj~1W@g2wd=u9D0=A)_rmor!XP_WL+hyGK98NNSJV*3o-PU@JU-4)fS<;%dZ` zEaw$zV@SbUYkibIX+p-Eh;u7?n>VVkr{A3);1rgQP#b;3-+B^Qmg9-p4c;OJ>kXz4cyagVo3|1@;~lUs*qw&9%Q4hwbUx$o2dstU zX`*vqlLbpGm)>Em3t%h4i9=4)5F+clUfCcS0;}xm4hQX-5Y2mk=TEvW^HI7rwp63R zAOGO=oQOR;e>K$?Ev2%7d zf>{u8dw@pch7yDHJjouO^eY6J7KcFJI%PwTLS5FJ)%T3r*Umn}Kyul$w*)p>QbjtJ zF)-XJEO-tQ-&k_%I6S_3_!QGIje^7ia2%fqsN6+LU*w_;@mLtPoP(i}$yG}t1m zM)p1I`@XOh*`bXMylQ5F?H}ijq?}creiuk8BEOTy>s-SG6q2A6W_WtUCGDj-)+J)a zJn2HP1$zt=?KHkc_i)4?*Zf@|W->o`uA}1u(4laT9~T_XHAyYiB(GiWKMFsnP98O^ zdfqTHz1_?eu}o^b{_~Efpq9o$wcPpFLF(M*_3|T-XIj1ezwF@uEgAqmRfhqSgzJ9= zTO$4mF!E=CGvG4UmU@n2u51tGV&IV236i`jPT5ETnaQy~T88E8SH7|G_cZC+r^~bZ zu{UnujaJvAL^Vo3S|-yJeNsxNWQ1mmRN4(Ric&~V2T!|bjAaB@0$+x8CZV=_=-kXGLtMYtPJVf?nI-PYhvjHm014__^LyYy8{$>osUJ& zJPF+qme@$u?FHp{7KT_PniquD>NNDCih0;%(S$DCmA(!gjxn|?kflKmQeFK#4_+3I zD8lGsXsW>z%L`h$eYdDCntjA{9jG~51hH5F!P;_rpnNsv85gN;(9?9e+cNSzXR+>x z3NHWWVAv%=Vfn=Na$OYo9%Kx zsFiE~4)XED=N!Qrs4tG2cqctuRBV;8bi@<6n%Y2vT>^rI7oe%&0fC1=5-H$)*7#?D z*2pyn;z$9Q1Bf7Xa;twTGkx_~aArEA%u6`K7uK-G6FHIIBJVKp8rj%B=O^8z`Hie% zbV`NdIQYoAk9RgJPcCRvfCScxX1kahH4 z!q<6R;2I^mPdC%(%CFq}G6^hlhB(E{&TXQnE~I?(PL*e;G%sIWbk&rZPTBtO>udXP zl$lh?Yw~H7d?>Jn$E2Muee=sG_Y>$op$|<%ch%U zsVK%PnY|%5$JW*+x4v;bKat!k#Ey zZl+sO#*Zkrr``ni32w7%yn+;OKd+V;_iDJ>)7uC2*Iynv$n^0M?cr^_^gnk_(YESi z>)le8HxJcU9IekVo)_F=A6Zj+P^wpqTKi!1E=SlbQmfHY)8WK|9tfgaIHi90u&@J^ zS$_HaycNjWZYQ!YOU|^8#rW{0GgiyBLy}&q^>$a}4CSXt)KOk)8CWR6^1aK-0C-V; z{_1{#^NO6#bGzp<)PZG8-;1uI!q+a8Zp4PSUv=wc2C3`vo7y$Q!$#4sdiTy_Wx+k( zraUehgMnec#E>%mooZO`brg&QXesenVVLrB5AO(6w#!4I1Y)tC~@l}0YbKFEnoCMH`_#Y z{Y3RFjFe0Tdc+-r={MdgGTM8L6TMF)ui(Z1y~T406j5AlU7PcLBiTY392_~eNwd!4 z*)o|c)e90B01j~?PjlzAXomJL)B<^kV;4JEnT~Lv2eq3Fqvj~sPkWyjVfA zzHd-cAyqprDv__12^32WH~ZDW!gDf@=VnCOP%FA6_`X9rQ_sZ78F5Wu!ugX!G3}{c zy?8|m)0_3x;(e_eR|a{$wZQ!!uuv&37}vi7IcnR0_`-B5DnW40-xll$#)o`24Et#G z?eYjZH*US~&Rdwq2ZN*ogM>2$M<8z9q3dJGzuZe4F$tUofkUBt2&|f7mpapwI!GGK zx5%&Q{|vXz`Qlr2W_DTD3%hc?ITNBQOQZS^AC_p=`@ekZv__rWq^*@fRWE!q+v~bn z6qTadC#37^CI0?0yK-i&b_tl?9FkFj&{CIxa8>n0f#ZZ%H|j^jU*1_^b-718G0D?B zFbe1x0wTb%=5J04ICJG)YnSn}RkeSvI5nJ5+S5f}*+7P)s&`0(_#7yTXop=efaSSX z@(EKRsUv18ZJqF-c~jYWP2lOB-{AtqrId>otUznIO9A(Vd9=}oQkgcTe0EwhJ=Q!p z7hX%Rv-&d8;0n2natC6vcw60U3%u^uE{H|aje>D5jim@m62yYMgWluPyyH1nDPoa| z7g|h#&8AzkO4b(d2#j^$i#GuWo5Cj0c4BZ1e$a7R5_Q1;VVpcO@KN}gj-eAr1=j3- zH9lqid$MbyrE>E@k?^!7L_?!l*?uP@o6x=!GXyO5#y>4s@*&nUw$7fPW@eoaIZ)BM zL`5KEVCMSLqQs|@S^fphbYHiEumFpx`yXdXrne-yTWLG5t3c^KhHVBzN>JqKbg!jn zocdoA0tGY~yH#bAUopI{7;EQRpdq?v1rAz|8j-n7iwh%{ZGW$HjaK3+(%rpd`&w*a zu2w2l(aK|030vzs5B2+}Ki^J5^I&b%bFI2X@%>swn)-QmA!TLW)L_)LBi! zuu)TwvL{W6$5t)z>2eMDBNy_9#^R0T$q`a`?DIElB71B8&t;;FFg=O3u2u^fPtTY=bKHHNmTaXL_R`^s$cmV0Nc8l>rQ{$w@^O!V(3tzC_PC~;7WJ{4 zOq>X8$e%U)S}ZzZ+~ABM$Z_Nig0O}B6>p3@^Q(WU#)9-aL#tR^(P?0-co}We>9*8tmf`+=bIR0TN3#43s-o%fQ_jQ5 zSf-s#Zv#%MrFrS1iW?(>&pkeeJa)8R1_T=&z#g2Axpb{VawMu~2-lYD)U>rFWFV$z z-$*2h!sbPH*@_IUXQkP-E%N&!`H{KYWMhf9ifE?XG(oKZ)FE? zPaBgT^u^Um9Xi=6kteuPB(I{OxJVwOo(GxI4XcpMkU8}oPmyAhk7+&ny$to4o-I4= zW?Wn5>+4&-YRm1PtNOGtjrIyvsx%s|>N?RW3vk!;2D%E)^_WIWvTN1(1APJ2cJW}W zdw>5Rpiac&idE{8+H`9n3yq1U=!M$MpmyLh{*7foYd{6= zvTg^pug$ys4<-q%5x4JjkNhq~k!lSNetGXNd6dWb)565ZsTnUZq3i8fcW$$RB94Nn z;&fa3*Hb|gb&F6}$Jh9uj!)&l1qjj&BI>dbw zvNu3}Y$AV!iXhJb3G3m@l=4V9$|nnLWhPnD?;KL5L#wL8ES0uk%WN8E8+%YJv89p> z;Xt6vdak|OKB2_Fh;r`jnXLV;J{DfsJdiB)six?B0yKePm2jtj>gApGvlGstOIAH; zS6_FFOVjT#WU2dob~Q83QS~fx-U_6rU4C%wuD_?zik7uKaS2-#zeAH02Yew2>Kpg5 z1i@_EKi2QHF{TRFy6uLWS=M8?&6x|B17{8af zSC1o={<_P@(ko`5L!*zb!XKJNF_FcT!BO4(d$=WI$#b}*q)<0!WUbZHSwwfYcAwQw2KlZuM<~F29*2-7%mxGGn7gtQ;m)2Gt7yL|5 zBtI*pZk_jpS3==!F4`t6`~zTnC{veGn^_cU@2l5@Ts+0d6*Qj=PwHJY-x6`7;--WI zqCDS4DGwg-R@FOj!TIg=EF`5>XMJtu)BFfWCc4j$R^`=u&rC%h!%dO0eBX_Db__ru z9r+v|!!X85qCU-;^JE0!#@gES(1JtVYm!%iS0<&?BX z)Pw0}aoT;&EzKXFG{wL`ztXxvUjH8!ztLFGP|-({MuV;~+gODziI-~)tP%j;3^b}% zC;;A1z#-#)m|#D6iSCPHn$$u6+HK#IS!GX@khp_A9-DA$d-2+nf7)>mkpE z=z&tBtFFID(Oz`c_fIT=P57f9nglU9(atw9hI@>{4U41p=GnZ8k$q&T$*!h9lhLHL zWs-R|mVlenAS?=XaR`GCmJ?&E1Md(F^+7)zBKw<$jZ!r zv=!omS+H5~!E#(tcv~i&)I%iXA4>{Vb&FN|cAk_TN%9Y2oe+M)hE`ve>6w6CmcWxfN??dnm={ley7B-=3LOe2a>z*WyrurW|opd+-A@bXm+$BgMxs-Xr%R^q5&BlubLu8pRkh{@|wQ_m=${7oC>LH8@>q?J+PGhp)J^Y&8` zsDA`={39CU4F)pm@5=gkV8Yie}ba1~YW^7>KQhsF>?sH+wZE?PD(LtD;*f?t_4Sko#b#Tsxm zLNL%G-6Ed%{Y4YjJY7Ff#QCTK!||XpTvebZT;oN+;Tr^D`I5H(V4lAK~0F zzJ98f;4?8h9{+Uv;-0WqkS3>+X-_eP>FBiKH@V0IA+;r3`pe3I#fKPuPpPIuin5>w zPy^3lrYM;2_RDDcB|!#DUk_zHG!=Sw2nnxF&(WAYJM69qbGw_M`!HQNO(NJ#bU?F~rkwSS*E)P2)521a;y4LSFFzEy(lN;e*FG}ofOS>wNF#H3 zW|&SRq@kju&|4Q`X=S+8ikNNFvZ@*?(zqKI?Lx(8aiztz{OQCR=NY38e;S6ae+W|z zA!ZMh_r!V`32mem=mId$i4S$aE}M9jX{*OJ~-x#v6>r*8P{!_TURbrl>%;wWX!_CC= zEexw^2>ViG$`I?49tEOZ*;ra@p|$|$9YM|i;NT!XN0pS}TxOaWBAxtQsL4p5kq(RC zNoV8yGsUQw{uSIe%y{{1A9390Sz01Zk`uh)_* z(usFM#->Rw9iH&AlLf5-c|nD%*j?a~Z*g{M%}~=DHU9_Donl>U)&tdi=LtP=0)-MS z+tTKulXelOZOIv`H0-?&a3l9{Be%cG1vBME|2qbUjgAtXFZreYMjBhSTl3RhjQ8yL ztV^Umk%c)C+RDj&#(ZfSf>#(y6z%&X3(qoCo&kf4BKVNzDhuogSF5m-QI7yI55?Tj zV(1X2*DSHz6s-x|vTmfaA`$~001dIfrASO7Kc#%;QC}R+f?Z21W2QHwNo(M@zCMt^ zTa(@Dc=AgWl*rk1x;RyF)N-rDqg5l1?e=#K#U=LAo#MnnB~Qh-qH8FZ)gZ^<{ilUA z92;E&xG8so4)(u57F}G@Q{%nQ>nM=XU!kP?TGE$QTMF{y>qlhP z&C`WOhJ1<>b8t41i|k2^iHaqjDz;K#-l9(qL*t{O%Usbgw9c3XLjKDHw_~0Puc%h0 zMyKt*4`?kJu-)-HXxE@UoB7GVQ}=>xu zU6UI*gADwh{v-KuU$*+HLRldKav%?TKqtlei+4S76$opSMsd zD2SB54a@ws?#5c#!RRc4?bhlJiBKIBOuQgcoC&T;@J)(?H}5Xalh4v$-#2~Q{Bht zg4!EZifQ90-;D;Eo-IrjK<~UDuLHDZQ19m2-ksMhIJ&}`N8(dDs6ocDbITQfk&23_ z`vN`oZ(L7;-qRBKe(rwI9HEe9j5&*QLt}VUnT=4Lv%h-gSHn%Vbenn7gs8jsCH9J+ zLiYIPA+kB+ab^96esi7f%UCNH{!2m%OOxBjN2{oPc1E(kOZcle;JZ*9!|p>Cwk`i6 z#mbz_qrU__nyT0=8?^sqM4WW*DFED6)!p@dkp5Hq(_f@^y-b)GYa{ACpTc1chKssW z(F)rwtwm9iwZha}g&f~W+kNF0@(;=M+bfz=A3w+@ooc*PP>!(V2ASh2!yde@)>MTy zwmg*}a9SLpNZZTrlr7;hbTGPAV$*z*SA5lw-j z%U70Oa;^Bep&bv4SXboUx%{-|HlXIs zPmsFKuG&qrW{twmWcfZE1?|8=%v{m0P(3gg&X9f?eKkR%t+-S8aEOKt`le-pkypcfb4$siHYR-5`q&}~(8t@sADOqPEHBq|S zgBvOw;N05_U|X>vbGM+tFcQYQ>$S1X{<8G=mVx2gZNx#%7__U2BHPVrz+aJ=W~6fV z)ztyDbHDh$XpmsWVol*n)iN?q%=eteK3Ncxt7a2Nx_rd@{VuK)J%*vEoh`Dl`8Ygb8NgB4s#P*qaM=Cm)^^8Whu8;+FURS zDc>yecgTR&*q6M*g-;OdZLrGUFb^dzI6WP!5G2Ex`6hLK5c0{tUFeU_>oZI|Tz8S1 zrd`WnF^y5U5*24&;iTRSO!n=jz_laqjHMveoaH-7`g_#NC#|l^<7M3=@~I|LbVNsA z!0L5&^iqx&U4I}ij#*!iR6j=D&_Zu5tlv7rfaWJNPw@`glZxVcnsOOyOpJ*}(O5#m zw=O8@K@6*M!mmS`3o%s?pZ`NUoL&@a zVL?k&g2~OBsSkz$OO;nW-~Wj+lKpS`NK`WfLy4BwDxCCY_n92>iL!a26wliQy)87o zu@a{wPBsAqd+i>{6a)lrPN&z02Ywfb{$#-2`#E8?;V>G!Q`iz*%nO^#WC|m8ubJvm zN|Qjjwa6e7$cZ__g$b1*7a4(Tm zOyeO{!^{m_* zV+Li8lCm6>r&MUHT8(-+kfZ5OX!pLSpN{a*QstSD2v}W1kfMnoD!c zy1)gY+b|P?(dGkzFNM|ob0a~N z(MpZEXcxc6NtwsT&qy3ONj;UDlTOnD#32bMbRE8aW$&E`$hb0RrOGgp4CBi!4O$Lz z2rX)b<@*+wLToB!a1s`!eDrA_b-t)1n;c`HmuwN@sSV5Ni->N(( zc@!`_YRdQsfALX~2~^wAUZ!;~P485IF1alIgWaL^$MjLs^v3rU$m-o+B)Pe2RD5b< zzb(+s83}i|lnNI;`Y#_6g{ z27}{EqY}n;Q<5s3R0X+1^a&{u22jDywz%2=S39%catdGAyi635M?QXS6wb?5>=!q- ziyXqcRH>SY`f)>Q^gzHwNV1abPyWk~BW+y;|E;JEcBal=W*R@$;OiSkmaYfmuBzOlB%nPjuX=)PwId*C{HVtbKZ~u^e{tTMQv+qAzvWd~PQdE>?!m z%D>lwu}7T^I;rvqjZYLdwdXF6w`xfFvS@I*EO+oJayyBLFzYC_ zf~Kpf?C3bx^@cn#p;1PlUs#>6K?duYEK_GHB^$5B)tjV4kb@e2LFN3NI4(8GiQ6zu zgC*{cU{!E+WD>}6@X~p*vxh*YcW)b#!=q~m#)7xLG;7l$H`6W>=Qj+nV~BHAxo2ii zLfHRB!e$<|&7a`*NKN0R1~V0NkiV^1`4W>IA6P6LX2P-s`IeI+;mo|n1=CkHqln7L zvX>hw-kNDWmz|CF7zMO+*=3I^dE-a#sf@1~T3tNA5Koy&rTs{r5uLn%2JLT!v~*0K z_ZZ*t3nlvdVm3D~8j54Lht`|0RA-|alhdAEmYz}NeZN|M2=(cjF?Kh^0kI_oYDeVWrYE8&KD2qBgIzRPYA*%BV z;$G|}tOy0^8qJS@YmS5+r|W}LFrwW_bsyhk_rgWIf_jTEEocSI8?D?Zc7pxrgqcD> zl*4->)hU|M8s5`!!TNcc+B2qp%Mu=t=}`8gqjDj%m&gD<7Mb z`CfBn2vZc%^d;OTCQ_kUCXmv6LV6ZQYSA#H2Ui!nZV_#rUcukzn?2My3es-#uK2c) zk&c68gI%kfNAs3~jWP&XG6qe9etX+WA_1N53sXNZJ2!k@v~H}y%ima=UZ2LLU%I5U zm1&+A^;_cO8A`7D)FJDjm7<|xWrl66(wx7i_zHey;SIaY3T zRYPk^#s2q*s(NGd8lq1}-a-ltm*+=(U5jpy(&^9lHRF9OOxvN_{EQ^spZj3xgD?BY7GI?b26VrB=x++us+gO;R4dqg?Xg3HEj&hgZ#dRjrNE#|C@VH!S=tgC(2|;418SJ$sxCqA3W`m1 z0x~>yAH@&1^Kf09Ki5*C?q5H9Y<;+V%8%|AI`lXB!T1tulO=ohJW;-x(K-eb!#{#e zo(0!9C75munQtlh^0lP+U6exb5nOPmk7CySdF3Y}louyRNVr!oHvTV2^8b!7_d8u8 zT@jqmn&P+hEf}nwku~K@CCr|lS-yE_L#CR6b~`Ton3YQ$G)5}#7sg8cO@WAmie$VP zT<%I+CFTm)Z>z8Hgk8_hfyA4cYyC0xok+QW9!KjWrPr8d5&Wc`NV#He5!Qklc>5|1 zur-Rv>^I&9fj~nlLux+RicszK($5u-y$hy@4(d8D3K@3UT28B`m)~iqdbY0YX3!IB zZBQZ4-b_h@;Ob#f_$4BXc?xx{Ep%*y4k-Y=5W|9#D$uH2Rf;CRJIjX5tOuFtWdkHQOzkx<>yk2}s@z2j+M{*BH z%1k_2yQKo<9DnaDXi#ftfu~M=-!Xa8@SMKP}D>gj0-_WI7 zR!{iaLTpIAR%Z!HO-4+&Xk0fh`31WuOO(u6bX%Vj2Shs{UfSLJ9dQ~wh1up(XVKg3 z0@`XIt^+m7=})k|pZdM=4XH-!H%3~#=S_+&!H}C9A!h8Gq{WY?T@uopydtfHu06_5 zUtxnkDT3Wve8G6)l|dtOm~2K9Ywr6GwT{A65+AD{FE&1*({r zwv##j@u^e%fwK9wcr#}(guw9qe0ZeB#LdA_|L1y3I=Us7rGxt@oOc|$nP-Dy&ueqd zS*{1$sEtH@($Nu%^UK^>*ihkTCR|;gxG&#i=FD=b*Y?P-*Ek6vloWDFam0_)8eFj& z?*ff_YoybmgY}%)l$UtLr1YkiNYev?p4jC!S|m>R(OsslO(vbb zcLdw7{eMS8ZGjtz-mJ|q&k@l6i7|kMsrb0htMjZDiNFo42eH=~q84&x<@|I7aKtcu z?F6+wfq@iykcbg4)`Cq+X_pj^I_6Y9Kyy80J^b<{fa~XfHeJx!#U{4Vs5@FpzIS8F zt~Q~#33qQ+B33ypwH z$+-^y+;}ZX;VIwcwl|q;u42vnwCC1n$uj7A2X{XNu<^0o9$D6~WmU!ec&be=3(fkB zWEi}m&gg)p0j%I$*&r>U0pnT69GXli38OK|5c|O>qWj3;(=st}lSH#I1avWHtPj*( zQ%K*ec-QO+6^1Fy5}~O(rUm+Hhm>f&d9I>C$Lml}!Y0CIcQfi%4Wsa}tW9SZGApql0X-^KKD`+5q01!v(FeLk;fcR%~Pzlj%>25Pr^{EyY;isA8h5Qz|c zyENWtJS-)Mm-e3?C5&?ZVF5R#H@F+5=5-lcodISSb@^0nMEiZ}=VB|BhFVjr4ht4! zs+B?p$2MP5V9SG_JJ}KxKL#(#5AYQj(nRJfSy~1j!j5#}Y&$5V0du1Cr+l@wXh_Ib zY`MoCLq>j0*D)oij=PTck2ksoO{JG>F%SaPpi{gliz>yrLrxfyiuvZ|FH%%zr+FA9 zg~bZZmz#^po7V@XagdOfd-|m^rqdk0zerMvGmB5jiVg2(FTJ1-CooncNP-&4%dmlz m-mW>61T_8<65;3M=VLKV8cP|Ei2v9|{#i%{e.exports=JSON.parse('{"pluginId":"default","version":"current","label":"v3","banner":null,"badge":true,"noIndex":false,"className":"docs-version-current","isLast":true,"docsSidebars":{"tutorialSidebar":[{"type":"link","label":"\u4ea7\u54c1\u4ecb\u7ecd","href":"/sqle-docs/docs/intro","docId":"intro"},{"type":"link","label":"\u5728\u7ebf\u4f53\u9a8c","href":"/sqle-docs/docs/online-demo","docId":"online-demo"},{"type":"category","label":"\u4ea7\u54c1\u652f\u6301","items":[{"type":"link","label":"\u529f\u80fd\u5bf9\u6bd4","href":"/sqle-docs/docs/support/compare","docId":"support/compare"},{"type":"link","label":"\u793e\u533a\u652f\u6301","href":"/sqle-docs/docs/support/community-support","docId":"support/community-support"},{"type":"link","label":"\u5546\u4e1a\u652f\u6301","href":"/sqle-docs/docs/support/commercial-support","docId":"support/commercial-support"}],"collapsed":true,"collapsible":true},{"type":"link","label":"\u5feb\u901f\u5f00\u59cb","href":"/sqle-docs/docs/quick-usage","docId":"quick-usage"},{"type":"category","label":"\u5b89\u88c5\u90e8\u7f72","items":[{"type":"link","label":"\u5b89\u88c5\u8bf4\u660e","href":"/sqle-docs/docs/deploy-manual/intro","docId":"deploy-manual/intro"},{"type":"link","label":"\u914d\u7f6e\u6587\u4ef6\u8bf4\u660e","href":"/sqle-docs/docs/deploy-manual/config","docId":"deploy-manual/config"},{"type":"link","label":"\u6e90\u7801\u5b89\u88c5","href":"/sqle-docs/docs/deploy-manual/source","docId":"deploy-manual/source"},{"type":"link","label":"RPM \u5b89\u88c5","href":"/sqle-docs/docs/deploy-manual/rpm","docId":"deploy-manual/rpm"},{"type":"link","label":"Docker\u90e8\u7f72","href":"/sqle-docs/docs/deploy-manual/Docker","docId":"deploy-manual/Docker"},{"type":"link","label":"Docker Compose \u90e8\u7f72","href":"/sqle-docs/docs/deploy-manual/DockerCompose","docId":"deploy-manual/DockerCompose"}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u7528\u6237\u624b\u518c","items":[{"type":"category","label":"\u9879\u76ee","items":[{"type":"link","label":"\u529f\u80fd\u4ecb\u7ecd","href":"/sqle-docs/docs/user-manual/project/intro","docId":"user-manual/project/intro"},{"type":"link","label":"\u521b\u5efa\u9879\u76ee\u3010\u4f01\u4e1a\u7248\u3011","href":"/sqle-docs/docs/user-manual/project/project_create","docId":"user-manual/project/project_create"},{"type":"link","label":"\u6570\u636e\u6e90\u7ba1\u7406","href":"/sqle-docs/docs/user-manual/project/instance-manager","docId":"user-manual/project/instance-manager"},{"type":"link","label":"\u5916\u90e8\u6570\u636e\u6e90\u540c\u6b65\u3010\u4f01\u4e1a\u7248\u3011","href":"/sqle-docs/docs/user-manual/project/instance_syn","docId":"user-manual/project/instance_syn"},{"type":"link","label":"\u6210\u5458/\u6210\u5458\u7ec4\u7ba1\u7406","href":"/sqle-docs/docs/user-manual/project/group_member","docId":"user-manual/project/group_member"},{"type":"link","label":"\u5ba1\u6838\u89c4\u5219\u6a21\u677f","href":"/sqle-docs/docs/user-manual/project/rule-template-manager","docId":"user-manual/project/rule-template-manager"},{"type":"link","label":"\u5ba1\u6838\u6d41\u7a0b\u6a21\u677f","href":"/sqle-docs/docs/user-manual/project/workflow-template-manager","docId":"user-manual/project/workflow-template-manager"},{"type":"link","label":"\u767d\u540d\u5355\u7ba1\u7406","href":"/sqle-docs/docs/user-manual/project/whitelist-manager","docId":"user-manual/project/whitelist-manager"},{"type":"link","label":"\u64cd\u4f5c\u8bb0\u5f55","href":"/sqle-docs/docs/user-manual/project/operation_records","docId":"user-manual/project/operation_records"},{"type":"link","label":"SQL\u7ba1\u63a7","href":"/sqle-docs/docs/user-manual/project/sqlmanage","docId":"user-manual/project/sqlmanage"},{"type":"link","label":"SQL\u5ba1\u6838","href":"/sqle-docs/docs/user-manual/project/quick_audit","docId":"user-manual/project/quick_audit"},{"type":"category","label":"\u5de5\u5355","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/user-manual/project/workflow/intro","docId":"user-manual/project/workflow/intro"},{"type":"link","label":"\u521b\u5efa\u5de5\u5355","href":"/sqle-docs/docs/user-manual/project/workflow/create-workflow","docId":"user-manual/project/workflow/create-workflow"},{"type":"link","label":"\u5ba1\u6838\u5de5\u5355","href":"/sqle-docs/docs/user-manual/project/workflow/audit-workflow","docId":"user-manual/project/workflow/audit-workflow"},{"type":"link","label":"\u4e0a\u7ebf\u5de5\u5355","href":"/sqle-docs/docs/user-manual/project/workflow/exec-workflow","docId":"user-manual/project/workflow/exec-workflow"}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u626b\u63cf\u4efb\u52a1","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/user-manual/project/audit_task/intro","docId":"user-manual/project/audit_task/intro"},{"type":"link","label":"\u5e93\u8868\u5143\u6570\u636e","href":"/sqle-docs/docs/user-manual/project/audit_task/metadata_audit","docId":"user-manual/project/audit_task/metadata_audit"},{"type":"link","label":"\u6162\u65e5\u5fd7","href":"/sqle-docs/docs/user-manual/project/audit_task/slowlog_audit","docId":"user-manual/project/audit_task/slowlog_audit"},{"type":"link","label":"\u4f1a\u8bddSQL\u626b\u63cf","href":"/sqle-docs/docs/user-manual/project/audit_task/processlist_audit","docId":"user-manual/project/audit_task/processlist_audit"},{"type":"link","label":"\u767e\u5ea6\u4e91RDS\u6162\u65e5\u5fd7\u626b\u63cf","href":"/sqle-docs/docs/user-manual/project/audit_task/baiduyunrds","docId":"user-manual/project/audit_task/baiduyunrds"},{"type":"link","label":"\u534e\u4e3a\u4e91RDS\u6162\u65e5\u5fd7\u626b\u63cf","href":"/sqle-docs/docs/user-manual/project/audit_task/huaweiyunrds","docId":"user-manual/project/audit_task/huaweiyunrds"},{"type":"link","label":"MyBatis\u626b\u63cf","href":"/sqle-docs/docs/user-manual/project/audit_task/mybatis","docId":"user-manual/project/audit_task/mybatis"},{"type":"link","label":"SQL\u6587\u4ef6\u626b\u63cf","href":"/sqle-docs/docs/user-manual/project/audit_task/SQLfile_audit","docId":"user-manual/project/audit_task/SQLfile_audit"},{"type":"link","label":"\u5e94\u7528\u7a0b\u5e8fSQL\u6293\u53d6\u3010\u4f01\u4e1a\u7248\u3011","href":"/sqle-docs/docs/user-manual/project/audit_task/java_application_audit","docId":"user-manual/project/audit_task/java_application_audit"},{"type":"link","label":"Java\u63a2\u9488\u7248\u5e94\u7528\u7a0b\u5e8fSQL\u6293\u53d6\u3010\u4f01\u4e1a\u7248\u3011","href":"/sqle-docs/docs/user-manual/project/audit_task/java_agent_audit","docId":"user-manual/project/audit_task/java_agent_audit"}],"collapsed":true,"collapsible":true}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u7cfb\u7edf\u8bbe\u7f6e","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/user-manual/sys-configuration/intro","docId":"user-manual/sys-configuration/intro"},{"type":"link","label":"\u767b\u5f55\u5bf9\u63a5","href":"/sqle-docs/docs/user-manual/sys-configuration/login_syn","docId":"user-manual/sys-configuration/login_syn"},{"type":"link","label":"\u6d88\u606f\u63a8\u9001","href":"/sqle-docs/docs/user-manual/sys-configuration/message_syn","docId":"user-manual/sys-configuration/message_syn"},{"type":"link","label":"\u6d41\u7a0b\u5bf9\u63a5","href":"/sqle-docs/docs/user-manual/sys-configuration/process_syn","docId":"user-manual/sys-configuration/process_syn"},{"type":"link","label":"webhook\u914d\u7f6e","href":"/sqle-docs/docs/user-manual/sys-configuration/webhook","docId":"user-manual/sys-configuration/webhook"},{"type":"link","label":"\u5168\u5c40\u914d\u7f6e","href":"/sqle-docs/docs/user-manual/sys-configuration/configuration","docId":"user-manual/sys-configuration/configuration"},{"type":"link","label":"\u4e2a\u6027\u5316\u8bbe\u7f6e\u3010\u4f01\u4e1a\u7248\u3011","href":"/sqle-docs/docs/user-manual/sys-configuration/customize","docId":"user-manual/sys-configuration/customize"}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u5de5\u4f5c\u53f0","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/user-manual/sql-workbench/introduction","docId":"user-manual/sql-workbench/introduction"},{"type":"link","label":"\u914d\u7f6e\u65b9\u6cd5","href":"/sqle-docs/docs/user-manual/sql-workbench/how-to-configure","docId":"user-manual/sql-workbench/how-to-configure"},{"type":"link","label":"\u4f7f\u7528\u5b9a\u5236\u5305\u5feb\u901f\u642d\u5efa\u73af\u5883","href":"/sqle-docs/docs/user-manual/sql-workbench/how-to-use","docId":"user-manual/sql-workbench/how-to-use"}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u7528\u6237\u7ba1\u7406","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/user-manual/user-manager/intro","docId":"user-manual/user-manager/intro"},{"type":"link","label":"\u7528\u6237\u7ba1\u7406","href":"/sqle-docs/docs/user-manual/user-manager/user","docId":"user-manual/user-manager/user"},{"type":"link","label":"\u89d2\u8272\u7ba1\u7406","href":"/sqle-docs/docs/user-manual/user-manager/role","docId":"user-manual/user-manager/role"}],"collapsed":true,"collapsible":true},{"type":"link","label":"\u81ea\u5b9a\u4e49\u5ba1\u6838\u89c4\u5219","href":"/sqle-docs/docs/user-manual/customrule","docId":"user-manual/customrule"},{"type":"link","label":"IDEA\u5ba1\u6838\u63d2\u4ef6","href":"/sqle-docs/docs/user-manual/jetbrains","docId":"user-manual/jetbrains"},{"type":"link","label":"\u89c4\u5219\u77e5\u8bc6\u5e93","href":"/sqle-docs/docs/user-manual/knowledgebase","docId":"user-manual/knowledgebase"}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u5f00\u53d1\u624b\u518c","items":[{"type":"category","label":"\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/dev-manual/plugins/intro","docId":"dev-manual/plugins/intro"},{"type":"link","label":"\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6\u4f7f\u7528","href":"/sqle-docs/docs/dev-manual/plugins/howtouse","docId":"dev-manual/plugins/howtouse"},{"type":"link","label":"\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6\u5f00\u53d1","href":"/sqle-docs/docs/dev-manual/plugins/howtodev","docId":"dev-manual/plugins/howtodev"}],"collapsed":true,"collapsible":true}],"collapsed":true,"collapsible":true},{"type":"category","label":"FAQ","items":[{"type":"link","label":"\u652f\u6301\u54ea\u4e9b\u6570\u636e\u5e93","href":"/sqle-docs/docs/FAQ/whichdatabase","docId":"FAQ/whichdatabase"}],"collapsed":true,"collapsible":true}]},"docs":{"deploy-manual/config":{"id":"deploy-manual/config","title":"\u914d\u7f6e\u6587\u4ef6\u8bf4\u660e","description":"SQLE\u7684\u914d\u7f6e\u6587\u4ef6\u91c7\u7528yml\u7684\u683c\u5f0f\uff0c\u9ed8\u8ba4\u60c5\u51b5\u4e0b\u4f4d\u4e8eSQLE\u5b89\u88c5\u76ee\u5f55\u4e0b\uff0c\u8def\u5f84\u4e3a./etc/config.yml","sidebar":"tutorialSidebar"},"deploy-manual/Docker":{"id":"deploy-manual/Docker","title":"Docker\u90e8\u7f72","description":"Docker hub \u5730\u5740","sidebar":"tutorialSidebar"},"deploy-manual/DockerCompose":{"id":"deploy-manual/DockerCompose","title":"Docker Compose \u90e8\u7f72","description":"\u914d\u7f6e\u6587\u4ef6","sidebar":"tutorialSidebar"},"deploy-manual/intro":{"id":"deploy-manual/intro","title":"\u5b89\u88c5\u8bf4\u660e","description":"SQLE \u63d0\u4f9b\u4e86\u591a\u79cd\u5b89\u88c5\u90e8\u7f72\u7684\u65b9\u5f0f\uff0c\u7528\u6237\u53ef\u4ee5\u7ed3\u5408\u81ea\u5df1\u7684\u73af\u5883\u548c\u73b0\u72b6\u9009\u62e9\u3002\u521d\u6b21\u4f53\u9a8c\u6216\u8005\u6d4b\u8bd5\u4f7f\u7528\u7684\u8bdd\u5efa\u8bae\u4f7f\u7528docker-compose \u6216 docker \u5feb\u901f\u90e8\u7f72\u3002","sidebar":"tutorialSidebar"},"deploy-manual/rpm":{"id":"deploy-manual/rpm","title":"RPM \u5b89\u88c5","description":"\u73af\u5883\u51c6\u5907","sidebar":"tutorialSidebar"},"deploy-manual/source":{"id":"deploy-manual/source","title":"\u6e90\u7801\u5b89\u88c5","description":"\u73af\u5883\u51c6\u5907","sidebar":"tutorialSidebar"},"dev-manual/intro":{"id":"dev-manual/intro","title":"\u4ea7\u54c1\u67b6\u6784","description":""},"dev-manual/plugins/howtodev":{"id":"dev-manual/plugins/howtodev","title":"\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6\u5f00\u53d1","description":"\u5728\u672c\u7bc7\u6587\u6863\u4e2d\uff0c\u4f1a\u4ecb\u7ecd\u5982\u4f55\u5f00\u53d1\u4e00\u4e2a\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6\uff0c\u5206\u4e3a\u5feb\u901f\u5f00\u59cb\u90e8\u5206\u548c\u8be6\u7ec6\u90e8\u5206\u3002","sidebar":"tutorialSidebar"},"dev-manual/plugins/howtouse":{"id":"dev-manual/plugins/howtouse","title":"\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6\u4f7f\u7528","description":"\u914d\u7f6e\u63d2\u4ef6","sidebar":"tutorialSidebar"},"dev-manual/plugins/intro":{"id":"dev-manual/plugins/intro","title":"\u529f\u80fd\u8bf4\u660e","description":"SQLE \u4f7f\u7528 go-plugin \u6765\u5b9e\u73b0\u5ba1\u6838\u63d2\u4ef6\u5316\u3002\u63d2\u4ef6\u53ea\u9700\u5b9e\u73b0\u4e24\u4e2a\u63a5\u53e3\uff0c\u5373\u53ef\u5b9e\u73b0\u4e0e SQLE \u4e3b\u8fdb\u7a0b\u901a\u4fe1\uff08\u8be6\u60c5\u89c1\u5ba1\u6838\u63d2\u4ef6\u5f00\u53d1\uff09\u3002","sidebar":"tutorialSidebar"},"FAQ/intro":{"id":"FAQ/intro","title":"FAQ","description":"\u672c\u7ae0\u5c06\u9488\u5bf9\u4f7f\u7528\u8fc7\u7a0b\u4e2d\u7684\u5e38\u89c1\u95ee\u9898\u8fdb\u884c\u89e3\u7b54\u3002"},"FAQ/whichdatabase":{"id":"FAQ/whichdatabase","title":"\u652f\u6301\u54ea\u4e9b\u6570\u636e\u5e93","description":"|\u6570\u636e\u5e93\u7c7b\u578b|\u9a8c\u8bc1\u53ef\u7528\u7684\u7248\u672c|","sidebar":"tutorialSidebar"},"guide":{"id":"guide","title":"\u7528\u6237\u6307\u5357","description":"\u4ea7\u54c1\u6982\u8ff0"},"intro":{"id":"intro","title":"\u4ea7\u54c1\u4ecb\u7ecd","description":"SQLE \u662f\u7231\u53ef\u751f\u81ea\u4e3b\u7814\u53d1\u652f\u6301\u591a\u5143\u6570\u636e\u5e93\u7684 SQL \u8d28\u91cf\u7ba1\u7406\u5e73\u53f0\u3002\u5e94\u7528\u4e8e\u5f00\u53d1\u3001\u6d4b\u8bd5\u3001\u4e0a\u7ebf\u53d1\u5e03\u3001\u751f\u4ea7\u8fd0\u884c\u9636\u6bb5\u7684 SQL \u8d28\u91cf\u6cbb\u7406\u3002\u901a\u8fc7 \u201c\u5efa\u7acb\u89c4\u8303\u3001\u4e8b\u524d\u63a7\u5236\u3001\u4e8b\u540e\u76d1\u7763\u3001\u6807\u51c6\u53d1\u5e03\u201d \u7684\u65b9\u5f0f\uff0c\u4e3a\u4f01\u4e1a\u63d0\u4f9b SQL \u5168\u751f\u547d\u5468\u671f\u8d28\u91cf\u7ba1\u63a7\u80fd\u529b\uff0c\u89c4\u907f\u4e1a\u52a1 SQL \u4e0d\u89c4\u8303\u5f15\u8d77\u7684\u751f\u4ea7\u4e8b\u6545\uff0c\u63d0\u9ad8\u4e1a\u52a1\u7a33\u5b9a\u6027\uff0c\u4e5f\u53ef\u63a8\u52a8\u4f01\u4e1a\u5185\u90e8\u5f00\u53d1\u89c4\u8303\u5feb\u901f\u843d\u5730\u3002","sidebar":"tutorialSidebar"},"online-demo":{"id":"online-demo","title":"\u5728\u7ebf\u4f53\u9a8c","description":"\u5730\u5740","sidebar":"tutorialSidebar"},"quick-usage":{"id":"quick-usage","title":"\u5feb\u901f\u5f00\u59cb","description":"\u672c\u6587\u7684\u76ee\u7684\u662f\u8ba9\u5927\u5bb6\u80fd\u5feb\u901f\u4f53\u9a8cSQLE\u7684\u57fa\u7840\u529f\u80fd\uff0c\u5e2e\u52a9\u5927\u5bb6\u5feb\u901f\u4e0a\u624bSQLE\u3002\u4e0b\u9762\u5c06\u6a21\u62df\u4e00\u4e2a\u7b80\u5355\u7684\u65e5\u5e38SQL\u4e0a\u7ebf\u573a\u666f\uff0c\u5f00\u53d1\u4eba\u5458\u63d0\u4ea4SQL\uff0cDBA\u8fdb\u884cSQL\u5ba1\u6838\u5e76\u4e0a\u7ebf\uff0c\u5927\u6982\u7684\u6b65\u9aa4\u5982\u4e0b\uff1a","sidebar":"tutorialSidebar"},"SUMMARY":{"id":"SUMMARY","title":"Summary","description":"* \u4ea7\u54c1\u4ecb\u7ecd"},"support/commercial-support":{"id":"support/commercial-support","title":"\u5546\u4e1a\u652f\u6301","description":"\u5982\u679c\u60f3\u83b7\u5f97 SQLE \u7684\u5546\u4e1a\u652f\u6301, \u60a8\u53ef\u4ee5\u626b\u63cf\u4e0b\u65b9\u7684\u5fae\u4fe1\u626b\u63cf\u5c0f\u7a0b\u5e8f\u7801\uff0c\u8fdb\u884c\u5728\u7ebf\u54a8\u8be2\u9884\u7ea6\uff1a","sidebar":"tutorialSidebar"},"support/community-support":{"id":"support/community-support","title":"\u793e\u533a\u652f\u6301","description":"\u5fae\u4fe1\u6280\u672f\u4ea4\u6d41\u7fa4","sidebar":"tutorialSidebar"},"support/compare":{"id":"support/compare","title":"\u529f\u80fd\u5bf9\u6bd4","description":"\u793e\u533a\u7248\u53ca\u4f01\u4e1a\u7248\u529f\u80fd\u5bf9\u6bd4","sidebar":"tutorialSidebar"},"user-manual/customrule":{"id":"user-manual/customrule","title":"\u81ea\u5b9a\u4e49\u5ba1\u6838\u89c4\u5219","description":"\u4f7f\u7528\u573a\u666f","sidebar":"tutorialSidebar"},"user-manual/intro":{"id":"user-manual/intro","title":"\u7528\u6237\u624b\u518c","description":"\u5728\u7a0b\u5e8f\u90e8\u7f72\u5b8c\u6210\u540e\uff0c\u7528\u6237\u5373\u53ef\u901a\u8fc7 SQLE UI \uff08http10000\uff09\u8bbf\u95ee\uff0c\u4f7f\u7528SQLE\u5e73\u53f0\u63d0\u4f9b\u7684SQL\u5ba1\u6838\u529f\u80fd\u3002"},"user-manual/jetbrains":{"id":"user-manual/jetbrains","title":"IDEA\u5ba1\u6838\u63d2\u4ef6","description":"\u8be5\u9879\u76ee\u662fSQLE \u7684 IDEA\u5ba1\u6838\u63d2\u4ef6 \uff0c\u65e8\u5728\u5e2e\u52a9\u5f00\u53d1\u4eba\u5458\u5728SQL\u5f00\u53d1\u7684\u5404\u4e2a\u9636\u6bb5\u8fdb\u884c\u5b9e\u65f6\u81ea\u52a9\u5f0f\u7684\u9759\u6001SQL\u5ba1\u6838\uff0c\u5e76\u5f15\u5165SQL\u5f00\u53d1\u89c4\u8303\u3002","sidebar":"tutorialSidebar"},"user-manual/knowledgebase":{"id":"user-manual/knowledgebase","title":"\u89c4\u5219\u77e5\u8bc6\u5e93","description":"\u4f7f\u7528\u573a\u666f","sidebar":"tutorialSidebar"},"user-manual/project/analysis":{"id":"user-manual/project/analysis","title":"SQL\u5206\u6790","description":"SQL\u5206\u6790\u662f\u4ec0\u4e48"},"user-manual/project/audit_task/baiduyunrds":{"id":"user-manual/project/audit_task/baiduyunrds","title":"\u767e\u5ea6\u4e91RDS\u6162\u65e5\u5fd7\u626b\u63cf","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55\u5728SQLE\u5e73\u53f0\u76d1\u7ba1\u767e\u5ea6\u4e91RDS\u5b9e\u4f8b\u4e0a\u4ea7\u751f\u7684\u6162SQL\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/huaweiyunrds":{"id":"user-manual/project/audit_task/huaweiyunrds","title":"\u534e\u4e3a\u4e91RDS\u6162\u65e5\u5fd7\u626b\u63cf","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55\u901a\u8fc7\u534e\u4e3a\u4e91SQLE\u5e73\u53f0\u76d1\u7ba1\u534e\u4e3a\u4e91RDS\u5b9e\u4f8b\u4e0a\u4ea7\u751f\u7684\u6162SQL\uff0c\u5e76\u8fdb\u884c\u76f8\u5e94\u7684\u5206\u6790\u548c\u5ba1\u6838\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/intro":{"id":"user-manual/project/audit_task/intro","title":"\u529f\u80fd\u8bf4\u660e","description":"\u80cc\u666f","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/java_agent_audit":{"id":"user-manual/project/audit_task/java_agent_audit","title":"Java\u63a2\u9488\u7248\u5e94\u7528\u7a0b\u5e8fSQL\u6293\u53d6\u3010\u4f01\u4e1a\u7248\u3011","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55\u5229\u7528SQLE\u5e73\u53f0\u6293\u53d6java\u5e94\u7528\u4e2d\u7684SQL\uff0c\u9009\u53d6\u7684\u4f8b\u5b50\u662f\u4e00\u4e2a\u5f00\u6e90\u7684\u95ee\u5377\u8c03\u67e5java\u5e94\u7528\uff0c\u67b6\u6784\u7b80\u5355\uff0c\u4e0a\u624b\u76f8\u5bf9\u5bb9\u6613\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/java_application_audit":{"id":"user-manual/project/audit_task/java_application_audit","title":"\u5e94\u7528\u7a0b\u5e8fSQL\u6293\u53d6\u3010\u4f01\u4e1a\u7248\u3011","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55\u5229\u7528SQLE\u5e73\u53f0\u6293\u53d6JAVA\u5e94\u7528\u4e2d\u7684SQL\uff0c\u9009\u53d6\u7684\u4f8b\u5b50\u662f\u4e00\u4e2a\u5f00\u6e90\u7684\u95ee\u5377\u8c03\u67e5java\u5e94\u7528\uff0c\u67b6\u6784\u7b80\u5355\uff0c\u4e0a\u624b\u76f8\u5bf9\u5bb9\u6613\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/metadata_audit":{"id":"user-manual/project/audit_task/metadata_audit","title":"\u5e93\u8868\u5143\u6570\u636e","description":"\u672c\u8282\u4ecb\u7ecd\u5e93\u8868\u5143\u6570\u636e\u626b\u63cf\u7684\u5e94\u7528\u573a\u666f\u3001\u4ee5\u53ca\u5982\u4f55\u521b\u5efa\u5e93\u8868\u5143\u6570\u636e\u7684\u626b\u63cf\u4efb\u52a1\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/mybatis":{"id":"user-manual/project/audit_task/mybatis","title":"MyBatis\u626b\u63cf","description":"\u672c\u8282\u4ecb\u7ecdMyBatis\u626b\u63cf\u7684\u5e94\u7528\u573a\u666f\u53ca\u914d\u7f6e\u65b9\u6cd5\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/processlist_audit":{"id":"user-manual/project/audit_task/processlist_audit","title":"\u4f1a\u8bddSQL\u626b\u63cf","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55\u5bf9MySQL\u8fdb\u884c\u4e2d\u7684\u4f1a\u8bddSQL\u8fdb\u884c\u76d1\u7763\u53ca\u5ba1\u6838\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/slowlog_audit":{"id":"user-manual/project/audit_task/slowlog_audit","title":"\u6162\u65e5\u5fd7","description":"\u672c\u8282\u4ecb\u7ecd\u6162\u65e5\u5fd7\u626b\u63cf\u7684\u5e94\u7528\u573a\u666f\u3001\u4ee5\u53ca\u5982\u4f55\u521b\u5efa\u6162\u65e5\u5fd7\u626b\u63cf\u4efb\u52a1\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/SQLfile_audit":{"id":"user-manual/project/audit_task/SQLfile_audit","title":"SQL\u6587\u4ef6\u626b\u63cf","description":"\u672c\u8282\u4ecb\u7ecdSQL\u6587\u4ef6\u626b\u63cf\u7684\u5e94\u7528\u573a\u666f\u53ca\u914d\u7f6e\u65b9\u6cd5\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/topsql":{"id":"user-manual/project/audit_task/topsql","title":"TopSQL","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55"},"user-manual/project/data_access_control/authorization_list":{"id":"user-manual/project/data_access_control/authorization_list","title":"\u6388\u6743\u6e05\u5355","description":"\u901a\u8fc7\u7edf\u4e00\u5206\u914d\u6307\u5b9a\u6743\u9650\u64cd\u4f5c\u7528\u6237\uff0c\u907f\u514d\u51fa\u73b0\u56e0\u4e1a\u52a1\u591a\u5bfc\u81f4\u6743\u9650\u7ba1\u7406\u5206\u6563\u7684\u56f0\u5883\uff0c\u540c\u65f6\u8ffd\u6eaf\u6743\u9650\u53d1\u653e\u539f\u56e0\u3002"},"user-manual/project/data_access_control/intro":{"id":"user-manual/project/data_access_control/intro","title":"intro","description":"\u5e73\u53f0\u901a\u8fc7\u6743\u9650\u63a7\u5236\uff0c\u6765\u5b9e\u73b0\u6570\u636e\u5b89\u5168\u3002"},"user-manual/project/data_access_control/permission_template":{"id":"user-manual/project/data_access_control/permission_template","title":"\u6743\u9650\u6a21\u677f","description":"\u6743\u9650\u6a21\u677f\u652f\u6301\u7075\u6d3b\u5206\u7ec4\uff0c\u6309\u96c6\u5408\u7ec4\u7ec7\u6743\u9650\u6a21\u677f\uff0c\u4ee5\u51cf\u5c11\u91cd\u590d\u5206\u914d\u76f8\u540c\u6743\u9650\u7684\u5de5\u4f5c\u91cf\uff0c\u63d0\u9ad8\u6743\u9650\u7ba1\u7406\u6548\u7387\u3002"},"user-manual/project/group_member":{"id":"user-manual/project/group_member","title":"\u6210\u5458/\u6210\u5458\u7ec4\u7ba1\u7406","description":"\u672c\u6587\u4ecb\u7ecd\u9879\u76ee\u5185\u6dfb\u52a0\u6210\u5458\u3001\u6210\u5458\u7ec4\u7684\u6b65\u9aa4\uff0c\u4ee5\u53ca\u5176\u4ed6\u7ba1\u7406\u64cd\u4f5c\u3002","sidebar":"tutorialSidebar"},"user-manual/project/instance_syn":{"id":"user-manual/project/instance_syn","title":"\u5916\u90e8\u6570\u636e\u6e90\u540c\u6b65\u3010\u4f01\u4e1a\u7248\u3011","description":"SQLE\u652f\u6301\u4ece\u5176\u4ed6\u5e73\u53f0\u5bfc\u5165\u6570\u636e\u6e90\u7684\u529f\u80fd\uff0c\u65b9\u4fbf\u7528\u6237\u63a5\u5165\u5916\u90e8\u5e73\u53f0\u7684\u6570\u636e\u6e90\uff0c\u76ee\u524d\u5df2\u5b9e\u73b0\u5bf9\u63a5\u7231\u53ef\u751f\u5546\u4e1a\u4ea7\u54c1\u201c\u4e91\u6811\xb7DMP\uff1a\u6570\u636e\u5e93\u96c6\u7fa4\u7ba1\u7406\u5e73\u53f0\u201d\u3002","sidebar":"tutorialSidebar"},"user-manual/project/instance-manager":{"id":"user-manual/project/instance-manager","title":"\u6570\u636e\u6e90\u7ba1\u7406","description":"\u672c\u6587\u4ecb\u7ecd\u5982\u4f55\u5728\u9879\u76ee\u4e2d\u8fdb\u884c\u6570\u636e\u6e90\u7ba1\u7406\uff0c\u5305\u62ec\u6570\u636e\u6e90\u7684\u589e\u52a0\u3001\u5220\u9664\u3001\u7f16\u8f91\u64cd\u4f5c\u3002","sidebar":"tutorialSidebar"},"user-manual/project/intro":{"id":"user-manual/project/intro","title":"\u529f\u80fd\u4ecb\u7ecd","description":"\u81ea2.22.11.0\u7248\u672c\u8d77\uff0c\u5e73\u53f0\u5f15\u5165\u9879\u76ee\u7ba1\u7406\u6982\u5ff5\uff0c\u4e0eSQL\u5ba1\u6838\u76f8\u5173\u7684\u8d44\u6e90\u5747\u4ee5\u9879\u76ee\u7684\u5f62\u5f0f\u8fdb\u884c\u8d44\u6e90\u9694\u79bb\u3002\u521b\u5efa\u5de5\u5355\u524d\uff0c\u9700\u8981\u7531\u9879\u76ee\u7ba1\u7406\u5458\u8bbe\u7f6e\u597d\u9879\u76ee\u5185\u90e8\u5fc5\u8981\u7684\u8d44\u6e90\u73af\u5883\uff0c\u5305\u62ec\u9879\u76ee\u4f7f\u7528\u7684\u6570\u636e\u6e90\u3001\u7528\u6237\u3001\u6d41\u7a0b\u6a21\u677f\u3001\u89c4\u5219\u6a21\u677f\u3001\u767d\u540d\u5355\u4fe1\u606f\u7b49\uff0c\u968f\u540e\uff0c\u9879\u76ee\u6210\u5458\u624d\u53ef\u5728\u9879\u76ee\u5185\u63d0\u4ea4\u5de5\u5355\u5e76\u5ba1\u6838\u4e0a\u7ebf\uff0c\u6216\u8bbe\u7f6e\u667a\u80fd\u626b\u63cf\u4efb\u52a1\u3002","sidebar":"tutorialSidebar"},"user-manual/project/operation_records":{"id":"user-manual/project/operation_records","title":"\u64cd\u4f5c\u8bb0\u5f55","description":"\u4f7f\u7528\u573a\u666f","sidebar":"tutorialSidebar"},"user-manual/project/project_create":{"id":"user-manual/project/project_create","title":"\u521b\u5efa\u9879\u76ee\u3010\u4f01\u4e1a\u7248\u3011","description":"\u672c\u6587\u4ecb\u7ecd\u5982\u4f55\u5728SQLE\u5e73\u53f0\u521b\u5efa\u9879\u76ee\u3002","sidebar":"tutorialSidebar"},"user-manual/project/quick_audit":{"id":"user-manual/project/quick_audit","title":"SQL\u5ba1\u6838","description":"\u672c\u6587\u4ecb\u7ecd\u5e73\u53f0\u7684SQL\u5ba1\u6838\u529f\u80fd\uff0c\u8be5\u529f\u80fd\u53ef\u4ee5\u5e2e\u52a9\u7528\u6237\u5feb\u901f\u5ba1\u6838SQL\u5e76\u4e86\u89e3\u4f18\u5316\u5efa\u8bae\u3002","sidebar":"tutorialSidebar"},"user-manual/project/rule-template-manager":{"id":"user-manual/project/rule-template-manager","title":"\u5ba1\u6838\u89c4\u5219\u6a21\u677f","description":"\u672c\u6587\u5c06\u4ecb\u7ecd\u5982\u4f55\u7ba1\u7406\u9879\u76ee\u4e2d\u7684\u5ba1\u6838\u89c4\u5219\u6a21\u677f\u3002","sidebar":"tutorialSidebar"},"user-manual/project/sqlmanage":{"id":"user-manual/project/sqlmanage","title":"SQL\u7ba1\u63a7","description":"SQL\u7ba1\u63a7\u9875\u9762\u96c6\u4e2d\u4e86\u7528\u6237\u5728SQL\u5ba1\u6838\u548c\u626b\u63cf\u4efb\u52a1\u4e2d\u751f\u6210\u7684SQL\uff0c\u65b9\u4fbf\u8fdb\u884c\u96c6\u4e2d\u7684\u7ba1\u7406\u3002\u7528\u6237\u53ef\u4ee5\u5feb\u901f\u53d1\u73b0\u5ba1\u6838\u51fa\u95ee\u9898\u7684SQL\uff0c\u5e76\u5c06\u5176\u5206\u914d\u7ed9\u5176\u4ed6\u6210\u5458\u5904\u7406\uff0c\u6216\u5c06\u4e0d\u5173\u5fc3\u7684SQL\u8bbe\u4e3a\u5ffd\u7565\u72b6\u6001\uff0c\u4ece\u800c\u5b9e\u73b0\u9ad8\u6548\u7684SQL\u7ba1\u7406\u3002","sidebar":"tutorialSidebar"},"user-manual/project/whitelist-manager":{"id":"user-manual/project/whitelist-manager","title":"\u767d\u540d\u5355\u7ba1\u7406","description":"\u672c\u6587\u4ecb\u7ecd\u5982\u4f55\u589e\u52a0\u3001\u7f16\u8f91\u3001\u5220\u9664\u9879\u76ee\u4e2d\u7684\u767d\u540d\u5355\u3002","sidebar":"tutorialSidebar"},"user-manual/project/workflow-template-manager":{"id":"user-manual/project/workflow-template-manager","title":"\u5ba1\u6838\u6d41\u7a0b\u6a21\u677f","description":"\u672c\u6587\u4ecb\u7ecd\u9879\u76ee\u4e2d\u7684\u5ba1\u6838\u6d41\u7a0b\u6a21\u677f\u7ba1\u7406\u3002","sidebar":"tutorialSidebar"},"user-manual/project/workflow/audit-workflow":{"id":"user-manual/project/workflow/audit-workflow","title":"\u5ba1\u6838\u5de5\u5355","description":"\u5ba1\u6838\u5de5\u5355\u5305\u542b\u4e24\u90e8\u5206","sidebar":"tutorialSidebar"},"user-manual/project/workflow/create-workflow":{"id":"user-manual/project/workflow/create-workflow","title":"\u521b\u5efa\u5de5\u5355","description":"\u5de5\u5355\u662fSQLE\u63d0\u4f9b\u7684\u5728\u7ebf\u5316SQL\u4e0a\u7ebf\u65b9\u5f0f\u3002\u7814\u53d1\u4eba\u5458\u53ef\u901a\u8fc7\u521b\u5efa\u5de5\u5355\uff0c\u63d0\u8bf7\u9700\u8981\u5ba1\u6279\u7684SQL\u8bed\u53e5\u3002","sidebar":"tutorialSidebar"},"user-manual/project/workflow/exec-workflow":{"id":"user-manual/project/workflow/exec-workflow","title":"\u4e0a\u7ebf\u5de5\u5355","description":"\u672c\u7ae0\u8be6\u7ec6\u4ecb\u7ecd\u7528\u6237\u5982\u4f55\u8fdb\u884c\u4e0a\u7ebf\u3002","sidebar":"tutorialSidebar"},"user-manual/project/workflow/intro":{"id":"user-manual/project/workflow/intro","title":"\u529f\u80fd\u8bf4\u660e","description":"\u5f88\u591a\u516c\u53f8\u901a\u5e38\u8bbe\u6709 DBA\uff08Database administrator\uff09 \u8fd9\u4e2a\u804c\u4f4d\uff0c\u4ed6\u4eec\u8d1f\u8d23\u5728\u7cfb\u7edf\u4e0a\u8fd0\u884c\u6570\u636e\u5e93\uff0c\u6267\u884c\u5907\u4efd\uff0c\u6267\u884c\u5b89\u5168\u7b56\u7565\u7b49\u65e5\u5e38\u6570\u636e\u5e93\u8fd0\u7ef4\u7684\u5de5\u4f5c\u3002\u5176\u4e2d\uff0cDBA\u4e00\u9879\u91cd\u8981\u7684\u5de5\u4f5c\u662f\u89c4\u8303\u7814\u53d1\u4eba\u5458\u5728\u5e94\u7528\u7a0b\u5e8f\u4e2d\u4f7f\u7528\u7684 SQL \u8bed\u53e5\u3002","sidebar":"tutorialSidebar"},"user-manual/sql-workbench/how-to-configure":{"id":"user-manual/sql-workbench/how-to-configure","title":"\u914d\u7f6e\u65b9\u6cd5","description":"\u5b89\u88c5CloudBeaver","sidebar":"tutorialSidebar"},"user-manual/sql-workbench/how-to-quick-deploy":{"id":"user-manual/sql-workbench/how-to-quick-deploy","title":"\u4f7f\u7528\u5b9a\u5236\u5305\u5feb\u901f\u642d\u5efa\u73af\u5883","description":"SQLE\u5728\u539f\u6709CloudBeaver release222_0 \u5206\u652f\u7684\u57fa\u7840\u4e0a, \u589e\u52a0\u4e86\u5bf9OceanBase \u548c TiDB \u7684\u652f\u6301, \u7528\u6237\u65e0\u9700\u518d\u624b\u52a8\u914d\u7f6e\u73af\u5883\uff0c\u53ef\u76f4\u63a5\u4f7f\u7528SQL\u5de5\u4f5c\u53f0\u529f\u80fd\u3002"},"user-manual/sql-workbench/how-to-use":{"id":"user-manual/sql-workbench/how-to-use","title":"\u4f7f\u7528\u5b9a\u5236\u5305\u5feb\u901f\u642d\u5efa\u73af\u5883","description":"SQLE\u5728\u539f\u6709CloudBeaver release222_0 \u5206\u652f\u7684\u57fa\u7840\u4e0a, \u589e\u52a0\u4e86\u5bf9OceanBase \u548c TiDB \u7684\u652f\u6301, \u7528\u6237\u65e0\u9700\u518d\u624b\u52a8\u914d\u7f6e\u73af\u5883\uff0c\u53ef\u76f4\u63a5\u4f7f\u7528SQL\u5de5\u4f5c\u53f0\u529f\u80fd\u3002","sidebar":"tutorialSidebar"},"user-manual/sql-workbench/introduction":{"id":"user-manual/sql-workbench/introduction","title":"\u529f\u80fd\u8bf4\u660e","description":"CloudBeaver Community \u662f\u4e00\u4e2a\u5f00\u6e90\u7684 Web \u6570\u636e\u5e93\u53ef\u89c6\u5316\u7ba1\u7406\u5de5\u5177\uff0c\u652f\u6301 PostgreSQL, MySQL, MariaDB, SQL Server, Oracle, DB2, Firebird, H2, Trino \u7b49\u6570\u636e\u5e93\u3002","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/configuration":{"id":"user-manual/sys-configuration/configuration","title":"\u5168\u5c40\u914d\u7f6e","description":"SQLE\u652f\u6301\u7ba1\u7406\u5458\u5bf9\u5e73\u53f0\u57fa\u7840\u914d\u7f6e\u8fdb\u884c\u7edf\u4e00\u7ba1\u7406\uff0c\u76ee\u524d\u652f\u6301\u4fee\u6539\u7684\u914d\u7f6e\u9879\u5305\u62ec\uff1a","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/customize":{"id":"user-manual/sys-configuration/customize","title":"\u4e2a\u6027\u5316\u8bbe\u7f6e\u3010\u4f01\u4e1a\u7248\u3011","description":"SQLE\u652f\u6301\u5bf9\u7f51\u7ad9logo\u53ca\u6807\u9898\u8fdb\u884c\u81ea\u5b9a\u4e49\u8bbe\u7f6e\uff0c\u6ee1\u8db3\u4f01\u4e1a\u7528\u6237\u7684\u4e2a\u6027\u5316\u9700\u6c42\u3002","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/intro":{"id":"user-manual/sys-configuration/intro","title":"\u529f\u80fd\u8bf4\u660e","description":"\u7cfb\u7edf\u8bbe\u7f6e\u4e2d\u53ef\u914d\u7f6e\u7684\u5185\u5bb9\u5305\u62ec\u5168\u5c40\u914d\u7f6e\u3001\u767b\u5f55\u5bf9\u63a5\u3001\u6d41\u7a0b\u5bf9\u63a5\u3001\u6d88\u606f\u63a8\u9001\u3002","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/login_syn":{"id":"user-manual/sys-configuration/login_syn","title":"\u767b\u5f55\u5bf9\u63a5","description":"\u5f53\u524d\u767b\u5f55\u5bf9\u63a5\u5df2\u5b9e\u73b0LDAP\u65b9\u5f0f\u53caOauth2.0\u65b9\u5f0f","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/message_syn":{"id":"user-manual/sys-configuration/message_syn","title":"\u6d88\u606f\u63a8\u9001","description":"\u5f53\u524d\u652f\u6301\u5c06\u5de5\u5355\u72b6\u6001\u53d8\u66f4\u540c\u6b65\u81f3\u90ae\u7bb1\u3001\u4f01\u4e1a\u5fae\u4fe1\u3001\u98de\u4e66\u3001Webhook\u3002","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/process_syn":{"id":"user-manual/sys-configuration/process_syn","title":"\u6d41\u7a0b\u5bf9\u63a5","description":"\u901a\u8fc7\u6d41\u7a0b\u5bf9\u63a5\u529f\u80fd\uff0c\u7528\u6237\u53ef\u4ee5\u5c06SQLE\u5e73\u53f0\u7684\u5de5\u5355\u5ba1\u6279\u64cd\u4f5c\u5bf9\u63a5\u5230\u6307\u5b9a\u7684\u5e73\u53f0\uff0c\u4f7f\u7528\u6237\u80fd\u591f\u5728\u8be5\u5e73\u53f0\u4e0a\u5b8c\u6210\u5de5\u5355\u5ba1\u6838\u548c\u4e0a\u7ebf\u64cd\u4f5c\uff0c\u907f\u514d\u5728\u591a\u4e2a\u5e73\u53f0\u4e4b\u95f4\u5207\u6362\u3002\u76ee\u524d\u6211\u4eec\u652f\u6301\u9489\u9489\u548c\u98de\u4e66\u5ba1\u6279\u3002","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/webhook":{"id":"user-manual/sys-configuration/webhook","title":"webhook\u914d\u7f6e","description":"Webhook\u662f\u7528\u6237\u5b9a\u4e49\u7684\u81ea\u5b9a\u4e49HTTP\u56de\u8c03\u3002\u5b83\u4eec\u901a\u5e38\u7531\u4e8b\u4ef6\u89e6\u53d1\uff0c\u4f8b\u5982SQLE\u4e2d\u5b58\u5728\u5de5\u5355\u72b6\u6001\u7684\u53d8\u5316\uff0c\u5219\u4f1a\u81ea\u52a8\u5411\u7528\u6237\u914d\u7f6e\u7684webhook URL\u53d1\u9001HTTP\u8bf7\u6c42\u3002","sidebar":"tutorialSidebar"},"user-manual/user-manager/intro":{"id":"user-manual/user-manager/intro","title":"\u529f\u80fd\u8bf4\u660e","description":"\u7528\u6237\u4e2d\u5fc3\u5305\u542b\u7528\u6237\u7ba1\u7406\u3001\u89d2\u8272\u7ba1\u7406\u53ca\u64cd\u4f5c\u6743\u9650\u5217\u8868\uff0c\u7531\u5e73\u53f0\u7ba1\u7406\u5458\u64cd\u4f5c\uff0c\u6d89\u53ca\u7528\u6237\u53ca\u89d2\u8272\u6743\u9650\u7684\u914d\u7f6e\u3002","sidebar":"tutorialSidebar"},"user-manual/user-manager/role":{"id":"user-manual/user-manager/role","title":"\u89d2\u8272\u7ba1\u7406","description":"\u5f53\u9700\u8981\u4e3a\u7528\u6237\u8bbe\u7f6e\u52a8\u4f5c\u6743\u9650\u65f6\uff0c\u53ef\u4f7f\u7528\u89d2\u8272\u7ba1\u7406\u914d\u7f6e\u52a8\u4f5c\u7ec4\u5408\u3002","sidebar":"tutorialSidebar"},"user-manual/user-manager/user":{"id":"user-manual/user-manager/user","title":"\u7528\u6237\u7ba1\u7406","description":"\u5f53\u9700\u8981\u521b\u5efa\u65b0\u7684\u7528\u6237\uff0c\u6216\u9700\u8981\u7531\u7ba1\u7406\u5458\u4fee\u6539\u7528\u6237\u57fa\u672c\u4fe1\u606f\u65f6\uff0c\u53ef\u4ee5\u8fdb\u884c\u7528\u6237\u7ba1\u7406\u7684\u76f8\u5173\u64cd\u4f5c\u3002","sidebar":"tutorialSidebar"}}}')}}]); \ No newline at end of file diff --git a/assets/js/935f2afb.6db62b48.js b/assets/js/935f2afb.6db62b48.js deleted file mode 100644 index 0b22f347..00000000 --- a/assets/js/935f2afb.6db62b48.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunksqle_docs=self.webpackChunksqle_docs||[]).push([[53],{1109:e=>{e.exports=JSON.parse('{"pluginId":"default","version":"current","label":"v3","banner":null,"badge":true,"noIndex":false,"className":"docs-version-current","isLast":true,"docsSidebars":{"tutorialSidebar":[{"type":"link","label":"\u4ea7\u54c1\u4ecb\u7ecd","href":"/sqle-docs/docs/intro","docId":"intro"},{"type":"link","label":"\u5728\u7ebf\u4f53\u9a8c","href":"/sqle-docs/docs/online-demo","docId":"online-demo"},{"type":"category","label":"\u4ea7\u54c1\u652f\u6301","items":[{"type":"link","label":"\u529f\u80fd\u5bf9\u6bd4","href":"/sqle-docs/docs/support/compare","docId":"support/compare"},{"type":"link","label":"\u793e\u533a\u652f\u6301","href":"/sqle-docs/docs/support/community-support","docId":"support/community-support"},{"type":"link","label":"\u5546\u4e1a\u652f\u6301","href":"/sqle-docs/docs/support/commercial-support","docId":"support/commercial-support"}],"collapsed":true,"collapsible":true},{"type":"link","label":"\u5feb\u901f\u5f00\u59cb","href":"/sqle-docs/docs/quick-usage","docId":"quick-usage"},{"type":"category","label":"\u5b89\u88c5\u90e8\u7f72","items":[{"type":"link","label":"\u5b89\u88c5\u8bf4\u660e","href":"/sqle-docs/docs/deploy-manual/intro","docId":"deploy-manual/intro"},{"type":"link","label":"\u914d\u7f6e\u6587\u4ef6\u8bf4\u660e","href":"/sqle-docs/docs/deploy-manual/config","docId":"deploy-manual/config"},{"type":"link","label":"\u6e90\u7801\u5b89\u88c5","href":"/sqle-docs/docs/deploy-manual/source","docId":"deploy-manual/source"},{"type":"link","label":"RPM \u5b89\u88c5","href":"/sqle-docs/docs/deploy-manual/rpm","docId":"deploy-manual/rpm"},{"type":"link","label":"Docker\u90e8\u7f72","href":"/sqle-docs/docs/deploy-manual/Docker","docId":"deploy-manual/Docker"},{"type":"link","label":"Docker Compose \u90e8\u7f72","href":"/sqle-docs/docs/deploy-manual/DockerCompose","docId":"deploy-manual/DockerCompose"}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u7528\u6237\u624b\u518c","items":[{"type":"category","label":"\u9879\u76ee","items":[{"type":"link","label":"\u529f\u80fd\u4ecb\u7ecd","href":"/sqle-docs/docs/user-manual/project/intro","docId":"user-manual/project/intro"},{"type":"link","label":"\u521b\u5efa\u9879\u76ee\u3010\u4f01\u4e1a\u7248\u3011","href":"/sqle-docs/docs/user-manual/project/project_create","docId":"user-manual/project/project_create"},{"type":"link","label":"\u6570\u636e\u6e90\u7ba1\u7406","href":"/sqle-docs/docs/user-manual/project/instance-manager","docId":"user-manual/project/instance-manager"},{"type":"link","label":"\u5916\u90e8\u6570\u636e\u6e90\u540c\u6b65\u3010\u4f01\u4e1a\u7248\u3011","href":"/sqle-docs/docs/user-manual/project/instance_syn","docId":"user-manual/project/instance_syn"},{"type":"link","label":"\u6210\u5458/\u6210\u5458\u7ec4\u7ba1\u7406","href":"/sqle-docs/docs/user-manual/project/group_member","docId":"user-manual/project/group_member"},{"type":"link","label":"\u5ba1\u6838\u89c4\u5219\u6a21\u677f","href":"/sqle-docs/docs/user-manual/project/rule-template-manager","docId":"user-manual/project/rule-template-manager"},{"type":"link","label":"\u5ba1\u6838\u6d41\u7a0b\u6a21\u677f","href":"/sqle-docs/docs/user-manual/project/workflow-template-manager","docId":"user-manual/project/workflow-template-manager"},{"type":"link","label":"\u767d\u540d\u5355\u7ba1\u7406","href":"/sqle-docs/docs/user-manual/project/whitelist-manager","docId":"user-manual/project/whitelist-manager"},{"type":"link","label":"\u64cd\u4f5c\u8bb0\u5f55","href":"/sqle-docs/docs/user-manual/project/operation_records","docId":"user-manual/project/operation_records"},{"type":"link","label":"SQL\u7ba1\u63a7","href":"/sqle-docs/docs/user-manual/project/sqlmanage","docId":"user-manual/project/sqlmanage"},{"type":"link","label":"SQL\u5ba1\u6838","href":"/sqle-docs/docs/user-manual/project/quick_audit","docId":"user-manual/project/quick_audit"},{"type":"category","label":"\u5de5\u5355","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/user-manual/project/workflow/intro","docId":"user-manual/project/workflow/intro"},{"type":"link","label":"\u521b\u5efa\u5de5\u5355","href":"/sqle-docs/docs/user-manual/project/workflow/create-workflow","docId":"user-manual/project/workflow/create-workflow"},{"type":"link","label":"\u5ba1\u6838\u5de5\u5355","href":"/sqle-docs/docs/user-manual/project/workflow/audit-workflow","docId":"user-manual/project/workflow/audit-workflow"},{"type":"link","label":"\u4e0a\u7ebf\u5de5\u5355","href":"/sqle-docs/docs/user-manual/project/workflow/exec-workflow","docId":"user-manual/project/workflow/exec-workflow"}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u626b\u63cf\u4efb\u52a1","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/user-manual/project/audit_task/intro","docId":"user-manual/project/audit_task/intro"},{"type":"link","label":"\u5e93\u8868\u5143\u6570\u636e","href":"/sqle-docs/docs/user-manual/project/audit_task/metadata_audit","docId":"user-manual/project/audit_task/metadata_audit"},{"type":"link","label":"\u6162\u65e5\u5fd7","href":"/sqle-docs/docs/user-manual/project/audit_task/slowlog_audit","docId":"user-manual/project/audit_task/slowlog_audit"},{"type":"link","label":"\u4f1a\u8bddSQL\u626b\u63cf","href":"/sqle-docs/docs/user-manual/project/audit_task/processlist_audit","docId":"user-manual/project/audit_task/processlist_audit"},{"type":"link","label":"\u767e\u5ea6\u4e91RDS\u6162\u65e5\u5fd7\u626b\u63cf","href":"/sqle-docs/docs/user-manual/project/audit_task/baiduyunrds","docId":"user-manual/project/audit_task/baiduyunrds"},{"type":"link","label":"\u534e\u4e3a\u4e91RDS\u6162\u65e5\u5fd7\u626b\u63cf","href":"/sqle-docs/docs/user-manual/project/audit_task/huaweiyunrds","docId":"user-manual/project/audit_task/huaweiyunrds"},{"type":"link","label":"MyBatis\u626b\u63cf","href":"/sqle-docs/docs/user-manual/project/audit_task/mybatis","docId":"user-manual/project/audit_task/mybatis"},{"type":"link","label":"SQL\u6587\u4ef6\u626b\u63cf","href":"/sqle-docs/docs/user-manual/project/audit_task/SQLfile_audit","docId":"user-manual/project/audit_task/SQLfile_audit"},{"type":"link","label":"\u5e94\u7528\u7a0b\u5e8fSQL\u6293\u53d6\u3010\u4f01\u4e1a\u7248\u3011","href":"/sqle-docs/docs/user-manual/project/audit_task/java_application_audit","docId":"user-manual/project/audit_task/java_application_audit"},{"type":"link","label":"Java\u63a2\u9488\u7248\u5e94\u7528\u7a0b\u5e8fSQL\u6293\u53d6\u3010\u4f01\u4e1a\u7248\u3011","href":"/sqle-docs/docs/user-manual/project/audit_task/java_agent_audit","docId":"user-manual/project/audit_task/java_agent_audit"}],"collapsed":true,"collapsible":true}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u7cfb\u7edf\u8bbe\u7f6e","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/user-manual/sys-configuration/intro","docId":"user-manual/sys-configuration/intro"},{"type":"link","label":"\u767b\u5f55\u5bf9\u63a5","href":"/sqle-docs/docs/user-manual/sys-configuration/login_syn","docId":"user-manual/sys-configuration/login_syn"},{"type":"link","label":"\u6d88\u606f\u63a8\u9001","href":"/sqle-docs/docs/user-manual/sys-configuration/message_syn","docId":"user-manual/sys-configuration/message_syn"},{"type":"link","label":"\u6d41\u7a0b\u5bf9\u63a5","href":"/sqle-docs/docs/user-manual/sys-configuration/process_syn","docId":"user-manual/sys-configuration/process_syn"},{"type":"link","label":"webhook\u914d\u7f6e","href":"/sqle-docs/docs/user-manual/sys-configuration/webhook","docId":"user-manual/sys-configuration/webhook"},{"type":"link","label":"\u5168\u5c40\u914d\u7f6e","href":"/sqle-docs/docs/user-manual/sys-configuration/configuration","docId":"user-manual/sys-configuration/configuration"},{"type":"link","label":"\u4e2a\u6027\u5316\u8bbe\u7f6e\u3010\u4f01\u4e1a\u7248\u3011","href":"/sqle-docs/docs/user-manual/sys-configuration/customize","docId":"user-manual/sys-configuration/customize"}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u5de5\u4f5c\u53f0","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/user-manual/sql-workbench/introduction","docId":"user-manual/sql-workbench/introduction"},{"type":"link","label":"\u914d\u7f6e\u65b9\u6cd5","href":"/sqle-docs/docs/user-manual/sql-workbench/how-to-configure","docId":"user-manual/sql-workbench/how-to-configure"},{"type":"link","label":"\u4f7f\u7528\u5b9a\u5236\u5305\u5feb\u901f\u642d\u5efa\u73af\u5883","href":"/sqle-docs/docs/user-manual/sql-workbench/how-to-use","docId":"user-manual/sql-workbench/how-to-use"}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u7528\u6237\u7ba1\u7406","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/user-manual/user-manager/intro","docId":"user-manual/user-manager/intro"},{"type":"link","label":"\u7528\u6237\u7ba1\u7406","href":"/sqle-docs/docs/user-manual/user-manager/user","docId":"user-manual/user-manager/user"},{"type":"link","label":"\u89d2\u8272\u7ba1\u7406","href":"/sqle-docs/docs/user-manual/user-manager/role","docId":"user-manual/user-manager/role"}],"collapsed":true,"collapsible":true},{"type":"link","label":"\u81ea\u5b9a\u4e49\u5ba1\u6838\u89c4\u5219","href":"/sqle-docs/docs/user-manual/customrule","docId":"user-manual/customrule"},{"type":"link","label":"IDEA\u5ba1\u6838\u63d2\u4ef6","href":"/sqle-docs/docs/user-manual/jetbrains","docId":"user-manual/jetbrains"},{"type":"link","label":"\u89c4\u5219\u77e5\u8bc6\u5e93","href":"/sqle-docs/docs/user-manual/knowledgebase","docId":"user-manual/knowledgebase"}],"collapsed":true,"collapsible":true},{"type":"category","label":"\u5f00\u53d1\u624b\u518c","items":[{"type":"category","label":"\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6","items":[{"type":"link","label":"\u529f\u80fd\u8bf4\u660e","href":"/sqle-docs/docs/dev-manual/plugins/intro","docId":"dev-manual/plugins/intro"},{"type":"link","label":"\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6\u4f7f\u7528","href":"/sqle-docs/docs/dev-manual/plugins/howtouse","docId":"dev-manual/plugins/howtouse"},{"type":"link","label":"\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6\u5f00\u53d1","href":"/sqle-docs/docs/dev-manual/plugins/howtodev","docId":"dev-manual/plugins/howtodev"}],"collapsed":true,"collapsible":true}],"collapsed":true,"collapsible":true},{"type":"category","label":"FAQ","items":[{"type":"link","label":"\u652f\u6301\u54ea\u4e9b\u6570\u636e\u5e93","href":"/sqle-docs/docs/FAQ/whichdatabase","docId":"FAQ/whichdatabase"}],"collapsed":true,"collapsible":true}]},"docs":{"deploy-manual/config":{"id":"deploy-manual/config","title":"\u914d\u7f6e\u6587\u4ef6\u8bf4\u660e","description":"SQLE\u7684\u914d\u7f6e\u6587\u4ef6\u91c7\u7528yml\u7684\u683c\u5f0f\uff0c\u9ed8\u8ba4\u60c5\u51b5\u4e0b\u4f4d\u4e8eSQLE\u5b89\u88c5\u76ee\u5f55\u4e0b\uff0c\u8def\u5f84\u4e3a./etc/config.yml","sidebar":"tutorialSidebar"},"deploy-manual/Docker":{"id":"deploy-manual/Docker","title":"Docker\u90e8\u7f72","description":"Docker hub \u5730\u5740","sidebar":"tutorialSidebar"},"deploy-manual/DockerCompose":{"id":"deploy-manual/DockerCompose","title":"Docker Compose \u90e8\u7f72","description":"\u914d\u7f6e\u6587\u4ef6","sidebar":"tutorialSidebar"},"deploy-manual/intro":{"id":"deploy-manual/intro","title":"\u5b89\u88c5\u8bf4\u660e","description":"SQLE \u63d0\u4f9b\u4e86\u591a\u79cd\u5b89\u88c5\u90e8\u7f72\u7684\u65b9\u5f0f\uff0c\u7528\u6237\u53ef\u4ee5\u7ed3\u5408\u81ea\u5df1\u7684\u73af\u5883\u548c\u73b0\u72b6\u9009\u62e9\u3002\u521d\u6b21\u4f53\u9a8c\u6216\u8005\u6d4b\u8bd5\u4f7f\u7528\u7684\u8bdd\u5efa\u8bae\u4f7f\u7528docker-compose \u6216 docker \u5feb\u901f\u90e8\u7f72\u3002","sidebar":"tutorialSidebar"},"deploy-manual/rpm":{"id":"deploy-manual/rpm","title":"RPM \u5b89\u88c5","description":"\u73af\u5883\u51c6\u5907","sidebar":"tutorialSidebar"},"deploy-manual/source":{"id":"deploy-manual/source","title":"\u6e90\u7801\u5b89\u88c5","description":"\u73af\u5883\u51c6\u5907","sidebar":"tutorialSidebar"},"dev-manual/intro":{"id":"dev-manual/intro","title":"\u4ea7\u54c1\u67b6\u6784","description":""},"dev-manual/plugins/howtodev":{"id":"dev-manual/plugins/howtodev","title":"\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6\u5f00\u53d1","description":"\u5728\u672c\u7bc7\u6587\u6863\u4e2d\uff0c\u4f1a\u4ecb\u7ecd\u5982\u4f55\u5f00\u53d1\u4e00\u4e2a\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6\uff0c\u5206\u4e3a\u5feb\u901f\u5f00\u59cb\u90e8\u5206\u548c\u8be6\u7ec6\u90e8\u5206\u3002","sidebar":"tutorialSidebar"},"dev-manual/plugins/howtouse":{"id":"dev-manual/plugins/howtouse","title":"\u6570\u636e\u5e93\u5ba1\u6838\u63d2\u4ef6\u4f7f\u7528","description":"\u914d\u7f6e\u63d2\u4ef6","sidebar":"tutorialSidebar"},"dev-manual/plugins/intro":{"id":"dev-manual/plugins/intro","title":"\u529f\u80fd\u8bf4\u660e","description":"SQLE \u4f7f\u7528 go-plugin \u6765\u5b9e\u73b0\u5ba1\u6838\u63d2\u4ef6\u5316\u3002\u63d2\u4ef6\u53ea\u9700\u5b9e\u73b0\u4e24\u4e2a\u63a5\u53e3\uff0c\u5373\u53ef\u5b9e\u73b0\u4e0e SQLE \u4e3b\u8fdb\u7a0b\u901a\u4fe1\uff08\u8be6\u60c5\u89c1\u5ba1\u6838\u63d2\u4ef6\u5f00\u53d1\uff09\u3002","sidebar":"tutorialSidebar"},"FAQ/intro":{"id":"FAQ/intro","title":"FAQ","description":"\u672c\u7ae0\u5c06\u9488\u5bf9\u4f7f\u7528\u8fc7\u7a0b\u4e2d\u7684\u5e38\u89c1\u95ee\u9898\u8fdb\u884c\u89e3\u7b54\u3002"},"FAQ/whichdatabase":{"id":"FAQ/whichdatabase","title":"\u652f\u6301\u54ea\u4e9b\u6570\u636e\u5e93","description":"|\u6570\u636e\u5e93\u7c7b\u578b|\u9a8c\u8bc1\u53ef\u7528\u7684\u7248\u672c|","sidebar":"tutorialSidebar"},"guide":{"id":"guide","title":"\u7528\u6237\u6307\u5357","description":"\u4ea7\u54c1\u6982\u8ff0"},"intro":{"id":"intro","title":"\u4ea7\u54c1\u4ecb\u7ecd","description":"SQLE \u662f\u7231\u53ef\u751f\u81ea\u4e3b\u7814\u53d1\u652f\u6301\u591a\u5143\u6570\u636e\u5e93\u7684 SQL \u8d28\u91cf\u7ba1\u7406\u5e73\u53f0\u3002\u5e94\u7528\u4e8e\u5f00\u53d1\u3001\u6d4b\u8bd5\u3001\u4e0a\u7ebf\u53d1\u5e03\u3001\u751f\u4ea7\u8fd0\u884c\u9636\u6bb5\u7684 SQL \u8d28\u91cf\u6cbb\u7406\u3002\u901a\u8fc7 \u201c\u5efa\u7acb\u89c4\u8303\u3001\u4e8b\u524d\u63a7\u5236\u3001\u4e8b\u540e\u76d1\u7763\u3001\u6807\u51c6\u53d1\u5e03\u201d \u7684\u65b9\u5f0f\uff0c\u4e3a\u4f01\u4e1a\u63d0\u4f9b SQL \u5168\u751f\u547d\u5468\u671f\u8d28\u91cf\u7ba1\u63a7\u80fd\u529b\uff0c\u89c4\u907f\u4e1a\u52a1 SQL \u4e0d\u89c4\u8303\u5f15\u8d77\u7684\u751f\u4ea7\u4e8b\u6545\uff0c\u63d0\u9ad8\u4e1a\u52a1\u7a33\u5b9a\u6027\uff0c\u4e5f\u53ef\u63a8\u52a8\u4f01\u4e1a\u5185\u90e8\u5f00\u53d1\u89c4\u8303\u5feb\u901f\u843d\u5730\u3002","sidebar":"tutorialSidebar"},"online-demo":{"id":"online-demo","title":"\u5728\u7ebf\u4f53\u9a8c","description":"\u5730\u5740","sidebar":"tutorialSidebar"},"quick-usage":{"id":"quick-usage","title":"\u5feb\u901f\u5f00\u59cb","description":"\u672c\u6587\u7684\u76ee\u7684\u662f\u8ba9\u5927\u5bb6\u80fd\u5feb\u901f\u4f53\u9a8cSQLE\u7684\u57fa\u7840\u529f\u80fd\uff0c\u5e2e\u52a9\u5927\u5bb6\u5feb\u901f\u4e0a\u624bSQLE\u3002\u4e0b\u9762\u5c06\u6a21\u62df\u4e00\u4e2a\u7b80\u5355\u7684\u65e5\u5e38SQL\u4e0a\u7ebf\u573a\u666f\uff0c\u5f00\u53d1\u4eba\u5458\u63d0\u4ea4SQL\uff0cDBA\u8fdb\u884cSQL\u5ba1\u6838\u5e76\u4e0a\u7ebf\uff0c\u5927\u6982\u7684\u6b65\u9aa4\u5982\u4e0b\uff1a","sidebar":"tutorialSidebar"},"SUMMARY":{"id":"SUMMARY","title":"Summary","description":"* \u4ea7\u54c1\u4ecb\u7ecd"},"support/commercial-support":{"id":"support/commercial-support","title":"\u5546\u4e1a\u652f\u6301","description":"\u5982\u679c\u60f3\u83b7\u5f97 SQLE \u7684\u5546\u4e1a\u652f\u6301, \u60a8\u53ef\u4ee5\u8054\u7cfb\u6211\u4eec:","sidebar":"tutorialSidebar"},"support/community-support":{"id":"support/community-support","title":"\u793e\u533a\u652f\u6301","description":"\u5fae\u4fe1\u6280\u672f\u4ea4\u6d41\u7fa4","sidebar":"tutorialSidebar"},"support/compare":{"id":"support/compare","title":"\u529f\u80fd\u5bf9\u6bd4","description":"\u793e\u533a\u7248\u53ca\u4f01\u4e1a\u7248\u529f\u80fd\u5bf9\u6bd4","sidebar":"tutorialSidebar"},"user-manual/customrule":{"id":"user-manual/customrule","title":"\u81ea\u5b9a\u4e49\u5ba1\u6838\u89c4\u5219","description":"\u4f7f\u7528\u573a\u666f","sidebar":"tutorialSidebar"},"user-manual/intro":{"id":"user-manual/intro","title":"\u7528\u6237\u624b\u518c","description":"\u5728\u7a0b\u5e8f\u90e8\u7f72\u5b8c\u6210\u540e\uff0c\u7528\u6237\u5373\u53ef\u901a\u8fc7 SQLE UI \uff08http10000\uff09\u8bbf\u95ee\uff0c\u4f7f\u7528SQLE\u5e73\u53f0\u63d0\u4f9b\u7684SQL\u5ba1\u6838\u529f\u80fd\u3002"},"user-manual/jetbrains":{"id":"user-manual/jetbrains","title":"IDEA\u5ba1\u6838\u63d2\u4ef6","description":"\u8be5\u9879\u76ee\u662fSQLE \u7684 IDEA\u5ba1\u6838\u63d2\u4ef6 \uff0c\u65e8\u5728\u5e2e\u52a9\u5f00\u53d1\u4eba\u5458\u5728SQL\u5f00\u53d1\u7684\u5404\u4e2a\u9636\u6bb5\u8fdb\u884c\u5b9e\u65f6\u81ea\u52a9\u5f0f\u7684\u9759\u6001SQL\u5ba1\u6838\uff0c\u5e76\u5f15\u5165SQL\u5f00\u53d1\u89c4\u8303\u3002","sidebar":"tutorialSidebar"},"user-manual/knowledgebase":{"id":"user-manual/knowledgebase","title":"\u89c4\u5219\u77e5\u8bc6\u5e93","description":"\u4f7f\u7528\u573a\u666f","sidebar":"tutorialSidebar"},"user-manual/project/analysis":{"id":"user-manual/project/analysis","title":"SQL\u5206\u6790","description":"SQL\u5206\u6790\u662f\u4ec0\u4e48"},"user-manual/project/audit_task/baiduyunrds":{"id":"user-manual/project/audit_task/baiduyunrds","title":"\u767e\u5ea6\u4e91RDS\u6162\u65e5\u5fd7\u626b\u63cf","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55\u5728SQLE\u5e73\u53f0\u76d1\u7ba1\u767e\u5ea6\u4e91RDS\u5b9e\u4f8b\u4e0a\u4ea7\u751f\u7684\u6162SQL\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/huaweiyunrds":{"id":"user-manual/project/audit_task/huaweiyunrds","title":"\u534e\u4e3a\u4e91RDS\u6162\u65e5\u5fd7\u626b\u63cf","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55\u901a\u8fc7\u534e\u4e3a\u4e91SQLE\u5e73\u53f0\u76d1\u7ba1\u534e\u4e3a\u4e91RDS\u5b9e\u4f8b\u4e0a\u4ea7\u751f\u7684\u6162SQL\uff0c\u5e76\u8fdb\u884c\u76f8\u5e94\u7684\u5206\u6790\u548c\u5ba1\u6838\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/intro":{"id":"user-manual/project/audit_task/intro","title":"\u529f\u80fd\u8bf4\u660e","description":"\u80cc\u666f","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/java_agent_audit":{"id":"user-manual/project/audit_task/java_agent_audit","title":"Java\u63a2\u9488\u7248\u5e94\u7528\u7a0b\u5e8fSQL\u6293\u53d6\u3010\u4f01\u4e1a\u7248\u3011","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55\u5229\u7528SQLE\u5e73\u53f0\u6293\u53d6java\u5e94\u7528\u4e2d\u7684SQL\uff0c\u9009\u53d6\u7684\u4f8b\u5b50\u662f\u4e00\u4e2a\u5f00\u6e90\u7684\u95ee\u5377\u8c03\u67e5java\u5e94\u7528\uff0c\u67b6\u6784\u7b80\u5355\uff0c\u4e0a\u624b\u76f8\u5bf9\u5bb9\u6613\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/java_application_audit":{"id":"user-manual/project/audit_task/java_application_audit","title":"\u5e94\u7528\u7a0b\u5e8fSQL\u6293\u53d6\u3010\u4f01\u4e1a\u7248\u3011","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55\u5229\u7528SQLE\u5e73\u53f0\u6293\u53d6JAVA\u5e94\u7528\u4e2d\u7684SQL\uff0c\u9009\u53d6\u7684\u4f8b\u5b50\u662f\u4e00\u4e2a\u5f00\u6e90\u7684\u95ee\u5377\u8c03\u67e5java\u5e94\u7528\uff0c\u67b6\u6784\u7b80\u5355\uff0c\u4e0a\u624b\u76f8\u5bf9\u5bb9\u6613\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/metadata_audit":{"id":"user-manual/project/audit_task/metadata_audit","title":"\u5e93\u8868\u5143\u6570\u636e","description":"\u672c\u8282\u4ecb\u7ecd\u5e93\u8868\u5143\u6570\u636e\u626b\u63cf\u7684\u5e94\u7528\u573a\u666f\u3001\u4ee5\u53ca\u5982\u4f55\u521b\u5efa\u5e93\u8868\u5143\u6570\u636e\u7684\u626b\u63cf\u4efb\u52a1\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/mybatis":{"id":"user-manual/project/audit_task/mybatis","title":"MyBatis\u626b\u63cf","description":"\u672c\u8282\u4ecb\u7ecdMyBatis\u626b\u63cf\u7684\u5e94\u7528\u573a\u666f\u53ca\u914d\u7f6e\u65b9\u6cd5\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/processlist_audit":{"id":"user-manual/project/audit_task/processlist_audit","title":"\u4f1a\u8bddSQL\u626b\u63cf","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55\u5bf9MySQL\u8fdb\u884c\u4e2d\u7684\u4f1a\u8bddSQL\u8fdb\u884c\u76d1\u7763\u53ca\u5ba1\u6838\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/slowlog_audit":{"id":"user-manual/project/audit_task/slowlog_audit","title":"\u6162\u65e5\u5fd7","description":"\u672c\u8282\u4ecb\u7ecd\u6162\u65e5\u5fd7\u626b\u63cf\u7684\u5e94\u7528\u573a\u666f\u3001\u4ee5\u53ca\u5982\u4f55\u521b\u5efa\u6162\u65e5\u5fd7\u626b\u63cf\u4efb\u52a1\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/SQLfile_audit":{"id":"user-manual/project/audit_task/SQLfile_audit","title":"SQL\u6587\u4ef6\u626b\u63cf","description":"\u672c\u8282\u4ecb\u7ecdSQL\u6587\u4ef6\u626b\u63cf\u7684\u5e94\u7528\u573a\u666f\u53ca\u914d\u7f6e\u65b9\u6cd5\u3002","sidebar":"tutorialSidebar"},"user-manual/project/audit_task/topsql":{"id":"user-manual/project/audit_task/topsql","title":"TopSQL","description":"\u672c\u8282\u4ecb\u7ecd\u5982\u4f55"},"user-manual/project/data_access_control/authorization_list":{"id":"user-manual/project/data_access_control/authorization_list","title":"\u6388\u6743\u6e05\u5355","description":"\u901a\u8fc7\u7edf\u4e00\u5206\u914d\u6307\u5b9a\u6743\u9650\u64cd\u4f5c\u7528\u6237\uff0c\u907f\u514d\u51fa\u73b0\u56e0\u4e1a\u52a1\u591a\u5bfc\u81f4\u6743\u9650\u7ba1\u7406\u5206\u6563\u7684\u56f0\u5883\uff0c\u540c\u65f6\u8ffd\u6eaf\u6743\u9650\u53d1\u653e\u539f\u56e0\u3002"},"user-manual/project/data_access_control/intro":{"id":"user-manual/project/data_access_control/intro","title":"intro","description":"\u5e73\u53f0\u901a\u8fc7\u6743\u9650\u63a7\u5236\uff0c\u6765\u5b9e\u73b0\u6570\u636e\u5b89\u5168\u3002"},"user-manual/project/data_access_control/permission_template":{"id":"user-manual/project/data_access_control/permission_template","title":"\u6743\u9650\u6a21\u677f","description":"\u6743\u9650\u6a21\u677f\u652f\u6301\u7075\u6d3b\u5206\u7ec4\uff0c\u6309\u96c6\u5408\u7ec4\u7ec7\u6743\u9650\u6a21\u677f\uff0c\u4ee5\u51cf\u5c11\u91cd\u590d\u5206\u914d\u76f8\u540c\u6743\u9650\u7684\u5de5\u4f5c\u91cf\uff0c\u63d0\u9ad8\u6743\u9650\u7ba1\u7406\u6548\u7387\u3002"},"user-manual/project/group_member":{"id":"user-manual/project/group_member","title":"\u6210\u5458/\u6210\u5458\u7ec4\u7ba1\u7406","description":"\u672c\u6587\u4ecb\u7ecd\u9879\u76ee\u5185\u6dfb\u52a0\u6210\u5458\u3001\u6210\u5458\u7ec4\u7684\u6b65\u9aa4\uff0c\u4ee5\u53ca\u5176\u4ed6\u7ba1\u7406\u64cd\u4f5c\u3002","sidebar":"tutorialSidebar"},"user-manual/project/instance_syn":{"id":"user-manual/project/instance_syn","title":"\u5916\u90e8\u6570\u636e\u6e90\u540c\u6b65\u3010\u4f01\u4e1a\u7248\u3011","description":"SQLE\u652f\u6301\u4ece\u5176\u4ed6\u5e73\u53f0\u5bfc\u5165\u6570\u636e\u6e90\u7684\u529f\u80fd\uff0c\u65b9\u4fbf\u7528\u6237\u63a5\u5165\u5916\u90e8\u5e73\u53f0\u7684\u6570\u636e\u6e90\uff0c\u76ee\u524d\u5df2\u5b9e\u73b0\u5bf9\u63a5\u7231\u53ef\u751f\u5546\u4e1a\u4ea7\u54c1\u201c\u4e91\u6811\xb7DMP\uff1a\u6570\u636e\u5e93\u96c6\u7fa4\u7ba1\u7406\u5e73\u53f0\u201d\u3002","sidebar":"tutorialSidebar"},"user-manual/project/instance-manager":{"id":"user-manual/project/instance-manager","title":"\u6570\u636e\u6e90\u7ba1\u7406","description":"\u672c\u6587\u4ecb\u7ecd\u5982\u4f55\u5728\u9879\u76ee\u4e2d\u8fdb\u884c\u6570\u636e\u6e90\u7ba1\u7406\uff0c\u5305\u62ec\u6570\u636e\u6e90\u7684\u589e\u52a0\u3001\u5220\u9664\u3001\u7f16\u8f91\u64cd\u4f5c\u3002","sidebar":"tutorialSidebar"},"user-manual/project/intro":{"id":"user-manual/project/intro","title":"\u529f\u80fd\u4ecb\u7ecd","description":"\u81ea2.22.11.0\u7248\u672c\u8d77\uff0c\u5e73\u53f0\u5f15\u5165\u9879\u76ee\u7ba1\u7406\u6982\u5ff5\uff0c\u4e0eSQL\u5ba1\u6838\u76f8\u5173\u7684\u8d44\u6e90\u5747\u4ee5\u9879\u76ee\u7684\u5f62\u5f0f\u8fdb\u884c\u8d44\u6e90\u9694\u79bb\u3002\u521b\u5efa\u5de5\u5355\u524d\uff0c\u9700\u8981\u7531\u9879\u76ee\u7ba1\u7406\u5458\u8bbe\u7f6e\u597d\u9879\u76ee\u5185\u90e8\u5fc5\u8981\u7684\u8d44\u6e90\u73af\u5883\uff0c\u5305\u62ec\u9879\u76ee\u4f7f\u7528\u7684\u6570\u636e\u6e90\u3001\u7528\u6237\u3001\u6d41\u7a0b\u6a21\u677f\u3001\u89c4\u5219\u6a21\u677f\u3001\u767d\u540d\u5355\u4fe1\u606f\u7b49\uff0c\u968f\u540e\uff0c\u9879\u76ee\u6210\u5458\u624d\u53ef\u5728\u9879\u76ee\u5185\u63d0\u4ea4\u5de5\u5355\u5e76\u5ba1\u6838\u4e0a\u7ebf\uff0c\u6216\u8bbe\u7f6e\u667a\u80fd\u626b\u63cf\u4efb\u52a1\u3002","sidebar":"tutorialSidebar"},"user-manual/project/operation_records":{"id":"user-manual/project/operation_records","title":"\u64cd\u4f5c\u8bb0\u5f55","description":"\u4f7f\u7528\u573a\u666f","sidebar":"tutorialSidebar"},"user-manual/project/project_create":{"id":"user-manual/project/project_create","title":"\u521b\u5efa\u9879\u76ee\u3010\u4f01\u4e1a\u7248\u3011","description":"\u672c\u6587\u4ecb\u7ecd\u5982\u4f55\u5728SQLE\u5e73\u53f0\u521b\u5efa\u9879\u76ee\u3002","sidebar":"tutorialSidebar"},"user-manual/project/quick_audit":{"id":"user-manual/project/quick_audit","title":"SQL\u5ba1\u6838","description":"\u672c\u6587\u4ecb\u7ecd\u5e73\u53f0\u7684SQL\u5ba1\u6838\u529f\u80fd\uff0c\u8be5\u529f\u80fd\u53ef\u4ee5\u5e2e\u52a9\u7528\u6237\u5feb\u901f\u5ba1\u6838SQL\u5e76\u4e86\u89e3\u4f18\u5316\u5efa\u8bae\u3002","sidebar":"tutorialSidebar"},"user-manual/project/rule-template-manager":{"id":"user-manual/project/rule-template-manager","title":"\u5ba1\u6838\u89c4\u5219\u6a21\u677f","description":"\u672c\u6587\u5c06\u4ecb\u7ecd\u5982\u4f55\u7ba1\u7406\u9879\u76ee\u4e2d\u7684\u5ba1\u6838\u89c4\u5219\u6a21\u677f\u3002","sidebar":"tutorialSidebar"},"user-manual/project/sqlmanage":{"id":"user-manual/project/sqlmanage","title":"SQL\u7ba1\u63a7","description":"SQL\u7ba1\u63a7\u9875\u9762\u96c6\u4e2d\u4e86\u7528\u6237\u5728SQL\u5ba1\u6838\u548c\u626b\u63cf\u4efb\u52a1\u4e2d\u751f\u6210\u7684SQL\uff0c\u65b9\u4fbf\u8fdb\u884c\u96c6\u4e2d\u7684\u7ba1\u7406\u3002\u7528\u6237\u53ef\u4ee5\u5feb\u901f\u53d1\u73b0\u5ba1\u6838\u51fa\u95ee\u9898\u7684SQL\uff0c\u5e76\u5c06\u5176\u5206\u914d\u7ed9\u5176\u4ed6\u6210\u5458\u5904\u7406\uff0c\u6216\u5c06\u4e0d\u5173\u5fc3\u7684SQL\u8bbe\u4e3a\u5ffd\u7565\u72b6\u6001\uff0c\u4ece\u800c\u5b9e\u73b0\u9ad8\u6548\u7684SQL\u7ba1\u7406\u3002","sidebar":"tutorialSidebar"},"user-manual/project/whitelist-manager":{"id":"user-manual/project/whitelist-manager","title":"\u767d\u540d\u5355\u7ba1\u7406","description":"\u672c\u6587\u4ecb\u7ecd\u5982\u4f55\u589e\u52a0\u3001\u7f16\u8f91\u3001\u5220\u9664\u9879\u76ee\u4e2d\u7684\u767d\u540d\u5355\u3002","sidebar":"tutorialSidebar"},"user-manual/project/workflow-template-manager":{"id":"user-manual/project/workflow-template-manager","title":"\u5ba1\u6838\u6d41\u7a0b\u6a21\u677f","description":"\u672c\u6587\u4ecb\u7ecd\u9879\u76ee\u4e2d\u7684\u5ba1\u6838\u6d41\u7a0b\u6a21\u677f\u7ba1\u7406\u3002","sidebar":"tutorialSidebar"},"user-manual/project/workflow/audit-workflow":{"id":"user-manual/project/workflow/audit-workflow","title":"\u5ba1\u6838\u5de5\u5355","description":"\u5ba1\u6838\u5de5\u5355\u5305\u542b\u4e24\u90e8\u5206","sidebar":"tutorialSidebar"},"user-manual/project/workflow/create-workflow":{"id":"user-manual/project/workflow/create-workflow","title":"\u521b\u5efa\u5de5\u5355","description":"\u5de5\u5355\u662fSQLE\u63d0\u4f9b\u7684\u5728\u7ebf\u5316SQL\u4e0a\u7ebf\u65b9\u5f0f\u3002\u7814\u53d1\u4eba\u5458\u53ef\u901a\u8fc7\u521b\u5efa\u5de5\u5355\uff0c\u63d0\u8bf7\u9700\u8981\u5ba1\u6279\u7684SQL\u8bed\u53e5\u3002","sidebar":"tutorialSidebar"},"user-manual/project/workflow/exec-workflow":{"id":"user-manual/project/workflow/exec-workflow","title":"\u4e0a\u7ebf\u5de5\u5355","description":"\u672c\u7ae0\u8be6\u7ec6\u4ecb\u7ecd\u7528\u6237\u5982\u4f55\u8fdb\u884c\u4e0a\u7ebf\u3002","sidebar":"tutorialSidebar"},"user-manual/project/workflow/intro":{"id":"user-manual/project/workflow/intro","title":"\u529f\u80fd\u8bf4\u660e","description":"\u5f88\u591a\u516c\u53f8\u901a\u5e38\u8bbe\u6709 DBA\uff08Database administrator\uff09 \u8fd9\u4e2a\u804c\u4f4d\uff0c\u4ed6\u4eec\u8d1f\u8d23\u5728\u7cfb\u7edf\u4e0a\u8fd0\u884c\u6570\u636e\u5e93\uff0c\u6267\u884c\u5907\u4efd\uff0c\u6267\u884c\u5b89\u5168\u7b56\u7565\u7b49\u65e5\u5e38\u6570\u636e\u5e93\u8fd0\u7ef4\u7684\u5de5\u4f5c\u3002\u5176\u4e2d\uff0cDBA\u4e00\u9879\u91cd\u8981\u7684\u5de5\u4f5c\u662f\u89c4\u8303\u7814\u53d1\u4eba\u5458\u5728\u5e94\u7528\u7a0b\u5e8f\u4e2d\u4f7f\u7528\u7684 SQL \u8bed\u53e5\u3002","sidebar":"tutorialSidebar"},"user-manual/sql-workbench/how-to-configure":{"id":"user-manual/sql-workbench/how-to-configure","title":"\u914d\u7f6e\u65b9\u6cd5","description":"\u5b89\u88c5CloudBeaver","sidebar":"tutorialSidebar"},"user-manual/sql-workbench/how-to-quick-deploy":{"id":"user-manual/sql-workbench/how-to-quick-deploy","title":"\u4f7f\u7528\u5b9a\u5236\u5305\u5feb\u901f\u642d\u5efa\u73af\u5883","description":"SQLE\u5728\u539f\u6709CloudBeaver release222_0 \u5206\u652f\u7684\u57fa\u7840\u4e0a, \u589e\u52a0\u4e86\u5bf9OceanBase \u548c TiDB \u7684\u652f\u6301, \u7528\u6237\u65e0\u9700\u518d\u624b\u52a8\u914d\u7f6e\u73af\u5883\uff0c\u53ef\u76f4\u63a5\u4f7f\u7528SQL\u5de5\u4f5c\u53f0\u529f\u80fd\u3002"},"user-manual/sql-workbench/how-to-use":{"id":"user-manual/sql-workbench/how-to-use","title":"\u4f7f\u7528\u5b9a\u5236\u5305\u5feb\u901f\u642d\u5efa\u73af\u5883","description":"SQLE\u5728\u539f\u6709CloudBeaver release222_0 \u5206\u652f\u7684\u57fa\u7840\u4e0a, \u589e\u52a0\u4e86\u5bf9OceanBase \u548c TiDB \u7684\u652f\u6301, \u7528\u6237\u65e0\u9700\u518d\u624b\u52a8\u914d\u7f6e\u73af\u5883\uff0c\u53ef\u76f4\u63a5\u4f7f\u7528SQL\u5de5\u4f5c\u53f0\u529f\u80fd\u3002","sidebar":"tutorialSidebar"},"user-manual/sql-workbench/introduction":{"id":"user-manual/sql-workbench/introduction","title":"\u529f\u80fd\u8bf4\u660e","description":"CloudBeaver Community \u662f\u4e00\u4e2a\u5f00\u6e90\u7684 Web \u6570\u636e\u5e93\u53ef\u89c6\u5316\u7ba1\u7406\u5de5\u5177\uff0c\u652f\u6301 PostgreSQL, MySQL, MariaDB, SQL Server, Oracle, DB2, Firebird, H2, Trino \u7b49\u6570\u636e\u5e93\u3002","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/configuration":{"id":"user-manual/sys-configuration/configuration","title":"\u5168\u5c40\u914d\u7f6e","description":"SQLE\u652f\u6301\u7ba1\u7406\u5458\u5bf9\u5e73\u53f0\u57fa\u7840\u914d\u7f6e\u8fdb\u884c\u7edf\u4e00\u7ba1\u7406\uff0c\u76ee\u524d\u652f\u6301\u4fee\u6539\u7684\u914d\u7f6e\u9879\u5305\u62ec\uff1a","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/customize":{"id":"user-manual/sys-configuration/customize","title":"\u4e2a\u6027\u5316\u8bbe\u7f6e\u3010\u4f01\u4e1a\u7248\u3011","description":"SQLE\u652f\u6301\u5bf9\u7f51\u7ad9logo\u53ca\u6807\u9898\u8fdb\u884c\u81ea\u5b9a\u4e49\u8bbe\u7f6e\uff0c\u6ee1\u8db3\u4f01\u4e1a\u7528\u6237\u7684\u4e2a\u6027\u5316\u9700\u6c42\u3002","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/intro":{"id":"user-manual/sys-configuration/intro","title":"\u529f\u80fd\u8bf4\u660e","description":"\u7cfb\u7edf\u8bbe\u7f6e\u4e2d\u53ef\u914d\u7f6e\u7684\u5185\u5bb9\u5305\u62ec\u5168\u5c40\u914d\u7f6e\u3001\u767b\u5f55\u5bf9\u63a5\u3001\u6d41\u7a0b\u5bf9\u63a5\u3001\u6d88\u606f\u63a8\u9001\u3002","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/login_syn":{"id":"user-manual/sys-configuration/login_syn","title":"\u767b\u5f55\u5bf9\u63a5","description":"\u5f53\u524d\u767b\u5f55\u5bf9\u63a5\u5df2\u5b9e\u73b0LDAP\u65b9\u5f0f\u53caOauth2.0\u65b9\u5f0f","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/message_syn":{"id":"user-manual/sys-configuration/message_syn","title":"\u6d88\u606f\u63a8\u9001","description":"\u5f53\u524d\u652f\u6301\u5c06\u5de5\u5355\u72b6\u6001\u53d8\u66f4\u540c\u6b65\u81f3\u90ae\u7bb1\u3001\u4f01\u4e1a\u5fae\u4fe1\u3001\u98de\u4e66\u3001Webhook\u3002","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/process_syn":{"id":"user-manual/sys-configuration/process_syn","title":"\u6d41\u7a0b\u5bf9\u63a5","description":"\u901a\u8fc7\u6d41\u7a0b\u5bf9\u63a5\u529f\u80fd\uff0c\u7528\u6237\u53ef\u4ee5\u5c06SQLE\u5e73\u53f0\u7684\u5de5\u5355\u5ba1\u6279\u64cd\u4f5c\u5bf9\u63a5\u5230\u6307\u5b9a\u7684\u5e73\u53f0\uff0c\u4f7f\u7528\u6237\u80fd\u591f\u5728\u8be5\u5e73\u53f0\u4e0a\u5b8c\u6210\u5de5\u5355\u5ba1\u6838\u548c\u4e0a\u7ebf\u64cd\u4f5c\uff0c\u907f\u514d\u5728\u591a\u4e2a\u5e73\u53f0\u4e4b\u95f4\u5207\u6362\u3002\u76ee\u524d\u6211\u4eec\u652f\u6301\u9489\u9489\u548c\u98de\u4e66\u5ba1\u6279\u3002","sidebar":"tutorialSidebar"},"user-manual/sys-configuration/webhook":{"id":"user-manual/sys-configuration/webhook","title":"webhook\u914d\u7f6e","description":"Webhook\u662f\u7528\u6237\u5b9a\u4e49\u7684\u81ea\u5b9a\u4e49HTTP\u56de\u8c03\u3002\u5b83\u4eec\u901a\u5e38\u7531\u4e8b\u4ef6\u89e6\u53d1\uff0c\u4f8b\u5982SQLE\u4e2d\u5b58\u5728\u5de5\u5355\u72b6\u6001\u7684\u53d8\u5316\uff0c\u5219\u4f1a\u81ea\u52a8\u5411\u7528\u6237\u914d\u7f6e\u7684webhook URL\u53d1\u9001HTTP\u8bf7\u6c42\u3002","sidebar":"tutorialSidebar"},"user-manual/user-manager/intro":{"id":"user-manual/user-manager/intro","title":"\u529f\u80fd\u8bf4\u660e","description":"\u7528\u6237\u4e2d\u5fc3\u5305\u542b\u7528\u6237\u7ba1\u7406\u3001\u89d2\u8272\u7ba1\u7406\u53ca\u64cd\u4f5c\u6743\u9650\u5217\u8868\uff0c\u7531\u5e73\u53f0\u7ba1\u7406\u5458\u64cd\u4f5c\uff0c\u6d89\u53ca\u7528\u6237\u53ca\u89d2\u8272\u6743\u9650\u7684\u914d\u7f6e\u3002","sidebar":"tutorialSidebar"},"user-manual/user-manager/role":{"id":"user-manual/user-manager/role","title":"\u89d2\u8272\u7ba1\u7406","description":"\u5f53\u9700\u8981\u4e3a\u7528\u6237\u8bbe\u7f6e\u52a8\u4f5c\u6743\u9650\u65f6\uff0c\u53ef\u4f7f\u7528\u89d2\u8272\u7ba1\u7406\u914d\u7f6e\u52a8\u4f5c\u7ec4\u5408\u3002","sidebar":"tutorialSidebar"},"user-manual/user-manager/user":{"id":"user-manual/user-manager/user","title":"\u7528\u6237\u7ba1\u7406","description":"\u5f53\u9700\u8981\u521b\u5efa\u65b0\u7684\u7528\u6237\uff0c\u6216\u9700\u8981\u7531\u7ba1\u7406\u5458\u4fee\u6539\u7528\u6237\u57fa\u672c\u4fe1\u606f\u65f6\uff0c\u53ef\u4ee5\u8fdb\u884c\u7528\u6237\u7ba1\u7406\u7684\u76f8\u5173\u64cd\u4f5c\u3002","sidebar":"tutorialSidebar"}}}')}}]); \ No newline at end of file diff --git a/assets/js/a1c7e5e9.7d2436e8.js b/assets/js/a1c7e5e9.7d2436e8.js deleted file mode 100644 index 96e509f1..00000000 --- a/assets/js/a1c7e5e9.7d2436e8.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunksqle_docs=self.webpackChunksqle_docs||[]).push([[269],{3905:(e,t,r)=>{r.d(t,{Zo:()=>u,kt:()=>d});var n=r(7294);function o(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function c(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function p(e){for(var t=1;t=0||(o[r]=e[r]);return o}(e,t);if(Object.getOwnPropertySymbols){var c=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(o[r]=e[r])}return o}var l=n.createContext({}),i=function(e){var t=n.useContext(l),r=t;return e&&(r="function"==typeof e?e(t):p(p({},t),e)),r},u=function(e){var t=i(e.components);return n.createElement(l.Provider,{value:t},e.children)},s="mdxType",m={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},f=n.forwardRef((function(e,t){var r=e.components,o=e.mdxType,c=e.originalType,l=e.parentName,u=a(e,["components","mdxType","originalType","parentName"]),s=i(r),f=o,d=s["".concat(l,".").concat(f)]||s[f]||m[f]||c;return r?n.createElement(d,p(p({ref:t},u),{},{components:r})):n.createElement(d,p({ref:t},u))}));function d(e,t){var r=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var c=r.length,p=new Array(c);p[0]=f;var a={};for(var l in t)hasOwnProperty.call(t,l)&&(a[l]=t[l]);a.originalType=e,a[s]="string"==typeof e?e:o,p[1]=a;for(var i=2;i{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>p,default:()=>s,frontMatter:()=>c,metadata:()=>a,toc:()=>i});var n=r(7462),o=(r(7294),r(3905));const c={title:"\u5546\u4e1a\u652f\u6301"},p="\u5546\u4e1a\u652f\u6301",a={unversionedId:"support/commercial-support",id:"support/commercial-support",title:"\u5546\u4e1a\u652f\u6301",description:"\u5982\u679c\u60f3\u83b7\u5f97 SQLE \u7684\u5546\u4e1a\u652f\u6301, \u60a8\u53ef\u4ee5\u8054\u7cfb\u6211\u4eec:",source:"@site/docs/support/commercial-support.md",sourceDirName:"support",slug:"/support/commercial-support",permalink:"/sqle-docs/docs/support/commercial-support",draft:!1,editUrl:"https://github.com/actiontech/sqle-docs/tree/main/docs/support/commercial-support.md",tags:[],version:"current",frontMatter:{title:"\u5546\u4e1a\u652f\u6301"},sidebar:"tutorialSidebar",previous:{title:"\u793e\u533a\u652f\u6301",permalink:"/sqle-docs/docs/support/community-support"},next:{title:"\u5feb\u901f\u5f00\u59cb",permalink:"/sqle-docs/docs/quick-usage"}},l={},i=[],u={toc:i};function s(e){let{components:t,...r}=e;return(0,o.kt)("wrapper",(0,n.Z)({},u,r,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"\u5546\u4e1a\u652f\u6301"},"\u5546\u4e1a\u652f\u6301"),(0,o.kt)("p",null,"\u5982\u679c\u60f3\u83b7\u5f97 SQLE \u7684\u5546\u4e1a\u652f\u6301, \u60a8\u53ef\u4ee5\u8054\u7cfb\u6211\u4eec:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"\u5168\u56fd\u652f\u6301: 400-820-6580"),(0,o.kt)("li",{parentName:"ul"},"\u534e\u5317\u5730\u533a: 86-13910506562, \u6c6a\u5148\u751f"),(0,o.kt)("li",{parentName:"ul"},"\u534e\u5357\u5730\u533a: 86-18503063188, \u66f9\u5148\u751f"),(0,o.kt)("li",{parentName:"ul"},"\u534e\u4e1c\u5730\u533a: 86-18930110869, \u6881\u5148\u751f"),(0,o.kt)("li",{parentName:"ul"},"\u897f\u5357\u5730\u533a: 86-13540040119, \u6d2a\u5148\u751f")))}s.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/a1c7e5e9.dd649570.js b/assets/js/a1c7e5e9.dd649570.js new file mode 100644 index 00000000..e8472779 --- /dev/null +++ b/assets/js/a1c7e5e9.dd649570.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunksqle_docs=self.webpackChunksqle_docs||[]).push([[269],{3905:(e,t,r)=>{r.d(t,{Zo:()=>l,kt:()=>d});var n=r(7294);function o(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function c(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function p(e){for(var t=1;t=0||(o[r]=e[r]);return o}(e,t);if(Object.getOwnPropertySymbols){var c=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(o[r]=e[r])}return o}var i=n.createContext({}),s=function(e){var t=n.useContext(i),r=t;return e&&(r="function"==typeof e?e(t):p(p({},t),e)),r},l=function(e){var t=s(e.components);return n.createElement(i.Provider,{value:t},e.children)},u="mdxType",m={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},f=n.forwardRef((function(e,t){var r=e.components,o=e.mdxType,c=e.originalType,i=e.parentName,l=a(e,["components","mdxType","originalType","parentName"]),u=s(r),f=o,d=u["".concat(i,".").concat(f)]||u[f]||m[f]||c;return r?n.createElement(d,p(p({ref:t},l),{},{components:r})):n.createElement(d,p({ref:t},l))}));function d(e,t){var r=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var c=r.length,p=new Array(c);p[0]=f;var a={};for(var i in t)hasOwnProperty.call(t,i)&&(a[i]=t[i]);a.originalType=e,a[u]="string"==typeof e?e:o,p[1]=a;for(var s=2;s{r.r(t),r.d(t,{assets:()=>i,contentTitle:()=>p,default:()=>u,frontMatter:()=>c,metadata:()=>a,toc:()=>s});var n=r(7462),o=(r(7294),r(3905));const c={title:"\u5546\u4e1a\u652f\u6301"},p="\u5546\u4e1a\u652f\u6301",a={unversionedId:"support/commercial-support",id:"support/commercial-support",title:"\u5546\u4e1a\u652f\u6301",description:"\u5982\u679c\u60f3\u83b7\u5f97 SQLE \u7684\u5546\u4e1a\u652f\u6301, \u60a8\u53ef\u4ee5\u626b\u63cf\u4e0b\u65b9\u7684\u5fae\u4fe1\u626b\u63cf\u5c0f\u7a0b\u5e8f\u7801\uff0c\u8fdb\u884c\u5728\u7ebf\u54a8\u8be2\u9884\u7ea6\uff1a",source:"@site/docs/support/commercial-support.md",sourceDirName:"support",slug:"/support/commercial-support",permalink:"/sqle-docs/docs/support/commercial-support",draft:!1,editUrl:"https://github.com/actiontech/sqle-docs/tree/main/docs/support/commercial-support.md",tags:[],version:"current",frontMatter:{title:"\u5546\u4e1a\u652f\u6301"},sidebar:"tutorialSidebar",previous:{title:"\u793e\u533a\u652f\u6301",permalink:"/sqle-docs/docs/support/community-support"},next:{title:"\u5feb\u901f\u5f00\u59cb",permalink:"/sqle-docs/docs/quick-usage"}},i={},s=[],l={toc:s};function u(e){let{components:t,...c}=e;return(0,o.kt)("wrapper",(0,n.Z)({},l,c,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"\u5546\u4e1a\u652f\u6301"},"\u5546\u4e1a\u652f\u6301"),(0,o.kt)("p",null,"\u5982\u679c\u60f3\u83b7\u5f97 SQLE \u7684\u5546\u4e1a\u652f\u6301, \u60a8\u53ef\u4ee5\u626b\u63cf\u4e0b\u65b9\u7684\u5fae\u4fe1\u626b\u63cf\u5c0f\u7a0b\u5e8f\u7801\uff0c\u8fdb\u884c\u5728\u7ebf\u54a8\u8be2\u9884\u7ea6\uff1a"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"commercial-support",src:r(5198).Z,width:"430",height:"430"})),(0,o.kt)("p",null,"\u6b64\u5916\uff0c\u60a8\u4e5f\u53ef\u4ee5\u76f4\u63a5\u8054\u7cfb\u6211\u4eec\u7684\u5546\u4e1a\u652f\u6301\u56e2\u961f\u83b7\u53d6\u66f4\u591a\u4fe1\u606f\uff0c\u8054\u7cfb\u65b9\u5f0f\u5982\u4e0b\uff1a"),(0,o.kt)("p",null,"400-820-6580 / 13916131869 / 18930110869"))}u.isMDXComponent=!0},5198:(e,t,r)=>{r.d(t,{Z:()=>n});const n=r.p+"assets/images/commercial-support-2c611b3527dfbaf5fc109185d28f38ac.jpeg"}}]); \ No newline at end of file diff --git a/assets/js/runtime~main.6707881b.js b/assets/js/runtime~main.4848967e.js similarity index 76% rename from assets/js/runtime~main.6707881b.js rename to assets/js/runtime~main.4848967e.js index 8a70d323..c8dfd35a 100644 --- a/assets/js/runtime~main.6707881b.js +++ b/assets/js/runtime~main.4848967e.js @@ -1 +1 @@ -(()=>{"use strict";var e,c,a,d,f,b={},t={};function r(e){var c=t[e];if(void 0!==c)return c.exports;var a=t[e]={id:e,loaded:!1,exports:{}};return b[e].call(a.exports,a,a.exports,r),a.loaded=!0,a.exports}r.m=b,r.c=t,e=[],r.O=(c,a,d,f)=>{if(!a){var b=1/0;for(i=0;i=f)&&Object.keys(r.O).every((e=>r.O[e](a[o])))?a.splice(o--,1):(t=!1,f0&&e[i-1][2]>f;i--)e[i]=e[i-1];e[i]=[a,d,f]},r.n=e=>{var c=e&&e.__esModule?()=>e.default:()=>e;return r.d(c,{a:c}),c},a=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,r.t=function(e,d){if(1&d&&(e=this(e)),8&d)return e;if("object"==typeof e&&e){if(4&d&&e.__esModule)return e;if(16&d&&"function"==typeof e.then)return e}var f=Object.create(null);r.r(f);var b={};c=c||[null,a({}),a([]),a(a)];for(var t=2&d&&e;"object"==typeof t&&!~c.indexOf(t);t=a(t))Object.getOwnPropertyNames(t).forEach((c=>b[c]=()=>e[c]));return b.default=()=>e,r.d(f,b),f},r.d=(e,c)=>{for(var a in c)r.o(c,a)&&!r.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:c[a]})},r.f={},r.e=e=>Promise.all(Object.keys(r.f).reduce(((c,a)=>(r.f[a](e,c),c)),[])),r.u=e=>"assets/js/"+({53:"935f2afb",125:"7f1bbce8",150:"75c63229",203:"01d09168",238:"ba4b70c6",258:"39a60e89",269:"a1c7e5e9",287:"d8c191fb",374:"e36cd5bd",411:"cbc434de",555:"642bfdc0",570:"2325fbab",611:"72e02e69",634:"ef0f38b4",639:"bec63ed4",685:"2bd126e0",791:"e664c7ae",805:"fda8954d",806:"09f34579",1003:"19e0803c",1005:"249f7d1b",1190:"b9ae17d7",1391:"02c90ec4",1530:"f02fac34",1566:"0280f80a",1693:"33ad9be9",1867:"dd6b5b85",2026:"3b566c5e",2082:"86820dd7",2234:"e6bffb5f",2395:"fbc01eff",2443:"524f0400",2564:"1505bef6",2595:"b1c5bb80",2608:"3d86b39a",2685:"9d5f5645",2781:"114c1ff0",2805:"4bc52cc2",2829:"3e324e54",2851:"91ed4a47",3022:"2d8e184c",3043:"a9fc8a51",3085:"1f391b9e",3237:"1df93b7f",3277:"8310fe8a",3296:"a71e30d2",3506:"6017ddd6",3528:"2e058920",3574:"40e013e2",3707:"cac012ec",3745:"5f5f0e81",3873:"e27cd41e",3979:"996e247a",4023:"b665e48e",4090:"2f44db8a",4122:"69aad86d",4187:"7570e0f0",4321:"f3a25e2d",4405:"183c7aa1",4462:"5b2d17d4",4663:"9d69580c",4664:"dfc44cf0",4701:"f2e73173",4748:"adc46ca9",4753:"e6a5c99d",4806:"cb7518d4",5098:"caf71071",5105:"05d7652c",5131:"75dae98d",5194:"ded4d786",5336:"3a09a690",5421:"346700ec",5426:"c50f615e",5427:"1c5076b2",5606:"288bea33",5635:"6f205e26",5795:"cd76f017",5811:"7cb84b9a",5883:"cdbed8c2",5962:"47c91765",5989:"82d13ca9",6015:"7f697b4f",6023:"fb3f0baf",6076:"e2f22478",6140:"c076d76c",6143:"9f9041d4",6515:"6508b26c",6540:"a8e97085",6630:"a2548957",6660:"dec7d928",6785:"ec7ec2c8",6799:"d241ea8a",6918:"6044f636",6963:"7d79a1d2",7033:"e831274c",7039:"a122856d",7225:"00b1e56a",7264:"2f54af3f",7281:"7eb65a46",7407:"b0c5a65d",7414:"393be207",7571:"f842788a",7622:"b47ecf00",7843:"597ed821",7918:"17896441",7920:"1a4e3797",7927:"264f5faa",7945:"dc1cb979",8102:"20b46364",8119:"81e444cd",8121:"846accde",8142:"646478a3",8157:"28125733",8271:"52660e4f",8294:"79c4cf48",8407:"77a4f982",8420:"5f86214a",8508:"a26b9836",8528:"5836c0c9",8538:"7dcde5ea",8599:"4179ad40",8686:"1bbd07b0",8690:"1185ed00",8703:"4f79a043",8756:"a8bb5334",8862:"fc4b6217",8924:"788e20e1",8952:"b47fb6cd",9031:"0ecef8a4",9093:"3628edc3",9145:"6757540d",9149:"d0ae6baa",9298:"d544b3ed",9346:"1c0d99bd",9514:"1be78505",9567:"a403ac1f",9671:"0e384e19",9687:"8fb2801c",9751:"9ff17efe",9956:"24a44ceb",9975:"d1255c8f",9988:"dc6ee667"}[e]||e)+"."+{53:"6db62b48",125:"7bc92f7b",150:"2e48f9c2",203:"53bec4c2",238:"23c85b61",258:"1fd338b4",269:"7d2436e8",272:"0c8139c9",287:"5e3f9a83",374:"2cac8adf",411:"1a067d05",555:"6b931bab",570:"df03055c",611:"b69c55c2",634:"5e95eb97",639:"5831f1bb",685:"5d1bc745",791:"917316aa",805:"9b8e8e23",806:"69597161",1003:"a518ec91",1005:"821d2db0",1190:"4e6c8518",1391:"d9c6df55",1426:"e633d866",1530:"7617e241",1566:"d62c5863",1693:"5138d849",1867:"cd6f2270",2026:"82056781",2082:"50d48211",2234:"f0f9d3bd",2395:"071e4c5a",2443:"248d5b57",2564:"a1d33a68",2595:"44884795",2608:"47bd9c28",2685:"381900ed",2781:"7418ae2d",2805:"66d186bf",2829:"9154dbf7",2851:"2096d5d0",3022:"a416db0f",3043:"758edc12",3085:"61ef836c",3237:"19e5ecaf",3277:"db27f138",3296:"a16fc120",3506:"614e05a4",3528:"827d28ab",3574:"aeaf8db3",3707:"69a2467e",3745:"c134d7d8",3873:"f9910208",3979:"0b41cc67",4023:"a6d25452",4090:"9a60307c",4122:"efe87db8",4187:"d79ef4f7",4321:"70b5ab93",4405:"5212f9f3",4462:"4a72f3bd",4663:"323fdbe6",4664:"05cab70c",4701:"24d60c94",4748:"d17d264f",4753:"f68ae029",4806:"92a18fce",4972:"cb5faa2f",5098:"c644b414",5105:"7b50af05",5131:"7bfd6e72",5194:"88fc3908",5336:"3b989522",5421:"679df7ac",5426:"c0892485",5427:"de7e03a6",5606:"1eaf0601",5635:"e84472d3",5795:"c5cd2d5a",5811:"ebc49c80",5883:"3a2160c3",5962:"bbc1d47d",5989:"8c08b580",6015:"61b99e31",6023:"477e3706",6076:"942712ab",6140:"27ec13b6",6143:"58b80cc6",6515:"a006b132",6540:"1b547c27",6630:"9b72d91b",6660:"9365247c",6785:"28a223b6",6799:"ec3bb833",6918:"e6dec94c",6945:"726379f6",6963:"603d9dad",7033:"1c79eb9e",7039:"18122d90",7225:"34511f5f",7264:"99045ee8",7281:"5bc5a1e5",7407:"726b5048",7414:"870f066f",7571:"5cb6fa06",7622:"ed5735e7",7843:"432f44a3",7918:"94ca8eeb",7920:"75ed752d",7927:"0001ad51",7945:"dfafcc47",8102:"e541efe2",8119:"feb0c687",8121:"1800bdbd",8142:"1df13702",8157:"94d2dbd7",8271:"9a20f507",8294:"620e3e1a",8407:"93d3652b",8420:"7eb358a5",8508:"e887799c",8528:"e53f79bf",8538:"bbd0b0aa",8599:"e2c2a153",8686:"67308561",8690:"7b344a86",8703:"176e8f23",8756:"ef93c7d9",8862:"a59ee3cb",8894:"a085d5f5",8924:"1a236ba1",8952:"d14e5e68",9031:"7773d7da",9093:"02837956",9145:"dc45f0f8",9149:"366483e8",9298:"7c3c1fbb",9346:"5ea82aa8",9514:"b9852c96",9567:"87c18998",9671:"8f83e3a6",9687:"fd8667d5",9751:"81906a7f",9956:"5e4950c1",9975:"563e50cf",9988:"a791fea8"}[e]+".js",r.miniCssF=e=>{},r.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),r.o=(e,c)=>Object.prototype.hasOwnProperty.call(e,c),d={},f="sqle-docs:",r.l=(e,c,a,b)=>{if(d[e])d[e].push(c);else{var t,o;if(void 0!==a)for(var n=document.getElementsByTagName("script"),i=0;i{t.onerror=t.onload=null,clearTimeout(s);var f=d[e];if(delete d[e],t.parentNode&&t.parentNode.removeChild(t),f&&f.forEach((e=>e(a))),c)return c(a)},s=setTimeout(u.bind(null,void 0,{type:"timeout",target:t}),12e4);t.onerror=u.bind(null,t.onerror),t.onload=u.bind(null,t.onload),o&&document.head.appendChild(t)}},r.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.p="/sqle-docs/",r.gca=function(e){return e={17896441:"7918",28125733:"8157","935f2afb":"53","7f1bbce8":"125","75c63229":"150","01d09168":"203",ba4b70c6:"238","39a60e89":"258",a1c7e5e9:"269",d8c191fb:"287",e36cd5bd:"374",cbc434de:"411","642bfdc0":"555","2325fbab":"570","72e02e69":"611",ef0f38b4:"634",bec63ed4:"639","2bd126e0":"685",e664c7ae:"791",fda8954d:"805","09f34579":"806","19e0803c":"1003","249f7d1b":"1005",b9ae17d7:"1190","02c90ec4":"1391",f02fac34:"1530","0280f80a":"1566","33ad9be9":"1693",dd6b5b85:"1867","3b566c5e":"2026","86820dd7":"2082",e6bffb5f:"2234",fbc01eff:"2395","524f0400":"2443","1505bef6":"2564",b1c5bb80:"2595","3d86b39a":"2608","9d5f5645":"2685","114c1ff0":"2781","4bc52cc2":"2805","3e324e54":"2829","91ed4a47":"2851","2d8e184c":"3022",a9fc8a51:"3043","1f391b9e":"3085","1df93b7f":"3237","8310fe8a":"3277",a71e30d2:"3296","6017ddd6":"3506","2e058920":"3528","40e013e2":"3574",cac012ec:"3707","5f5f0e81":"3745",e27cd41e:"3873","996e247a":"3979",b665e48e:"4023","2f44db8a":"4090","69aad86d":"4122","7570e0f0":"4187",f3a25e2d:"4321","183c7aa1":"4405","5b2d17d4":"4462","9d69580c":"4663",dfc44cf0:"4664",f2e73173:"4701",adc46ca9:"4748",e6a5c99d:"4753",cb7518d4:"4806",caf71071:"5098","05d7652c":"5105","75dae98d":"5131",ded4d786:"5194","3a09a690":"5336","346700ec":"5421",c50f615e:"5426","1c5076b2":"5427","288bea33":"5606","6f205e26":"5635",cd76f017:"5795","7cb84b9a":"5811",cdbed8c2:"5883","47c91765":"5962","82d13ca9":"5989","7f697b4f":"6015",fb3f0baf:"6023",e2f22478:"6076",c076d76c:"6140","9f9041d4":"6143","6508b26c":"6515",a8e97085:"6540",a2548957:"6630",dec7d928:"6660",ec7ec2c8:"6785",d241ea8a:"6799","6044f636":"6918","7d79a1d2":"6963",e831274c:"7033",a122856d:"7039","00b1e56a":"7225","2f54af3f":"7264","7eb65a46":"7281",b0c5a65d:"7407","393be207":"7414",f842788a:"7571",b47ecf00:"7622","597ed821":"7843","1a4e3797":"7920","264f5faa":"7927",dc1cb979:"7945","20b46364":"8102","81e444cd":"8119","846accde":"8121","646478a3":"8142","52660e4f":"8271","79c4cf48":"8294","77a4f982":"8407","5f86214a":"8420",a26b9836:"8508","5836c0c9":"8528","7dcde5ea":"8538","4179ad40":"8599","1bbd07b0":"8686","1185ed00":"8690","4f79a043":"8703",a8bb5334:"8756",fc4b6217:"8862","788e20e1":"8924",b47fb6cd:"8952","0ecef8a4":"9031","3628edc3":"9093","6757540d":"9145",d0ae6baa:"9149",d544b3ed:"9298","1c0d99bd":"9346","1be78505":"9514",a403ac1f:"9567","0e384e19":"9671","8fb2801c":"9687","9ff17efe":"9751","24a44ceb":"9956",d1255c8f:"9975",dc6ee667:"9988"}[e]||e,r.p+r.u(e)},(()=>{var e={1303:0,532:0};r.f.j=(c,a)=>{var d=r.o(e,c)?e[c]:void 0;if(0!==d)if(d)a.push(d[2]);else if(/^(1303|532)$/.test(c))e[c]=0;else{var f=new Promise(((a,f)=>d=e[c]=[a,f]));a.push(d[2]=f);var b=r.p+r.u(c),t=new Error;r.l(b,(a=>{if(r.o(e,c)&&(0!==(d=e[c])&&(e[c]=void 0),d)){var f=a&&("load"===a.type?"missing":a.type),b=a&&a.target&&a.target.src;t.message="Loading chunk "+c+" failed.\n("+f+": "+b+")",t.name="ChunkLoadError",t.type=f,t.request=b,d[1](t)}}),"chunk-"+c,c)}},r.O.j=c=>0===e[c];var c=(c,a)=>{var d,f,b=a[0],t=a[1],o=a[2],n=0;if(b.some((c=>0!==e[c]))){for(d in t)r.o(t,d)&&(r.m[d]=t[d]);if(o)var i=o(r)}for(c&&c(a);n{"use strict";var e,c,d,a,f,b={},t={};function r(e){var c=t[e];if(void 0!==c)return c.exports;var d=t[e]={id:e,loaded:!1,exports:{}};return b[e].call(d.exports,d,d.exports,r),d.loaded=!0,d.exports}r.m=b,r.c=t,e=[],r.O=(c,d,a,f)=>{if(!d){var b=1/0;for(i=0;i=f)&&Object.keys(r.O).every((e=>r.O[e](d[o])))?d.splice(o--,1):(t=!1,f0&&e[i-1][2]>f;i--)e[i]=e[i-1];e[i]=[d,a,f]},r.n=e=>{var c=e&&e.__esModule?()=>e.default:()=>e;return r.d(c,{a:c}),c},d=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,r.t=function(e,a){if(1&a&&(e=this(e)),8&a)return e;if("object"==typeof e&&e){if(4&a&&e.__esModule)return e;if(16&a&&"function"==typeof e.then)return e}var f=Object.create(null);r.r(f);var b={};c=c||[null,d({}),d([]),d(d)];for(var t=2&a&&e;"object"==typeof t&&!~c.indexOf(t);t=d(t))Object.getOwnPropertyNames(t).forEach((c=>b[c]=()=>e[c]));return b.default=()=>e,r.d(f,b),f},r.d=(e,c)=>{for(var d in c)r.o(c,d)&&!r.o(e,d)&&Object.defineProperty(e,d,{enumerable:!0,get:c[d]})},r.f={},r.e=e=>Promise.all(Object.keys(r.f).reduce(((c,d)=>(r.f[d](e,c),c)),[])),r.u=e=>"assets/js/"+({53:"935f2afb",125:"7f1bbce8",150:"75c63229",203:"01d09168",238:"ba4b70c6",258:"39a60e89",269:"a1c7e5e9",287:"d8c191fb",374:"e36cd5bd",411:"cbc434de",555:"642bfdc0",570:"2325fbab",611:"72e02e69",634:"ef0f38b4",639:"bec63ed4",685:"2bd126e0",791:"e664c7ae",805:"fda8954d",806:"09f34579",1003:"19e0803c",1005:"249f7d1b",1190:"b9ae17d7",1391:"02c90ec4",1530:"f02fac34",1566:"0280f80a",1693:"33ad9be9",1867:"dd6b5b85",2026:"3b566c5e",2082:"86820dd7",2234:"e6bffb5f",2395:"fbc01eff",2443:"524f0400",2564:"1505bef6",2595:"b1c5bb80",2608:"3d86b39a",2685:"9d5f5645",2781:"114c1ff0",2805:"4bc52cc2",2829:"3e324e54",2851:"91ed4a47",3022:"2d8e184c",3043:"a9fc8a51",3085:"1f391b9e",3237:"1df93b7f",3277:"8310fe8a",3296:"a71e30d2",3506:"6017ddd6",3528:"2e058920",3574:"40e013e2",3707:"cac012ec",3745:"5f5f0e81",3873:"e27cd41e",3979:"996e247a",4023:"b665e48e",4090:"2f44db8a",4122:"69aad86d",4187:"7570e0f0",4321:"f3a25e2d",4405:"183c7aa1",4462:"5b2d17d4",4663:"9d69580c",4664:"dfc44cf0",4701:"f2e73173",4748:"adc46ca9",4753:"e6a5c99d",4806:"cb7518d4",5098:"caf71071",5105:"05d7652c",5131:"75dae98d",5194:"ded4d786",5336:"3a09a690",5421:"346700ec",5426:"c50f615e",5427:"1c5076b2",5606:"288bea33",5635:"6f205e26",5795:"cd76f017",5811:"7cb84b9a",5883:"cdbed8c2",5962:"47c91765",5989:"82d13ca9",6015:"7f697b4f",6023:"fb3f0baf",6076:"e2f22478",6140:"c076d76c",6143:"9f9041d4",6515:"6508b26c",6540:"a8e97085",6630:"a2548957",6660:"dec7d928",6785:"ec7ec2c8",6799:"d241ea8a",6918:"6044f636",6963:"7d79a1d2",7033:"e831274c",7039:"a122856d",7225:"00b1e56a",7264:"2f54af3f",7281:"7eb65a46",7407:"b0c5a65d",7414:"393be207",7571:"f842788a",7622:"b47ecf00",7843:"597ed821",7918:"17896441",7920:"1a4e3797",7927:"264f5faa",7945:"dc1cb979",8102:"20b46364",8119:"81e444cd",8121:"846accde",8142:"646478a3",8157:"28125733",8271:"52660e4f",8294:"79c4cf48",8407:"77a4f982",8420:"5f86214a",8508:"a26b9836",8528:"5836c0c9",8538:"7dcde5ea",8599:"4179ad40",8686:"1bbd07b0",8690:"1185ed00",8703:"4f79a043",8756:"a8bb5334",8862:"fc4b6217",8924:"788e20e1",8952:"b47fb6cd",9031:"0ecef8a4",9093:"3628edc3",9145:"6757540d",9149:"d0ae6baa",9298:"d544b3ed",9346:"1c0d99bd",9514:"1be78505",9567:"a403ac1f",9671:"0e384e19",9687:"8fb2801c",9751:"9ff17efe",9956:"24a44ceb",9975:"d1255c8f",9988:"dc6ee667"}[e]||e)+"."+{53:"3fb9cbef",125:"7bc92f7b",150:"2e48f9c2",203:"53bec4c2",238:"23c85b61",258:"1fd338b4",269:"dd649570",272:"0c8139c9",287:"5e3f9a83",374:"2cac8adf",411:"1a067d05",555:"6b931bab",570:"df03055c",611:"b69c55c2",634:"5e95eb97",639:"5831f1bb",685:"5d1bc745",791:"917316aa",805:"9b8e8e23",806:"69597161",1003:"a518ec91",1005:"821d2db0",1190:"4e6c8518",1391:"d9c6df55",1426:"e633d866",1530:"7617e241",1566:"d62c5863",1693:"5138d849",1867:"cd6f2270",2026:"82056781",2082:"50d48211",2234:"f0f9d3bd",2395:"071e4c5a",2443:"248d5b57",2564:"a1d33a68",2595:"44884795",2608:"47bd9c28",2685:"381900ed",2781:"7418ae2d",2805:"66d186bf",2829:"9154dbf7",2851:"2096d5d0",3022:"a416db0f",3043:"758edc12",3085:"61ef836c",3237:"19e5ecaf",3277:"db27f138",3296:"a16fc120",3506:"614e05a4",3528:"827d28ab",3574:"aeaf8db3",3707:"69a2467e",3745:"c134d7d8",3873:"f9910208",3979:"0b41cc67",4023:"a6d25452",4090:"9a60307c",4122:"efe87db8",4187:"d79ef4f7",4321:"70b5ab93",4405:"5212f9f3",4462:"4a72f3bd",4663:"323fdbe6",4664:"05cab70c",4701:"24d60c94",4748:"d17d264f",4753:"f68ae029",4806:"92a18fce",4972:"cb5faa2f",5098:"c644b414",5105:"7b50af05",5131:"7bfd6e72",5194:"88fc3908",5336:"3b989522",5421:"679df7ac",5426:"c0892485",5427:"de7e03a6",5606:"1eaf0601",5635:"e84472d3",5795:"c5cd2d5a",5811:"ebc49c80",5883:"3a2160c3",5962:"bbc1d47d",5989:"8c08b580",6015:"61b99e31",6023:"477e3706",6076:"942712ab",6140:"27ec13b6",6143:"58b80cc6",6515:"a006b132",6540:"1b547c27",6630:"9b72d91b",6660:"9365247c",6785:"28a223b6",6799:"ec3bb833",6918:"e6dec94c",6945:"726379f6",6963:"603d9dad",7033:"1c79eb9e",7039:"18122d90",7225:"34511f5f",7264:"99045ee8",7281:"5bc5a1e5",7407:"726b5048",7414:"870f066f",7571:"5cb6fa06",7622:"ed5735e7",7843:"432f44a3",7918:"94ca8eeb",7920:"75ed752d",7927:"0001ad51",7945:"dfafcc47",8102:"e541efe2",8119:"feb0c687",8121:"1800bdbd",8142:"1df13702",8157:"94d2dbd7",8271:"9a20f507",8294:"620e3e1a",8407:"93d3652b",8420:"7eb358a5",8508:"e887799c",8528:"e53f79bf",8538:"bbd0b0aa",8599:"e2c2a153",8686:"67308561",8690:"7b344a86",8703:"176e8f23",8756:"ef93c7d9",8862:"a59ee3cb",8894:"a085d5f5",8924:"1a236ba1",8952:"d14e5e68",9031:"7773d7da",9093:"02837956",9145:"dc45f0f8",9149:"366483e8",9298:"7c3c1fbb",9346:"5ea82aa8",9514:"b9852c96",9567:"87c18998",9671:"8f83e3a6",9687:"fd8667d5",9751:"81906a7f",9956:"5e4950c1",9975:"563e50cf",9988:"a791fea8"}[e]+".js",r.miniCssF=e=>{},r.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),r.o=(e,c)=>Object.prototype.hasOwnProperty.call(e,c),a={},f="sqle-docs:",r.l=(e,c,d,b)=>{if(a[e])a[e].push(c);else{var t,o;if(void 0!==d)for(var n=document.getElementsByTagName("script"),i=0;i{t.onerror=t.onload=null,clearTimeout(s);var f=a[e];if(delete a[e],t.parentNode&&t.parentNode.removeChild(t),f&&f.forEach((e=>e(d))),c)return c(d)},s=setTimeout(u.bind(null,void 0,{type:"timeout",target:t}),12e4);t.onerror=u.bind(null,t.onerror),t.onload=u.bind(null,t.onload),o&&document.head.appendChild(t)}},r.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.p="/sqle-docs/",r.gca=function(e){return e={17896441:"7918",28125733:"8157","935f2afb":"53","7f1bbce8":"125","75c63229":"150","01d09168":"203",ba4b70c6:"238","39a60e89":"258",a1c7e5e9:"269",d8c191fb:"287",e36cd5bd:"374",cbc434de:"411","642bfdc0":"555","2325fbab":"570","72e02e69":"611",ef0f38b4:"634",bec63ed4:"639","2bd126e0":"685",e664c7ae:"791",fda8954d:"805","09f34579":"806","19e0803c":"1003","249f7d1b":"1005",b9ae17d7:"1190","02c90ec4":"1391",f02fac34:"1530","0280f80a":"1566","33ad9be9":"1693",dd6b5b85:"1867","3b566c5e":"2026","86820dd7":"2082",e6bffb5f:"2234",fbc01eff:"2395","524f0400":"2443","1505bef6":"2564",b1c5bb80:"2595","3d86b39a":"2608","9d5f5645":"2685","114c1ff0":"2781","4bc52cc2":"2805","3e324e54":"2829","91ed4a47":"2851","2d8e184c":"3022",a9fc8a51:"3043","1f391b9e":"3085","1df93b7f":"3237","8310fe8a":"3277",a71e30d2:"3296","6017ddd6":"3506","2e058920":"3528","40e013e2":"3574",cac012ec:"3707","5f5f0e81":"3745",e27cd41e:"3873","996e247a":"3979",b665e48e:"4023","2f44db8a":"4090","69aad86d":"4122","7570e0f0":"4187",f3a25e2d:"4321","183c7aa1":"4405","5b2d17d4":"4462","9d69580c":"4663",dfc44cf0:"4664",f2e73173:"4701",adc46ca9:"4748",e6a5c99d:"4753",cb7518d4:"4806",caf71071:"5098","05d7652c":"5105","75dae98d":"5131",ded4d786:"5194","3a09a690":"5336","346700ec":"5421",c50f615e:"5426","1c5076b2":"5427","288bea33":"5606","6f205e26":"5635",cd76f017:"5795","7cb84b9a":"5811",cdbed8c2:"5883","47c91765":"5962","82d13ca9":"5989","7f697b4f":"6015",fb3f0baf:"6023",e2f22478:"6076",c076d76c:"6140","9f9041d4":"6143","6508b26c":"6515",a8e97085:"6540",a2548957:"6630",dec7d928:"6660",ec7ec2c8:"6785",d241ea8a:"6799","6044f636":"6918","7d79a1d2":"6963",e831274c:"7033",a122856d:"7039","00b1e56a":"7225","2f54af3f":"7264","7eb65a46":"7281",b0c5a65d:"7407","393be207":"7414",f842788a:"7571",b47ecf00:"7622","597ed821":"7843","1a4e3797":"7920","264f5faa":"7927",dc1cb979:"7945","20b46364":"8102","81e444cd":"8119","846accde":"8121","646478a3":"8142","52660e4f":"8271","79c4cf48":"8294","77a4f982":"8407","5f86214a":"8420",a26b9836:"8508","5836c0c9":"8528","7dcde5ea":"8538","4179ad40":"8599","1bbd07b0":"8686","1185ed00":"8690","4f79a043":"8703",a8bb5334:"8756",fc4b6217:"8862","788e20e1":"8924",b47fb6cd:"8952","0ecef8a4":"9031","3628edc3":"9093","6757540d":"9145",d0ae6baa:"9149",d544b3ed:"9298","1c0d99bd":"9346","1be78505":"9514",a403ac1f:"9567","0e384e19":"9671","8fb2801c":"9687","9ff17efe":"9751","24a44ceb":"9956",d1255c8f:"9975",dc6ee667:"9988"}[e]||e,r.p+r.u(e)},(()=>{var e={1303:0,532:0};r.f.j=(c,d)=>{var a=r.o(e,c)?e[c]:void 0;if(0!==a)if(a)d.push(a[2]);else if(/^(1303|532)$/.test(c))e[c]=0;else{var f=new Promise(((d,f)=>a=e[c]=[d,f]));d.push(a[2]=f);var b=r.p+r.u(c),t=new Error;r.l(b,(d=>{if(r.o(e,c)&&(0!==(a=e[c])&&(e[c]=void 0),a)){var f=d&&("load"===d.type?"missing":d.type),b=d&&d.target&&d.target.src;t.message="Loading chunk "+c+" failed.\n("+f+": "+b+")",t.name="ChunkLoadError",t.type=f,t.request=b,a[1](t)}}),"chunk-"+c,c)}},r.O.j=c=>0===e[c];var c=(c,d)=>{var a,f,b=d[0],t=d[1],o=d[2],n=0;if(b.some((c=>0!==e[c]))){for(a in t)r.o(t,a)&&(r.m[a]=t[a]);if(o)var i=o(r)}for(c&&c(d);n FAQ | SQLE 文档 - + - + \ No newline at end of file diff --git a/docs/FAQ/whichdatabase/index.html b/docs/FAQ/whichdatabase/index.html index d96443b8..e9cc9f12 100644 --- a/docs/FAQ/whichdatabase/index.html +++ b/docs/FAQ/whichdatabase/index.html @@ -4,13 +4,13 @@ 支持哪些数据库 | SQLE 文档 - +
版本:v3

支持的数据库及版本

数据库类型验证可用的版本
MySQL5.7.25 、8.0.33
PostgreSQL9.3 – 13
Oracle11.2、12.1、12.2
SQL server2008、2012、2016
DB211.5
TiDB4.0.8
OceanBase For MySQL3.5
达梦V8
提示

当前版本为SQLE验证确认可用的版本,若需要使用其他版本,需自行验证

- + \ No newline at end of file diff --git a/docs/SUMMARY/index.html b/docs/SUMMARY/index.html index 3718234c..aaff3603 100644 --- a/docs/SUMMARY/index.html +++ b/docs/SUMMARY/index.html @@ -4,13 +4,13 @@ Summary | SQLE 文档 - + - + \ No newline at end of file diff --git a/docs/deploy-manual/Docker/index.html b/docs/deploy-manual/Docker/index.html index 8b05bb9d..99709015 100644 --- a/docs/deploy-manual/Docker/index.html +++ b/docs/deploy-manual/Docker/index.html @@ -4,13 +4,13 @@ Docker部署 | SQLE 文档 - +
版本:v3

Docker部署

Docker hub 地址

actiontech/sqle-ce

Docker 参考命令

docker run -d -it \
--name sqle-server \
-p 10000:10000 \
-p 10001:10001 \
-e MYSQL_HOST="10.10.10.10" \
-e MYSQL_PORT=3306 \
-e MYSQL_USER="root" \
-e MYSQL_PASSWORD="123456" \
-e MYSQL_DMS_SCHEMA="dms" \
-e MYSQL_SQLE_SCHEMA="sqle" \
actiontech/sqle-ce:latest

参数说明

使用环境变量传递参数,这些指定的配置会映射到 /opt/sqle/etc/config.yaml 配置内,指定数据库的配置等。

变量说明
MYSQL_HOST访问地址
MYSQL_PORT访问端口
MYSQL_USER数据库用户
MYSQL_PASSWORD数据库密码
MYSQL_DMS_SCHEMASQLE 服务使用的指定的 schema
MYSQL_SQLE_SCHEMADMS服务使用的指定的 schema
DEBUG是否输出 debug 日志,默认为false
AUTO_MIGRATE_TABLE是否自动创建表格和初始化数据,默认为true

注意点

提示

使用 docker 命令运行容器需要提前准备 MySQL 服务并且创建对应的数据库 schema,创建数据库的SQL可参考:RPM 部署

提示

如果 SQLE 容器启动失败可以使用docker logs sqle-server查看启用日志,其中sqle-server是容器名称。

- + \ No newline at end of file diff --git a/docs/deploy-manual/DockerCompose/index.html b/docs/deploy-manual/DockerCompose/index.html index 8ab141b0..7d25a5be 100644 --- a/docs/deploy-manual/DockerCompose/index.html +++ b/docs/deploy-manual/DockerCompose/index.html @@ -4,13 +4,13 @@ Docker Compose 部署 | SQLE 文档 - +
版本:v3

Docker Compose 部署

配置文件

下载地址:docker-compose.yaml

下载地址:init

使用方法

将 docker-compose.yaml 文件和init 文件夹下载到本地目录,并进入目录内,通过环境变量SQLE_IMAGE指定不同版本的 SQLE 镜像,默认是 latest

SQLE_IMAGE=actiontech/sqle-ce:latest docker-compose up -d
- + \ No newline at end of file diff --git a/docs/deploy-manual/config/index.html b/docs/deploy-manual/config/index.html index c624c1b4..d8062f1e 100644 --- a/docs/deploy-manual/config/index.html +++ b/docs/deploy-manual/config/index.html @@ -4,13 +4,13 @@ 配置文件说明 | SQLE 文档 - +
版本:v3

配置文件说明

提示

SQLE的配置文件采用yml的格式,默认情况下位于SQLE安装目录下,路径为./etc/config.yml

默认文件参考

dms:
id: 1
api:
addr: "0.0.0.0"
port: 10000
enable_https: false
cert_file_path: './etc/cert.pem'
key_file_path: './etc/key.pem'
secret_key: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
service:
database:
host: "127.0.0.1"
port: 3306
username: "root"
password: "123456"
database: "dms"
debug: true
auto_migrate: true
log:
level: DEBUG
path: logs
max_size_mb: 100
max_backup_number: 10
cloudbeaver:
enable_https: false
host: "127.0.0.1"
port: 8978
admin_user: "cbadmin"
admin_password: "123456"
database_driver_options:
- db_type: MySQL
logo_path: "/logo/mysql.png"
params:
- db_type: Postgres
logo_path: "/static/logo/pg.png"
params:
- db_type: Oracle
logo_path: "/static/logo/oracle.png"
params: [
{
"key":"service_name",
"value":"XE",
"desc":"service name",
"type":"string"
},
]
sqle:
id: 1
dms_server_address: "http://127.0.0.1:10000"
api:
addr: "127.0.0.1"
port: 10001
enable_https: false
cert_file_path: './etc/cert.pem'
key_file_path: './etc/key.pem'
secret_key: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
service:
auto_migrate_table: true
debug_log: false
log_path: './logs'
log_max_size_mb: 1024
log_max_backup_number: 2
plugin_path: './plugins'
database:
mysql_host: '127.0.0.1'
mysql_port: 3306
mysql_user: 'root'
mysql_password: '123456'
mysql_schema: 'sqle'

配置说明

通用配置

参数说明
idserver id,辨识集群节点,集群内不重复即可
api当前服务的web接口参数
secret_key全局AES加密秘钥,影响登录和用户密码等的存储;生产环境建议配置该值替换掉程序默认值,不然会存在安全风险;格式是32位随机字符串

通用配置.api

参数说明
addr访问服务器时需要的网络地址
port当前服务的web接口参数
enable_https是否开启https,默认不开启
cert_file_pathhttps 证书路径
key_file_pathhttps 私钥路径

DMS 配置

参数说明
id通用配置
api通用配置
secret_key通用配置
service服务
cloudbeaverSQL工作台

DMS.service.database

参数说明
hostDMS 后端数据库地址
portDMS 后端数据库地址
usernameDMS 后端数据库用户
passwordDMS 后端数据库密码
databaseDMS 后端数据库 schema
debug

DMS.service.log

参数说明
levelDMS日志级别
pathDMS日志存在路径
max_size_mbDMS日志文件大小
max_backup_numberDMS保留日志文件数

DMS.cloudbeaver

SQL工作台的配置,配置则代表开启SQL工作台。

参数说明
enable_https是否是https连接
hostcloudbeaver 地址
portcloudbeaver 端口
admin_usercloudbeaver 超级管理员名称
admin_passwordcloudbeaver 超级管理员密码

SQLE 配置

参数说明
id通用配置
api通用配置
secret_key通用配置
service服务

SQLE.service

参数说明
auto_migrate_table自动创建表结构,初始化数据
debug_log开启debug模式,打印更多日志,会打印业务SQL,开发环境可开启
log_path日志目录
log_max_size_mb单个日志文件最大大小,单位MB
log_max_backup_number日志文件最大备份数量
plugin_pathSQL审核插件的加载地址

SQLE.service.database

参数说明
mysql_hostSQLE存储库的地址
mysql_portSQLE存储库的端口
mysql_userSQLE存储库的数据库用户
mysql_passwordSQLE存储库的数据库密码
mysql_schemaSQLE存储库的数据库 schema

数据库插件配置请参考:如何配置数据库审核插件

- + \ No newline at end of file diff --git a/docs/deploy-manual/intro/index.html b/docs/deploy-manual/intro/index.html index 0a242e42..66871386 100644 --- a/docs/deploy-manual/intro/index.html +++ b/docs/deploy-manual/intro/index.html @@ -4,13 +4,13 @@ 安装说明 | SQLE 文档 - +
版本:v3

安装说明

SQLE 提供了多种安装部署的方式,用户可以结合自己的环境和现状选择。初次体验或者测试使用的话建议使用docker-compose 或 docker 快速部署。

安装方式

  1. 源码安装
  2. RPM 部署
  3. Docker 部署
  4. Docker Compsoe 部署

如何访问

SQLE 对外提供 web 服务,在程序部署完成后,即可通过 SQLE UI 访问:http://127.0.0.1:10000, 地址和端口为配置文件内 dms.api 配置项。

提示

ps:ip 和端口请根据前面的配置自行替换,默认端口是10000。

初始用户

  • 用户名:admin
  • 密码:admin
- + \ No newline at end of file diff --git a/docs/deploy-manual/rpm/index.html b/docs/deploy-manual/rpm/index.html index a159d928..6bdd84c7 100644 --- a/docs/deploy-manual/rpm/index.html +++ b/docs/deploy-manual/rpm/index.html @@ -4,13 +4,13 @@ RPM 安装 | SQLE 文档 - +
版本:v3

RPM安装

环境准备

  • CentOS 7
  • MySQL 5.7

下载安装包

下载 SQLE 的 RPM 安装包,下载连接点击这里

安装 SQLE

执行 RPM 的安装命令:

rpm -ivh /path/to/sqle-ce-${version}.qa.el7.x86_64.rpm --prefix=/opt/sqle

创建数据库

准备一台 MySQL5.7 作为 SQLE 的后端存储数据库。执行下面命令创建 SQLE 需要的 schema:

CREATE DATABASE IF NOT EXISTS sqle default character set utf8mb4 collate utf8mb4_unicode_ci;
CREATE DATABASE IF NOT EXISTS dms default character set utf8mb4 collate utf8mb4_unicode_ci;
提示

创建好的 Schema 将在下面修改SQLE配置时使用到。

修改 SQLE 配置文件

安装完 SQLE 后,需要根据实际情况修改SQLE的配置,参考:配置文件说明。SQLE安装完成后提供一个配置模版可直接修改。

cd /opt/sqle/etc
vim config.yml
提示

确保 config.yml 的文件 owner 为 actiontech-universe:actiontech

启动 SQLE

SQLE 进程通过 Systemd 管理。在成功安装 RPM 后,执行启动命令:

cd /opt/sqle
chmod +x scripts/init_start.sh
./scripts/init_start.sh

访问SQLE

SQLE 对外提供 web 服务,在程序部署完成后,即可通过 SQLE UI 访问:http://127.0.0.1:10000, 地址和端口为配置文件内 dms.api 配置项。

启动失败问题诊断

参考:https://github.com/actiontech/sqle/discussions/1239

- + \ No newline at end of file diff --git a/docs/deploy-manual/source/index.html b/docs/deploy-manual/source/index.html index 86ba5d86..113717bd 100644 --- a/docs/deploy-manual/source/index.html +++ b/docs/deploy-manual/source/index.html @@ -4,13 +4,13 @@ 源码安装 | SQLE 文档 - +
版本:v3

源码安装

环境准备

  • CentOS 7
  • MySQL 5.7
  • Docker
  • Docker Compose(可选)

获取源码

SQLE 前端与后端代码分两个仓库维护,所以想要通过源码安装,需要构建前后端代码。

首先选择一个源码安装的工作目录,例如 ~/sqle-build/。

获取后端源码:

cd ~/sqle-build/
git clone https://github.com/actiontech/sqle.git
cd sqle && git checkout -b release-3.2310.x

cd ~/sqle-build/
git clone https://github.com/actiontech/dms.git
cd dms && git checkout -b release-3.2310.x

获取前端源码:

cd ~/sqle-build/
git clone https://github.com/actiontech/dms-ui.git

编译源码

编译前端代码,并将前端代码拷贝至后端代码目录:

cd ~/sqle-build/dms-ui
docker run --rm -v $PWD:/app -w /app gplane/pnpm:8.3.1 sh -c "git config --global --add safe.directory /app && pnpm config set registry https://registry.npm.taobao.org && pnpm install --no-frozen-lockfile && pnpm build"
rm -rf ~/sqle-build/sqle/static && cp -r ~/sqle-build/dms-ui/packages/base/dist ~/sqle-build/sqle/static

编译后端代码并打包:

cd ~/sqle-build/dms
make docker_install
cp -r ~/sqle-build/dms/bin ~/sqle-build/sqle/bin
cd ~/sqle-build/sqle
make docker_rpm_with_dms

打包完成后会在当前目录下生成一个 SQLE 的 RPM 包,后续的步骤参考:RPM 部署

- + \ No newline at end of file diff --git a/docs/dev-manual/intro/index.html b/docs/dev-manual/intro/index.html index 6e395c50..9efe039e 100644 --- a/docs/dev-manual/intro/index.html +++ b/docs/dev-manual/intro/index.html @@ -4,13 +4,13 @@ 产品架构 | SQLE 文档 - + - + \ No newline at end of file diff --git a/docs/dev-manual/plugins/howtodev/index.html b/docs/dev-manual/plugins/howtodev/index.html index 3b35c437..22825fd1 100644 --- a/docs/dev-manual/plugins/howtodev/index.html +++ b/docs/dev-manual/plugins/howtodev/index.html @@ -4,7 +4,7 @@ 数据库审核插件开发 | SQLE 文档 - + @@ -12,7 +12,7 @@
版本:v3

数据库审核插件开发

在本篇文档中,会介绍如何开发一个数据库审核插件,分为快速开始部分和详细部分。

  • 如果你是一个对 Go 语言不太了解的人,可以先通过快速开始部分的文档,实现一个简单的数据库审核插件。
  • 当你对插件开发有了一定的了解之后,可以通过详细部分的文档,通过更多自定义的方式,实现更加复杂的数据库审核插件。

快速开始

前置

1. 语法

由于 SQLE 是一个用 Go 语言开发的开源项目,如果你对 Go 语言完全不了解,需要先了解 Go 语言的基础语法,建议使用官方的 Go 语言快速开始文档(Go Tour 或者 Go 语言之旅),如果你已经了解了 Go 语言的基础语法,可以直接跳过本部分。

2. 包管理

SQLE 插件是一个独立于 SQLE 的进程,所以编写插件的方式与开发一个新的 Go 语言项目并没有什么差异。Go 语言项目使用 Go Modules 来管理包,所以在开始之前你需要先了解一下 Go Modules 的使用方法。建议参考这篇文档,文档中大致介绍了如果开始一个新的 Go 语言项目,并通过 Go Modules 的方式来调用其他项目的包,如果你已经了解了 Go Modules 的使用方法,可以直接跳过本部分。

3. Go语言项目构建

编写插件

这一小节会假设你已经创建了一个由 Go Modules 管理的审核插件项目。下面开始介绍插件核心代码的开发。

1. 数据库插件介绍

SQLE 为了方便插件的开发,在自身的插件层之上做了一层封装(Adaptor),插件开发者可以使用这个封装库来快速的开发一个数据库审核插件。

在开发之前,你需要先引入 SQLE:

go get github.com/actiontech/sqle@v2.2305.0-pre2 # 此版本为该文档编辑时的最新版本

选择 SQLE 中两个库插件相关的库:

  • github.com/actiontech/sqle/sqle/driver
  • github.com/actiontech/sqle/sqle/pkg/driver
提示
  • 第一个库定义了插件规则的结构体,在你编写插件规则时需要用到这个库。
  • 第二个库中实现了一些默认的插件,在引入这个库后,只需要实现相应的规则与规则处理函数即可。其中三个默认的插件为:
    • PostgreSQL
    • Oracle
    • SQL Server
  • 如果这三个默认的插件不能满足需求,可以自己实现一个插件,参考本篇文档自定义插件小节。

2. 选择插件

下面假设你想要实现一个 SQL Server 的审核插件。在 main 函数中创建一个空的 SQL Server 审核插件,这时你的 main 文件应该是这样的:

package main

import (
"github.com/actiontech/sqle/sqle/driver"
adaptor "github.com/actiontech/sqle/sqle/pkg/driver"
)

func main() {
plugin := adaptor.NewAdaptor(&adaptor.MssqlDialector{})
}

3. 编写插件规则与规则处理函数

假设你需要实现一个规则,该规则检查 SQL 是否使用了 select *。定义规则如下:

Rule{
Name: "aviod_select_all_column", # 规则ID,该值会与插件类型一起作为这条规则在 SQLE 的唯一标识
Desc: "避免查询所有的列", # 规则描述
Category: "DQL规范", # 规则分类,用于分组,相同类型的规则会在 SQLE 的页面上展示在一起
Level: driver.RuleLevelError, # 规则等级,表示该规则的严重程度。在插件注册阶段,会使用所有 RuleLevelError 级别的规则创建一个默认的规则模板。
}

规则的处理函数如下:

func(ctx context.Context, rule *driver.Rule, sql string) (string, error) {
if strings.Contains(sql, "select *") {
return rule.Desc, nil
}
return "", nil
}

这里为了演示,这个处理函数只是简单的使用了字符串匹配的方式,你也可以使用正则或者 AST 语法树的方式来检查 SQL 语句(AST 的方式会在自定义SQL解析器一小节中介绍)。

最后将插件规则与规则处理函数通过 plugin.AddRule()函数注册到 SQLE 中,注册完成后,你的 main 文件应该是这样的:

package main

import (
"github.com/actiontech/sqle/sqle/driver"
adaptor "github.com/actiontech/sqle/sqle/pkg/driver"
)

func main() {
plugin := adaptor.NewAdaptor(&adaptor.MssqlDialector{})
aviodSelectAllColumn := &driver.Rule{
Name: "aviod_select_all_column",
Desc: "避免查询所有的列",
Category: "DQL规范",
Level: driver.RuleLevelError,
}
aviodSelectAllColumnHandler := func(ctx context.Context, rule *driver.Rule, sql string) (string, error) {
if strings.Contains(sql, "select *") {
return rule.Desc, nil
}
return "", nil
}
plugin.AddRule(aviodSelectAllColumn, aviodSelectAllColumnHandler)

////////////////////////////////////////////
// ... 编写更多规则并通过 AddRule 注册到 SQLE 中
////////////////////////////////////////////

// 最后关键一步,调用 `plugin.Serve()` 启动插件:
plugin.Serve()
}

4. 构建并使用插件

和通常的程序编写流程一样,编写完插件代码后,需要将其构建成二进制文件,然后才能将其注册到 SQLE 中。执行 go build -o ${二进制名} main.go 将插件代码构建成二进制文件。最后参考数据库审核插件使用 来使用你的自定义插件。

自定义部分

1.自定义SQL解析器

前面介绍的审核规则都是通过字符串匹配的方式来解析 SQL 的内容。这种方式适合规则较少且 SQL 简单的情况下使用。

如果需要对 SQL 进行更复杂的解析匹配,恰好你选择的数据库插件又有相应的 SQL 解析器,这时可以使用自定义 SQL 解析器的方式来编写插件。

首先通过调用 WithSQLParser() 注册自己的 SQL 解析器。在添加规则时则使用 plugin.AddRuleWithSQLParser() 添加带有解析器的处理函数。在处理函数中,将 interface{} 断言成具体的 AST 语法树,通过语法树级别的操作来更加精细的处理 SQL。PostgreSQL 提供了基于 cgo 调用的解析器(见:PostgreSQL SQL 解析器),下面的代码展示了如何写一个 SQL 解析器的插件:

func main() {
plugin := adaptor.NewAdaptor(&adaptor.PostgresDialector{})

// 依然是定义规则
aviodSelectAllColumn := &driver.Rule{
Name: "aviod_select_all_column",
Desc: "避免查询所有的列",
Category: "DQL规范",
Level: driver.RuleLevelError,
}

// 依然是定义处理函数,这时处理函数的参数是 interface{} 类型,需要将其断言成 AST 语法树。
aviodSelectAllColumnHandler := func(ctx context.Context, rule *driver.Rule, ast interface{}) (string, error) {
node, ok := ast.(*parser.RawStmt)
if !ok {
return "", errors.New("ast is not *parser.RawStmt")
}

switch stmt := node.GetStmt().GetNode().(type) {
case *parser.Node_SelectStmt:
for _, target := range stmt.SelectStmt.GetTargetList() {
column, ok := target.GetResTarget().GetVal().GetNode().(*parser.Node_ColumnRef)
if !ok {
continue
}
for _, filed := range column.ColumnRef.GetFields() {
_, ok = filed.GetNode().(*parser.Node_AStar)
if ok {
return rule.Desc, nil
}
}
}
}
return "", nil
}

// 依然是注册规则,与前面的例子不同的是,这时使用的是 `plugin.AddRuleWithSQLParser()` 。
plugin.AddRuleWithSQLParser(aviodSelectAllColumn, aviodSelectAllColumnHandler)

// 依然是启动插件,与前面的例子不同的是,需要将 SQL 解析的方法注册到插件中。
plugin.Serve(adaptor.WithSQLParser(func(sql string) (ast interface{}, err error) {
// parser.Parse 使用 PostgreSQL 的解析器,将 sql 解析成 AST 语法树。
result, err := parser.Parse(sql)
if err != nil {
return nil, errors.Wrap(err, "parse sql error")
}
if len(result.Stmts) != 1 {
return nil, fmt.Errorf("unexpected statement count: %d", len(result.Stmts))
}

// 将 SQL 的语法树返回。
return result.Stmts[0], nil
}))
}

2.自定义插件

如果 driver 包中默认的 PostgreSQL、Oracle 与 SQL Server 插件不能满足你的需求的话,你也可以自定义一个数据库插件。方法就是实现一个接口:

type Dialector interface {
Dialect(dsn *driver.DSN) (driverName string, dsnDetail string)
ShowDatabaseSQL() string
String() string
}

在实现这个接口前,你需要先了解一下 Go 语言原生 Driver 的概念(以 MySQL Driver 为例)。

下面介绍 Dialector 接口的含义:

  • Dialect:实现该方法,通过 DSN 提供的 Host Port User Password Database 信息和你选择的数据库 driver,构造出 driverName 与 dsnDetail。driverName 是你引入的数据库 driver 名称;dsnDetail 是连接数据库驱动的必要信息。这两个参数最终会通过 sql.Open() 来创建一个数据库连接。
  • ShowDatabaseSQL:实现该方法,可以自定义你数据源中默认展示的数据库列表,该数据库列表最终会展示在工单审核列表的数据库下拉框中,如下图: pluginworkflow
  • String:实现该方法,该方法的返回值会作为你实现的数据库审核插件名展示在 SQLE 的相关下拉框中,如下图: plugintype

将你的实现作为 NewAdaptor 的参数传入即可,后续的步骤与前面规则相关的介绍一致。

详细

SQLE与插件的交互图

sqleplugin

插件接口说明

1.注册接口说明

该接口定义了该插件的名称和实现的规则,SQLE启动的时候会调用该接口获取插件名称和该插件支持的规则列表。

type Registerer interface {
Name() string
Rules() []*model.Rule
}
  • Name: 插件名,最终会展示在 SQLE 页面的数据源类型的下拉框中;
  • Rules: 插件支持的规则,在启动 SQLE 时,会调用插件获取这些规则,你将在规则模板内看到它们。

2.审核接口说明

该接口定义了SQLE进行审核时,由插件完成的和具体数据库底层交互的操作

type Driver interface {
Close(ctx context.Context)
Ping(ctx context.Context) error
Exec(ctx context.Context, query string) (driver.Result, error)
Tx(ctx context.Context, queries ...string) ([]driver.Result, error)
Schemas(ctx context.Context) ([]string, error)
Parse(ctx context.Context, sqlText string) ([]Node, error)
Audit(ctx context.Context, sql string) (*AuditResult, error)
GenRollbackSQL(ctx context.Context, sql string) (string, string, error)
}
  • Close: 关闭审核插件使用的相关资源,通常是完成一次审核后,关闭数据库连接等资源;
  • Ping: 检测数据库的连接性,通常在添加数据源时,为了检测填写的数据是否正确,会调用此方法;
  • Exec: 执行 SQL 上线时执行此方法;
  • Tx: 执行 SQL 上线时执行此方法,一般当SQL是DML时且需要事务执行时会批量执行SQL;
  • Schemas: 返回审核插件展示给用户的 Schema 列表;
  • Parse: 解析审核插件支持的 SQL 格式;
  • Audit: 根据指定的SQL语句生成审核建议;
  • GenRollbackSQL: 生成 SQL 的回滚语句。

3.插件的配置信息说明

type Config struct {
DSN *DSN
Rules []*Rule
}
  • DSN: 数据源信息, 待审核的数据库;
  • Rules: 本次审核制定的规则列表。

4.初始化函数说明

插件的主进程入口,由插件的 main 函数调用即可实现插件

func ServePlugin(r Registerer, newDriver func(cfg *Config) Driver)
  • r: 传入 Registerer 的接口实现, 由插件侧实现;
  • newDriver: 传入 Driver 的初始化函数,该函数的入参是 Config 是由 SQLE 向插件传递的配置信息,函数的出参是 Driver 的接口实现,由插件侧实现。
- + \ No newline at end of file diff --git a/docs/dev-manual/plugins/howtouse/index.html b/docs/dev-manual/plugins/howtouse/index.html index 42458631..7d8cfd02 100644 --- a/docs/dev-manual/plugins/howtouse/index.html +++ b/docs/dev-manual/plugins/howtouse/index.html @@ -4,7 +4,7 @@ 数据库审核插件使用 | SQLE 文档 - + @@ -14,7 +14,7 @@ pluginrules 验证能否添加插件类型的数据源:添加数据源,显示已经可以添加 PostgreSQL 类型的数据源。 plugintype

- + \ No newline at end of file diff --git a/docs/dev-manual/plugins/intro/index.html b/docs/dev-manual/plugins/intro/index.html index 11f041d8..d37b9da9 100644 --- a/docs/dev-manual/plugins/intro/index.html +++ b/docs/dev-manual/plugins/intro/index.html @@ -4,13 +4,13 @@ 功能说明 | SQLE 文档 - +
版本:v3

功能说明

SQLE 使用 go-plugin 来实现审核插件化。插件只需实现两个接口,即可实现与 SQLE 主进程通信(详情见审核插件开发)。

将 SQLE 的数据库审核插件化主要有以下目的:

  • 将审核流程(业务)的代码和具体审核实现的代码进行分离,支持多数据源类型的审核
  • 审核插件在满足基本规范情况下,与 SQLE 独立开发

部分插件项目地址

- + \ No newline at end of file diff --git a/docs/guide/index.html b/docs/guide/index.html index 87a0c3f6..72eb11d4 100644 --- a/docs/guide/index.html +++ b/docs/guide/index.html @@ -4,13 +4,13 @@ 用户指南 | SQLE 文档 - +
版本:v3

用户指南

产品概述

SQLE 是爱可生自主研发支持多元数据库的 SQL 质量管理平台。应用于开发、测试、上线发布、生产运行阶段的 SQL 质量治理。通过 “建立规范、事前控制、事后监督、标准发布” 的方式,为企业提供 SQL 全生命周期质量管控能力,规避业务 SQL 不规范引起的生产事故,提高业务稳定性,也可推动企业内部开发规范快速落地。

- + \ No newline at end of file diff --git a/docs/intro/index.html b/docs/intro/index.html index 79c7e3a7..7a8a7317 100644 --- a/docs/intro/index.html +++ b/docs/intro/index.html @@ -4,13 +4,13 @@ 产品介绍 | SQLE 文档 - +
版本:v3

产品介绍

SQLE 是爱可生自主研发支持多元数据库的 SQL 质量管理平台。应用于开发、测试、上线发布、生产运行阶段的 SQL 质量治理。通过 “建立规范、事前控制、事后监督、标准发布” 的方式,为企业提供 SQL 全生命周期质量管控能力,规避业务 SQL 不规范引起的生产事故,提高业务稳定性,也可推动企业内部开发规范快速落地。

产品特性

更丰富的数据源支持

支持主流商业和开源数据库,包括 MySQL、PostgreSQL、Oracle、SQL Server、DB2、TiDB、OceanBase 等,持续增加新的数据源类型,以满足您不同的需求。

更全面的审核规则

审核规则源自我们经验丰富的 DBA 运维专家团队多年的技术积累。您可以借助我们的审核规则快速达到专家级的 SQL 诊断能力,并且我们的规则库目前已经拥有规则 700+,并在不断增加中。

更智能的 SQL 采集

提供多种智能扫描方式,例如慢日志、JAVA 应用等,以满足您的事前和事后 SQL 采集需求。一旦配置完成,我们的系统会自动持续采集各业务库中的 SQL,极大地减轻了您对 SQL 监督的压力,并及时发现问题 SQL。

更高效的审批流转路径

提供标准化的工作流,化解了在沟通和进度追踪上的难题,从而提升了上线效率。您可以通过与飞书、钉钉等多种消息通道的对接,及时了解更新进度,减少了沟通交流的成本。

更便捷的 SQL 数据操作

提供审核管控的SQL客户端,杜绝执行不合规SQL

全生命周期的 SQL 管控

提供 SQL 全流程的管控视角,帮助您统一管理SQL质量。您可以追踪问题SQL的解决进度,并提供快捷的优化功能,以提升 SQL 的效率。

使用场景

SQL 太复杂,执行性能低,如何优化?
知识赋能,助您构建质量规范、提升 SQL 质量。提供审核规则及规则知识库,将专家经验赋能开发,快速提升问题 SQL 诊断能力,并支持私有云用户自主沉淀。
  • 从审核结果看 SQL 优化方向

    平台提供丰富的审核规则,用以覆盖不同 SQL 审核场景,您可以根据触发的规则,有针对性地优化 SQL。

  • 从知识库了解问题解决经验

    每个规则包含对应的知识库,是运维专家的经验沉淀,您可以借鉴并强化自身的运维认知。

  • 对知识库做自主沉淀

    除了平台提供的知识库信息,我们还支持私有云用户在知识库中进行自主沉淀,建立您的质量规范。

应用数量多,SQL 采集难,如何摆脱重复劳动?

提供智能扫描任务,可以自动持续采集不同来源的 SQL,帮助您摆脱重复劳动,极大地降低 SQL 采集难度。同时,根据不同业务要求定期巡检和生成审核报告,快速发现问题并提供优化建议。

  • 配置扫描任务,释放 SQL 采集负担

    平台支持十余种扫描任务类型,支持采集不同来源的 SQL,如:JAVA 应用程序、慢日志文件、TopSQL、MyBatis 文件等。

  • 定期持续巡检,提前发现问题 SQL

    平台将根据配置的采集周期,为您自动、持续采集相应 SQL。

    平台将根据配置的审核规则模板,定期巡检和生成审核报告,有助于您及时发现问题 SQL,并提供优化方向。

公司规模大,流程周转长,如何有效追踪进度?
提供标准化工作流,帮助提高工作透明度和上线效率。您可以根据实际组织架构配置自定义审批流程模板,化解沟通和进度追踪难题。同时,平台支持与多种消息通道对接,可以及时更新进度,减少沟通成本。
  • 生成您的自定义审批流程

    平台支持您根据自身实际业务,配置SQL审批、上线流程,适配不同业务的上线节奏,提升业务响应效率。

  • 配置消息推送渠道,快捷订阅变更

    平台支持对接多种主流IM应用,您可以将 SQL 审核集成到日常工作流中,协同办公,提升工作效率。

SQL 变更频,审批瓶颈大,如何分散审核压力?
将审核环节灵活嵌入到研发流程,从研发环节入手,减轻 DBA 审核压力。平台支持多种事前审核场景,将 SQL 审核前置到代码阶段,从源头实现降本增效。
  • 使用 IDE 插件,前置规范检查

    可以使用 IDE 审核插件,在代码编写过程中进行实时审核和规范检查,实现编码即审核的效果。

  • 对接 CI/CD 流程,保证应用代码上线无忧

    可以配置 CI/CD 审核流程,自动抓取代码变更中的 SQL,减少人工错误和代码缺陷,提高开发团队的效率和代码质量。

- + \ No newline at end of file diff --git a/docs/online-demo/index.html b/docs/online-demo/index.html index a891df6d..1a31bc4c 100644 --- a/docs/online-demo/index.html +++ b/docs/online-demo/index.html @@ -4,13 +4,13 @@ 在线体验 | SQLE 文档 - +
版本:v3

在线体验

地址

登录用户

userpassword
adminadmin

测试 MySQL

variablevalue
host20.20.20.3
port3306
userroot
passtest

注意事项

  1. 该服务仅用于在线功能体验,请勿在生产环境使用;
  2. 该测试服务数据会定期清理。
- + \ No newline at end of file diff --git a/docs/quick-usage/index.html b/docs/quick-usage/index.html index b2ed83ba..9d337ccb 100644 --- a/docs/quick-usage/index.html +++ b/docs/quick-usage/index.html @@ -4,7 +4,7 @@ 快速开始 | SQLE 文档 - + @@ -21,7 +21,7 @@ project-workflow-1 点击批量立即上线,完成SQL上线操作。 project-workflow-1

提示

SQLE 支持通过邮件,微信企业号等途径推送工单通知。也可以配置工单对接,在钉钉、飞书上进行工单审批

- + \ No newline at end of file diff --git a/docs/support/commercial-support/index.html b/docs/support/commercial-support/index.html index a32eb845..886984ef 100644 --- a/docs/support/commercial-support/index.html +++ b/docs/support/commercial-support/index.html @@ -3,14 +3,14 @@ -商业支持 | SQLE 文档 - +商业支持 | SQLE 文档 +
-
版本:v3

商业支持

如果想获得 SQLE 的商业支持, 您可以联系我们:

  • 全国支持: 400-820-6580
  • 华北地区: 86-13910506562, 汪先生
  • 华南地区: 86-18503063188, 曹先生
  • 华东地区: 86-18930110869, 梁先生
  • 西南地区: 86-13540040119, 洪先生
- +
版本:v3

商业支持

如果想获得 SQLE 的商业支持, 您可以扫描下方的微信扫描小程序码,进行在线咨询预约:

commercial-support

此外,您也可以直接联系我们的商业支持团队获取更多信息,联系方式如下:

400-820-6580 / 13916131869 / 18930110869

+ \ No newline at end of file diff --git a/docs/support/community-support/index.html b/docs/support/community-support/index.html index d0f8cfe9..5daa924d 100644 --- a/docs/support/community-support/index.html +++ b/docs/support/community-support/index.html @@ -4,13 +4,13 @@ 社区支持 | SQLE 文档 - +
版本:v3

社区支持

微信技术交流群

欢迎加入微信群进行交流,反馈使用中遇到的问题或者使用建议。

进群方式:添加管理员微信 ActionOpenSource

爱可生社区公众号

关注爱可生社区公众号,获取最新SQLE动态包括新功能清单与产品规划。

项目列表

- + \ No newline at end of file diff --git a/docs/support/compare/index.html b/docs/support/compare/index.html index bcef1e04..cad99746 100644 --- a/docs/support/compare/index.html +++ b/docs/support/compare/index.html @@ -4,13 +4,13 @@ 功能对比 | SQLE 文档 - +
版本:v3

功能对比

社区版及企业版功能对比

模块功能企业版社区版
平台基础能力资源管理
权限管理
用户对接:LDAP
用户对接:Oauth2.0单点登录
对接钉钉在线审批
支持爱可生云树DMP数据源同步
量化管理项目管理
报表统计
Dashboard
SQL管控
支持的数据源类型MySQL
Mycat
TDSQL for InnoDB
OceanBase For MySQL
DB2
TiDB
PostgreSQL
Oracle
OceanBase For Oracle
SQL Server
达梦
SQL审核同一工单多数据源
多种SQL上传方式
IDE审核插件
快捷审核
工单审核
SQL美化
动态配置审核规则模板
规则知识库
审核白名单
基于规则的审核建议
审核建议去重展示
SQL下钻分析
大表进行 Online DDL
SQL上下文关联
生成回滚语句
审核评分
审核报告下载
SQL语句下载
工单上线自定义审核流程
多数据源批量上线
立即上线
定时上线
线下执行,线上标记
中止上线
智能扫描MySQL|MyBatis 扫描
MySQL|库表元数据
MySQL|阿里云 RDS慢日志
MySQL|阿里云 RDS审计日志
MySQL|百度云RDS慢日志
MySQL|华为云RDS慢日志
MySQL|慢日志审核
MySQL|会话SQL扫描
SQL文件扫描
应用程序SQL抓取
支持JAVA探针采集JAVA应用SQL
Oracle TopSQL
TiDB审计日志
OceanBase for MySQL|MyBatis 扫描
OceanBase for MySQL|Top SQL
自定义(通过调用接口推送bash脚本、python程序中的SQL)
告警通知邮件告警
微信企业号告警
飞书告警
webhook告警
SQL工作台集成CloudBeaver-提供在线SQL客户端
安全管控
OpenAPI提供完整的标准接口方案
专家服务提供数据对接、SQL规范制定、SQL优化建议等7x24小时服务

各数据源支持程度对比

提示

目前支持的数据源类型中,除MySQL为社区版,其他均为企业版。

MySQL系

MySQLMycatTDSQL for InnoDBOceanBase For MySQLTiDB
功能SQL分析
SQL上下文
元数据检查
SQL回滚
上线中止
扫描任务库表元数据
慢日志
Processlist
TopSQL
TiDB审计日志
MyBatis
阿里RDS MySQL慢日志
阿里RDS MySQL审计日志
百度云RDS MySQL慢日志扫描
SQL文件扫描
应用程序抓取
自定义
其他规则数量155122146117119

非MySQL系

OracleOceanBase For OracleDB2PostgreSQLSQL server达梦
功能SQL分析
SQL上下文
元数据检查
SQL回滚
上线中止
扫描任务库表元数据
慢日志
Processlist
TopSQL
TiDB审计日志
MyBatis
阿里RDS MySQL慢日志
阿里RDS MySQL审计日志
百度云RDS MySQL慢日志扫描
SQL文件扫描
应用程序抓取
自定义
其他规则数量8583602123
- + \ No newline at end of file diff --git a/docs/user-manual/customrule/index.html b/docs/user-manual/customrule/index.html index fa9a3d17..778a7cd8 100644 --- a/docs/user-manual/customrule/index.html +++ b/docs/user-manual/customrule/index.html @@ -4,7 +4,7 @@ 自定义审核规则 | SQLE 文档 - + @@ -13,7 +13,7 @@ customrule-regex

提示

当前支持golang正则语法。

应用自定义规则

1.编辑数据源应用的规则模板,启用新建的自定义规则; 2.创建工单,新建表customers123,从工单审核结果中可以看到自定义规则已生效; customrule-result

提示

目前仅支持在SQLE平台新建自定义规则,暂不支持导入导出规则模板时携带自定义规则。

后续操作

目前,自定义规则也支持编辑知识库页面,以进一步优化审核规则的使用。可以参考知识库

- + \ No newline at end of file diff --git a/docs/user-manual/intro/index.html b/docs/user-manual/intro/index.html index a4c607a9..b2b64ce6 100644 --- a/docs/user-manual/intro/index.html +++ b/docs/user-manual/intro/index.html @@ -4,13 +4,13 @@ 用户手册 | SQLE 文档 - + - + \ No newline at end of file diff --git a/docs/user-manual/jetbrains/index.html b/docs/user-manual/jetbrains/index.html index 70e826e6..08bff101 100644 --- a/docs/user-manual/jetbrains/index.html +++ b/docs/user-manual/jetbrains/index.html @@ -4,7 +4,7 @@ IDEA审核插件 | SQLE 文档 - + @@ -15,7 +15,7 @@ ide-install-use

2.用户也可以选中文件后,点击右键, 选中 [SQLE] - [Audit],将获得对文件中SQL的审核结果,支持一次性审核整个文件夹下的MyBatis文件; ide-install-use2

审核结果

插件会以弹窗的形式将审核结果进行展示,用户可查看SQL触发的审核规则,并查看对应的知识库说明。 ide-install-result

常见问题解答

为什么插件配置项中的 [DB Type] 点击时偶尔会卡一下

这是因为点击下拉框时下拉框会连接SQLE获取支持的实例类型, 这个过程可能会出现网络延迟

SQLE在审核时使用的规则模板是什么

SQLE会根据设置中指定的数据库类型, 选择对应类型的默认模板进行审核, 且只会使用默认模板中的静态审核规则

我没有SQLE环境可以使用这个插件吗

SQLE有演示环境, 如果只是想尝试一下这个插件可以连接演示环境

插件支持哪些IDE

Jetbrains家的所有软件和 [Android Studio] 都是支持的

SQLE插件的配置存在什么地方

 {用户根目录}\AppData\Roaming\JetBrains\{idea版本号对应目录}\options\SQLESettings.xml
变量说明
用户根目录一般为 C:\Users 目录下和用户名同名的目录, 内部一般包含 '桌面', '下载' 等文件夹
idea版本号对应目录一般为 软件名版本号 的格式, 如社区版idea 2022.1版本对应目录名为 IdealC2022.1
- + \ No newline at end of file diff --git a/docs/user-manual/knowledgebase/index.html b/docs/user-manual/knowledgebase/index.html index 305e5661..cbe8dfc6 100644 --- a/docs/user-manual/knowledgebase/index.html +++ b/docs/user-manual/knowledgebase/index.html @@ -4,13 +4,13 @@ 规则知识库 | SQLE 文档 - +
版本:v3

规则知识库

使用场景

规则知识库是用于帮助用户理解规则背景、原理、优化建议以及规范SQL示例的页面。通过规则知识库,用户可以更深入和全面地了解规则,以实现更高效的开发和优化工作。

使用入口

  1. 在系统设置中点击查看规则,点击具体规则,再点击规则知识库标签下的查看更多按钮,即可进入规则知识库详情;
  2. 在SQL审核、工单、扫描任务详情页面中,点击触发的规则说明后的查看更多按钮,即可进入规则知识库详情;

范围

规则知识库目前支持内置规则和自定义规则的编辑和查看。

编辑步骤

限制

目前,只有平台管理员具有规则知识库的编辑权限,以确保知识库中的信息准确且权威。

编辑

平台管理员可以按照以下步骤编辑规则知识库内容:

  1. 登录平台并进入规则知识库页面,入口可以参考使用入口
  2. 点击'编辑'按钮,即可修改规则对应的知识库内容。

操作结果

knowledgebase-use

提示

目前,平台已为MySQL和TDSQL两种数据库类型的规则填充了规则知识库,并正致力于为其他数据库类型提供相应的知识库内容。

- + \ No newline at end of file diff --git a/docs/user-manual/project/analysis/index.html b/docs/user-manual/project/analysis/index.html index 22dd560e..97a46820 100644 --- a/docs/user-manual/project/analysis/index.html +++ b/docs/user-manual/project/analysis/index.html @@ -4,13 +4,13 @@ SQL分析 | SQLE 文档 - +
版本:v3

SQL分析

SQL分析是什么

当用户需要了解执行SQL的对象情况时,可以点击SQL后的分析操作,进入SQL分析页面

使用场景

操作步骤

使用限制

- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/SQLfile_audit/index.html b/docs/user-manual/project/audit_task/SQLfile_audit/index.html index 01fdac28..4801118d 100644 --- a/docs/user-manual/project/audit_task/SQLfile_audit/index.html +++ b/docs/user-manual/project/audit_task/SQLfile_audit/index.html @@ -4,14 +4,14 @@ SQL文件扫描 | SQLE 文档 - +
版本:v3

SQL文件扫描

本节介绍SQL文件扫描的应用场景及配置方法。

备注

平台已支持的所有数据源类型均支持SQL文件扫描

使用场景

当用户需要在批量执行SQL前扫描SQL,发现潜在的安全漏洞、提高数据库性能及数据库开发质量时,可以使用SQL文件进行批量扫描。

使用方式

前置条件

在后端环境中准备SQL文件

新建智能扫描任务

进入智能扫描任务列表,点击新建,选择SQL文件扫描任务类型。

执行Scannerd文件

提示

注意:使用rpm或docker部署的情况下,scannerd通常在SQLE的bin目录下。

示例如下:

./scannerd sqlFile -H127.0.0.1 -N"SQLfile" -P"10000" -J"default" -D/root/sqle/sqle/cmd/scannerd/scanners/mybatis/testdata/ -A"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhcG4iOiJ0ZXN0MDcyNCIsImV4cCI6MTcyMTcyODU0NywibmFtZSI6ImFkbWluIn0.CojdTvBkr-iN_26tWI-Kr6mMnJt1NIDr-Y3v7m9ySuM"

参数解释如下:

  • -J, --project:说明扫描任务所在项目,例如“default”;
  • -H, --host string:指定SQLE主机所在地址;
  • -P, --port string:指定SQLE所在端口;
  • -N, --name string:指定扫描任务名称,scannerd会将获得的SQL传至指定的任务池中审核;
  • -D, --dir string:指定要扫描的SQL文件路径;
  • -A, --token string:输入扫描任务凭证token;
  • -K, --skip-sql-file-audit:只上传sql,不审核sql;
  • -S, --skip-error-sql-file; 跳过无法解析的sql文件;

获得执行结果: sqlfile_audit

平台查看执行结果

  • 用户进入扫描任务详情,可以查看SQLw文件中已采集到的SQL信息;
  • 用户点击立即审核,可以在扫描任务报告中获取当前SQL的审核结果;
- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/baiduyunrds/index.html b/docs/user-manual/project/audit_task/baiduyunrds/index.html index 9ab3ddc3..170f5826 100644 --- a/docs/user-manual/project/audit_task/baiduyunrds/index.html +++ b/docs/user-manual/project/audit_task/baiduyunrds/index.html @@ -4,14 +4,14 @@ 百度云RDS慢日志扫描 | SQLE 文档 - +
版本:v3

百度云RDS慢日志扫描

本节介绍如何在SQLE平台监管百度云RDS实例上产生的慢SQL。

支持的数据源类型

  • MySQL

使用场景

如果用户使用百度云RDS实例,并且想要监管实例上产生的慢SQL,可以通过创建一个百度云RDS慢日志扫描任务来实现。该任务将会定期扫描百度云RDS实例上的慢日志,并将扫描结果发送到SQLE中进行分析。

前置操作

  • 用户需创建双机高可用版本的百度云RDS实例;
  • 对该实例开通慢日志;

baiduyunrds

操作步骤

新建智能扫描任务

  • 任务名称:输入审核任务名称,必须以字母开头;
  • 数据源名称:指定扫描任务实施的数据源;
  • 数据库:填写需要审核的目标库,若不填则仅进行静态分析不会连库;
  • 数据库类型:根据选取的数据源呈现;
  • 任务类型:选择需要执行的审核任务类型,选择百度云RDS MySQL慢日志
  • 实例ID:填写百度云RDS实例的ID。
  • Access Key:为账号安全认证中的Access Key,用于登录百度云RDS,需要与Secret Key一同使用。
  • Access Secret Key:账号安全认证中Access Key对应的Secret Key。
  • 启动任务时拉取慢日志时间范围(单位:小时,最大7天):扫描任务读取慢日志的时间范围,单位为小时,最大范围为7天。
  • 审核过去时间段内抓取的SQL(分钟): 审核该时间段内抓取到的慢SQL。
  • RDS Open API地址:RDS的地址前缀,用以调用RDS服务,需根据实例所在区域进行填写。如当前实例在华东-上海范围,则应填写rds.fsh.baidubce.com baiduyunrdsurl

点击提交,完成扫描任务创建。

执行结果

  • 用户进入扫描任务详情,可以查看扫描任务抓取到的慢SQL。
  • 点击立即审核,可查看对慢SQL的审核结果。
- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/huaweiyunrds/index.html b/docs/user-manual/project/audit_task/huaweiyunrds/index.html index b3b6d6d0..c27f66c9 100644 --- a/docs/user-manual/project/audit_task/huaweiyunrds/index.html +++ b/docs/user-manual/project/audit_task/huaweiyunrds/index.html @@ -4,14 +4,14 @@ 华为云RDS慢日志扫描 | SQLE 文档 - +
版本:v3

华为云RDS慢日志扫描

本节介绍如何通过华为云SQLE平台监管华为云RDS实例上产生的慢SQL,并进行相应的分析和审核。

支持的数据源类型

  • MySQL

使用场景

如果用户正在使用华为云RDS实例,并且希望监管实例上产生的慢SQL,可以通过创建华为云RDS慢日志扫描任务实现。该任务会定期扫描华为云RDS实例上的慢日志,并将扫描结果发送到SQLE平台进行分析。

前置操作

在进行以下操作之前,请确保已完成以下步骤:

  • 创建华为云RDS实例,并获取实例的项目ID和实例ID。
  • 开启慢日志明文显示,并设置慢查询时间阈值。参考华为云用户手册
  • 获取访问密钥。访问密钥文件需要下载至本地查看。参考华为云用户手册

操作步骤

新建智能扫描任务

  • 任务名称:输入审核任务名称,必须以字母开头;
  • 数据源名称:指定扫描任务实施的数据源;
  • 数据库:填写需要审核的目标库,若不填则仅进行静态分析不会连库;
  • 数据库类型:根据选取的数据源呈现;
  • 任务类型:选择需要执行的审核任务类型,选择华为云RDS MySQL慢日志
  • 项目ID:实例所在项目ID;
  • 实例ID:实例ID;
  • Access Key ID:在步骤3中获取的访问密钥 ID;
  • Access Key Secret:在步骤3中获取的访问密钥Secret;
  • 启动慢日志时拉取慢日志时间范围(小时):由于开启明文显示后,华为云平台会自动删除30天前的日志,所以时间范围上限是30天;
  • 当前API开放的地区:参考华为云用户手册

点击提交,完成扫描任务创建。

执行结果

  • 用户进入扫描任务详情,可以查看扫描任务抓取到的慢SQL。
  • 点击立即审核,可查看对慢SQL的审核结果。

以下是华为云RDS慢日志扫描示意图: huaweiyunrds

- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/intro/index.html b/docs/user-manual/project/audit_task/intro/index.html index 5644c16a..e8aa5ec6 100644 --- a/docs/user-manual/project/audit_task/intro/index.html +++ b/docs/user-manual/project/audit_task/intro/index.html @@ -4,13 +4,13 @@ 功能说明 | SQLE 文档 - +
版本:v3

功能介绍

背景

在审核工单中我们介绍了如何通过 SQLE 进行 SQL 审核并上线的流程。审核工单管理,主要解决 SQL 上线的规范化流程化的问题,它能够帮助 DBA 自动化处理整个 SQL 上线过程中一些重复繁琐的工作。

不过审核工单管理也有它的局限性。

  • 第一,通常工单中的审核是一次性操作。上线后,通常还会有业务 SQL访问数据库。这时可能会遇到一些执行效率较低的业务 SQL 造成数据库的性能问题,因而这类业务型SQL同样需要审核。
  • 第二,临近发版,如果这时审核出 SQL 存在一些问题,是否修复这些问题,可能会受到很多因素的影响(如 SQL 问题的影响面大小,项目发版的紧急程度等),因而需要对即将上线的SQL做全量扫描。

因而,需要引入扫描任务,进行周期性的SQL审核,用以补充工单审核覆盖不到的场景。

SQLE扫描任务支持的采集模式

1.SQLE 自动抓取

  • 功能说明
    • 使用SQLE自动抓取,将由SQLE获取指定的SQL文件,传输至指定审核池后,由SQLE进行审核并展示审核结果。
  • 支持的任务类型
    • 库表元数据
    • TopSQL
    • processlist列表

2.Scanner 抓取

  • 功能说明
    • 使用Scanner抓取,可利用scanner插件获取指定的SQL文件,传输至指定审核池后,由SQLE进行审核并展示审核结果。
  • 支持的任务类型
    • 慢日志
    • Mybatis扫描

3.OpenAPI 推送

  • 功能说明
    • 使用应用程序SQL抓取,可利用api接口动态获取指定应用程序中的SQL,传输至指定审核池后,由SQLE进行审核并展示审核结果。
  • 支持的任务类型
    • openapi推送
    • 自定义
- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/java_agent_audit/index.html b/docs/user-manual/project/audit_task/java_agent_audit/index.html index c1124987..f6bcfa9d 100644 --- a/docs/user-manual/project/audit_task/java_agent_audit/index.html +++ b/docs/user-manual/project/audit_task/java_agent_audit/index.html @@ -4,13 +4,13 @@ Java探针版应用程序SQL抓取【企业版】 | SQLE 文档 - +
版本:v3

Java探针版应用程序SQL抓取【企业版】

本节介绍如何利用SQLE平台抓取java应用中的SQL,选取的例子是一个开源的问卷调查java应用,架构简单,上手相对容易。

支持的数据源类型

  • MySQL
  • Oracle
  • DB2
  • OceanBase for MySQL
  • PostgreSQL
  • TiDB
  • SQL Server

前置准备

环境准备

准备一台 linux 服务器,ubuntu即可,架构版本暂无要求

  1. 安装JAVA
sudo apt install default-jdk
  1. 部署并启动MySQL服务

部署java应用

  • 准备Java应用
  • 准备Java应用SQL初始化文件
  • 准备SQLE定制的JAVA agent JAR包
    提示

    JAVA agent JAR包为企业版功能,如有使用需求,请联系SQLE商业支持

Java应用前置步骤

1、初始化Java应用

mysql -h127.0.0.1 -P3306 -uroot -p -e "CREATE DATABASE IF NOT EXISTS jw default character set utf8mb4 collate utf8mb4_unicode_ci"
mysql -h127.0.0.1 -P3306 -uroot -D jw -p < init-mysql.sql

2、将Java应用Jar包,定制jdbc上传服务器指定目录下,可以放在 /opt/surveyking 目录下,示例:

root@ubuntu:/opt/surveyking# pwd
/opt/surveyking
root@ubuntu:/opt/surveyking# ls -l
total 55652
-rw-r--r-- 1 root root 2932784 Feb 24 08:38 sql-agent-1.0-SNAPSHOT.jar
-rw-r--r-- 1 root root 54508748 Feb 24 08:37 surveyking-v0.3.0-beta.4.jar

使用方式

创建扫描任务

进入智能扫描任务列表,点击新建,扫描任务类型选择应用程序SQL抓取。

启动Java应用

提示

以下命令需要在本地编辑替换完参数后,一次性拷贝到环境内执行

SQLE_COLLECT_ENABLE=true \
SQLE_BASE_URL=http://10.186.62.16:10000 \
SQLE_TASK_NAME=jw_app \
SQLE_TASK_TOKEN=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhcG4iOiJqd19hcHAiLCJleHAiOjE2NzcyMjYxNzcsIm5hbWUiOiJhZG1pbiJ9.3d0pA1hiVnFEWJokSFBwCT8d1pKOYV6SViENj4GFqgI \
SQLE_EXCLUDE_JAVA_FILE=UserServiceImpl.java \
SQLE_LOG_FILE=/tmp/collect.log \
java -javaagent:sql-agent-1.0-SNAPSHOT.jar \
-jar surveyking-v0.3.0-beta.4.sqle.jar \
--server.port=1991 \
--spring.datasource.url=jdbc:mysql://10.186.62.18:3306/jw \
--spring.datasource.username=root \
--spring.datasource.password=mysqlpass \
& >>/opt/surveyking/std.log

参数说明(环境变量)

  • SQLE_COLLECT_ENABLE=true :是否开启SQL采集,默认不推送到SQLE只输出本地日志
  • SQLE_BASE_URL:SQLE 服务地址,格式“http://ip:port”
  • SQLE_TASK_NAME:SQLE 审核任务的名称
  • SQLE_TASK_TOKEN:审核任务的token,从SQLE页面复制
  • SQLE_PROJECT_NAME:SQLE JDBC配置:项目名
  • SQLE_LOG_FILE:指定SQLE 采集日志文件,不指定则代表输出到标准输出
  • SQLE_EXCLUDE_JAVA_FILE:忽略部分JAVA文件不插桩,主要是兼容性问题,当修改字节码失败时为了保障能运行抓取。文件按逗号分隔

参数说明(java 参数)

  • server.port:web服务启用端口
  • spring.datasource.url:jdbc url
  • spring.datasource.username:jdbc user name
  • spring.datasource.password:jdbc password

访问Java应用

  • 访问地址:如果配置的网页端口是1991则通过网页访问http://xx.xx.xx.xx:1991
  • 用户名:admin
  • 密码:123456
- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/java_application_audit/index.html b/docs/user-manual/project/audit_task/java_application_audit/index.html index ff17feb6..f4806476 100644 --- a/docs/user-manual/project/audit_task/java_application_audit/index.html +++ b/docs/user-manual/project/audit_task/java_application_audit/index.html @@ -4,13 +4,13 @@ 应用程序SQL抓取【企业版】 | SQLE 文档 - +
版本:v3

应用程序SQL抓取【企业版】

本节介绍如何利用SQLE平台抓取JAVA应用中的SQL,选取的例子是一个开源的问卷调查java应用,架构简单,上手相对容易。

支持的数据源类型

  • MySQL
  • Oracle
  • DB2
  • OceanBase for MySQL
  • PostgreSQL
  • TiDB
  • SQL Server

前置准备

环境准备

准备一台 linux 服务器,ubuntu即可,架构版本暂无要求

  1. 安装JAVA
sudo apt install default-jdk
  1. 部署并启动MySQL服务

部署java应用

  • 准备Java应用
  • 准备Java应用SQL初始化文件
  • 准备SQLE定制的JDBC jar 包
    提示

    JDBC jar包为企业版功能,如有使用需求,请联系SQLE商业支持

Java应用前置步骤

1、初始化Java应用

mysql -h127.0.0.1 -P3306 -uroot -p -e "CREATE DATABASE IF NOT EXISTS jw default character set utf8mb4 collate utf8mb4_unicode_ci"
mysql -h127.0.0.1 -P3306 -uroot -D jw -p < init-mysql.sql

2、将Java应用Jar包,定制jdbc上传服务器指定目录下,可以放在 /opt/surveyking 目录下,示例:

root@ubuntu:/opt/surveyking# pwd
/opt/surveyking
root@ubuntu:/opt/surveyking# ls -l
total 55652
-rw-r--r-- 1 root root 2477925 Feb 24 08:38 mysql-connector-java-8.0.28-SQLE.jar
-rw-r--r-- 1 root root 54508748 Feb 24 08:37 surveyking-v0.3.0-beta.4.jar

3、替换Java应用Jar包的MySQL jdbc jar 包

cd /opt/surveyking/
mkdir jar
cp surveyking-v0.3.0-beta.4.jar jar/
cd jar/
jar xvf surveyking-v0.3.0-beta.4.jar # 解压jar包,如果执行失败也可使用 unzip surveyking-v0.3.0-beta.4.jar 代替
cp ../mysql-connector-java-8.0.28-SQLE.jar BOOT-INF/lib/mysql-connector-java-8.0.26.jar # 替换jdbc
rm -rf surveyking-v0.3.0-beta.4.jar
jar cvfM0 surveyking-v0.3.0-beta.4.sqle.jar * # 打包
mv surveyking-v0.3.0-beta.4.sqle.jar ../
cd ..
rm -rf jar/

使用方式

创建扫描任务

进入智能扫描任务列表,点击新建,扫描任务类型选择应用程序SQL抓取。

启动Java应用

提示

以下命令需要在本地编辑替换完参数后,一次性拷贝到环境内执行

cd /opt/surveyking/
SQLE_COLLECT_ENABLE=true SQLE_HOST=10.186.62.18:10000 SQLE_TASK_NAME=jw_app SQLE_TASK_TOKEN=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhcG4iOiJqd19hcHAiLCJleHAiOjE2NzcyMjYxNzcsIm5hbWUiOiJhZG1pbiJ9.3d0pA1hiVnFEWJokSFBwCT8d1pKOYV6SViENj4GFqgI \
java -jar surveyking-v0.3.0-beta.4.sqle.jar \
--server.port=1991 \
--spring.datasource.url=jdbc:mysql://10.186.62.18:3306/jw \
--spring.datasource.username=root \
--spring.datasource.password=mysqlpass \
& >>/opt/surveyking/std.log

参数说明(环境变量):

  • SQLE_COLLECT_ENABLE:是否开启SQL采集
  • SQLE_HOST=10.186.62.18:10000:SQLE 服务地址 ip:port
  • SQLE_TASK_NAME=jw_app :审核任务的名称
  • SQLE_TASK_TOKEN:审核任务的token,从SQLE页面复制
  • SQLE_PROJECT_NAME:SQLE JDBC配置:项目名

参数说明(java 参数)

  • server.port:web服务启用端口
  • spring.datasource.url:jdbc url
  • spring.datasource.username:jdbc user name
  • spring.datasource.password:jdbc password

访问Java应用

  • 访问地址:如果配置的网页端口是1991则通过网页访问http://xx.xx.xx.xx:1991
  • 用户名:admin
  • 密码:123456
- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/metadata_audit/index.html b/docs/user-manual/project/audit_task/metadata_audit/index.html index e424ebc1..4891a220 100644 --- a/docs/user-manual/project/audit_task/metadata_audit/index.html +++ b/docs/user-manual/project/audit_task/metadata_audit/index.html @@ -4,7 +4,7 @@ 库表元数据 | SQLE 文档 - + @@ -12,7 +12,7 @@
版本:v3

库表元数据

本节介绍库表元数据扫描的应用场景、以及如何创建库表元数据的扫描任务。

支持的数据源类型

  • MySQL
  • DB2
  • TDSQL

使用场景:

  1. 需要检查已上线业务对应数据源的建库建表语句是否符合 统一的SQL质量规范。
  2. 需要定期检查上线业务的库表变更是否符合 统一的SQL质量规范。

前置条件

已添加对应数据源。

操作步骤

  1. 新建智能扫描任务
  • 任务名称:输入审核任务名称,必须以字母开头;
  • 数据源名称:指定扫描任务实施的数据源;
  • 数据库:填写需要审核的目标库,若不填则仅进行静态分析不会连库;
  • 数据库类型:根据选取的数据源呈现;
  • 任务类型:选择需要执行的审核任务类型,选择库表元数据;
  • 采集周期(分钟):将采集设定时间内产生的SQL;
  • 是否采集视图信息:默认不采集视图信息,若开启,则将一并扫描数据源上的视图SQL;
  • 审核规则模板:如果未指定此项会优先使用数据源绑定的模板;
  • 任务审核周期:配置的是SQLE对审核任务进行自动审核的执行时间;
  1. 进入扫描任务详情页,刷新,获得SQL采集结果

执行结果

在扫描任务列表页面查看新建的库表元数据扫描任务。 list

在扫描任务详情中查看该扫描任务采集的SQL,及生成的扫描任务报告。 result

后续步骤

  • 查看审核记录,查看不同时间点的审核结果,包括审核的SQL语句、审核结果。
  • 分析语句,用户可对SQL语句进行分析操作,获取优化建议。
- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/mybatis/index.html b/docs/user-manual/project/audit_task/mybatis/index.html index 38ecea96..f3748428 100644 --- a/docs/user-manual/project/audit_task/mybatis/index.html +++ b/docs/user-manual/project/audit_task/mybatis/index.html @@ -4,7 +4,7 @@ MyBatis扫描 | SQLE 文档 - + @@ -21,7 +21,7 @@ coding-editinfo

编辑后点击保存,完成构建计划。

触发构建,获得审核结果

在构建计划中点击立即构建按钮; coding-do

可以在在构建过程中查看构建结果,也可以在SQLE平台的扫描任务中查看审核结果。 coding-result

- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/processlist_audit/index.html b/docs/user-manual/project/audit_task/processlist_audit/index.html index febc3d9e..04d0de32 100644 --- a/docs/user-manual/project/audit_task/processlist_audit/index.html +++ b/docs/user-manual/project/audit_task/processlist_audit/index.html @@ -4,14 +4,14 @@ 会话SQL扫描 | SQLE 文档 - +
版本:v3

会话SQL扫描

本节介绍如何对MySQL进行中的会话SQL进行监督及审核。

支持的数据源类型

  • MySQL

使用场景

除了上线前和上线后的审核,在SQL语句执行过程中,用户往往也需要对其进行监控和审核,用以及时识别出潜在的问题SQL。然而,当前的审核场景往往无法覆盖事中这一环节的审核。为此,SQLE新增了processlist列表审核扫描任务,实现了事前、事中、事后的全覆盖,使得用户可以在SQL语句的整个生命周期内进行审核和管理,从而减少审核时间和工作量。

操作步骤

新建智能扫描任务

  • 任务名称:输入审核任务名称,必须以字母开头;
  • 数据源名称:指定扫描任务实施的数据源;
  • 数据库:填写需要审核的目标库,若不填则仅进行静态分析不会连库;
  • 数据库类型:根据选取的数据源呈现;
  • 任务类型:选择需要执行的审核任务类型,选择processlist列表扫描任务;
  • 采集周期(秒):表示SQLE对 MySQL processlist表的采集频率,SQLE将按照该时间间隔进行SQL采集。如果该值过低,会影响实例性能;
  • SQL最小执行时间(秒):表示SQLE对 MySQL processlist 的采集过滤条件,只有大于等于该时间的SQL才会被采集记录。如果为0,则表示不进行过滤;
  • 审核过去时间段内抓取的SQL(分钟):processlist列表扫描任务是增量审核,不在该时间段内执行的SQL将不会被再次采集;
  • 审核规则模板:如果未指定此项会优先使用数据源绑定的模板;
  • 任务审核周期:配置的是SQLE对审核任务进行自动审核的执行时间;

执行结果

  • 用户进入扫描任务详情,可以查看已采集到的processlist列表中的SQL信息;
  • 用户点击立即审核,可以在扫描任务报告中获取processlist列表中当前采集周期内产生的SQL及审核结果; processlist-audit
- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/slowlog_audit/index.html b/docs/user-manual/project/audit_task/slowlog_audit/index.html index c408fdeb..bb14347b 100644 --- a/docs/user-manual/project/audit_task/slowlog_audit/index.html +++ b/docs/user-manual/project/audit_task/slowlog_audit/index.html @@ -4,13 +4,13 @@ 慢日志 | SQLE 文档 - +
版本:v3

慢日志

本节介绍慢日志扫描的应用场景、以及如何创建慢日志扫描任务。

当前SQLE支持两种慢日志采集方式,一种由scanner采集慢日志文件中的慢查询,一种由SQLE直接采集慢查表中的慢查询,用户可在编辑页面选取需要的采集方式,您可选择需要的方式采集产生的慢查询。

支持的数据源类型

  • MySQL

使用场景

需要检查已上线业务是否有超过指定时长的慢SQL产生。

采集方式

方式一:采集慢日志文件

前置条件

  • 已添加对应数据源;
  • 修改配置文件my.cnf,在文件中设置以下内容:
my.cnf
slow_query_log = ON //开启慢日志
slow_query_log_file = /var/lib/mysql/tmp_slow.log //设置慢日志文件路径
long_query_time = 1 //设置慢查询时间阈值,当前示例时间为1s,可根据实际业务变更

步骤一:新建智能扫描任务

新建智能扫描任务,填写以下字段信息:

  • 任务名称:指定扫描任务的名称,当前仅支持英文名称;
  • 数据源名称:选择扫描任务对应的数据源;
  • 数据库:选择扫描任务使用的数据库;
  • 数据库类型:根据选取的数据源呈现;
  • 任务类型:选择慢日志;
  • 审核过去时间段内抓取的SQL(分钟):扫描的时间覆盖范围;
  • 采集来源:填写0,代表采集mysql-slow.log 文件;
  • 审核规则模板:选择对应的审核规则模板;
  • 审核任务周期:配置的是SQLE对审核任务进行自动审核的执行时间;

点击提交,完成慢日志扫描任务创建。

步骤二:执行scannerd文件

提示

注意:scannerd文件通常在SQLE的bin目录下,需将scannerd文件放在数据源环境下执行。

示例如下:

./scannerd slowquery -H "127.0.0.1" -P "10000" -N "slowlog_of_GRADE1" -J "default" -A eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhcG4iOiJzbG93bG9nX29mX0dSQURFMSIsImV4cCI6MTcwODA3MjMzNSwibmFtZSI6ImFkbWluIn0.ArU5HpU7aSSVrRutxSAwRFYahSx0_4RNzD4KB6LTfpM --log-file /var/lib/mysql/mysql-for-test-slow.log

参数解释如下:

  • -J, --project:说明扫描任务所在项目,例“default”;
  • -H, --host string:指定SQLE主机所在地址;
  • -N, --name string:指定扫描任务名称,scannerd会将获得的慢SQL传至指定的任务池中审核;
  • -P, --port string:指定SQLE所在端口;
  • -A, --token string:输入扫描任务凭证token;
  • --log-file:指定慢日志文件,scannerd从该文件中获取慢SQL;

方式二:采集慢日志表

前置条件

  • 已添加数据源
  • 在MySQL中设置以下内容:
set global long_query_time=1; // 需根据实际业务调整慢查询时间阈值,此处仅供参考
set global slow_query_log=1; // 开启慢日志查询
SET GLOBAL log_output='FILE,TABLE';// 开启 MySQL 的慢日志收集功能,并且确认将慢日志内容写入文件 mysql-slow.log 和表 mysql.slow_log
提示

为了优化查询性能,使用这一采集方式时,需要用户手动运行下面的SQL,将mysql.slow_log表的引擎改为MyISAM,并添加索引。

ALTER TABLE mysql.slow_log ENGINE = MyISAM;
ALTER TABLE mysql.slow_log ADD INDEX idx_start_time (start_time);

新建智能扫描任务

新建智能扫描任务,填写以下字段信息:

  • 任务名称:指定扫描任务的名称,当前仅支持英文名称;
  • 数据源名称:选择扫描任务对应的数据源核;
  • 数据库:选择扫描任务使用的数据库;
  • 数据库类型:根据选取的数据源呈现;
  • 任务类型:选择慢日志扫描任务;
  • 采集周期(分钟):SQLE进行采集的周期,若设置为10分钟,则SQLE将每隔10分钟去采集慢日志表中生成的慢查询;
  • 审核过去时间段内抓取的SQL(分钟):扫描的时间覆盖范围;
  • 采集来源:填写1,代表采集mysql.slow_log 表;
  • 审核规则模板:选择对应的审核规则模板;
  • 审核任务周期:配置的是SQLE对审核任务进行自动审核的执行时间;

点击提交,完成慢日志扫描任务创建。

执行结果

在扫描任务详情查看扫描的SQL语句及审核报告。

后续步骤

  1. 分析扫描任务报告中出现的慢SQL:用户可以重点关注慢SQL的部分,这些SQL可能需要进行性能优化或数据库结构调整,以提升系统的响应速度。
  2. 过滤不关心的SQL:用户可以通过在sqle.black_list_audit_plan_sqls表中添加需要过滤的SQL片段,实现对scanner扫描任务中不关心的SQL的过滤。这样,在SQLE的增量和全量接口中包含了指定关键字的SQL将被自动过滤掉,减少冗余的结果展示。
- + \ No newline at end of file diff --git a/docs/user-manual/project/audit_task/topsql/index.html b/docs/user-manual/project/audit_task/topsql/index.html index c46310c7..2d17f139 100644 --- a/docs/user-manual/project/audit_task/topsql/index.html +++ b/docs/user-manual/project/audit_task/topsql/index.html @@ -4,13 +4,13 @@ TopSQL | SQLE 文档 - + - + \ No newline at end of file diff --git a/docs/user-manual/project/data_access_control/authorization_list/index.html b/docs/user-manual/project/data_access_control/authorization_list/index.html index 017273df..a958576f 100644 --- a/docs/user-manual/project/data_access_control/authorization_list/index.html +++ b/docs/user-manual/project/data_access_control/authorization_list/index.html @@ -4,14 +4,14 @@ 授权清单 | SQLE 文档 - +
版本:v3

授权清单

通过统一分配指定权限操作用户,避免出现因业务多导致权限管理分散的困境,同时追溯权限发放原因。

使用场景

在数据库权限的发放过程中,通常需要进行追溯和审计,特别是对于安全要求较高的系统。授权清单功能可以追溯记录权限发放的详细信息,如授权模板、有效期、授权目的、备注等,以满足对权限发放过程的审计和跟踪需求,保障系统的安全性和合规性。

前置条件

在执行授权清单操作之前,请确保已完成以下步骤:

  • 已添加权限模板;
  • 已添加成员;

操作步骤

步骤一:进入授权清单列表并点击授权

步骤二:填写授权基本信息

  • 选择授权模板
    • 选择权限模板
    • 设置授权有效期
  • 配置授权目的
    • 选择使用人
    • 输入授权目的或用途
    • 填写授权备注信息
  • 新建数据库连接账号
    • 输入连接账号名
    • 输入连接域
    • 输入连接密码并确认

完成以上步骤后,点击确认,即可完成当前的授权操作。

执行结果

授权操作完成后,您将在授权清单列表中看到相应的执行结果。可以参考下方的示意图 auth_list

更多操作

除了上述的基本操作之外,还可以进行以下操作:

  • 回收权限:回收当前授权产生的数据库连接账号,绑定用户不再拥有权限模板中的数据操作能力;
  • 续期授权:延期数据库连接账号的可用时间;
- + \ No newline at end of file diff --git a/docs/user-manual/project/data_access_control/intro/index.html b/docs/user-manual/project/data_access_control/intro/index.html index a4d575ac..4d870e83 100644 --- a/docs/user-manual/project/data_access_control/intro/index.html +++ b/docs/user-manual/project/data_access_control/intro/index.html @@ -4,13 +4,13 @@ intro | SQLE 文档 - + - + \ No newline at end of file diff --git a/docs/user-manual/project/data_access_control/permission_template/index.html b/docs/user-manual/project/data_access_control/permission_template/index.html index ceec4837..afa6462d 100644 --- a/docs/user-manual/project/data_access_control/permission_template/index.html +++ b/docs/user-manual/project/data_access_control/permission_template/index.html @@ -4,13 +4,13 @@ 权限模板 | SQLE 文档 - +
版本:v3

权限模板

权限模板支持灵活分组,按集合组织权限模板,以减少重复分配相同权限的工作量,提高权限管理效率。

使用场景

当需要对大量用户进行授权时,权限模板可以帮助您快速批量分配相同的权限。您只需创建一个权限模板,在模板中组合不同数据源的数据操作权限,然后将该模板应用于所需的用户。这样可以节省大量手动分配权限的时间和工作量。

前置条件

  • 已添加数据源

操作步骤

步骤一:进入权限模板列表,点击添加模板

步骤二:填写模板名称

步骤三:填写模板数据权限

  • 选择数据源对应的业务:必选,用以确定数据源的可选范围;
  • 选择该业务下可用的数据源:必选,用以限制可操作的数据源;
  • 选择数据源下的库和表:非必选,如果不选,则对整个数据源的所有库表均有权限;
  • 选择该数据源上可用的数据操作权限:非必选,如果不选,则对整个数据库的所有数据表均有权限;

点击保存后,可以继续向权限模板中添加数据权限,或完成当前权限模板配置。

执行结果

permission_template

更多操作

  • 授权:指定拥有该模板权限的用户及数据库操作账号;
  • 类似创建:克隆当前规则模板;
- + \ No newline at end of file diff --git a/docs/user-manual/project/group_member/index.html b/docs/user-manual/project/group_member/index.html index 7dff468e..754ff5eb 100644 --- a/docs/user-manual/project/group_member/index.html +++ b/docs/user-manual/project/group_member/index.html @@ -4,7 +4,7 @@ 成员/成员组管理 | SQLE 文档 - + @@ -12,7 +12,7 @@
版本:v3

成员/成员组管理

本文介绍项目内添加成员、成员组的步骤,以及其他管理操作。

前置条件

  • 项目管理员进入指定的项目;
  • 平台管理员已完成用户的添加;
  • 平台管理员已完成角色的添加;

成员管理

成员由项目管理员添加,只有被添加为成员后,才可查看、操作项目内资源。

使用场景

  • 一个业务以项目的形式管理SQL工单、扫描任务等资源,若用户需要在指定项目中执行SQL工单、扫描任务等相关操作,则需要成为该项目的成员,并具有相应角色操作权限。

添加成员

步骤

项目管理员点击成员标签,点击添加成员按钮;

字段说明

  • 用户名:选择平台已添加的用户;
  • 选择是否为项目管理员:项目管理员将负责项目管理行为,例如添加数据源和成员等;
    • 若将当前成员设为项目管理员,则该成员将对项目内所有数据源拥有所有操作权限,无需额外配置权限;
    • 若未设置,则当前成员在项目内的操作权限将根据下一步添加角色与数据源的绑定获得;
  • 添加角色与数据源的绑定;
    • 添加数据源:指定当前成员能操作的数据源;
    • 添加角色:指定当前成员在该数据源上的角色权限,角色设置请参见角色管理
  • 删除角色与数据源的绑定;

执行结果

项目管理员可查看当前项目中添加的成员列表。 成员列表

后续步骤

配置项目审核流程模板:可以指定成员作为审核/上线环节的操作人,请参见审核流程模板

更多操作

  • 编辑成员:添加成员后,项目管理员可修改成员可用的数据源及对应角色权限;
    • 限制:编辑之前产生的工单不受影响,编辑之后工单创建时将应用最新的数据源及权限对应关系;
  • 删除成员:项目管理员可删除项目中的成员;
    • 限制:若成员已不在项目内,则无权操作工单;

成员组管理

使用场景

  • 如果若干用户在项目内具备相同的操作权限或访问权限,可以通过将他们加入同一个成员组来配置他们对项目资源的权限。

添加成员组

步骤

项目管理员点击成员组标签,点击添加成员组按钮;

字段说明

  • 成员组名:填写成员组的名称;
  • 用户名:选择需要加入为组员的用户;
  • 选择是否为项目管理员:项目管理员将负责项目管理行为,例如添加数据源和成员等;
    • 若将当前成员设为项目管理员,则该成员将对项目内所有数据源拥有所有操作权限,无需额外配置权限;
    • 若未设置,则当前成员在项目内的操作权限将根据下一步添加角色与数据源的绑定获得;
  • 添加角色与数据源的绑定;
    • 添加数据源:指定当前成员能操作的数据源;
    • 添加角色:指定当前成员在该数据源上的角色权限,平台默认提供DEV、DBA两种角色,负责SQL语句的提交、审核及上线操作;更多角色设置请参见角色管理
  • 删除角色与数据源的绑定;

执行结果

项目管理员可查看当前项目中添加的成员组列表。 成员组列表

后续步骤

  • 配置项目审核流程模板:可以批量匹配具有同一权限的成员作为审核/上线环节的操作人,,请参见审核流程模板

更多操作

  • 编辑成员组:添加成员组后,项目管理员可修改成员组可用的数据源及对应角色权限;
    • 限制:编辑之前创建的工单不受影响,之后创建的工单将依据新的数据源及权限;
  • 删除成员组:项目管理员可删除项目中的成员组;
    • 限制:若成员组内成员已不在项目内,则无权操作工单;
- + \ No newline at end of file diff --git a/docs/user-manual/project/instance-manager/index.html b/docs/user-manual/project/instance-manager/index.html index 88213a8e..c727b08d 100644 --- a/docs/user-manual/project/instance-manager/index.html +++ b/docs/user-manual/project/instance-manager/index.html @@ -4,14 +4,14 @@ 数据源管理 | SQLE 文档 - +
版本:v3

数据源管理

本文介绍如何在项目中进行数据源管理,包括数据源的增加、删除、编辑操作。 数据源是工单和扫描任务的实施对象,用户在平台创建的工单和扫描任务都将针对指定的数据源执行。因而项目创建后需要首先配置项目内可用的数据源。

提示

数据源是SQLE连库审核的对象,任何审核的场景下若可以不选数据源则代表将进行脱库审核。

使用场景

实际生产中,如果需要针对某个数据源下发SQL或创建扫描任务,需要首先将数据源添加至SQLE平台,测试连通成功后才可创建工单、创建扫描任务。

添加数据源

前置操作

项目管理员进入指定的项目

操作步骤

点击左侧导航栏的数据源菜单,进入数据源管理页面后,点击添加数据源,填写数据源相关信息

  • 数据源名称:命名当前新建的数据源,如:actionsky-test;
  • 数据源描述:用户可对数据源补充更多描述,便于用户通过名称+描述快速更精准地区分数据源;
  • 数据库类型:选择数据库实例对应的数据库类型,当前支持的数据库类型包括MySQL、PostgreSQL、Oracle、SQL server、DB2、TiDB、OceanBase For MySQL、OceanBase For Oracle、Mycat、TDSQL for InnoDB、达梦;
  • 数据库地址:输入数据库实例的连接地址,支持IP地址、域名两种方式;
  • 数据库端口:添加数据源时根据数据源类型自动切换默认端口;
  • 连接用户:输入数据库实例的连接用户,SQLE在执行SQL审核以及SQL上线时,会通过该连接用户访问数据库实例及下发SQL;
  • 密码:输入数据库实例的连接用户密码;
  • 审核规则模板:审核规则模板将用于创建工单时的审核、扫描任务的审核、SQL查询的审核;
  • 运维时间:如果配置了运维时间, 工单将只能在运维时间内上线(立即上线和定时上线都受此影响), 支持配置多个运维时间, 默认无运维时间,即不限制上线时间;
  • SQL查询是否需要审核:默认不审核;如用户选择开启该功能,则用户在SQL工作台中提交的SQL语句,将匹配审核规则模板进行SQL审核操作;
  • 运行查询的最高审核等级:只有开启 SQL查询的审核功能才生效;支持四种审核等级:normal、notice、warn、error,如设置运行查询的最高审核等级为warn,则触发了warn等级规则以上的SQL语句将报错,并不予执行;未触发warn等级规则以上的SQL语句将被执行;

执行结果

数据源添加成功后,可在数据源列表查看新增的数据源信息。

数据源列表

后续步骤

  • 创建审核规则:添加数据源后,可针对指定数据源创建适用的审核规则,请参见审核规则模板管理
  • 添加成员/成员组:添加数据源后,需要引入成员/成员组对数据源进行操作,请参见成员/成员组管理

更多管理功能

  • 编辑数据源:点击数据源列表页面对应数据源条目后的编辑按钮,可以修改指定数据源。
    • 限制:数据源名称及数据库类型不支持修改,其他信息均可修改
  • 删除数据源:点击数据源列表页面对应数据源条目后的删除按钮,可以删除指定数据源。
    • 限制:若数据源上还有相应工单未完成,则该数据源暂时不可删除
  • 连通性测试:点击更多按钮,选择连通性测试,测试是否可以用当前的数据源地址及用户密码成功连入数据源。
- + \ No newline at end of file diff --git a/docs/user-manual/project/instance_syn/index.html b/docs/user-manual/project/instance_syn/index.html index c00d56a2..2c06728d 100644 --- a/docs/user-manual/project/instance_syn/index.html +++ b/docs/user-manual/project/instance_syn/index.html @@ -4,7 +4,7 @@ 外部数据源同步【企业版】 | SQLE 文档 - + @@ -14,7 +14,7 @@ sip

3.针对需要同步的实例组添加项目标签

为需要同步的数据源组,添加业务标签,SQLE同步时,将依据项目标签值,将实例同步至指定项目中,并赋予指定业务属性。 tag

操作步骤

  • 进入SQLE平台,展开数据源管理,点击外部数据源同步,进入同步任务页面
  • 添加同步任务,填写以下相关信息
    • 来源:目前仅支持DMP平台;
    • 地址:默认格式为http://ip:port;
    • 数据源类型:选择需要同步的实例对应的数据源类型,如MySQL;
    • 审核规则模板:选择数据源使用的规则模板;
    • 设置同步间隔:SQLE平台将按照指定的同步时间执行数据源同步任务;
  • 点击提交 按钮,SQLE会立即进行一次数据源同步。

操作结果

同步成功后进入对应项目,查看数据源列表页面,可以看到DMP上配置了SIP的数据源组已经被添加到SQLE平台,可以对这个数据源进行创建工单或创建扫描任务等操作。

syn-result instance-syn

后续操作

管理员可编辑或删除同步任务,也可在同步周期之外,手动执行同步任务。

- + \ No newline at end of file diff --git a/docs/user-manual/project/intro/index.html b/docs/user-manual/project/intro/index.html index 8e51ca7c..d84c73d9 100644 --- a/docs/user-manual/project/intro/index.html +++ b/docs/user-manual/project/intro/index.html @@ -4,7 +4,7 @@ 功能介绍 | SQLE 文档 - + @@ -12,7 +12,7 @@
版本:v3

功能介绍

自2.22.11.0版本起,平台引入项目管理概念,与SQL审核相关的资源均以项目的形式进行资源隔离。创建工单前,需要由项目管理员设置好项目内部必要的资源环境,包括项目使用的数据源、用户、流程模板、规则模板、白名单信息等,随后,项目成员才可在项目内提交工单并审核上线,或设置智能扫描任务。 本文介绍项目管理的使用场景以及如何以项目形式管理SQL工单、扫描任务等项目资源。在进行项目管理之前,需要由管理员进行创建项目,具体操作请参见创建项目

说明

提示

社区版仅支持一个默认项目,项目管理员是admin,企业版可创建多个项目,有创建项目权限的用户可以创建项目,创建项目后,可指定其他项目成员为项目管理员。

使用场景

企业内容存在多个业务,且各个业务之间的数据源、工单、扫描任务可能由不同团队在负责,希望不同团队之间的数据相互隔离。此时,可在平台内以不同项目的行为去管理多个业务资源(数据源、工单、扫描任务等)。

项目内资源调度

资源调度 项目内的主要业务为工单审核及智能扫描任务审核。围绕工单及智能扫描任务,涉及到数据源管理、审核规则模板管理、白名单管理、审核流程管理、成员管理。

以工单审核为例

工单是为了满足下发SQL时审核、上线环节的流程化需求。

工单的完整生命周期包括创建、审核、上线,其中涉及数据源、审核流程、审核规则模板、白名单的操作。

备注
  • 审核流程:一个项目可绑定一个审核流程,该审核流程将应用于该项目下的所有工单审核。
  • 数据源:工单作用于具体的数据源,创建工单时,需要指定一个或多个数据源。
  • 审核规则模板:创建工单时,平台会基于该数据源应用的审核规则模板,对成员提交的SQL语句进行审核,满足应用的审核规则后,才可创建工单。
  • 白名单:创建工单时,若存在不需要审核的SQL语句,可将该SQL语句添加至白名单,提交该SQL时平台将不做审核。

以智能扫描任务为例

智能扫描任务是为了满足长期的SQL审核,平台支持的扫描任务类型包括库表元数据、TopSQL、慢日志、Mybatis扫描、应用程序SQL抓取及其他自定义扫描任务。

智能扫描任务的完整生命周期包括创建、查看扫描任务报告,其中涉及数据源、审核规则模板、白名单的操作。

备注
  • 数据源:智能扫描任务作用于具体的数据源,创建智能扫描任务时,需要指定一个数据源。
  • 审核规则模板:创建的智能扫描任务,将基于该任务下数据源应用的审核规则模板,审核任务中的SQL语句,并生成报告。
  • 白名单:创建扫描任务时,若存在不需要审核的SQL语句,可将该SQL语句添加至白名单,执行扫描任务时,将略过该语句。

项目内资源权限

资源权限

项目内由成员执行工单及扫描任务。

前置条件

  • 需要将平台创建的用户/用户组引入项目,成为项目成员/项目成员组后,才可在项目内进行操作。平台用户/用户组的创建,请参见平台用户管理
  • 引入项目成员/成员组时,需要指定成员/成员组在对应数据源上的操作角色,成员/成员组将继承角色对应的操作权限。角色的配置,请参见平台角色管理

资源权限说明

  • 一个项目内可引入多个成员/成员组
  • 成员/成员组将依据自身绑定的数据源及对应角色权限,对指定数据源进行指定的操作。
  • 如当前项目引入了成员user1,并在user1上绑定了数据源local,并指定角色为DEV(创建工单),那么user1在当前项目中可执行的操作为:针对数据源local创建工单/管理自己创建的工单。
- + \ No newline at end of file diff --git a/docs/user-manual/project/operation_records/index.html b/docs/user-manual/project/operation_records/index.html index 1c71fc8b..0dc25611 100644 --- a/docs/user-manual/project/operation_records/index.html +++ b/docs/user-manual/project/operation_records/index.html @@ -4,13 +4,13 @@ 操作记录 | SQLE 文档 - +
版本:v3

操作记录

使用场景

SQLE平台提供操作记录,当审核/上线产生问题时,用户需要从操作行为判定问题责任方。此时,用户可以使用平台的操作记录功能,查看平台行为的操作人、操作时间。

入口

用户点击操作与审计标签,进入操作记录页面,查看权限范围内可见的操作记录。

  • 用户可对操作记录进行筛选,查看符合条件的操作记录;
  • 用户也可在当前筛选条件下,导出平台操作记录,用以线下审计;

操作记录

更多操作

SQLE会定时回收已产生的操作记录,目前该过期时间默认为90天。如果用户需要自定义过期时间,可以在全局配置中修改。

- + \ No newline at end of file diff --git a/docs/user-manual/project/project_create/index.html b/docs/user-manual/project/project_create/index.html index 10aac433..00d41871 100644 --- a/docs/user-manual/project/project_create/index.html +++ b/docs/user-manual/project/project_create/index.html @@ -4,7 +4,7 @@ 创建项目【企业版】 | SQLE 文档 - + @@ -12,7 +12,7 @@
版本:v3

创建项目【企业版】

本文介绍如何在SQLE平台创建项目。 SQLE平台通过引入项目实现业务、资源的隔离,项目内创建的工单及扫描任务都将带有项目属性,仅项目成员可查看、操作。

使用场景

企业内容存在多个业务,且各个业务之间的数据源、工单、扫描任务可能由不同团队在负责,希望不同团队之间的数据相互隔离。此时,可在平台内以不同项目的行为去管理多个业务资源(数据源、工单、扫描任务等)。

前置条件

创建新项目时,需要用户拥有创建项目的权限,这部分内容可通过管理员账号配置,请参见平台用户管理,或由平台管理员直接创建项目。

操作步骤

拥有项目创建权限的用户/平台管理员点击页面顶部菜单栏项目,选择查看所有项目,点击列表右上角创建项目按钮

  • 输入项目名称。如:actionsky;
  • 输入项目描述。如:处理爱可生项目的数据源、工单及扫描任务;
  • 点击提交;

执行结果

  • 项目创建完成后,可在项目列表中查看当前用户创建的项目。
  • 选中指定项目,可进入项目详情页面,查看并管理项目内的数据源、成员、审核规则模板、审核流程模板等内容。

项目列表

提示

项目创建人在创建项目后会成为项目成员,承担项目管理员的身份,支持指定其他成员成为项目管理员,一个项目可对应多个项目管理员。

后续步骤

项目创建后,用户在进行创建工单、创建扫描任务的核心业务之前,还需要做如下操作:

  • 初始化工单、扫描任务的实施对象即数据源,具体操作请参见数据源管理
  • 初始化工单、扫描任务的使用人员以及使用人员的操作权限即项目成员,具体操作请参见成员管理
  • 初始化工单、扫描任务的审核规则模板,一个项目内可为不同数据源定义不同的规则模板,具体操作请参见规则模板管理
  • 若存在无需审核的SQL,可在白名单管理中初始化白名单,请参见白名单管理; 初始化工单的项目审核流程模板,一个项目内所有工单共用一个审核流程,具体操作请参见流程模板管理

更多管理功能

项目管理包含编辑及删除操作。

  • 项目编辑:项目创建人/平台管理员可在项目列表编辑项目条目信息,可编辑项为项目描述。
  • 项目删除:项目创建人/平台管理员可在项目列表删除项目条目。
    • 限制:删除项目前,需要确保项目下没有进行中的工单,才可成功删除。
    • 影响:删除项目后,该项目下的数据源、工单及扫描任务信息都将被删除。
  • 冻结项目:若有项目需要临时停用,项目创建人/平台管理员可在项目列表点击冻结项目。
    • 限制:冻结项目前,需要确保项目内没有未完成的工单。
    • 影响:冻结项目后,项目内所有操作均不可执行。
    • 后续:用户可点击启用操作,重新启用该项目。
- + \ No newline at end of file diff --git a/docs/user-manual/project/quick_audit/index.html b/docs/user-manual/project/quick_audit/index.html index e84543f4..9ba80533 100644 --- a/docs/user-manual/project/quick_audit/index.html +++ b/docs/user-manual/project/quick_audit/index.html @@ -4,14 +4,14 @@ SQL审核 | SQLE 文档 - +
版本:v3

SQL快捷审核

本文介绍平台的SQL审核功能,该功能可以帮助用户快速审核SQL并了解优化建议。

使用场景

当用户需要快速审核SQL并了解可优化点时,可以使用平台的SQL审核功能,快速获取审核结果。相较于SQL工单,SQL审核更注重用户快速自检,其目的是获取审核结果。而SQL工单除了获取平台的审核结果外,更侧重SQL的标准化上线。

前置条件

用户需要进入项目页面才能使用SQL审核功能。

操作步骤

用户点击左侧菜单栏的SQL审核标签,进入SQL审核列表页面,点击'新建'按钮。

输入审核标签

  • 用户可以使用标签来区分SQL的性质、来源等特性;
  • 平台默认提供两种标签,用户可根据需要新建标签;

选择审核模式

平台默认提供两种审核模式

  • 静态审核:脱库审核,无需选择数据源和数据库,但需要选择SQL对应的数据源类型。
  • 动态审核:连库审核,需要指定数据源、数据库;

输入待审核SQL

平台当前提供5种审核方式,以满足不同的SQL场景。

  • 在线输入:直接在界面上输入SQL。
  • 上传XML文件:上传包含SQL的XML文件。
  • 上传SQL文件:上传SQL文件进行审核。
  • 上传ZIP文件:上传包含多个SQL文件的ZIP文件进行审核。
  • 配置GIT仓库:从GIT仓库中获取SQL文件进行审核。

点击立即审核,获得审核结果

完成SQL输入后,用户点击立即审核按钮,获得平台给出的审核建议

执行结果

审核完成后,用户可以查看审核结果并在SQL审核列表中查看生成的审核记录。 quick-audit

后续操作

添加了标签的SQL审核记录将进入SQL管控列表页面,用户可以在管控列表页面统一管理SQL。

- + \ No newline at end of file diff --git a/docs/user-manual/project/rule-template-manager/index.html b/docs/user-manual/project/rule-template-manager/index.html index 2aa40d53..1f9fc8b1 100644 --- a/docs/user-manual/project/rule-template-manager/index.html +++ b/docs/user-manual/project/rule-template-manager/index.html @@ -4,13 +4,13 @@ 审核规则模板 | SQLE 文档 - +
版本:v3

规则模版

本文将介绍如何管理项目中的审核规则模板。

规则模版分为全局模版和项目模版:

  • 全局模版 为超级管理员配置,所有项目都可见和使用;
  • 项目模版 由超级管理员或者项目拥有者配置,仅在项目内使用

使用场景

SQLE平台提供不同数据库类型的审核规则,是在长期实践中依据数据库特性总结出的一些规范。用户可以根据需要,将这些规则进行聚合,生成不同的规则模板,通过审核规则模板为不同的数据源配置不同的审核规则,用以应对不同场景、不同业务的审核需求。

提示

每个规则模版内可独立配置规则的级别和参数

前置条件

项目管理员进入指定的项目

创建规则模板

入口

项目管理员点击左侧导航栏规则模板菜单,点击创建规则模板按钮。

步骤一:输入基本信息

  • 模板名称:命名当前规则模板,须以字母开头,只能包含字母、数字、中划线和下划线。如:test
  • 模板描述:补充描述模板的其他信息。如:用于测试规则模板触发的告警等级
  • 数据库类型:选择该规则模板应用的数据库类型,当前支持的数据库类型可参考数据源管理

步骤二:选择要启用/禁用的规则

  • 启用/禁用规则
  • 编辑规则告警等级:当前可设置项为普通、提示、警告、告警
  • 编辑规则参数默认值

步骤三:提交规则模板

执行结果

成功创建自定义审核规则模板后,项目管理员可查看已创建的自定义规则模板及其对应的数据库类型。

审核规则模板

后续步骤

  • 设置数据源的审核规则模板:用户可为不同数据源设置相同或者不同的审核规则模板,具体操作请参见数据源管理
  • 创建工单:工单中SQL的审核将依据该数据源配置的审核规则模板,请参见工单说明
  • 创建智能扫描任务:智能扫描任务中SQL的审核将依据该数据源配置的审核规则模板,请参见扫描任务说明

更多操作

  • 导入规则模板:可以导入其他项目中形成的规则模板文件
  • 编辑规则模板:编辑规则模板的基本信息及应用的规则
  • 删除规则模板:删除自行创建的规则模板
    • 限制:当已有数据源绑定了该规则模板,该规则模板不可被删除
  • 克隆规则模板:克隆当前的模板,克隆的规则模版只会继承源模版所有启用的规则、以及变更过的规则等级和阈值。克隆出的新规则模版的模版名称等基本信息需要手动填写。
  • 导出规则模板:导出当前选中的规则模板,以json格式下载规则模板内容。
- + \ No newline at end of file diff --git a/docs/user-manual/project/sqlmanage/index.html b/docs/user-manual/project/sqlmanage/index.html index ad6b987c..df7a2c01 100644 --- a/docs/user-manual/project/sqlmanage/index.html +++ b/docs/user-manual/project/sqlmanage/index.html @@ -4,14 +4,14 @@ SQL管控 | SQLE 文档 - +
版本:v3

SQL全生命周期管控

SQL管控页面集中了用户在SQL审核和扫描任务中生成的SQL,方便进行集中的管理。用户可以快速发现审核出问题的SQL,并将其分配给其他成员处理,或将不关心的SQL设为忽略状态,从而实现高效的SQL管理。

使用场景

当用户的SQL来源多且分散时,需要将这些SQL集中到一个页面进行管理,以避免遗漏问题SQL,并方便追溯问题SQL的产生及后续解决方式

前置条件

用户需要登录平台并生成审核记录,满足以下条件之一:

  • 在使用SQL快捷审核时,为SQL附加了审核标签。
  • 成功配置了扫描任务并生成了审核记录。

使用步骤

用户点击左侧菜单栏的SQL管控标签,进入SQL管控页面。

SQL筛选

平台提供多种筛选方式,帮助用户快速找到符合条件的SQL:

  • SQL来源:根据SQL的来源方式进行筛选,如SQL审核、扫描任务;
  • 数据源:根据SQL所属的数据源进行筛选;
  • Schema:根据SQL所属的Schema进行筛选;
  • 审核规则等级:根据审核规则的等级进行筛选,如error、warning、notice、normal;
  • 时间范围:根据SQL生成的时间范围进行筛选;
  • SQL状态:根据SQL的状态进行筛选,如待处理、已解决、已忽略等;
  • 与我相关:根据SQL是否与当前用户相关进行筛选,可以选择只显示与当前用户有关的SQL。
  • 端点信息:根据SQL的来源端点进行筛选

SQL操作

除了展示和过滤SQL,平台还提供多种SQL操作方式,帮助用户快捷处理SQL:

  • 按指纹查看SQL:支持按SQL指纹做聚合,跳转查看SQL审核列表;
  • 查看SQL执行计划:支持查看SQL分析结果,快速了解SQL的执行计划;
  • 指派负责人:可以将SQL指派给对应负责人处理;
  • 变更状态:可以将表单中的SQL标记为已解决、已忽略或已人工审核的状态;
  • 导出:可以根据当前筛选条件导出SQL管控列表的信息。

操作结果

通过以上步骤,用户可以使用SQL管控功能集中管理SQL,快速发现问题SQL并进行处理。 sqlmanage

- + \ No newline at end of file diff --git a/docs/user-manual/project/whitelist-manager/index.html b/docs/user-manual/project/whitelist-manager/index.html index 6377a0b2..a86c5031 100644 --- a/docs/user-manual/project/whitelist-manager/index.html +++ b/docs/user-manual/project/whitelist-manager/index.html @@ -4,14 +4,14 @@ 白名单管理 | SQLE 文档 - +
版本:v3

白名单企业版

本文介绍如何增加、编辑、删除项目中的白名单。

SQLE在企业版中提供白名单功能,便于用户在特定场景下规避具体规则的审核。添加在SQL审核白名单中的语句,在提交工单申请时,不受审核规则的约束。

提示

白名单目前支持两种方式匹配SQL,字符串匹配和SQL指纹匹配,字符串匹配需要SQL内容一致,SQL指纹匹配匹配同类型的SQL。

使用场景

当已知一些 SQL 存在不规范之处,但又想忽略时,可以将SQL语句添加至白名单。

前置条件

项目管理员进入指定的项目。

添加白名单

项目管理员点击左侧导航栏白名单菜单,点击白名单列表右上角的添加白名单按钮。

  • 选择匹配模式:提供以下两种方式
    • 字符串匹配:若选择通过字符串匹配,则将应用于指定SQL语句。
    • SQL指纹匹配:若选择通过SQL指纹匹配,则应用于语句结构一致的SQL。
  • 输入白名单描述:用以提示该条白名单SQL的应用场景
  • 输入SQL语句

执行结果

成功添加白名单后,您可以在当前项目中查看所有的项目白名单及其匹配模式。

whitelist

此时,审核对应的SQL语句,审核结果处将出现白名单的提示。 whitelist

后续步骤

  • 创建工单:添加白名单后,可继续创建工单,白名单中的语句将不会触发审核,请参见工单说明
  • 创建智能扫描任务:添加白名单后,审核将跳过白名单中的语句,请参见扫描任务说明

更多操作

  • 编辑白名单
  • 删除白名单
- + \ No newline at end of file diff --git a/docs/user-manual/project/workflow-template-manager/index.html b/docs/user-manual/project/workflow-template-manager/index.html index 6bcfe6da..7b450844 100644 --- a/docs/user-manual/project/workflow-template-manager/index.html +++ b/docs/user-manual/project/workflow-template-manager/index.html @@ -4,14 +4,14 @@ 审核流程模板 | SQLE 文档 - +
版本:v3

流程模版

本文介绍项目中的审核流程模板管理。

SQLE平台应用审核流程模板来规范项目内工单审核、上线的流程,项目管理员可配置审核涉及的节点、上线节点,及对应的操作用户。

提示

一个项目有且仅有一个审核流程模板。项目创建后会初始化一个默认模版,用户可根据实际情况调整。

警告

修改流程模版仅对之后的工单有效,之前的工单流程步骤不变

使用场景

一个业务团队中,开发需要在指定数据源上执行SQL,上线的SQL需要符合DBA约定了的安全以及性能规范。因此,SQLE为工单场景提供了不同人员之间的协作工作流,即审核流程。

前置条件

  • 项目管理员进入指定的项目;
  • 项目管理员已添加项目成员/成员组;

配置审核流程

项目管理员点击左侧导航栏流程模板菜单, 点击修改当前审批流程模板按钮

设定模板的基本信息

设置允许创建工单的最高审核等级

当前提供四种审核等级,包括:

  • 普通normal
  • 提示notice
  • 告警warn
  • 错误error

若设置“运行查询的最高审核等级”为告警warn,则审核结果小于等于warn的SQL都可以执行.

设置流程节点

审核流程自工单发起开始,通过设置的审核步骤后,最后以执行上线结束

第一步 工单发起

这一步骤通常指代项目成员创建工单

第二步 工单审核

配置审核节点后,对应审核操作人在该步骤可以执行审核通过或驳回操作

  • 选择审核人类型,可以选择指定审核人或匹配拥有数据源审核权限的成员
  • 添加步骤描述:用以补充说明步骤信息
  • 添加审核步骤:审核流程模板最多可设置4个审核节点,也可不设置审核步骤
提示
  • 若选择指定审核人
    • 需要项目管理员指定项目成员
    • 最少需要添加一个指定人,最多只能添加三个指定人
    • 指定的审核人可以没有工单审核权限
  • 若选择匹配拥有数据源审核权限的成员
    • 将按实例匹配数据源上拥有审核权限的成员
    • 如果创建工单时没有任何用户拥有此数据源工单审核权限, 则项目管理员将会被指定为工单审核人

第三步 工单上线:执行人在该步骤可以执行上线或驳回操作。

  • 选择审核人类型,当前提供两种方式:指定上线人或匹配拥有数据源上线权限的成员
  • 添加步骤描述
提示
  • 若选择指定审核人
    • 需要项目管理员指定项目成员
    • 最少需要添加一个指定人,最多只能添加三个指定人
    • 指定的上线人可以没有工单上线权限
  • 若选择匹配拥有数据源上线权限的成员
    • 将按实例匹配数据源上拥有上线权限的成员
    • 如果创建工单时没有任何用户拥有此数据源工单上线权限, 则项目管理员将会被指定为工单上线人

第四步 提交审核流程模板

提交审核流程后,流程修改之前创建的工单仍以提交工单时的审核流程执行,流程修改后的创建的工单将以当前的审核流程执行流转。

执行结果

提交审核流程模板后,可查看当前设置的审批流程模板涉及的步骤节点,及各步骤的审核人。 审核流程模板

后续步骤

创建工单:创建审核流程模板后,成员可进入项目中创建工单,请参见:创建工单

- + \ No newline at end of file diff --git a/docs/user-manual/project/workflow/audit-workflow/index.html b/docs/user-manual/project/workflow/audit-workflow/index.html index 7e92c539..fe656c72 100644 --- a/docs/user-manual/project/workflow/audit-workflow/index.html +++ b/docs/user-manual/project/workflow/audit-workflow/index.html @@ -4,7 +4,7 @@ 审核工单 | SQLE 文档 - + @@ -13,7 +13,7 @@ 自动审核通常在创建工单时执行,本节主要介绍人工审核部分。

使用场景

实际生产中会存在业务变更、业务上线,比如初始化构建业务库、跑批等,当工单创建后,通常需要审核人员执行审批操作,审批过程中,审批用户可选择审核通过或全部驳回。

前置条件

工单已被创建。

操作步骤

步骤一 查看待审核的工单

  • 入口一:您可在dashboard中查看待自己审核的工单
  • 入口二:进入项目的工单列表,筛选工单状态为待审核,查看项目内待审核的工单

步骤二 点击待审核的工单名称,进入查看工单详情

工单详情页信息包含以下几个方面:

  • 工单基础信息:包括工单名称、工单创建人、工单创建时间及工单描述;
  • 工单进度:查看当前工单的执行进度,及工单整体流经的流程节点,流程节点与审核流程模板中设置的节点保持一致;
  • 工单审核结果查看:
    • 概览:查看工单的整体概况信息,显示工单整体应用的数据源及审核情况
    • 按数据源查看:按数据源查看数据源上的SQL及其审核结果,并查看分析结果,也可下载审核报告、下载SQL语句、去重SQL;

步骤三 审核通过或驳回工单

  • 审核通过:成员查看工单详情后,若审核通过,可点击审核通过按钮,完成审核;
  • 全部驳回:若审核不通过,可点击全部驳回按钮,并填写驳回原因,工单将返回至工单创建人处;

执行结果

  • 审核通过:若点击审核通过,工单将按照审核流程模板流转至下一操作节点,状态变更为待审核或待上线; approve
  • 全部驳回:若点击全部驳回,工单状态将变更为已驳回,工单进度栏将提示提交的驳回原因,工单将返回至创建人处。 deny

后续步骤

  • 审核工单:若工单涉及其他审核流程节点,工单将继续流转至下一审核节点审核
  • 上线工单:若工单不涉及其他审核流程节点,工单将流转至上线人处执行上线,可参考上线工单
- + \ No newline at end of file diff --git a/docs/user-manual/project/workflow/create-workflow/index.html b/docs/user-manual/project/workflow/create-workflow/index.html index bead3b8c..cf6c1029 100644 --- a/docs/user-manual/project/workflow/create-workflow/index.html +++ b/docs/user-manual/project/workflow/create-workflow/index.html @@ -4,7 +4,7 @@ 创建工单 | SQLE 文档 - + @@ -12,7 +12,7 @@
版本:v3

创建工单

工单是SQLE提供的在线化SQL上线方式。研发人员可通过创建工单,提请需要审批的SQL语句。

使用场景

实际生产中会存在业务变更、业务上线,比如初始化构建业务库、跑批。此时,需要针对某个数据库执行一批SQL。用户可通过SQLE创建工单,输入SQL语句或者上传SQL脚本。

前置条件

  • 项目管理员已添加数据源;

操作步骤

步骤一:填写工单基本信息

创建工单前,需要为工单指定唯一的工单名称,并填写工单说明。

  • 填写工单名称:
    • 工单名称支持中英文;
    • 若未填写,平台将根据使用的数据源及添加时间组合填充工单名称;
  • 填写工单描述:输入工单描述信息,限3000个字符;

步骤二:上传SQL语句并审核

需要填写工单中涉及的SQL语句,执行审核操作,SQLE会根据数据源配置的审核规则模板,自动进行SQL语句的规则审核,并在线反馈审核结果。

  • 选择数据源:表示当前SQL最终会应用到哪个数据源;
    • 社区版:一个工单内仅支持选择一个数据源;
    • 企业版:一个工单内支持添加多个数据源;
  • 是否选择相同SQL:当添加多个数据源时,可设置是否选择相同SQL;
    • 使用相同SQL模式,
      • 限制:数据源的数据库类型须相同;
      • 效果:对不同数据源下发相同SQL;
    • 若不使用相同SQL模式
      • 效果:对不同数据源下发不同SQL;
  • 选择数据库:选择要执行SQL的数据库,相当于执行 use 语句;
  • 选择审核SQL语句上传方式:平台提供三种上传方式,包括在线输入SQL语句、上传SQL文件、上传MyBatis的XML文件;
    • 在线输入SQL语句:项目成员可在平台编辑器中直接输入SQL;
    • 上传SQL文件:项目成员可选择本地的SQL文件上传;
    • 上传Mybatis的XML文件:项目成员可选择本地的XML文件上传;
      • 限制:平台仅支持审核XML文件中上传的SQL语句,尚不支持对其创建工单;
  • 点击审核,显示平台审核结果;
提示

在线输入SQL的场景下,平台支持对输入框中的SQL进行美化,以此提高SQL可读性。

注:当前支持SQL美化的数据源类型包括:

  • MySQL
  • DB2
  • SQL Server
  • Oceanbase For MySQL
  • Oracle
  • PostgreSQL

步骤三:查看审核结果

将根据数据源不同,展示不同数据源下的SQL审核结果。 审核结果由以下几部分组成:

  • 数据源标签:显示当前SQL操作的数据源,当有多个数据源时,可切换数据源标签,查看不同数据源上的审核情况;
  • 数据源上SQL的整体审核通过率、审核结果评分及操作的数据库;
  • 数据源上每条SQL的审核结果,包括
    • SQL语句:查看原始SQL
    • 审核结果:查看SQL触发的规则及规则等级;
      • 点击SQL及审核结果栏,可以在右侧抽屉中查看完整信息;
      • 在GIT仓库审核及ZIP文件审核时,可以查看SQL具体的来源路径;
    • SQL分析:企业版用户支持查看SQL分析结果;
  • 功能区:
    • 下载审核报告:查看当前数据源下审核的sql语句及其审核结果;
    • 下载SQL语句:下载文件,可查看当前数据源下审核的SQL语句及其审核结果;
    • 设置是否去重:若SQL语句结构一致,去重后将仅显示去重后的SQL;
审核通过率计算方式
审核通过率=正常sql/sql总数
审核结果等级为notice,warn,err的sql均为非正常sql
审核结果评分计算方式
1.Error以上级别SQL出现率 = Error级别SQL/SQL
2.Warn以上级别SQL出现率 = (Error级别SQL+ Warn级别SQL) /SQL
3.Warn以上级别SQL出现率 = (Error级别SQL+ Warn级别SQL+ Notice级别SQL) /SQL
4.总分 = 审核通过率 x 30 +
(1 - Error以上级别SQL出现率) x 15 +
(1 - Warn以上级别SQL出现率) x 10 +
(1 - Notice以上级别SQL出现率) x 5 +
(Error以上级别SQL出现概率 == 0 ? 15 : 0) +
(Warn以上级别SQL出现概率 == 0 ? 10 : 0) +
(Notice以上级别SQL出现概率 == 0 ? 5 : 0) +
(Error以上级别SQL出现概率 <0.1 ? 5 : 0) +
(Warn以上级别SQL出现概率 <0.1? 3 : 0) +
(Notice以上级别SQL出现概率 <0.1 ? 2 : 0)

备注: 三元表达式 ==> ( 条件 ? 如果条件为真则为此值 : 如果条件为假则为此值 )

步骤四:点击创建工单

完成创建后,进入工单列表,即可看到该工单显示为待审核。

执行结果

创建工单后,可在工单列表查看已创建的所有工单。 list

后续步骤

  • 审核工单:工单创建完成后,将依据审核流程模板的设定,流转至指定的审核成员处,审核成员需登录后进行审核操作,详情可参见审核工单
  • 导出工单:当用户需要审计当前已创建的工单时,可选择筛选条件后,点击工单列表的导出工单按钮,以csv格式导出满足条件的工单信息。
- + \ No newline at end of file diff --git a/docs/user-manual/project/workflow/exec-workflow/index.html b/docs/user-manual/project/workflow/exec-workflow/index.html index 29c712cb..85a629cb 100644 --- a/docs/user-manual/project/workflow/exec-workflow/index.html +++ b/docs/user-manual/project/workflow/exec-workflow/index.html @@ -4,14 +4,14 @@ 上线工单 | SQLE 文档 - +
版本:v3

上线工单

本章详细介绍用户如何进行上线。

  • 从数据源角度,支持多数据源同时上线、单数据源分别上线;
  • 从上线时间角度,支持立即上线、定时上线;
  • 从上线方式角度,支持平台直接上线,也支持后台执行后,线上标记为人工上线;

使用场景

实际生产中上线环节也会存在业务变更等诸多情况,除了对工单做整体上线操作外,还存在以下需求:

  • 需要根据数据源分别上线;
  • 需要避开业务高峰期,在指定时间上线;
  • 已在后台执行SQL,需要线上标记为人工上线;

为此,SQLE平台也提供了多种上线方式,满足用户的上线需求。

前置条件

工单状态为待上线;

操作步骤

步骤一 进入待上线的工单

  • 方式一:上线操作人可在dashboard中点击“需上线”标签,查看当前需要上线的工单;
  • 方式二:上线操作人也可在项目的工单列表中,筛选工单状态为“待上线”的工单,查看当前需要上线的工单;

步骤二 设置工单上线

根据使用场景,区分为以下四种工单上线方式;

1.批量立即上线

针对一个工单内涉及多个数据源,且多个数据源需要同时立即上线的,点击批量上线,平台将对工单内涉及的所有数据源执行上线操作;

2.单个数据源立即上线

点击立即上线后,平台将立即连入指定数据源,并执行SQL变更;

3.单个数据源定时上线

点击定时上线,并设置上线时间,平台将于指定时间上线SQL; 用户也可取消定时上线,重新设置上线方式。

4.标记为人工上线

针对已经线下执行过的工单SQL,用户可点击标记为人工上线按钮,切换工单状态;

提示

上线人仍可选择全部驳回:用户判定工单中存在不合规、性能问题等SQL语句时,则可点击全部驳回,让工单创建人修正后再次进入审核流程。

备注

针对上线中的工单,用户可点击“中止上线”按钮,中断上线流程,以避免当前的上线操作影响正常业务。

执行结果

result

- + \ No newline at end of file diff --git a/docs/user-manual/project/workflow/intro/index.html b/docs/user-manual/project/workflow/intro/index.html index e68130d3..e7e04015 100644 --- a/docs/user-manual/project/workflow/intro/index.html +++ b/docs/user-manual/project/workflow/intro/index.html @@ -4,14 +4,14 @@ 功能说明 | SQLE 文档 - +
版本:v3

功能说明

很多公司通常设有 DBA(Database administrator) 这个职位,他们负责在系统上运行数据库,执行备份,执行安全策略等日常数据库运维的工作。其中,DBA一项重要的工作是规范研发人员在应用程序中使用的 SQL 语句。

场景举例:

产品在迭代过程中,某个表需要新增一个字段,这会涉及到改表操作。 当前处理方法:DBA 依据数据库规范评估SQL语句的合理性。如果评估没有问题,则将修改操作应用到线上数据库。如果公司对于这类操作比较严格,在上线前,可能还需要经过层层审批。所有上线流程中的人都同意后,再将修改操作应用到数据库。

由此引出的问题:

  • SQL上线牵涉范围较广,缺乏规范化流程支撑
  • 工单运转节点不透明,需要DBA去手动通知

定位

SQLE审核工单的出现主要是为了解决上述整个过程中的规范化、流程化的问题。

  • 通过引入审核规则模板,在人工审核前,首先利用规范化的DBA审核经验进行平台预审,提高整体审核效率
  • 通过引入审核流程模板,将SQL语句的流程节点透明化,并明确操作权限归属,提供规范化流程支持

流程

process

状态说明
待审核创建完的工单自动进入「待审核」状态;该状态的工单将由项目流程设置的审核人进行审核。
待上线工单的每一道审核流程均执行通过后,工单状态将由「待审核」状态变更为「待上线」状态;上线人此时可选择立即上线或批量驳回,或针对具体数据源进行立即上线或定时上线。设置定时上线后,工单状态仍为「待上线」,到达预设的上线时间后,变更为「正在上线」状态;设置定时上线但还未到达上线时间的工单,可以由上线人取消定时上线,可以再次对工单进关闭、定时上线/立即上线等操作。
正在上线当上线人进行立即上线,工单会短暂的进入「正在上线」阶段,该阶段的时间取决于SQL是否上线完毕;当上线人选择定时上线,定时上线的工单到预设时间会自动执行SQL上线,此时工单也会由「待上线」状态变更为「正在上线」状态;SQL上线遇到阻塞的工单会一直处于「正在上线」状态。
上线成功SQL上线成功的工单会进入「上线成功」状态;上线成功标志工单流转结束,无法再对工单进行操作。
上线失败SQL上线失败的工单会进入「上线失败」状态;上线失败同样标志工单流转结束,无法再对工单进行操作
已驳回「待审核」的工单可以由每级的审批人进行审核,若审核不通过,被驳回,工单将进入「已驳回」状态;此状态的工单可以由创建人或者超管用户进行修改并重新提交工单,流程将被重置。
已关闭状态为「待审核」、「待上线」或「已驳回」的工单可以由创建人或者超管用户在任何时刻关闭工单,「已关闭」状态标志工单流转结束,无法再对工单进行操作;已经进入上线流程的工单无法关闭。
- + \ No newline at end of file diff --git a/docs/user-manual/sql-workbench/how-to-configure/index.html b/docs/user-manual/sql-workbench/how-to-configure/index.html index 9264e0da..5725389e 100644 --- a/docs/user-manual/sql-workbench/how-to-configure/index.html +++ b/docs/user-manual/sql-workbench/how-to-configure/index.html @@ -4,14 +4,14 @@ 配置方法 | SQLE 文档 - +
版本:v3

配置方法

安装CloudBeaver

提示

SQLE目前支持的CloudBeaver版本包括22.2.0、22.2.1、22.2.3、22.3.1、23.2.1版本

docker 部署:https://github.com/dbeaver/cloudbeaver/wiki/Run-Docker-Container

源码安装:https://github.com/dbeaver/cloudbeaver/wiki/Build-and-deploy

配置CloudBeaver

步骤一 修改CloudBeaver配置文件cloudbeaver.conf

cloudbeaver.conf配置文件通常在conf路径下

配置文件名是否必须修改修改内容修改原因
cloudbeaver.conf将server.rootURI的值改为'/sql_query';将server.serviceURI 的值改为 '/api/'(server.serviceURI默认就是/api/)SQLE目前只支持代理这个路由

config

步骤二 重启CloudBeaver

配置cloudbeaver后,需要重启cloudbeaver以使配置项生效

步骤三 初始化CloudBeaver

  • 使用 http://{IP}:8978/sql_query#/ 可以进入CloudBeaver即代表配置正确
  • 设置管理员用户名及密码:该用户名及密码将用于后续SQLE配置文件中
  • 确认security服务开启
  • 完成设置,登录管理员账号成功,则初始化成功

步骤四 配置完成后检查

  • 确认角色正确:[访问管理] - [角色] 处应当只有admin和user两个角色

  • 确认没有冲突用户:[访问管理] - [用户] 处不应当有名称格式为 sqle-xxx的用户存在, 这会与SQLE自动创建的用户冲突

提示

用admin 跳转Cloudbeaver的时候,SQLE会在Cloudbeaver创建一个新的用户叫sqle-admin ,同时把这个用户缓存到数据库里,每次跳转先去数据库里找这个用户,如果已经存在,就会拿这个用户直接去登陆cb

配置SQLE

步骤一 修改SQLE配置文件, 增加SQL工作台参数

打开SQLE配置文件,配置文件一般位于SQLE工作目录的etc目录下, 文件名一般为sqled.yml 配置文件新增参数sql_query_config

参数字段参数说明
sql_query_configsql工作台参数, 此参数与 sqle_config在同一级

在sql_query_config参数下增加子参数,子参数在 sql_query_config 的下一级, 需要注意缩进

参数字段参数说明
cloud_beaver_hostcloudbeaver IP地址
cloud_beaver_portcloudbeaver访问端口
cloud_beaver_admin_usercloudbeaver管理员账户
cloud_beaver_admin_passwordcloudbeaver管理员密码

配置文件内容参考:

sqleconfig

步骤二 重启SQLE

需要重启以使配置项生效。

步骤三 检查SQLE是否已成功集成CloudBeaver

SQLE重启后进入平台,点击打开SQL工作台,若成功跳转,则说明当前SQLE平台已成功集成CloudBeaver。

提示
  • 平台管理员账户需要有 [添加/修改/删除][用户/实例/权限] 的权限
  • SQLE集成CloudBeaver后请勿使用CloudBeaver的管理员账户直接操作CloudBeaver的用户/实例/权限

常见问题

如果在配置CloudBeaver时,出现跳转不正确等问题,可参考如何解决CloudBeaver跳转不正确的问题

- + \ No newline at end of file diff --git a/docs/user-manual/sql-workbench/how-to-quick-deploy/index.html b/docs/user-manual/sql-workbench/how-to-quick-deploy/index.html index f01b9b85..c843986a 100644 --- a/docs/user-manual/sql-workbench/how-to-quick-deploy/index.html +++ b/docs/user-manual/sql-workbench/how-to-quick-deploy/index.html @@ -4,13 +4,13 @@ 使用定制包快速搭建环境 | SQLE 文档 - +
版本:v3

使用定制包快速搭建环境

SQLE在原有CloudBeaver release_22_2_0 分支的基础上, 增加了对OceanBase 和 TiDB 的支持, 用户无需再手动配置环境,可直接使用SQL工作台功能。

cb

定制分支与原分支区别详情

  • 支持并默认启用 OceanBase 驱动
  • 支持并默认启用 TiDB 驱动
  • 默认访问路由调整为 /sql_query, 便于与SQLE集成
  • 默认会话超时时间调整为12小时(之前是30分钟)
  • 移除了默认创建的 PG 演示实例和 SQLite 演示实例
  • docker镜像名调整为 actiontech/sqle-cloudbeaver:22_2_0
  • 优化打包方式, 大幅提高打包效率
  • 默认主题改为暗色

项目地址

定制包下载地址

https://github.com/actiontech/cloudbeaver/releases/tag/sqle.22.2.0

使用说明

编译和运行项目

与原项目编译运行方式保持一致

编译docker镜像

进入项目的 deploy/docker 目录, 然后执行 ./make-docker-container.sh

运行docker镜像

  • 方式一: 进入项目的 deploy/docker 目录, 然后执行 ./run-docker-container.sh
  • 方式二: 手动启动镜像, 镜像参数和 原项目镜像参数 保持一致

已有CloudBeaver环境升级为定制环境

CloudBeaver程序目录下应当有以下几个文件

cb

将CloudBeaver程序目录下的conf目录和workspace目录移动到定制CloudBeaver程序目录下(覆盖原目录), 随后停止旧CloudBeaver, 运行新CloudBeaver即可

- + \ No newline at end of file diff --git a/docs/user-manual/sql-workbench/how-to-use/index.html b/docs/user-manual/sql-workbench/how-to-use/index.html index a4f95120..2f9697b3 100644 --- a/docs/user-manual/sql-workbench/how-to-use/index.html +++ b/docs/user-manual/sql-workbench/how-to-use/index.html @@ -4,13 +4,13 @@ 使用定制包快速搭建环境 | SQLE 文档 - +
版本:v3

使用定制包快速搭建环境

SQLE在原有CloudBeaver release_22_2_0 分支的基础上, 增加了对OceanBase 和 TiDB 的支持, 用户无需再手动配置环境,可直接使用SQL工作台功能。

cb

定制分支与原分支区别详情

  • 支持并默认启用 OceanBase 驱动
  • 支持并默认启用 TiDB 驱动
  • 默认访问路由调整为 /sql_query, 便于与SQLE集成
  • 默认会话超时时间调整为12小时(之前是30分钟)
  • 移除了默认创建的 PG 演示实例和 SQLite 演示实例
  • docker镜像名调整为 actiontech/sqle-cloudbeaver:22_2_0
  • 优化打包方式, 大幅提高打包效率
  • 默认主题改为暗色

项目地址

定制包下载地址

https://github.com/actiontech/cloudbeaver/releases/tag/sqle.22.2.0

使用说明

编译和运行项目

与 原项目编译运行方式 保持一致

编译docker镜像

进入项目的 deploy/docker 目录, 然后执行 ./make-docker-container.sh

运行docker镜像

  • 方式一: 进入项目的 deploy/docker 目录, 然后执行 ./run-docker-container.sh
  • 方式二: 手动启动镜像, 镜像参数和 原项目镜像参数 保持一致

已有CloudBeaver环境升级为定制环境

CloudBeaver程序目录下应当有以下几个文件

cb

将CloudBeaver程序目录下的conf目录和workspace目录移动到定制CloudBeaver程序目录下(覆盖原目录), 随后停止旧CloudBeaver, 运行新CloudBeaver即可

- + \ No newline at end of file diff --git a/docs/user-manual/sql-workbench/introduction/index.html b/docs/user-manual/sql-workbench/introduction/index.html index f513dd3e..eba97062 100644 --- a/docs/user-manual/sql-workbench/introduction/index.html +++ b/docs/user-manual/sql-workbench/introduction/index.html @@ -4,7 +4,7 @@ 功能说明 | SQLE 文档 - + @@ -13,7 +13,7 @@ error

审核拦截场景

步骤一 SQLE平台配置用户及角色

  • 创建一个用户A;
  • 创建一个有SQL查询权限的角色:SQL查询;

步骤二 SQLE平台配置数据库实例审核等级

进入项目,创建/修改一个数据源实例A, 在配置中开启SQL查询,并设置运行查询的最高审核等级;

参数名参数含义
SQL查询是否需要审核只有开启此项,才会在执行SQL查询时进行审核
运行查询的最高审核等级如果审核等级低于或等于这个等级将会放行, 高于这个等级将无法执行

步骤三 SQLE平台配置成员权限

  • 在项目内添加成员A,并设置A在实例test上有SQL查询的角色;

步骤四 登录CloudBeaver

切换成员A账号后,点击SQL工作台跳转CloudBeaver,SQLE将会自动使用当前SQLE用户登录CloudBeaver。

警告

若当前用户无SQL查询权限,则无权登录。

步骤五 下发SQL

选择需要操作的数据源,并输入SQL语句点击运行,可查看SQL查询结果

操作结果

审核失败的SQL将会被拦截, 并报出错误, 可以点击详情查看错误详情 error

按要求修改SQL, 再次执行, 如果审核通过将会执行当前SQL success

- + \ No newline at end of file diff --git a/docs/user-manual/sys-configuration/configuration/index.html b/docs/user-manual/sys-configuration/configuration/index.html index 0a8f64d9..07350fe3 100644 --- a/docs/user-manual/sys-configuration/configuration/index.html +++ b/docs/user-manual/sys-configuration/configuration/index.html @@ -4,14 +4,14 @@ 全局配置 | SQLE 文档 - +
版本:v3

全局配置

SQLE支持管理员对平台基础配置进行统一管理,目前支持修改的配置项包括:

  • 已完成的工单自动过期时间;
  • 操作记录过期时间;
  • URL地址前缀;

已完成的工单自动过期时间

使用场景

SQLE会定时回收已完成的工单,目前该过期时间默认为30天。如果用户需要自定义过期时间,可在全局配置中修改。

填写范例

  • 进入全局配置页面,点击修改
  • 点击已完成的工单过期时间输入框;
  • 输入预期的过期时间,例如:360小时;
  • 点击提交,保存配置;
  • 此时查看项目工单列表,已完成15天以上的工单将被删除;

操作记录过期时间

使用场景

SQLE会定时回收已产生的操作记录,目前该过期时间默认为90天。如果用户需要自定义过期时间,可在全局配置中修改。

填写范例

  • 进入全局配置页面,点击修改
  • 点击操作记录过期时间输入框;
  • 输入预期的过期时间,例如:2小时;
  • 点击提交,保存配置;
  • 此时查看平台操作记录,仅显示2个小时内产生的操作行为;

URL地址前缀

使用场景

配置消息推送或流程对接后,用户可以从外部应用程序中直接查看待操作提示。此时,如果用户需要跳转到SQLE,进一步查看工单详细信息,则可以在全局配置中更改URL地址前缀,以满足访问需求。

填写范例

  • 进入全局配置页面,点击修改
  • 点击URL地址前缀输入框;
  • 输入URL前缀,格式为http://ip:port,例如:http://localhost:10000 ;
  • 点击提交,保存配置;
  • 创建一条工单,待审批人在第三方应用中可查看工单链接,点击链接可快速跳转至SQLE平台; configuration-url
- + \ No newline at end of file diff --git a/docs/user-manual/sys-configuration/customize/index.html b/docs/user-manual/sys-configuration/customize/index.html index 98233bda..f9e7c02b 100644 --- a/docs/user-manual/sys-configuration/customize/index.html +++ b/docs/user-manual/sys-configuration/customize/index.html @@ -4,13 +4,13 @@ 个性化设置【企业版】 | SQLE 文档 - +
版本:v3

个性化设置【企业版】

SQLE支持对网站logo及标题进行自定义设置,满足企业用户的个性化需求。

使用场景

若用户对企业一致性有需求,需要变更所使用的网站LOGO及标题,以增加企业辨识度时,可以使用平台的个性化设置进行变更。

操作步骤

  • 用户点击系统设置,选择个性化设置
  • 编辑个性化标题:用户点击个性化标题后的编辑icon,输入新名称,回车键保存后,页面标题将即时变更;
  • 编辑个性化logo:用户点击上传及更新icon后,登录页logo将变更为所选图片;
    • 限制:图片大小不可超过102,400 Bytes;

customize

- + \ No newline at end of file diff --git a/docs/user-manual/sys-configuration/intro/index.html b/docs/user-manual/sys-configuration/intro/index.html index b55fcce0..49827e36 100644 --- a/docs/user-manual/sys-configuration/intro/index.html +++ b/docs/user-manual/sys-configuration/intro/index.html @@ -4,13 +4,13 @@ 功能说明 | SQLE 文档 - +
版本:v3

功能说明

系统设置中可配置的内容包括全局配置、登录对接、流程对接、消息推送。

  • 全局配置:当前可配置工单过期时间及外部URL;
    • 工单失效时间:平台会定期清理已完成的工单,管理员可自定义工单过期的时间;
    • URL地址前缀:当使用流程对接时,通常由外部平台访问SQLE工单详情,需要配置URL地址前缀,配置能访问SQLE的URL地址信息;
  • 登录对接:用户除使用SQLE账号登录平台,也可使用LDAP及OAuth2.0的方式实现对接登录,可参考登录对接
  • 流程对接:使用流程对接,可在外部工作平台审批工单,目前支持钉钉审批及飞书审批,可参考流程对接
  • 消息推送:使用消息推送,可将工单状态变更推送到外部工作平台,目前支持对接邮箱、企业微信、飞书、Webhook的方式,可参考消息推送
- + \ No newline at end of file diff --git a/docs/user-manual/sys-configuration/login_syn/index.html b/docs/user-manual/sys-configuration/login_syn/index.html index 3309d669..f6207373 100644 --- a/docs/user-manual/sys-configuration/login_syn/index.html +++ b/docs/user-manual/sys-configuration/login_syn/index.html @@ -4,14 +4,14 @@ 登录对接 | SQLE 文档 - +
版本:v3

登录对接

当前登录对接已实现LDAP方式及Oauth2.0方式

入口

管理员账号,点击更多按钮,点击系统设置,跳转系统设置页面后,点击“对接登录”标签

推送方式

LDAP

功能说明

SQLE中支持通过配置的方式接入LDAP系统, 如同其他系统一样接受统一的用户管理, 以便于管理员管理SQLE中的用户, 也使得员工无需在使用一套公司内通用账号密码的同时单独记录SQLE的账号密码。 在SQLE中, 如果正确配置并启用了LDAP功能, 用户就可以在登录界面使用LDAP中记录的账号密码进行登录, SQLE会在员工第一次登录时同步此员工的账号和邮箱, 并在以后的登录中均通过LDAP校验此账户

使用场景

当组织配置了LDAP对接登录系统时,平台管理员可进行相关配置。

前置操作

已配置LDAP

操作步骤

点击修改,选择启用LDAP

  • LDAP服务器地址:用于LDAP登陆时SQLE找到LDAP服务器的位置
  • LDAP服务器端口:用于LDAP登陆时SQLE找到LDAP服务的工作端口
  • 连接用户DN:当用户登录时需要先使用管理用户登录到LDAP中查找出登录用户在LDAP中的DN, 再使用查找出的DN和登录用户填写的密码进行LDAP登录校验
  • 连接用户密码:连接用户DN登录时的密码
  • 查询根DN:用于限定SQLE中LDAP登录的作用范围
  • 用户属性名:用于LDAP用户登录时查询登录用户的DN, LDAP中此属性对应的值也将用作此用户第一次登录SQLE自动注册时的用户名
  • 用户邮箱属性名:SQLE将根据此属性名从LDAP中获取到用户的邮箱, 并将此邮箱用于此用户第一次登录SQLE自动注册时的用户邮箱

后续操作

修改后用户即可通过LDAP账号登录SQLE平台

OAuth 2.0【企业版】

功能说明

SQLE中支持通过配置的方式接入OAuth 2.0系统, 如同其他系统一样接受统一的用户管理, 以便于管理员管理SQLE中的用户, 也使得员工无需在使用一套公司内通用账号密码的同时单独记录SQLE的账号密码

在SQLE中, 如果正确配置并启用了OAuth 2.0功能, 用户就可以在登录界面使用第三方登录, SQLE会在员工第一次登录时要求用户绑定或自动创建一个SQLE用户, 并在以后的登录中可以使用OAuth 2.0用户登录, 也可以用绑定的SQLE用户账号密码登录

使用场景

当组织配置了OAuth 2.0对接登录系统时,平台管理员可进行相关配置。

前置操作

已配置OAuth 2.0

操作步骤

点击修改,选择启用OAuth 2.0

  • 应用ID:应用的唯一标识, 从要对接的平台申请 , 在OAuth2.0认证过程中,appid的值即为oauth_consumer_key的值
  • 应用密钥:appid对应的密钥,访问用户资源时用来验证应用的合法性。在OAuth2.0认证过程中,appkey的值即为oauth_consumer_secret的值
  • 外部访问SQLE的地址:格式为 http(s)://ip:port
  • oauth2登录授权页面地址:格式类似于 http(s)://ip:port/xxx
  • oauth2 access_token 获取地址:格式类似于 http(s)://ip:port/xxx
  • oauth2 user id 获取地址:格式类似于 http(s)://ip:port/xxx
  • 请求资源范围:此范围由验证服务器定义
  • access_token放置位置:SQLE会在获取用户ID时将access_token放在这个key对应的value中, 此参数会作为get请求的参数发送给用户ID获取地址
  • 用户ID保存位置:SQLE会尝试使用此key从第三方平台的响应中解析出用户ID,用户ID应当为唯一ID
  • 登录按钮文字
提示

当仅允许内网访问SQLE服务时,请确保回调地址的后缀为"/v1/oauth2/callback"。

后续操作

启用后SQLE登录界面出现其他方式跳转登录入口,点击,可跳转至对应登录页面

- + \ No newline at end of file diff --git a/docs/user-manual/sys-configuration/message_syn/index.html b/docs/user-manual/sys-configuration/message_syn/index.html index 34f114ca..30902925 100644 --- a/docs/user-manual/sys-configuration/message_syn/index.html +++ b/docs/user-manual/sys-configuration/message_syn/index.html @@ -4,7 +4,7 @@ 消息推送 | SQLE 文档 - + @@ -18,7 +18,7 @@ example
  • 当t1审核通过后,成员admin作为待上线人, admin手机号绑定的飞书账号下,收到一则待上线的工单通知; example
  • 当admin上线成功后,工单创建人将收到一则工单上线成功的消息; example
  • 根据以上示例,用户可了解飞书消息推送的部分场景。

    - + \ No newline at end of file diff --git a/docs/user-manual/sys-configuration/process_syn/index.html b/docs/user-manual/sys-configuration/process_syn/index.html index ec90e605..aaabfbce 100644 --- a/docs/user-manual/sys-configuration/process_syn/index.html +++ b/docs/user-manual/sys-configuration/process_syn/index.html @@ -4,7 +4,7 @@ 流程对接 | SQLE 文档 - + @@ -25,7 +25,7 @@ dingding-telconfig

    打开全局配置,配置SQLE的URL地址,配置URL地址后,用户可从飞书跳转访问SQLE工单详情页面; globalurl

    利用飞书进行审批

    当发生工单变化时,工单关联成员可在对应飞书账号中收到通知,并进行相应的审批操作; dingding-flow

    - + \ No newline at end of file diff --git a/docs/user-manual/sys-configuration/webhook/index.html b/docs/user-manual/sys-configuration/webhook/index.html index e85b1e7a..ceb11775 100644 --- a/docs/user-manual/sys-configuration/webhook/index.html +++ b/docs/user-manual/sys-configuration/webhook/index.html @@ -4,14 +4,14 @@ webhook配置 | SQLE 文档 - +
    版本:v3

    webhook配置

    Webhook是用户定义的自定义HTTP回调。它们通常由事件触发,例如SQLE中存在工单状态的变化,则会自动向用户配置的webhook URL发送HTTP请求。

    使用场景

    当用户配置了自定义API服务,想要在API服务中实时获取工单执行状态时,可在系统设置中配置webhook服务。在SQLE中配置回调地址后,工单状态一旦发生变更,即可在API服务中获取状态通知信息,无需定时登录SQLE平台以查询结果。

    提示

    当前会触发通知的事件有:

    • 有新工单被创建
    • 工单审核被通过
    • 工单审核被驳回
    • 工单被成功上线
    • 工单上线失败

    前置操作

    用户需在使用的API服务中生成用于接收回调通知的webhook url。

    备注

    当前webhook url仅支持http格式。

    操作步骤

    1. 以平台管理员账号登录, 进入系统设置-消息推送,选择webhook配置,并点击修改;
    2. 选择启用webhook;
    3. 填写webhook url:用于工单消息推送的 API 地址;
    4. 填写最大重试次数:默认3次,取值范围0-5。如果推送存在失败,每一个事件请求将最多连续3次执行推送,如3次都失败,则不再推送本次事件;
    5. 填写重试间隔:默认1秒,取值范围1-5。如果推送存在失败,重试时将以1s的时间间隔进行重试;
    6. 填写Token:云服务在发送通知时使用的访问令牌,参考规范:https://datatracker.ietf.org/doc/html/rfc6750;
    7. 提交保存配置;

    后续步骤

    用户点击“测试”,如配置正确,能在API服务端收到正确的调用测试信息: "This is a SQLE test notification\nIf you receive this message, it only means that the message can be pushed".

    接口文档

    SQLE POST 请求格式
    POST / HTTP/1.1
    Host: 192.168.21.34:8000
    Accept-Encoding: gzip
    Authorization: Bearer test123
    Content-Length: 239
    User-Agent: Go-http-client/1.1

    {"event":"workflow","action":"create","timestamp":"2023-05-18T15:45:25+08:00","payload":{"workflow":{"project_name":"test_project","workflow_id":"1658637666259832832","workflow_subject":"test_workflow","workflow_status":"wait_for_audit"}}}
    • "event":当前取值恒为 "workflow"(目前SQLE只支持工单通知);
    • "action":可能的取值有 ["create", "approve", "reject", "exec_success", "exec_failed"]。分别对应「工单创建」、「审核通过」、「审核驳回」、「上线成功」、「上线失败」;
    • "timestamp":表示请求发出的时间,RFC3339 格式;
    • "payload":表示该请求的主要业务内容,目前仅支持工单;
    • "workflow":表示该工单的当前信息,与 sqle 后端数据库中记录保持一致;

    注意事项

    • 用户配置的 token 会被放置在请求 Header 中的 Authorization 字段。参考规范:https://datatracker.ietf.org/doc/html/rfc6750 。SQLE对token字段没有任何限制。需要接受端根据自身情况决定是否使用 token;
    • 接收请求的服务端在收到请求后,需要返回 200 响应。否则 sqle 会打印返回 body 中的文本信息。
    • 在发送测试请求时,请确保接收请求的服务端运行正常。否则可能出现如下问题:
    {
    "code": 0,
    "message": "ok",
    "data": {
    "send_error_message": "Post \"http://192.168.21.34:8000\": dial tcp 192.168.21.34:8000: connect: connection refused"
    }
    }
    - + \ No newline at end of file diff --git a/docs/user-manual/user-manager/intro/index.html b/docs/user-manual/user-manager/intro/index.html index addda1d1..a877d9ca 100644 --- a/docs/user-manual/user-manager/intro/index.html +++ b/docs/user-manual/user-manager/intro/index.html @@ -4,13 +4,13 @@ 功能说明 | SQLE 文档 - +
    版本:v3

    功能说明

    用户中心包含用户管理、角色管理及操作权限列表,由平台管理员操作,涉及用户及角色权限的配置。

    • 用户管理:指平台用户的管理,由管理员创建用户或编辑用户基本信息,可参考用户管理
    • 角色管理:SQLE平台使用角色管理来实现操作权限组合,由管理员创建,可参考角色管理

    使用场景

    • 在添加项目成员、成员组之前,需要由管理员首先创建平台用户,项目管理员才可将用户添加为项目成员。
    • 为项目成员绑定数据源与角色操作权限前,需要由管理员创建相应权限的角色模板,项目管理员可为成员绑定配置的角色模板。
    - + \ No newline at end of file diff --git a/docs/user-manual/user-manager/role/index.html b/docs/user-manual/user-manager/role/index.html index c06e2e21..f6a31cbe 100644 --- a/docs/user-manual/user-manager/role/index.html +++ b/docs/user-manual/user-manager/role/index.html @@ -4,13 +4,13 @@ 角色管理 | SQLE 文档 - +
    版本:v3

    角色管理

    当需要为用户设置动作权限时,可使用角色管理配置动作组合。

    如用户需要有创建工单、审核工单、SQL查询的动作权限,管理员可以在角色管理创建一个角色,并绑定创建工单、审核工单、SQL查询这三个动作,随后只需将此角色关联至指定成员,即可完成用户的动作权限设置。

    操作步骤

    • 点击顶部导航栏更多按钮,点击平台管理栏目下的用户中心选项,查看角色管理标签。
    • 点击列表右上角创建角色按钮,填写相关信息
      • 角色名
      • 角色描述
      • 选择动作权限:配置该角色所拥有的操作权限,SQLE平台支持的动作权限如下:
    权限名权限码权限说明
    查看他人工单20100当角色拥有该动作权限时,角色可以查看绑定的数据源上其他用户创建的工单
    创建/编辑工单20200当角色拥有该动作权限时,角色可以在绑定的数据源上创建工单
    工单审批20300当审核流程模版中的某个审核步骤指定为允许所有有权限的用户审批时, 拥有此权限的用户将可以审批对应工单
    审核任务查看30100拥有此权限的用户可以查看所有审核任务, 无此权限的用户只能查看自己创建审核任务
    审核任务创建30200拥有此权限的用户可以创建审核任务
    sql查询40100拥有此权限的用户可以上线工单

    执行结果

    可在角色列表查看创建的角色信息。

    role

    后续步骤

    • 添加成员/成员组:项目管理员在项目中添加成员/成员组时,需要绑定成员/成员组在对应数据源上的角色权限,可参考成员/成员组管理

    更多操作

    • 编辑角色:点击角色列表的编辑按钮,编辑角色信息。角色名不可更改,可设置角色禁用,则对应权限不会生效。
    • 删除角色:点击角色列表的删除按钮,删除角色信息。
    - + \ No newline at end of file diff --git a/docs/user-manual/user-manager/user/index.html b/docs/user-manual/user-manager/user/index.html index 3aab4ffc..20cd1f43 100644 --- a/docs/user-manual/user-manager/user/index.html +++ b/docs/user-manual/user-manager/user/index.html @@ -4,13 +4,13 @@ 用户管理 | SQLE 文档 - +
    版本:v3

    用户管理

    当需要创建新的用户,或需要由管理员修改用户基本信息时,可以进行用户管理的相关操作。

    操作步骤

    • 点击顶部导航栏更多按钮,点击平台管理栏目下的用户中心选项,查看用户管理标签。

    • 点击列表右上角创建用户按钮,填写用户相关信息:

      • 用户名
      • 密码
      • 确认密码
      • 邮箱:若开启邮件推送或飞书推送服务,则将会以邮件形式通知对应用户工单的流转状态
      • 微信ID:若开启企业微信推送服务,则将通过企业微信通知对应用户工单的流转状态
      • 平台管理权限:当前可选项为创建项目,若选择该权限,则该用户将具有创建项目的权限
    • 点击提交,完成用户创建

    执行结果

    创建成功后,可在用户列表中查看已创建的用户信息

    userlist

    后续步骤

    • 添加项目成员:项目管理员可进入指定项目,将创建的用户添加为项目成员,可参考成员/成员组管理

    更多操作

    • 编辑用户:其中,用户名不可更改,其他信息项均可更改。
    • 删除用户
    • 修改用户密码:点击用户列表的更多按钮,下拉菜单中点击更修改该用户密码
      提示

      管理员还可以对指定的用户进行禁用或者启用。 当用户被管理员禁用后,该用户将无法登录,也无法进行任何操作。 管理员用户永远无法禁用自己本身。

    - + \ No newline at end of file diff --git a/docs/v2/FAQ/intro/index.html b/docs/v2/FAQ/intro/index.html index 3ee72810..5cf24156 100644 --- a/docs/v2/FAQ/intro/index.html +++ b/docs/v2/FAQ/intro/index.html @@ -4,13 +4,13 @@ FAQ | SQLE 文档 - +
    版本:v2

    FAQ

    本章将针对使用过程中的常见问题进行解答。

    - + \ No newline at end of file diff --git a/docs/v2/FAQ/whichdatabase/index.html b/docs/v2/FAQ/whichdatabase/index.html index dae72928..209a3464 100644 --- a/docs/v2/FAQ/whichdatabase/index.html +++ b/docs/v2/FAQ/whichdatabase/index.html @@ -4,13 +4,13 @@ 支持哪些数据库 | SQLE 文档 - +
    版本:v2

    支持的数据库及版本

    数据库类型验证可用的版本
    MySQL5.7.25 、8.0.33
    PostgreSQL9.3 – 13
    Oracle11.2、12.1、12.2
    SQL server2008、2012、2016
    DB211.5
    TiDB4.0.8
    OceanBase For MySQL3.5
    达梦V8
    提示

    当前版本为SQLE验证确认可用的版本,若需要使用其他版本,需自行验证

    - + \ No newline at end of file diff --git a/docs/v2/SUMMARY/index.html b/docs/v2/SUMMARY/index.html index 11c36c82..bd546e28 100644 --- a/docs/v2/SUMMARY/index.html +++ b/docs/v2/SUMMARY/index.html @@ -4,13 +4,13 @@ Summary | SQLE 文档 - + - + \ No newline at end of file diff --git a/docs/v2/deploy-manual/cluster/index.html b/docs/v2/deploy-manual/cluster/index.html index 4b7c9e22..7c688f76 100644 --- a/docs/v2/deploy-manual/cluster/index.html +++ b/docs/v2/deploy-manual/cluster/index.html @@ -4,13 +4,13 @@ 集群部署【企业版】 | SQLE 文档 - +
    版本:v2

    集群部署【企业版】

    SQLE支持集群模式,支持主节点宕机后,从节点能够提升为主并支持后台任务,执行如工单定时上线,智能扫描任务,工单回收,外部数据源对接,钉钉工单对接等任务,保证任务正常执行。

    cluster

    使用场景

    当用户需要对SQLE配置高可用场景,确保任一服务节点宕机均不会影响到业务的正常执行时,用户可开启集群模式。

    配置说明

    开启集群模式仅需用户进入SQLE配置文件,修改如下内容:

    参数说明示例备注
    server:sqle_config:enable_cluster_mode是否开启集群模式true当需要开启集群模式时,新增该参数,并设为开启
    server:sqle_config:server_idSQLE节点的IDnode_1目前未对节点进行全局唯一校验,需要人工确认集群内不能重复,重复会导致出现多leader等情况
    配置文件示例
      server:
    sqle_config:
    server_port: 10000
    auto_migrate_table: true
    debug_log: false
    log_path: './logs'
    plugin_path: './plugins'
    enable_cluster_mode: true # true表示开启集群模式
    server_id: node_1 # 设置当前节点编号
    db_config:
    mysql_cnf:
    mysql_host:
    mysql_port:
    mysql_user:
    mysql_password:
    mysql_schema:
    提示

    修改配置文件后,需要重启SQLE生效。

    - + \ No newline at end of file diff --git a/docs/v2/deploy-manual/config/index.html b/docs/v2/deploy-manual/config/index.html index 0afbd2b7..3d987f59 100644 --- a/docs/v2/deploy-manual/config/index.html +++ b/docs/v2/deploy-manual/config/index.html @@ -4,13 +4,13 @@ 配置文件说明 | SQLE 文档 - +
    版本:v2

    配置文件说明

    提示

    SQLE的配置文件采用yml的格式,默认情况下位于SQLE安装目录下,路径为./etc/sqled.yml

    默认文件参考

    server:
    sqle_config:
    server_port: 10000
    enable_https: false
    cert_file_path: './etc/cert.pem'
    key_file_path: './etc/key.pem'
    auto_migrate_table: true
    debug_log: false
    log_path: './logs'
    log_max_size_mb: 1024
    log_max_backup_number: 2
    secret_key: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' #从 v1.2203.0 版本引入
    db_config:
    mysql_cnf:
    mysql_host: '127.0.0.1'
    mysql_port: 3306
    mysql_user: 'root'
    mysql_password: '123456'
    mysql_schema: 'sqle'

    配置说明

    sqle_config

    参数说明
    server_portsqle 服务的 http 端口,默认10000
    enable_https是否开启https,默认不开启
    cert_file_pathhttps 证书路径
    key_file_pathhttps 私钥路径
    auto_migrate_table自动创建表结构,初始化数据
    debug_log开启debug模式,打印更多日志,会打印业务SQL,开发环境可开启
    log_path日志目录
    log_max_size_mb单个日志文件最大大小,单位MB
    log_max_backup_number日志文件最大备份数量
    secret_key全局AES加密秘钥,影响登录和用户密码等的存储;生产环境建议配置该值替换掉程序默认值,不然会存在安全风险;格式是32位随机字符串

    db_config

    参数说明
    mysql_hostSQLE存储库的地址
    mysql_portSQLE存储库的端口
    mysql_userSQLE存储库的数据库用户
    mysql_passwordSQLE存储库的数据库密码
    mysql_schemaSQLE存储库的数据库 schema
    - + \ No newline at end of file diff --git a/docs/v2/deploy-manual/docker-compose/index.html b/docs/v2/deploy-manual/docker-compose/index.html index 5760b350..612b0486 100644 --- a/docs/v2/deploy-manual/docker-compose/index.html +++ b/docs/v2/deploy-manual/docker-compose/index.html @@ -4,13 +4,13 @@ Docker Compose 部署 | SQLE 文档 - +
    版本:v2

    Docker Compose 部署

    使用 docker-compose 部署不需要提前准备 MySQL 环境,可以一键生成 SQLE 环境

    配置文件

    下载地址:docker-compose.yaml

    使用说明

    将 docker-compose.yaml 文件下载到本地目录,并进入目录内,通过环境变量SQLE_IMAGE指定不同版本的 SQLE 镜像,默认是 latest。

    SQLE_IMAGE=actiontech/sqle-ce:latest docker-compose up -d

    访问

    http://127.0.0.1:10000

    - + \ No newline at end of file diff --git a/docs/v2/deploy-manual/docker/index.html b/docs/v2/deploy-manual/docker/index.html index 763e3203..aeb097f5 100644 --- a/docs/v2/deploy-manual/docker/index.html +++ b/docs/v2/deploy-manual/docker/index.html @@ -4,13 +4,13 @@ Docker 部署 | SQLE 文档 - +
    版本:v2

    Docker 部署

    Docker hub 地址

    actiontech/sqle-ce

    Docker 参考命令

    docker run -d -it \
    --name sqle-server \
    -p 10000:10000 \
    -e MYSQL_HOST="10.10.10.10" \
    -e MYSQL_PORT=3306 \
    -e MYSQL_USER="username" \
    -e MYSQL_PASSWORD="password" \
    -e MYSQL_SCHEMA="sqle" \
    actiontech/sqle-ce:latest

    参数说明

    使用环境变量传递参数,这些指定的配置会映射到 sqled.yml 配置内,指定数据库的配置等。

    变量说明
    MYSQL_HOST数据库地址
    MYSQL_PORT数据库端口
    MYSQL_USER数据库用户
    MYSQL_PASSWORD数据库密码
    MYSQL_SCHEMASQLE 服务使用的指定的 schema
    DEBUG是否输出 debug 日志,默认为false
    AUTO_MIGRATE_TABLE是否自动创建表格和初始化数据,默认为true

    注意点

    提示

    使用 docker 命令运行容器需要提前准备 MySQL 服务并且创建对应的数据库 schema,创建数据库的SQL可参考:RPM 部署

    提示

    如果 SQLE 容器启动失败可以使用 docker logs sqle-server 查看启用日志,其中 sqle-server是容器名称。

    - + \ No newline at end of file diff --git a/docs/v2/deploy-manual/intro/index.html b/docs/v2/deploy-manual/intro/index.html index c7146d9e..d1d3e125 100644 --- a/docs/v2/deploy-manual/intro/index.html +++ b/docs/v2/deploy-manual/intro/index.html @@ -4,13 +4,13 @@ 安装说明 | SQLE 文档 - +
    版本:v2

    安装说明

    SQLE 提供了多种安装部署的方式,用户可以结合自己的环境和现状选择。初次体验或者测试使用的话建议使用docker-compose 或 docker 快速部署。

    安装方式

    1. 源码安装
    2. RPM 部署
    3. Docker 部署
    4. Docker Compsoe 部署

    如何访问

    SQLE 对外提供 web 服务,在程序部署完成后,即可通过 SQLE UI 访问:http://127.0.0.1:10000

    提示

    ps:ip 和端口请根据前面的配置自行替换,默认端口是10000。

    初始用户

    • 用户名:admin
    • 密码:admin
    - + \ No newline at end of file diff --git a/docs/v2/deploy-manual/rpm/index.html b/docs/v2/deploy-manual/rpm/index.html index ceef1b07..c1a07632 100644 --- a/docs/v2/deploy-manual/rpm/index.html +++ b/docs/v2/deploy-manual/rpm/index.html @@ -4,13 +4,13 @@ RPM 安装 | SQLE 文档 - +
    版本:v2

    RPM安装

    环境准备

    • CentOS 7
    • MySQL 5.7

    下载安装包

    下载 SQLE 的 RPM 安装包,下载连接点击这里

    安装 SQLE

    执行 RPM 的安装命令:

    rpm -ivh /path/to/sqle-ce-${version}.qa.el7.x86_64.rpm --prefix=/opt/sqle

    创建数据库

    准备一台 MySQL5.7 作为 SQLE 的后端存储数据库。执行下面命令创建 SQLE 需要的 schema:

    CREATE DATABASE IF NOT EXISTS sqle default character set utf8mb4 collate utf8mb4_unicode_ci
    提示

    创建好的 Schema 将在下面修改SQLE配置时使用到。

    修改 SQLE 配置文件

    安装完 SQLE 后,需要根据实际情况修改SQLE的配置,参考:配置文件说明。SQLE安装完成后提供一个配置模版可直接修改。

    cd /opt/sqle/etc
    mv sqled.yml.template sqled.yml
    vim sqled.yml
    提示

    确保 sqled.yml 的文件 owner 为 actiontech-universe:actiontech

    启动 SQLE

    SQLE 进程通过 Systemd 管理。在成功安装 RPM 后,执行启动命令:

    systemctl start sqled

    启动失败问题诊断

    参考:https://github.com/actiontech/sqle/discussions/1239

    - + \ No newline at end of file diff --git a/docs/v2/deploy-manual/source/index.html b/docs/v2/deploy-manual/source/index.html index 790a7db0..f4768873 100644 --- a/docs/v2/deploy-manual/source/index.html +++ b/docs/v2/deploy-manual/source/index.html @@ -4,13 +4,13 @@ 源码安装 | SQLE 文档 - +
    版本:v2

    源码安装

    环境准备

    • CentOS 7
    • MySQL 5.7
    • Docker
    • Docker Compose(可选)

    获取源码

    SQLE 前端与后端代码分两个仓库维护,所以想要通过源码安装,需要构建前后端代码。

    首先选择一个源码安装的工作目录,例如 ~/sqle-build/。

    获取后端源码:

    cd ~/sqle-build/
    git clone https://github.com/actiontech/sqle.git

    获取前端源码:

    cd ~/sqle-build/
    git clone https://github.com/actiontech/sqle-ui.git

    编译源码

    编译前端代码,并将前端代码拷贝至后端代码目录:

    cd ~/sqle-build/sqle-ui
    docker container run --rm -v $PWD:/app -w /app node:15.3.0 sh -c "yarn install && yarn build"
    rm -rf ~/sqle-build/sqle/ui && cp -r ~/sqle-build/sqle-ui/build/ ~/sqle-build/sqle/ui/

    编译后端代码并打包:

    cd ~/sqle-build/sqle
    make docker_rpm

    打包完成后会在当前目录下生成一个 SQLE 的 RPM 包,后续的步骤参考:RPM 部署

    - + \ No newline at end of file diff --git a/docs/v2/dev-manual/intro/index.html b/docs/v2/dev-manual/intro/index.html index f20c84d9..19301d89 100644 --- a/docs/v2/dev-manual/intro/index.html +++ b/docs/v2/dev-manual/intro/index.html @@ -4,13 +4,13 @@ 产品架构 | SQLE 文档 - +
    - + \ No newline at end of file diff --git a/docs/v2/dev-manual/plugins/howtodev/index.html b/docs/v2/dev-manual/plugins/howtodev/index.html index 80838502..0e26cd64 100644 --- a/docs/v2/dev-manual/plugins/howtodev/index.html +++ b/docs/v2/dev-manual/plugins/howtodev/index.html @@ -4,7 +4,7 @@ 数据库审核插件开发 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    数据库审核插件开发

    在本篇文档中,会介绍如何开发一个数据库审核插件,分为快速开始部分和详细部分。

    • 如果你是一个对 Go 语言不太了解的人,可以先通过快速开始部分的文档,实现一个简单的数据库审核插件。
    • 当你对插件开发有了一定的了解之后,可以通过详细部分的文档,通过更多自定义的方式,实现更加复杂的数据库审核插件。

    快速开始

    前置

    1. 语法

    由于 SQLE 是一个用 Go 语言开发的开源项目,如果你对 Go 语言完全不了解,需要先了解 Go 语言的基础语法,建议使用官方的 Go 语言快速开始文档(Go Tour 或者 Go 语言之旅),如果你已经了解了 Go 语言的基础语法,可以直接跳过本部分。

    2. 包管理

    SQLE 插件是一个独立于 SQLE 的进程,所以编写插件的方式与开发一个新的 Go 语言项目并没有什么差异。Go 语言项目使用 Go Modules 来管理包,所以在开始之前你需要先了解一下 Go Modules 的使用方法。建议参考这篇文档,文档中大致介绍了如果开始一个新的 Go 语言项目,并通过 Go Modules 的方式来调用其他项目的包,如果你已经了解了 Go Modules 的使用方法,可以直接跳过本部分。

    3. Go语言项目构建

    编写插件

    这一小节会假设你已经创建了一个由 Go Modules 管理的审核插件项目。下面开始介绍插件核心代码的开发。

    1. 数据库插件介绍

    SQLE 为了方便插件的开发,在自身的插件层之上做了一层封装(Adaptor),插件开发者可以使用这个封装库来快速的开发一个数据库审核插件。

    在开发之前,你需要先引入 SQLE:

    go get github.com/actiontech/sqle@v2.2305.0-pre2 # 此版本为该文档编辑时的最新版本

    选择 SQLE 中两个库插件相关的库:

    • github.com/actiontech/sqle/sqle/driver
    • github.com/actiontech/sqle/sqle/pkg/driver
    提示
    • 第一个库定义了插件规则的结构体,在你编写插件规则时需要用到这个库。
    • 第二个库中实现了一些默认的插件,在引入这个库后,只需要实现相应的规则与规则处理函数即可。其中三个默认的插件为:
      • PostgreSQL
      • Oracle
      • SQL Server
    • 如果这三个默认的插件不能满足需求,可以自己实现一个插件,参考本篇文档自定义插件小节。

    2. 选择插件

    下面假设你想要实现一个 SQL Server 的审核插件。在 main 函数中创建一个空的 SQL Server 审核插件,这时你的 main 文件应该是这样的:

    package main

    import (
    "github.com/actiontech/sqle/sqle/driver"
    adaptor "github.com/actiontech/sqle/sqle/pkg/driver"
    )

    func main() {
    plugin := adaptor.NewAdaptor(&adaptor.MssqlDialector{})
    }

    3. 编写插件规则与规则处理函数

    假设你需要实现一个规则,该规则检查 SQL 是否使用了 select *。定义规则如下:

    Rule{
    Name: "aviod_select_all_column", # 规则ID,该值会与插件类型一起作为这条规则在 SQLE 的唯一标识
    Desc: "避免查询所有的列", # 规则描述
    Category: "DQL规范", # 规则分类,用于分组,相同类型的规则会在 SQLE 的页面上展示在一起
    Level: driver.RuleLevelError, # 规则等级,表示该规则的严重程度。在插件注册阶段,会使用所有 RuleLevelError 级别的规则创建一个默认的规则模板。
    }

    规则的处理函数如下:

    func(ctx context.Context, rule *driver.Rule, sql string) (string, error) {
    if strings.Contains(sql, "select *") {
    return rule.Desc, nil
    }
    return "", nil
    }

    这里为了演示,这个处理函数只是简单的使用了字符串匹配的方式,你也可以使用正则或者 AST 语法树的方式来检查 SQL 语句(AST 的方式会在自定义SQL解析器一小节中介绍)。

    最后将插件规则与规则处理函数通过 plugin.AddRule()函数注册到 SQLE 中,注册完成后,你的 main 文件应该是这样的:

    package main

    import (
    "github.com/actiontech/sqle/sqle/driver"
    adaptor "github.com/actiontech/sqle/sqle/pkg/driver"
    )

    func main() {
    plugin := adaptor.NewAdaptor(&adaptor.MssqlDialector{})
    aviodSelectAllColumn := &driver.Rule{
    Name: "aviod_select_all_column",
    Desc: "避免查询所有的列",
    Category: "DQL规范",
    Level: driver.RuleLevelError,
    }
    aviodSelectAllColumnHandler := func(ctx context.Context, rule *driver.Rule, sql string) (string, error) {
    if strings.Contains(sql, "select *") {
    return rule.Desc, nil
    }
    return "", nil
    }
    plugin.AddRule(aviodSelectAllColumn, aviodSelectAllColumnHandler)

    ////////////////////////////////////////////
    // ... 编写更多规则并通过 AddRule 注册到 SQLE 中
    ////////////////////////////////////////////

    // 最后关键一步,调用 `plugin.Serve()` 启动插件:
    plugin.Serve()
    }

    4. 构建并使用插件

    和通常的程序编写流程一样,编写完插件代码后,需要将其构建成二进制文件,然后才能将其注册到 SQLE 中。执行 go build -o ${二进制名} main.go 将插件代码构建成二进制文件。最后参考数据库审核插件使用 来使用你的自定义插件。

    自定义部分

    1.自定义SQL解析器

    前面介绍的审核规则都是通过字符串匹配的方式来解析 SQL 的内容。这种方式适合规则较少且 SQL 简单的情况下使用。

    如果需要对 SQL 进行更复杂的解析匹配,恰好你选择的数据库插件又有相应的 SQL 解析器,这时可以使用自定义 SQL 解析器的方式来编写插件。

    首先通过调用 WithSQLParser() 注册自己的 SQL 解析器。在添加规则时则使用 plugin.AddRuleWithSQLParser() 添加带有解析器的处理函数。在处理函数中,将 interface{} 断言成具体的 AST 语法树,通过语法树级别的操作来更加精细的处理 SQL。PostgreSQL 提供了基于 cgo 调用的解析器(见:PostgreSQL SQL 解析器),下面的代码展示了如何写一个 SQL 解析器的插件:

    func main() {
    plugin := adaptor.NewAdaptor(&adaptor.PostgresDialector{})

    // 依然是定义规则
    aviodSelectAllColumn := &driver.Rule{
    Name: "aviod_select_all_column",
    Desc: "避免查询所有的列",
    Category: "DQL规范",
    Level: driver.RuleLevelError,
    }

    // 依然是定义处理函数,这时处理函数的参数是 interface{} 类型,需要将其断言成 AST 语法树。
    aviodSelectAllColumnHandler := func(ctx context.Context, rule *driver.Rule, ast interface{}) (string, error) {
    node, ok := ast.(*parser.RawStmt)
    if !ok {
    return "", errors.New("ast is not *parser.RawStmt")
    }

    switch stmt := node.GetStmt().GetNode().(type) {
    case *parser.Node_SelectStmt:
    for _, target := range stmt.SelectStmt.GetTargetList() {
    column, ok := target.GetResTarget().GetVal().GetNode().(*parser.Node_ColumnRef)
    if !ok {
    continue
    }
    for _, filed := range column.ColumnRef.GetFields() {
    _, ok = filed.GetNode().(*parser.Node_AStar)
    if ok {
    return rule.Desc, nil
    }
    }
    }
    }
    return "", nil
    }

    // 依然是注册规则,与前面的例子不同的是,这时使用的是 `plugin.AddRuleWithSQLParser()` 。
    plugin.AddRuleWithSQLParser(aviodSelectAllColumn, aviodSelectAllColumnHandler)

    // 依然是启动插件,与前面的例子不同的是,需要将 SQL 解析的方法注册到插件中。
    plugin.Serve(adaptor.WithSQLParser(func(sql string) (ast interface{}, err error) {
    // parser.Parse 使用 PostgreSQL 的解析器,将 sql 解析成 AST 语法树。
    result, err := parser.Parse(sql)
    if err != nil {
    return nil, errors.Wrap(err, "parse sql error")
    }
    if len(result.Stmts) != 1 {
    return nil, fmt.Errorf("unexpected statement count: %d", len(result.Stmts))
    }

    // 将 SQL 的语法树返回。
    return result.Stmts[0], nil
    }))
    }

    2.自定义插件

    如果 driver 包中默认的 PostgreSQL、Oracle 与 SQL Server 插件不能满足你的需求的话,你也可以自定义一个数据库插件。方法就是实现一个接口:

    type Dialector interface {
    Dialect(dsn *driver.DSN) (driverName string, dsnDetail string)
    ShowDatabaseSQL() string
    String() string
    }

    在实现这个接口前,你需要先了解一下 Go 语言原生 Driver 的概念(以 MySQL Driver 为例)。

    下面介绍 Dialector 接口的含义:

    • Dialect:实现该方法,通过 DSN 提供的 Host Port User Password Database 信息和你选择的数据库 driver,构造出 driverName 与 dsnDetail。driverName 是你引入的数据库 driver 名称;dsnDetail 是连接数据库驱动的必要信息。这两个参数最终会通过 sql.Open() 来创建一个数据库连接。
    • ShowDatabaseSQL:实现该方法,可以自定义你数据源中默认展示的数据库列表,该数据库列表最终会展示在工单审核列表的数据库下拉框中,如下图: pluginworkflow
    • String:实现该方法,该方法的返回值会作为你实现的数据库审核插件名展示在 SQLE 的相关下拉框中,如下图: plugintype

    将你的实现作为 NewAdaptor 的参数传入即可,后续的步骤与前面规则相关的介绍一致。

    详细

    SQLE与插件的交互图

    sqleplugin

    插件接口说明

    1.注册接口说明

    该接口定义了该插件的名称和实现的规则,SQLE启动的时候会调用该接口获取插件名称和该插件支持的规则列表。

    type Registerer interface {
    Name() string
    Rules() []*model.Rule
    }
    • Name: 插件名,最终会展示在 SQLE 页面的数据源类型的下拉框中;
    • Rules: 插件支持的规则,在启动 SQLE 时,会调用插件获取这些规则,你将在规则模板内看到它们。

    2.审核接口说明

    该接口定义了SQLE进行审核时,由插件完成的和具体数据库底层交互的操作

    type Driver interface {
    Close(ctx context.Context)
    Ping(ctx context.Context) error
    Exec(ctx context.Context, query string) (driver.Result, error)
    Tx(ctx context.Context, queries ...string) ([]driver.Result, error)
    Schemas(ctx context.Context) ([]string, error)
    Parse(ctx context.Context, sqlText string) ([]Node, error)
    Audit(ctx context.Context, sql string) (*AuditResult, error)
    GenRollbackSQL(ctx context.Context, sql string) (string, string, error)
    }
    • Close: 关闭审核插件使用的相关资源,通常是完成一次审核后,关闭数据库连接等资源;
    • Ping: 检测数据库的连接性,通常在添加数据源时,为了检测填写的数据是否正确,会调用此方法;
    • Exec: 执行 SQL 上线时执行此方法;
    • Tx: 执行 SQL 上线时执行此方法,一般当SQL是DML时且需要事务执行时会批量执行SQL;
    • Schemas: 返回审核插件展示给用户的 Schema 列表;
    • Parse: 解析审核插件支持的 SQL 格式;
    • Audit: 根据指定的SQL语句生成审核建议;
    • GenRollbackSQL: 生成 SQL 的回滚语句。

    3.插件的配置信息说明

    type Config struct {
    DSN *DSN
    Rules []*Rule
    }
    • DSN: 数据源信息, 待审核的数据库;
    • Rules: 本次审核制定的规则列表。

    4.初始化函数说明

    插件的主进程入口,由插件的 main 函数调用即可实现插件

    func ServePlugin(r Registerer, newDriver func(cfg *Config) Driver)
    • r: 传入 Registerer 的接口实现, 由插件侧实现;
    • newDriver: 传入 Driver 的初始化函数,该函数的入参是 Config 是由 SQLE 向插件传递的配置信息,函数的出参是 Driver 的接口实现,由插件侧实现。
    - + \ No newline at end of file diff --git a/docs/v2/dev-manual/plugins/howtouse/index.html b/docs/v2/dev-manual/plugins/howtouse/index.html index 36a4ba2c..775a0e24 100644 --- a/docs/v2/dev-manual/plugins/howtouse/index.html +++ b/docs/v2/dev-manual/plugins/howtouse/index.html @@ -4,7 +4,7 @@ 数据库审核插件使用 | SQLE 文档 - + @@ -13,7 +13,7 @@ pluginrules 验证能否添加插件类型的数据源:添加数据源,显示已经可以添加 PostgreSQL 类型的数据源。 plugintype

    - + \ No newline at end of file diff --git a/docs/v2/dev-manual/plugins/intro/index.html b/docs/v2/dev-manual/plugins/intro/index.html index f9f27d2d..70813b65 100644 --- a/docs/v2/dev-manual/plugins/intro/index.html +++ b/docs/v2/dev-manual/plugins/intro/index.html @@ -4,13 +4,13 @@ 功能说明 | SQLE 文档 - +
    版本:v2

    功能说明

    SQLE 使用 go-plugin 来实现审核插件化。插件只需实现两个接口,即可实现与 SQLE 主进程通信(详情见审核插件开发)。

    将 SQLE 的数据库审核插件化主要有以下目的:

    • 将审核流程(业务)的代码和具体审核实现的代码进行分离,支持多数据源类型的审核
    • 审核插件在满足基本规范情况下,与 SQLE 独立开发

    部分插件项目地址

    - + \ No newline at end of file diff --git a/docs/v2/guide/index.html b/docs/v2/guide/index.html index 926e3dd8..4ea0cfb7 100644 --- a/docs/v2/guide/index.html +++ b/docs/v2/guide/index.html @@ -4,13 +4,13 @@ 用户指南 | SQLE 文档 - +
    版本:v2

    用户指南

    产品概述

    SQLE 是由上海爱可生信息技术股份有限公司 开发并开源,支持SQL审核、索引优化、事前审核、事后审核、支持标准化上线流程、原生支持 MySQL 审核且数据库类型可扩展的 SQL 审核工具

    - + \ No newline at end of file diff --git a/docs/v2/intro/index.html b/docs/v2/intro/index.html index abfe0132..a38423ff 100644 --- a/docs/v2/intro/index.html +++ b/docs/v2/intro/index.html @@ -4,13 +4,13 @@ 产品介绍 | SQLE 文档 - +
    版本:v2

    产品介绍

    SQLE 是由上海爱可生信息技术股份有限公司 开发并开源,支持SQL审核、索引优化、事前审核、事后审核、支持标准化上线流程、原生支持 MySQL 审核且数据库类型可扩展的 SQL 审核工具

    产品特性

    SQL审核规范

    1. 审核规则自定义(700+条)
    2. 支持审核结果分级展示,支持生成下载审核报告
    3. 支持规则模版,灵活组合规则
    4. 审核白名单,跳过特例SQL
    5. 支持集成 IDE 自助审核

    多场景审核

    支持事前事后审核,覆盖开发、测试、上线、生产等环节

    标准化上线流程

    1. SQL审核流程按需自定义,满足企业内部不同流程管理要求
    2. 支持定时上线
    3. 支持设置运维时间
    4. 支持Online DDL

    多数据库类型支持

    1. 统一接口,可通过插件进行多数据库审核扩展
    2. 内置MySQL审核插件,官方支持常用数据库类型,包括PostgreSQL、Db2、SQL Server、Oracle、TiDB、OceanBase

    统一的SQL客户端入口

    提供审核管控的SQL客户端,杜绝执行不合规SQL

    丰富的集成能力

    1. 标准HTTP API接口可与客户内部流程系统对接
    2. 支持LDAP,Oauth2用户对接
    3. 支持邮件、微信企业号、webhook 告警对接

    应用场景

    上线前控制

    1. SQLE赋能开发,在代码开发阶段检查SQL质量
    2. SQLE集成专家经验,形成可复用的SQL规范标准规则,用户在平台提交工单后,平台将基于审核规则模板对提交的SQL语句进行初审,用以解决事前审核规范不标准难题

    上线后监督

    1. SQLE提供智能扫描审核功能,实现生产环境下的SQL审核优化
    2. SQLE支持多种类型的扫描任务,基于任务需求执行周期性的扫描任务,并生成扫描结果报告,及时告警
    - + \ No newline at end of file diff --git a/docs/v2/online-demo/index.html b/docs/v2/online-demo/index.html index e73c0cad..4bc76f6b 100644 --- a/docs/v2/online-demo/index.html +++ b/docs/v2/online-demo/index.html @@ -4,13 +4,13 @@ 在线体验 | SQLE 文档 - +
    版本:v2

    在线体验

    地址

    登录用户

    userpassword
    adminadmin

    测试 MySQL

    variablevalue
    host20.20.20.3
    port3306
    userroot
    passtest

    注意事项

    1. 该服务仅用于在线功能体验,请勿在生产环境使用;
    2. 该测试服务数据会定期清理。
    - + \ No newline at end of file diff --git a/docs/v2/quick-usage/index.html b/docs/v2/quick-usage/index.html index 7e217420..1680facd 100644 --- a/docs/v2/quick-usage/index.html +++ b/docs/v2/quick-usage/index.html @@ -4,7 +4,7 @@ 快速开始 | SQLE 文档 - + @@ -23,7 +23,7 @@ project-workflow-1

    DBA用户 B 上线

    使用 B 用户进入SQLE后,即可看到由A提交的上线工单,点击详情后可进行审批操作。

    提示

    SQLE 支持通过邮件,微信企业号等途径推送工单通知。也可以配置工单对接来在钉钉上进行工单审批

    project-workflow-1 project-workflow-1 project-workflow-1

    - + \ No newline at end of file diff --git a/docs/v2/support/commercial-support/index.html b/docs/v2/support/commercial-support/index.html index cc8b0651..11404a7c 100644 --- a/docs/v2/support/commercial-support/index.html +++ b/docs/v2/support/commercial-support/index.html @@ -4,13 +4,13 @@ 商业支持 | SQLE 文档 - +
    版本:v2

    商业支持

    如果想获得 SQLE 的商业支持, 您可以联系我们:

    • 全国支持: 400-820-6580
    • 华北地区: 86-13910506562, 汪先生
    • 华南地区: 86-18503063188, 曹先生
    • 华东地区: 86-18930110869, 梁先生
    • 西南地区: 86-13540040119, 洪先生
    - + \ No newline at end of file diff --git a/docs/v2/support/community-support/index.html b/docs/v2/support/community-support/index.html index b58b9f56..67a48bfe 100644 --- a/docs/v2/support/community-support/index.html +++ b/docs/v2/support/community-support/index.html @@ -4,13 +4,13 @@ 社区支持 | SQLE 文档 - +
    版本:v2

    社区支持

    微信技术交流群

    欢迎加入微信群进行交流,反馈使用中遇到的问题或者使用建议。

    进群方式:添加管理员微信 ActionOpenSource

    爱可生社区公众号

    关注爱可生社区公众号,获取最新SQLE动态包括新功能清单与产品规划。

    项目列表

    - + \ No newline at end of file diff --git a/docs/v2/support/compare/index.html b/docs/v2/support/compare/index.html index b676ca94..6cbb64b7 100644 --- a/docs/v2/support/compare/index.html +++ b/docs/v2/support/compare/index.html @@ -4,13 +4,13 @@ 功能对比 | SQLE 文档 - +
    版本:v2

    功能对比

    社区版及企业版功能对比

    模块功能企业版社区版
    平台基础能力资源管理
    权限管理
    用户对接:LDAP
    用户对接:Oauth2.0单点登录
    对接钉钉在线审批
    支持爱可生云树DMP数据源同步
    量化管理项目管理
    报表统计
    Dashboard
    支持的数据源类型MySQL
    Mycat
    TDSQL for InnoDB
    OceanBase For MySQL
    DB2
    TiDB
    PostgreSQL
    Oracle
    OceanBase For Oracle
    SQL Server
    达梦
    SQL审核同一工单多数据源
    多种SQL上传方式
    IDE审核插件
    自助审核
    SQL美化
    动态配置审核规则模板
    审核白名单
    基于规则的审核建议
    审核建议去重展示
    SQL下钻分析
    大表进行 Online DDL
    SQL上下文关联
    生成回滚语句
    审核评分
    审核报告下载
    SQL语句下载
    工单上线自定义审核流程
    多数据源批量上线
    立即上线
    定时上线
    线下执行,线上标记
    中止上线
    智能扫描MySQL|MyBatis 扫描
    MySQL|库表元数据
    MySQL|阿里云 RDS慢日志
    MySQL|阿里云 RDS审计日志
    MySQL|慢日志审核
    MySQL|会话SQL扫描
    MySQL|百度云RDS慢日志
    SQL文件扫描
    应用程序SQL抓取
    支持JAVA探针采集JAVA应用SQL
    Oracle TopSQL
    TiDB审计日志
    OceanBase for MySQL|MyBatis 扫描
    OceanBase for MySQL|Top SQL
    自定义(通过调用接口推送bash脚本、python程序中的SQL)
    告警通知邮件告警
    微信企业号告警
    飞书告警
    webhook告警
    SQL工作台集成CloudBeaver-提供在线SQL客户端
    安全管控
    OpenAPI提供完整的标准接口方案
    专家服务提供数据对接、SQL规范制定、SQL优化建议等7x24小时服务

    各数据源支持程度对比

    提示

    目前支持的数据源类型中,除MySQL为社区版,其他均为企业版。

    MySQL系

    MySQLMycatTDSQL for InnoDBOceanBase For MySQLTiDB
    功能SQL分析
    SQL上下文
    元数据检查
    SQL回滚
    上线中止
    扫描任务库表元数据
    慢日志
    Processlist
    TopSQL
    TiDB审计日志
    MyBatis
    阿里RDS MySQL慢日志
    阿里RDS MySQL审计日志
    百度云RDS MySQL慢日志扫描
    SQL文件扫描
    应用程序抓取
    自定义
    其他规则数量133122129117119

    非MySQL系

    OracleOceanBase For OracleDB2PostgreSQLSQL server达梦
    功能SQL分析
    SQL上下文
    元数据检查
    SQL回滚
    上线中止
    扫描任务库表元数据
    慢日志
    Processlist
    TopSQL
    TiDB审计日志
    MyBatis
    阿里RDS MySQL慢日志
    阿里RDS MySQL审计日志
    百度云RDS MySQL慢日志扫描
    SQL文件扫描
    应用程序抓取
    自定义
    其他规则数量8583602123
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/customrule/index.html b/docs/v2/user-manual/customrule/index.html index 85a983e9..9b3dace4 100644 --- a/docs/v2/user-manual/customrule/index.html +++ b/docs/v2/user-manual/customrule/index.html @@ -4,7 +4,7 @@ 自定义审核规则 | SQLE 文档 - + @@ -16,7 +16,7 @@ customrule-usetemplate 2.创建工单,新建表users123,从工单审核结果中可以看到自定义规则已生效; customrule-result

    提示

    目前仅支持在SQLE平台新建自定义规则,暂不支持导入导出规则模板时携带自定义规则。

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/intro/index.html b/docs/v2/user-manual/intro/index.html index b763eaeb..e92d14af 100644 --- a/docs/v2/user-manual/intro/index.html +++ b/docs/v2/user-manual/intro/index.html @@ -4,13 +4,13 @@ 用户手册 | SQLE 文档 - +
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/jetbrains/index.html b/docs/v2/user-manual/jetbrains/index.html index f07a906f..672d0eb0 100644 --- a/docs/v2/user-manual/jetbrains/index.html +++ b/docs/v2/user-manual/jetbrains/index.html @@ -4,7 +4,7 @@ IDEA审核插件 | SQLE 文档 - + @@ -15,7 +15,7 @@ ide-install-use

    2.用户也可以选中文件后,点击右键, 选中 [SQLE] - [Audit],将获得对文件中SQL的审核结果,支持一次性审核整个文件夹下的MyBatis文件; ide-install-use2

    审核结果

    插件会以弹窗的形式将审核结果进行展示 ide-install-result

    常见问题解答

    为什么插件配置项中的 [DB Type] 点击时偶尔会卡一下

    这是因为点击下拉框时下拉框会连接SQLE获取支持的实例类型, 这个过程可能会出现网络延迟

    SQLE在审核时使用的规则模板是什么

    SQLE会根据设置中指定的数据库类型, 选择对应类型的默认模板进行审核, 且只会使用默认模板中的静态审核规则

    我没有SQLE环境可以使用这个插件吗

    SQLE有演示环境, 如果只是想尝试一下这个插件可以连接演示环境

    插件支持哪些IDE

    Jetbrains家的所有软件和 [Android Studio] 都是支持的

    SQLE插件的配置存在什么地方

     {用户根目录}\AppData\Roaming\JetBrains\{idea版本号对应目录}\options\SQLESettings.xml
    变量说明
    用户根目录一般为 C:\Users 目录下和用户名同名的目录, 内部一般包含 '桌面', '下载' 等文件夹
    idea版本号对应目录一般为 软件名版本号 的格式, 如社区版idea 2022.1版本对应目录名为 IdealC2022.1
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/operation_records/index.html b/docs/v2/user-manual/operation_records/index.html index 237e02bf..19db2af7 100644 --- a/docs/v2/user-manual/operation_records/index.html +++ b/docs/v2/user-manual/operation_records/index.html @@ -4,14 +4,14 @@ 操作记录 | SQLE 文档 - +
    版本:v2

    操作记录

    使用场景

    SQLE平台提供操作记录,当审核/上线产生问题时,用户需要从操作行为判定问题责任方。此时,用户可以使用平台的操作记录功能,查看平台行为的操作人、操作时间。

    入口

    用户点击平台右上方操作记录icon后,跳转至操作记录页面,查看权限范围内可见的操作记录。

    • 用户可对操作记录进行筛选,查看符合条件的操作记录;
    • 用户也可在当前筛选条件下,导出平台操作记录,用以线下审计; operation

    更多操作

    SQLE会定时回收已产生的操作记录,目前该过期时间默认为90天。如果用户需要自定义过期时间,可以在全局配置中修改。

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/analysis/index.html b/docs/v2/user-manual/project/analysis/index.html index b3304c26..e6bf2fff 100644 --- a/docs/v2/user-manual/project/analysis/index.html +++ b/docs/v2/user-manual/project/analysis/index.html @@ -4,13 +4,13 @@ SQL分析 | SQLE 文档 - +
    版本:v2

    SQL分析

    SQL分析是什么

    当用户需要了解执行SQL的对象情况时,可以点击SQL后的分析操作,进入SQL分析页面

    使用场景

    操作步骤

    使用限制

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/audit_task/SQLfile_audit/index.html b/docs/v2/user-manual/project/audit_task/SQLfile_audit/index.html index eeacef5c..78dff29e 100644 --- a/docs/v2/user-manual/project/audit_task/SQLfile_audit/index.html +++ b/docs/v2/user-manual/project/audit_task/SQLfile_audit/index.html @@ -4,7 +4,7 @@ SQL文件扫描 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    SQL文件扫描

    本节介绍SQL文件扫描的应用场景及配置方法。

    备注

    平台已支持的所有数据源类型均支持SQL文件扫描

    使用场景

    当用户需要在批量执行SQL前扫描SQL,发现潜在的安全漏洞、提高数据库性能及数据库开发质量时,可以使用SQL文件进行批量扫描。

    使用方式

    前置条件

    在后端环境中准备SQL文件

    新建智能扫描任务

    进入智能扫描任务列表,点击新建,选择SQL文件扫描任务类型。

    执行Scannerd文件

    提示

    注意:使用rpm或docker部署的情况下,scannerd通常在SQLE的bin目录下。

    示例如下:

    ./scannerd sqlfile -H127.0.0.1 -N"SQLfile" -P"10000" -J"default" -D/root/sqle/sqle/cmd/scannerd/scanners/mybatis/testdata/ -A"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhcG4iOiJ0ZXN0MDcyNCIsImV4cCI6MTcyMTcyODU0NywibmFtZSI6ImFkbWluIn0.CojdTvBkr-iN_26tWI-Kr6mMnJt1NIDr-Y3v7m9ySuM"

    参数解释如下:

    • -J, --project:说明扫描任务所在项目,例如“default”;
    • -H, --host string:指定SQLE主机所在地址;
    • -P, --port string:指定SQLE所在端口;
    • -N, --name string:指定扫描任务名称,scannerd会将获得的SQL传至指定的任务池中审核;
    • -D, --dir string:指定要扫描的SQL文件路径;
    • -A, --token string:输入扫描任务凭证token;
    • -K, --skip-sql-file-audit:只上传sql,不审核sql;
    • -S, --skip-error-sql-file; 跳过无法解析的sql文件;

    获得执行结果: sqlfile_audit

    平台查看执行结果

    • 用户进入扫描任务详情,可以查看SQLw文件中已采集到的SQL信息;
    • 用户点击立即审核,可以在扫描任务报告中获取当前SQL的审核结果; sqlfile_result
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/audit_task/baiduyunrds/index.html b/docs/v2/user-manual/project/audit_task/baiduyunrds/index.html index c68c0505..a8f539fe 100644 --- a/docs/v2/user-manual/project/audit_task/baiduyunrds/index.html +++ b/docs/v2/user-manual/project/audit_task/baiduyunrds/index.html @@ -4,14 +4,14 @@ 百度云RDS慢日志扫描 | SQLE 文档 - +
    版本:v2

    百度云RDS慢日志扫描

    本节介绍如何在SQLE平台监管百度云RDS实例上产生的慢SQL。

    支持的数据源类型

    • MySQL

    使用场景

    如果用户使用百度云RDS实例,并且想要监管实例上产生的慢SQL,可以通过创建一个百度云RDS慢日志扫描任务来实现。该任务将会定期扫描百度云RDS实例上的慢日志,并将扫描结果发送到SQLE中进行分析。

    前置操作

    • 用户需创建双机高可用版本的百度云RDS实例;
    • 对该实例开通慢日志;

    baiduyunrds

    操作步骤

    新建智能扫描任务

    • 任务名称:输入审核任务名称,必须以字母开头;
    • 数据源名称:指定扫描任务实施的数据源;
    • 数据库:填写需要审核的目标库,若不填则仅进行静态分析不会连库;
    • 数据库类型:根据选取的数据源呈现;
    • 任务类型:选择需要执行的审核任务类型,选择百度云RDS MySQL慢日志
    • 实例ID:填写百度云RDS实例的ID。
    • Access Key:为账号安全认证中的Access Key,用于登录百度云RDS,需要与Secret Key一同使用。
    • Access Secret Key:账号安全认证中Access Key对应的Secret Key。
    • 启动任务时拉取慢日志时间范围(单位:小时,最大7天):扫描任务读取慢日志的时间范围,单位为小时,最大范围为7天。
    • 审核过去时间段内抓取的SQL(分钟): 审核该时间段内抓取到的慢SQL。
    • RDS Open API地址:RDS的地址前缀,用以调用RDS服务,需根据实例所在区域进行填写。如当前实例在华东-上海范围,则应填写rds.fsh.baidubce.com baiduyunrdsurl

    点击提交,完成扫描任务创建。

    执行结果

    • 用户进入扫描任务详情,可以查看扫描任务抓取到的慢SQL。
    • 点击立即审核,可查看对慢SQL的审核结果。

    baiduyunrdsaudit

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/audit_task/intro/index.html b/docs/v2/user-manual/project/audit_task/intro/index.html index e0ff9f01..5ee20b6b 100644 --- a/docs/v2/user-manual/project/audit_task/intro/index.html +++ b/docs/v2/user-manual/project/audit_task/intro/index.html @@ -4,13 +4,13 @@ 功能说明 | SQLE 文档 - +
    版本:v2

    功能介绍

    背景

    在审核工单中我们介绍了如何通过 SQLE 进行 SQL 审核并上线的流程。审核工单管理,主要解决 SQL 上线的规范化流程化的问题,它能够帮助 DBA 自动化处理整个 SQL 上线过程中一些重复繁琐的工作。

    不过审核工单管理也有它的局限性。

    • 第一,通常工单中的审核是一次性操作。上线后,通常还会有业务 SQL访问数据库。这时可能会遇到一些执行效率较低的业务 SQL 造成数据库的性能问题,因而这类业务型SQL同样需要审核。
    • 第二,临近发版,如果这时审核出 SQL 存在一些问题,是否修复这些问题,可能会受到很多因素的影响(如 SQL 问题的影响面大小,项目发版的紧急程度等),因而需要对即将上线的SQL做全量扫描。

    因而,需要引入扫描任务,进行周期性的SQL审核,用以补充工单审核覆盖不到的场景。

    SQLE扫描任务支持的采集模式

    1.SQLE 自动抓取

    • 功能说明
      • 使用SQLE自动抓取,将由SQLE获取指定的SQL文件,传输至指定审核池后,由SQLE进行审核并展示审核结果。
    • 支持的任务类型
      • 库表元数据
      • TopSQL
      • processlist列表

    2.Scanner 抓取

    • 功能说明
      • 使用Scanner抓取,可利用scanner插件获取指定的SQL文件,传输至指定审核池后,由SQLE进行审核并展示审核结果。
    • 支持的任务类型
      • 慢日志
      • Mybatis扫描

    3.OpenAPI 推送

    • 功能说明
      • 使用应用程序SQL抓取,可利用api接口动态获取指定应用程序中的SQL,传输至指定审核池后,由SQLE进行审核并展示审核结果。
    • 支持的任务类型
      • openapi推送
      • 自定义
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/audit_task/java_agent_audit/index.html b/docs/v2/user-manual/project/audit_task/java_agent_audit/index.html index 7a21a6aa..c7d1acef 100644 --- a/docs/v2/user-manual/project/audit_task/java_agent_audit/index.html +++ b/docs/v2/user-manual/project/audit_task/java_agent_audit/index.html @@ -4,13 +4,13 @@ Java探针版应用程序SQL抓取【企业版】 | SQLE 文档 - +
    版本:v2

    Java探针版应用程序SQL抓取【企业版】

    本节介绍如何利用SQLE平台抓取java应用中的SQL,选取的例子是一个开源的问卷调查java应用,架构简单,上手相对容易。

    支持的数据源类型

    • MySQL
    • Oracle
    • DB2
    • OceanBase for MySQL
    • PostgreSQL
    • TiDB
    • SQL Server

    前置准备

    环境准备

    准备一台 linux 服务器,ubuntu即可,架构版本暂无要求

    1. 安装JAVA
    sudo apt install default-jdk
    1. 部署并启动MySQL服务

    部署java应用

    • 准备Java应用
    • 准备Java应用SQL初始化文件
    • 准备SQLE定制的JAVA agent JAR包
      提示

      JAVA agent JAR包为企业版功能,如有使用需求,请联系SQLE商业支持

    Java应用前置步骤

    1、初始化Java应用

    mysql -h127.0.0.1 -P3306 -uroot -p -e "CREATE DATABASE IF NOT EXISTS jw default character set utf8mb4 collate utf8mb4_unicode_ci"
    mysql -h127.0.0.1 -P3306 -uroot -D jw -p < init-mysql.sql

    2、将Java应用Jar包,定制jdbc上传服务器指定目录下,可以放在 /opt/surveyking 目录下,示例:

    root@ubuntu:/opt/surveyking# pwd
    /opt/surveyking
    root@ubuntu:/opt/surveyking# ls -l
    total 55652
    -rw-r--r-- 1 root root 2932784 Feb 24 08:38 sql-agent-1.0-SNAPSHOT.jar
    -rw-r--r-- 1 root root 54508748 Feb 24 08:37 surveyking-v0.3.0-beta.4.jar

    使用方式

    创建扫描任务

    进入智能扫描任务列表,点击新建,扫描任务类型选择应用程序SQL抓取。

    启动Java应用

    提示

    以下命令需要在本地编辑替换完参数后,一次性拷贝到环境内执行

    SQLE_COLLECT_ENABLE=true \
    SQLE_BASE_URL=http://10.186.62.16:10000 \
    SQLE_TASK_NAME=jw_app \
    SQLE_TASK_TOKEN=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhcG4iOiJqd19hcHAiLCJleHAiOjE2NzcyMjYxNzcsIm5hbWUiOiJhZG1pbiJ9.3d0pA1hiVnFEWJokSFBwCT8d1pKOYV6SViENj4GFqgI \
    SQLE_EXCLUDE_JAVA_FILE=UserServiceImpl.java \
    SQLE_LOG_FILE=/tmp/collect.log \
    java -javaagent:sql-agent-1.0-SNAPSHOT.jar \
    -jar surveyking-v0.3.0-beta.4.sqle.jar \
    --server.port=1991 \
    --spring.datasource.url=jdbc:mysql://10.186.62.18:3306/jw \
    --spring.datasource.username=root \
    --spring.datasource.password=mysqlpass \
    & >>/opt/surveyking/std.log

    参数说明(环境变量)

    • SQLE_COLLECT_ENABLE=true :是否开启SQL采集,默认不推送到SQLE只输出本地日志
    • SQLE_BASE_URL:SQLE 服务地址,格式“http://ip:port”
    • SQLE_TASK_NAME:SQLE 审核任务的名称
    • SQLE_TASK_TOKEN:审核任务的token,从SQLE页面复制
    • SQLE_PROJECT_NAME:SQLE JDBC配置:项目名
    • SQLE_LOG_FILE:指定SQLE 采集日志文件,不指定则代表输出到标准输出
    • SQLE_EXCLUDE_JAVA_FILE:忽略部分JAVA文件不插桩,主要是兼容性问题,当修改字节码失败时为了保障能运行抓取。文件按逗号分隔

    参数说明(java 参数)

    • server.port:web服务启用端口
    • spring.datasource.url:jdbc url
    • spring.datasource.username:jdbc user name
    • spring.datasource.password:jdbc password

    访问Java应用

    • 访问地址:如果配置的网页端口是1991则通过网页访问http://xx.xx.xx.xx:1991
    • 用户名:admin
    • 密码:123456
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/audit_task/java_application_audit/index.html b/docs/v2/user-manual/project/audit_task/java_application_audit/index.html index e79808c6..a2892e23 100644 --- a/docs/v2/user-manual/project/audit_task/java_application_audit/index.html +++ b/docs/v2/user-manual/project/audit_task/java_application_audit/index.html @@ -4,13 +4,13 @@ 应用程序SQL抓取【企业版】 | SQLE 文档 - +
    版本:v2

    应用程序SQL抓取【企业版】

    本节介绍如何利用SQLE平台抓取JAVA应用中的SQL,选取的例子是一个开源的问卷调查java应用,架构简单,上手相对容易。

    支持的数据源类型

    • MySQL
    • Oracle
    • DB2
    • OceanBase for MySQL
    • PostgreSQL
    • TiDB
    • SQL Server

    前置准备

    环境准备

    准备一台 linux 服务器,ubuntu即可,架构版本暂无要求

    1. 安装JAVA
    sudo apt install default-jdk
    1. 部署并启动MySQL服务

    部署java应用

    • 准备Java应用
    • 准备Java应用SQL初始化文件
    • 准备SQLE定制的JDBC jar 包
      提示

      JDBC jar包为企业版功能,如有使用需求,请联系SQLE商业支持

    Java应用前置步骤

    1、初始化Java应用

    mysql -h127.0.0.1 -P3306 -uroot -p -e "CREATE DATABASE IF NOT EXISTS jw default character set utf8mb4 collate utf8mb4_unicode_ci"
    mysql -h127.0.0.1 -P3306 -uroot -D jw -p < init-mysql.sql

    2、将Java应用Jar包,定制jdbc上传服务器指定目录下,可以放在 /opt/surveyking 目录下,示例:

    root@ubuntu:/opt/surveyking# pwd
    /opt/surveyking
    root@ubuntu:/opt/surveyking# ls -l
    total 55652
    -rw-r--r-- 1 root root 2477925 Feb 24 08:38 mysql-connector-java-8.0.28-SQLE.jar
    -rw-r--r-- 1 root root 54508748 Feb 24 08:37 surveyking-v0.3.0-beta.4.jar

    3、替换Java应用Jar包的MySQL jdbc jar 包

    cd /opt/surveyking/
    mkdir jar
    cp surveyking-v0.3.0-beta.4.jar jar/
    cd jar/
    jar xvf surveyking-v0.3.0-beta.4.jar # 解压jar包,如果执行失败也可使用 unzip surveyking-v0.3.0-beta.4.jar 代替
    cp ../mysql-connector-java-8.0.28-SQLE.jar BOOT-INF/lib/mysql-connector-java-8.0.26.jar # 替换jdbc
    rm -rf surveyking-v0.3.0-beta.4.jar
    jar cvfM0 surveyking-v0.3.0-beta.4.sqle.jar * # 打包
    mv surveyking-v0.3.0-beta.4.sqle.jar ../
    cd ..
    rm -rf jar/

    使用方式

    创建扫描任务

    进入智能扫描任务列表,点击新建,扫描任务类型选择应用程序SQL抓取。

    启动Java应用

    提示

    以下命令需要在本地编辑替换完参数后,一次性拷贝到环境内执行

    cd /opt/surveyking/
    SQLE_COLLECT_ENABLE=true SQLE_HOST=10.186.62.18:10000 SQLE_TASK_NAME=jw_app SQLE_TASK_TOKEN=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhcG4iOiJqd19hcHAiLCJleHAiOjE2NzcyMjYxNzcsIm5hbWUiOiJhZG1pbiJ9.3d0pA1hiVnFEWJokSFBwCT8d1pKOYV6SViENj4GFqgI \
    java -jar surveyking-v0.3.0-beta.4.sqle.jar \
    --server.port=1991 \
    --spring.datasource.url=jdbc:mysql://10.186.62.18:3306/jw \
    --spring.datasource.username=root \
    --spring.datasource.password=mysqlpass \
    & >>/opt/surveyking/std.log

    参数说明(环境变量):

    • SQLE_COLLECT_ENABLE:是否开启SQL采集
    • SQLE_HOST=10.186.62.18:10000:SQLE 服务地址 ip:port
    • SQLE_TASK_NAME=jw_app :审核任务的名称
    • SQLE_TASK_TOKEN:审核任务的token,从SQLE页面复制
    • SQLE_PROJECT_NAME:SQLE JDBC配置:项目名

    参数说明(java 参数)

    • server.port:web服务启用端口
    • spring.datasource.url:jdbc url
    • spring.datasource.username:jdbc user name
    • spring.datasource.password:jdbc password

    访问Java应用

    • 访问地址:如果配置的网页端口是1991则通过网页访问http://xx.xx.xx.xx:1991
    • 用户名:admin
    • 密码:123456
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/audit_task/metadata_audit/index.html b/docs/v2/user-manual/project/audit_task/metadata_audit/index.html index 83c15e31..cf3d1415 100644 --- a/docs/v2/user-manual/project/audit_task/metadata_audit/index.html +++ b/docs/v2/user-manual/project/audit_task/metadata_audit/index.html @@ -4,7 +4,7 @@ 库表元数据 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    库表元数据

    本节介绍库表元数据扫描的应用场景、以及如何创建库表元数据的扫描任务。

    支持的数据源类型

    • MySQL
    • DB2

    使用场景:

    1. 需要检查已上线业务对应数据源的建库建表语句是否符合 统一的SQL质量规范。
    2. 需要定期检查上线业务的库表变更是否符合 统一的SQL质量规范。

    前置条件

    已添加对应数据源。

    操作步骤

    新建智能扫描任务

    • 任务名称:输入审核任务名称,必须以字母开头;
    • 数据源名称:指定扫描任务实施的数据源;
    • 数据库:填写需要审核的目标库,若不填则仅进行静态分析不会连库;
    • 数据库类型:根据选取的数据源呈现;
    • 任务类型:选择需要执行的审核任务类型,选择库表元数据;
    • 采集周期(分钟):将采集设定时间内产生的SQL;
    • 是否采集视图信息:默认不采集视图信息,若开启,则将一并扫描数据源上的视图SQL;
    • 审核规则模板:如果未指定此项会优先使用数据源绑定的模板;
    • 任务审核周期:配置的是SQLE对审核任务进行自动审核的执行时间;

    执行结果

    可在扫描任务列表页面查看新建的库表元数据扫描任务。 list

    点击扫描任务,可查看该扫描任务采集的SQL,及生成的扫描任务报告。 result

    后续步骤

    • 查看审核记录,查看不同时间点的审核结果,包括审核的SQL语句、审核结果。
    • 分析语句,用户可对SQL语句进行分析操作,获取优化建议。
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/audit_task/mybatis/index.html b/docs/v2/user-manual/project/audit_task/mybatis/index.html index b9e3caf6..a92063cf 100644 --- a/docs/v2/user-manual/project/audit_task/mybatis/index.html +++ b/docs/v2/user-manual/project/audit_task/mybatis/index.html @@ -4,7 +4,7 @@ MyBatis扫描 | SQLE 文档 - + @@ -22,7 +22,7 @@ coding-editinfo

    编辑后点击保存,完成构建计划。

    触发构建,获得审核结果

    在构建计划中点击立即构建按钮; coding-do

    可以在在构建过程中查看构建结果,也可以在SQLE平台的扫描任务中查看审核结果。 coding-result

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/audit_task/processlist_audit/index.html b/docs/v2/user-manual/project/audit_task/processlist_audit/index.html index e1b0cdf8..b3eefccb 100644 --- a/docs/v2/user-manual/project/audit_task/processlist_audit/index.html +++ b/docs/v2/user-manual/project/audit_task/processlist_audit/index.html @@ -4,14 +4,14 @@ 会话SQL扫描 | SQLE 文档 - +
    版本:v2

    会话SQL扫描

    本节介绍如何对MySQL进行中的会话SQL进行监督及审核。

    支持的数据源类型

    • MySQL

    使用场景

    除了上线前和上线后的审核,在SQL语句执行过程中,用户往往也需要对其进行监控和审核,用以及时识别出潜在的问题SQL。然而,当前的审核场景往往无法覆盖事中这一环节的审核。为此,SQLE新增了processlist列表审核扫描任务,实现了事前、事中、事后的全覆盖,使得用户可以在SQL语句的整个生命周期内进行审核和管理,从而减少审核时间和工作量。

    操作步骤

    新建智能扫描任务

    • 任务名称:输入审核任务名称,必须以字母开头;
    • 数据源名称:指定扫描任务实施的数据源;
    • 数据库:填写需要审核的目标库,若不填则仅进行静态分析不会连库;
    • 数据库类型:根据选取的数据源呈现;
    • 任务类型:选择需要执行的审核任务类型,选择processlist列表扫描任务;
    • 采集周期(秒):表示SQLE对 MySQL processlist表的采集频率,SQLE将按照该时间间隔进行SQL采集。如果该值过低,会影响实例性能;
    • SQL最小执行时间(秒):表示SQLE对 MySQL processlist 的采集过滤条件,只有大于等于该时间的SQL才会被采集记录。如果为0,则表示不进行过滤;
    • 审核过去时间段内抓取的SQL(分钟):processlist列表扫描任务是增量审核,不在该时间段内执行的SQL将不会被再次采集;
    • 审核规则模板:如果未指定此项会优先使用数据源绑定的模板;
    • 任务审核周期:配置的是SQLE对审核任务进行自动审核的执行时间;

    执行结果

    • 用户进入扫描任务详情,可以查看已采集到的processlist列表中的SQL信息;
    • 用户点击立即审核,可以在扫描任务报告中获取processlist列表中当前采集周期内产生的SQL及审核结果; processlist-audit
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/audit_task/slowlog_audit/index.html b/docs/v2/user-manual/project/audit_task/slowlog_audit/index.html index 93262286..66fc3678 100644 --- a/docs/v2/user-manual/project/audit_task/slowlog_audit/index.html +++ b/docs/v2/user-manual/project/audit_task/slowlog_audit/index.html @@ -4,7 +4,7 @@ 慢日志 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    慢日志

    本节介绍慢日志扫描的应用场景、以及如何创建慢日志扫描任务。

    当前SQLE支持两种慢日志采集方式,一种由scanner采集慢日志文件中的慢查询,一种由SQLE直接采集慢查表中的慢查询,用户可在编辑页面选取需要的采集方式,您可选择需要的方式采集产生的慢查询。

    支持的数据源类型

    • MySQL

    使用场景

    需要检查已上线业务是否有超过指定时长的慢SQL产生。

    采集方式

    方式一:采集慢日志文件

    前置条件

    • 已添加对应数据源;
    • 修改配置文件my.cnf,在文件中设置以下内容:
    my.cnf
    slow_query_log = ON //开启慢日志
    slow_query_log_file = /var/lib/mysql/tmp_slow.log //设置慢日志文件路径
    long_query_time = 1 //设置慢查询时间阈值,当前示例时间为1s,可根据实际业务变更

    步骤一:新建智能扫描任务

    新建智能扫描任务,填写以下字段信息:

    • 任务名称:指定扫描任务的名称,当前仅支持英文名称;
    • 数据源名称:选择扫描任务对应的数据源;
    • 数据库:选择扫描任务使用的数据库;
    • 数据库类型:根据选取的数据源呈现;
    • 任务类型:选择慢日志;
    • 审核过去时间段内抓取的SQL(分钟):扫描的时间覆盖范围;
    • 采集来源:填写0,代表采集mysql-slow.log 文件;
    • 审核规则模板:选择对应的审核规则模板;
    • 审核任务周期:配置的是SQLE对审核任务进行自动审核的执行时间;

    点击提交,完成慢日志扫描任务创建。

    步骤二:执行scannerd文件

    提示

    注意:scannerd文件通常在SQLE的bin目录下,需将scannerd文件放在数据源环境下执行。

    示例如下:

    ./scannerd slowquery -H "127.0.0.1" -P "10000" -N "slowlog_of_GRADE1" -J "default" -A eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhcG4iOiJzbG93bG9nX29mX0dSQURFMSIsImV4cCI6MTcwODA3MjMzNSwibmFtZSI6ImFkbWluIn0.ArU5HpU7aSSVrRutxSAwRFYahSx0_4RNzD4KB6LTfpM --log-file /var/lib/mysql/mysql-for-test-slow.log

    参数解释如下:

    • -J, --project:说明扫描任务所在项目,例“default”;
    • -H, --host string:指定SQLE主机所在地址;
    • -N, --name string:指定扫描任务名称,scannerd会将获得的慢SQL传至指定的任务池中审核;
    • -P, --port string:指定SQLE所在端口;
    • -A, --token string:输入扫描任务凭证token;
    • --log-file:指定慢日志文件,scannerd从该文件中获取慢SQL;

    方式二:采集慢日志表

    前置条件

    • 已添加数据源
    • 在MySQL中设置以下内容:
    set global long_query_time=1; // 需根据实际业务调整慢查询时间阈值,此处仅供参考
    set global slow_query_log=1; // 开启慢日志查询
    SET GLOBAL log_output='FILE,TABLE';// 开启 MySQL 的慢日志收集功能,并且确认将慢日志内容写入文件 mysql-slow.log 和表 mysql.slow_log
    提示

    为了优化查询性能,使用这一采集方式时,需要用户手动运行下面的SQL,将mysql.slow_log表的引擎改为MyISAM,并添加索引。

    ALTER TABLE mysql.slow_log ENGINE = MyISAM;
    ALTER TABLE mysql.slow_log ADD INDEX idx_start_time (start_time);

    新建智能扫描任务

    新建智能扫描任务,填写以下字段信息:

    • 任务名称:指定扫描任务的名称,当前仅支持英文名称;
    • 数据源名称:选择扫描任务对应的数据源核;
    • 数据库:选择扫描任务使用的数据库;
    • 数据库类型:根据选取的数据源呈现;
    • 任务类型:选择慢日志扫描任务;
    • 采集周期(分钟):SQLE进行采集的周期,若设置为10分钟,则SQLE将每隔10分钟去采集慢日志表中生成的慢查询;
    • 审核过去时间段内抓取的SQL(分钟):扫描的时间覆盖范围;
    • 采集来源:填写1,代表采集mysql.slow_log 表;
    • 审核规则模板:选择对应的审核规则模板;
    • 审核任务周期:配置的是SQLE对审核任务进行自动审核的执行时间;

    点击提交,完成慢日志扫描任务创建。

    执行结果

    在扫描任务详情查看扫描的SQL语句及审核报告。 result result2

    后续步骤

    分析扫描任务报告中出现的慢SQL。

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/audit_task/topsql/index.html b/docs/v2/user-manual/project/audit_task/topsql/index.html index c2d686e5..8293284b 100644 --- a/docs/v2/user-manual/project/audit_task/topsql/index.html +++ b/docs/v2/user-manual/project/audit_task/topsql/index.html @@ -4,13 +4,13 @@ TopSQL | SQLE 文档 - +
    版本:v2

    TopSQL

    本节介绍如何

    支持的数据源类型

    • DB2
    • Oracle
    • OceanBase for MySQL
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/group_member/index.html b/docs/v2/user-manual/project/group_member/index.html index ab68f45e..43a42e73 100644 --- a/docs/v2/user-manual/project/group_member/index.html +++ b/docs/v2/user-manual/project/group_member/index.html @@ -4,7 +4,7 @@ 成员/成员组管理 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    成员/成员组管理

    本文介绍项目内添加成员、成员组的步骤,以及其他管理操作。

    成员/成员组由项目管理员添加,只有被添加为成员后,才可查看、操作项目内资源。

    使用场景

    • 一个业务以项目的形式管理SQL工单、扫描任务等资源,若用户需要在指定项目中执行SQL工单、扫描任务等相关操作,则需要成为该项目的成员,并具有相应角色操作权限。
    • 如果用户具备相同的操作权限或者访问相同的资源,可以通过将他们加入同一个成员组来配置他们对项目资源的操作权限。

    前置条件

    • 项目管理员进入指定的项目;
    • 平台管理员已完成用户/用户组的添加;
    • 平台管理员已完成角色的添加;

    添加成员

    步骤

    项目管理员点击左侧导航栏成员标签,在成员列表点击添加成员按钮;

    字段说明

    • 用户名:选择平台已添加的用户;
    • 选择是否为项目管理员:项目管理员将负责项目管理行为,例如添加数据源和成员等;
      • 若将当前成员设为项目管理员,则该成员将对项目内所有数据源拥有所有操作权限,无需额外配置权限;
      • 若未设置,则当前成员在项目内的操作权限将根据下一步添加角色与数据源的绑定获得;
    • 添加角色与数据源的绑定;
      • 添加数据源:指定当前成员能操作的数据源;
      • 添加角色:指定当前成员在该数据源上的角色权限,平台默认提供DEV、DBA两种角色,负责SQL语句的提交、审核及上线操作;更多角色设置请参见角色管理
    • 删除角色与数据源的绑定;

    执行结果

    项目管理员可查看当前项目中添加的成员列表。 成员列表

    后续步骤

    配置项目审核流程模板:一个项目有且仅有一个审核流程,应用于该项目下的所有工单。需要配置审核流程在审核、上线环节的操作人,请参见审核流程模板

    更多操作

    • 编辑成员:添加成员后,项目管理员可修改成员可用的数据源及对应角色权限;
      • 限制:编辑之前产生的工单不受影响,编辑之后工单创建时将应用最新的数据源及权限对应关系;
    • 删除成员:项目管理员可删除项目中的成员;
      • 限制:若成员已不在项目内,则无权操作工单;

    添加成员组

    步骤

    项目管理员点击左侧菜单栏成员标签,在成员组列表点击添加成员组按钮;

    字段说明

    • 用户组名:选择平台已添加的用户组;
    • 添加角色与数据源的绑定:
      • 添加数据源:指定当前成员组能操作的数据源;
      • 添加角色:指定当前成员组在该数据源上的角色权限,平台默认提供DEV、DBA两种角色,负责SQL语句的提交、审核及上线操作;更多角色设置请参见角色管理
    • 删除角色与数据源的绑定:删除为当前成员组设定的数据源及角色信息;

    执行结果

    项目管理员可查看当前项目中添加的成员组列表。 成员组列表

    后续步骤

    • 配置项目审核流程模板:一个项目有且仅有一个审核流程,应用于该项目下的所有工单。需要配置审核流程在审核、上线环节的操作人,请参见审核流程模板

    更多操作

    • 编辑成员组:添加成员组后,项目管理员可修改成员组可用的数据源及对应角色权限;
      • 限制:编辑之前创建的工单不受影响,之后创建的工单将依据新的数据源及权限;
    • 删除成员组:项目管理员可删除项目中的成员组;
      • 限制:若成员组内成员已不在项目内,则无权操作工单;
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/instance-manager/index.html b/docs/v2/user-manual/project/instance-manager/index.html index 5c4ed896..54c6f2cd 100644 --- a/docs/v2/user-manual/project/instance-manager/index.html +++ b/docs/v2/user-manual/project/instance-manager/index.html @@ -4,14 +4,14 @@ 数据源管理 | SQLE 文档 - +
    版本:v2

    数据源管理

    本文介绍如何在项目中进行数据源管理,包括数据源的增加、删除、编辑操作。 数据源是工单和扫描任务的实施对象,用户在平台创建的工单和扫描任务都将针对指定的数据源执行。因而项目创建后需要首先配置项目内可用的数据源。

    提示

    数据源是SQLE连库审核的对象,任何审核的场景下若可以不选数据源则代表将进行脱库审核。

    使用场景

    实际生产中,如果需要针对某个数据源下发SQL或创建扫描任务,需要首先将数据源添加至SQLE平台,测试连通成功后才可创建工单、创建扫描任务。

    添加数据源

    前置操作

    项目管理员进入指定的项目

    操作步骤

    点击左侧导航栏的「数据源」菜单,进入数据源管理页面后,点击「添加数据源」,填写数据源相关信息

    • 数据源名称:命名当前新建的数据源,如:actionsky-test;
    • 数据源描述:用户可对数据源补充更多描述,便于用户通过名称+描述快速更精准地区分数据源;
    • 数据库类型:选择数据库实例对应的数据库类型,当前支持的数据库类型可参考支持的数据库及版本
    • 数据库地址:输入数据库实例的连接地址,支持IP地址、域名两种方式;
    • 数据库端口:添加数据源时根据数据源类型自动切换默认端口;
    • 连接用户:输入数据库实例的连接用户,SQLE在执行SQL审核以及SQL上线时,会通过该连接用户访问数据库实例及下发SQL;
    • 密码:输入数据库实例的连接用户密码;
    • 审核规则模板:审核规则模板将用于创建工单时的审核、扫描任务的审核、SQL查询的审核;
    • 运维时间:如果配置了运维时间, 工单将只能在运维时间内上线(立即上线和定时上线都受此影响), 支持配置多个运维时间, 默认无运维时间,即不限制上线时间;
    • SQL查询是否需要审核:默认不审核;如用户选择开启该功能,则用户在SQL工作台中提交的SQL语句,将匹配审核规则模板进行SQL审核操作;
    • 运行查询的最高审核等级:只有开启 SQL查询的审核功能才生效;支持四种审核等级:normal、notice、warn、error,如设置运行查询的最高审核等级为warn,则触发了warn等级规则以上的SQL语句将报错,并不予执行;未触发warn等级规则以上的SQL语句将被执行;

    执行结果

    数据源添加成功后,可在数据源列表查看新增的数据源信息。

    可根据数据源名称、数据库地址、数据库类型、使用的审核规则模板筛选项进行筛选。

    数据源列表

    后续步骤

    • 创建审核规则:添加数据源后,可针对指定数据源创建适用的审核规则,请参见审核规则模板管理
    • 添加成员/成员组:添加数据源后,需要引入成员/成员组对数据源进行操作,请参见成员/成员组管理

    更多管理功能

    • 编辑数据源:点击数据源列表页面对应数据源条目后的【编辑】按钮,可以修改指定数据源。
      • 限制:数据源名称及数据库类型不支持修改,其他信息均可修改
    • 删除数据源:点击数据源列表页面对应数据源条目后的【删除】按钮,可以删除指定数据源。
      • 限制:若数据源上还有相应工单未完成,则该数据源暂时不可删除
    • 连通性测试:点击【更多】按钮,选择连通性测试,测试是否可以用当前的数据源地址及用户密码成功连入数据源。
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/intro/index.html b/docs/v2/user-manual/project/intro/index.html index 3bf36fc7..3dc94cd8 100644 --- a/docs/v2/user-manual/project/intro/index.html +++ b/docs/v2/user-manual/project/intro/index.html @@ -4,7 +4,7 @@ 功能介绍 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    功能介绍

    自2.22.11.0版本起,平台引入项目管理概念,与SQL审核相关的资源均以项目的形式进行资源隔离。创建工单前,需要由项目管理员设置好项目内部必要的资源环境,包括项目使用的数据源、用户、流程模板、规则模板、白名单信息等,随后,项目成员才可在项目内提交工单并审核上线,或设置智能扫描任务。 本文介绍项目管理的使用场景以及如何以项目形式管理SQL工单、扫描任务等项目资源。在进行项目管理之前,需要由管理员进行创建项目,具体操作请参见创建项目

    说明

    提示

    社区版仅支持一个默认项目,项目管理员是admin,企业版可创建多个项目,有创建项目权限的用户可以创建项目,创建项目后,可指定其他项目成员为项目管理员。

    使用场景

    企业内容存在多个业务,且各个业务之间的数据源、工单、扫描任务可能由不同团队在负责,希望不同团队之间的数据相互隔离。此时,可在平台内以不同项目的行为去管理多个业务资源(数据源、工单、扫描任务等)。

    项目内资源调度

    资源调度 项目内的主要业务为工单审核及智能扫描任务审核。围绕工单及智能扫描任务,涉及到数据源管理、审核规则模板管理、白名单管理、审核流程管理、成员管理。

    以工单审核为例

    工单是为了满足下发SQL时审核、上线环节的流程化需求。

    工单的完整生命周期包括创建、审核、上线,其中涉及数据源、审核流程、审核规则模板、白名单的操作。

    备注
    • 审核流程:一个项目可绑定一个审核流程,该审核流程将应用于该项目下的所有工单审核。
    • 数据源:工单作用于具体的数据源,创建工单时,需要指定一个或多个数据源。
    • 审核规则模板:创建工单时,平台会基于该数据源应用的审核规则模板,对成员提交的SQL语句进行审核,满足应用的审核规则后,才可创建工单。
    • 白名单:创建工单时,若存在不需要审核的SQL语句,可将该SQL语句添加至白名单,提交该SQL时平台将不做审核。

    以智能扫描任务为例

    智能扫描任务是为了满足长期的SQL审核,平台支持的扫描任务类型包括库表元数据、TopSQL、慢日志、Mybatis扫描、应用程序SQL抓取及其他自定义扫描任务。

    智能扫描任务的完整生命周期包括创建、查看扫描任务报告,其中涉及数据源、审核规则模板、白名单的操作。

    备注
    • 数据源:智能扫描任务作用于具体的数据源,创建智能扫描任务时,需要指定一个数据源。
    • 审核规则模板:创建的智能扫描任务,将基于该任务下数据源应用的审核规则模板,审核任务中的SQL语句,并生成报告。
    • 白名单:创建扫描任务时,若存在不需要审核的SQL语句,可将该SQL语句添加至白名单,执行扫描任务时,将略过该语句。

    项目内资源权限

    资源权限

    项目内由成员执行工单及扫描任务。

    前置条件

    • 需要将平台创建的用户/用户组引入项目,成为项目成员/项目成员组后,才可在项目内进行操作。平台用户/用户组的创建,请参见平台用户管理
    • 引入项目成员/成员组时,需要指定成员/成员组在对应数据源上的操作角色,成员/成员组将继承角色对应的操作权限。角色的配置,请参见平台角色管理

    资源权限说明

    • 一个项目内可引入多个成员/成员组
    • 成员/成员组将依据自身绑定的数据源及对应角色权限,对指定数据源进行指定的操作。
    • 如当前项目引入了成员user1,并在user1上绑定了数据源local,并指定角色为DEV(创建工单),那么user1在当前项目中可执行的操作为:针对数据源local创建工单/管理自己创建的工单。
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/project_create/index.html b/docs/v2/user-manual/project/project_create/index.html index e987a12e..1acb0ce8 100644 --- a/docs/v2/user-manual/project/project_create/index.html +++ b/docs/v2/user-manual/project/project_create/index.html @@ -4,7 +4,7 @@ 创建项目【企业版】 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    创建项目【企业版】

    本文介绍如何在SQLE平台创建项目。 SQLE平台通过引入项目实现业务、资源的隔离,项目内创建的工单及扫描任务都将带有项目属性,仅项目成员可查看、操作。

    使用场景

    企业内容存在多个业务,且各个业务之间的数据源、工单、扫描任务可能由不同团队在负责,希望不同团队之间的数据相互隔离。此时,可在平台内以不同项目的行为去管理多个业务资源(数据源、工单、扫描任务等)。

    前置条件

    创建新项目时,需要用户拥有创建项目的权限,这部分内容可通过管理员账号配置,请参见平台用户管理,或由平台管理员直接创建项目。

    操作步骤

    拥有项目创建权限的用户/平台管理员点击页面顶部菜单栏项目,选择查看所有项目,点击列表右上角创建项目按钮

    • 输入项目名称。如:actionsky;
    • 输入项目描述。如:处理爱可生项目的数据源、工单及扫描任务;
    • 点击提交;

    执行结果

    • 项目创建完成后,可在项目列表中查看当前用户创建的项目。
    • 选中指定项目,可进入项目详情页面,查看并管理项目内的数据源、成员、审核规则模板、审核流程模板等内容。

    项目列表

    提示

    项目创建人在创建项目后会成为项目成员,承担项目管理员的身份,支持指定其他成员成为项目管理员,一个项目可对应多个项目管理员。

    后续步骤

    项目创建后,用户在进行创建工单、创建扫描任务的核心业务之前,还需要做如下操作:

    • 初始化工单、扫描任务的实施对象即数据源,具体操作请参见数据源管理
    • 初始化工单、扫描任务的使用人员以及使用人员的操作权限即项目成员,具体操作请参见成员管理
    • 初始化工单、扫描任务的审核规则模板,一个项目内可为不同数据源定义不同的规则模板,具体操作请参见规则模板管理
    • 若存在无需审核的SQL,可在白名单管理中初始化白名单,请参见白名单管理; 初始化工单的项目审核流程模板,一个项目内所有工单共用一个审核流程,具体操作请参见流程模板管理

    更多管理功能

    项目管理包含编辑及删除操作。

    • 项目编辑:项目创建人/平台管理员可在项目列表编辑项目条目信息,可编辑项为项目描述。
    • 项目删除:项目创建人/平台管理员可在项目列表删除项目条目。
      • 限制:删除项目前,需要确保项目下没有进行中的工单,才可成功删除。
      • 影响:删除项目后,该项目下的数据源、工单及扫描任务信息都将被删除。
    • 冻结项目:若有项目需要临时停用,项目创建人/平台管理员可在项目列表点击冻结项目。
      • 限制:冻结项目前,需要确保项目内没有未完成的工单。
      • 影响:冻结项目后,项目内所有操作均不可执行。
      • 后续:用户可点击启用操作,重新启用该项目。
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/rule-template-manager/index.html b/docs/v2/user-manual/project/rule-template-manager/index.html index d74811c0..d6a9055e 100644 --- a/docs/v2/user-manual/project/rule-template-manager/index.html +++ b/docs/v2/user-manual/project/rule-template-manager/index.html @@ -4,7 +4,7 @@ 审核规则模板 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    规则模版

    本文将介绍如何管理项目中的审核规则模板。 SQLE平台提供对应数据库类型的默认审核规则模板,是在长期实践中依据数据库特性总结出的一些规范的集合。审核规则模板在平台上的使用场景包括:创建工单时的审核、扫描任务的审核、SQL查询的审核。 同时也支持项目管理员基于实际业务需求定制审核规则模板,匹配具体的数据源审核需求。

    提示

    规则模版分为全局模版和项目模版,全局模版为超级管理员配置,所有项目都可见和使用;项目模版由超级管理员或者项目拥有者配置,仅在项目内使用

    提示

    每个规则模版内可独立配置规则的级别和参数

    使用场景

    在实际生产中,不同业务/不同数据源对上线的SQL存在不同审核要求,在SQLE平台中,项目管理员可通过审核规则模板为不同的数据源配置不同的审核规则。

    前置条件

    项目管理员进入指定的项目

    创建规则模板

    入口

    项目管理员点击左侧导航栏【规则模板】菜单,点击项目规则模板列表中的【创建规则模板】按钮。

    步骤一:输入基本信息

    • 模板名称:命名当前规则模板,须以字母开头,只能包含字母、数字、中划线和下划线。如:test
    • 模板描述:补充描述模板的其他信息。如:用于测试规则模板触发的告警等级
    • 数据库类型:选择该规则模板应用的数据库类型,当前支持的数据库类型包括MySQL、TiDB、DB2、SQL Server、OceanBase For MySQL、Oracle、PostgreSQL、达梦。

    步骤二:选择要启用/禁用的规则

    • 编辑规则告警等级:当前可设置项为普通、提示、警告、告警
    • 编辑规则参数默认值

    步骤三:提交规则模板

    执行结果

    成功创建自定义审核规则模板后,项目管理员可查看已创建的自定义规则模板及其对应的数据库类型。

    审核规则模板

    后续步骤

    • 设置数据源的审核规则模板:用户可为不同数据源设置相同或者不同的审核规则模板,具体操作请参见数据源管理
    • 创建工单:工单中SQL的审核将依据该数据源配置的审核规则模板,请参见工单说明
    • 创建智能扫描任务:智能扫描任务中SQL的审核将依据该数据源配置的审核规则模板,请参见扫描任务说明

    更多操作

    • 导入规则模板:可以导入其他项目中形成的规则模板文件
    • 编辑规则模板:编辑规则模板的基本信息及应用的规则
    • 删除规则模板:删除自行创建的规则模板
      • 限制:当已有数据源绑定了该规则模板,该规则模板不可被删除
    • 克隆规则模板:克隆当前的模板,克隆的规则模版只会继承源模版所有启用的规则、以及变更过的规则等级和阈值。克隆出的新规则模版的模版名称等基本信息需要手动填写。
    • 导出规则模板:导出当前选中的规则模板,以json格式下载规则模板内容。
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/whitelist-manager/index.html b/docs/v2/user-manual/project/whitelist-manager/index.html index af53ebcd..34594d69 100644 --- a/docs/v2/user-manual/project/whitelist-manager/index.html +++ b/docs/v2/user-manual/project/whitelist-manager/index.html @@ -4,7 +4,7 @@ 白名单管理【企业版】 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    白名单【企业版】

    本文介绍如何增加、编辑、删除项目中的白名单。 SQLE在企业版中提供白名单功能,便于用户在特定场景下规避具体规则的审核。 添加在SQL审核白名单中的语句,在提交工单申请时,不受审核规则的约束。。

    提示

    白名单目前支持两种方式匹配SQL,字符串匹配和SQL指纹匹配,前者需要SQL内容一致,后置匹配同类型的SQL

    使用场景

    当已知一些 SQL 存在不规范之处,但又想忽略时,可以将SQL语句添加至白名单。

    前置条件

    项目管理员进入指定的项目

    添加白名单

    项目管理员点击左侧导航栏【白名单】菜单,点击白名单列表右上角的【添加白名单】按钮。

    • 选择匹配模式:提供以下两种方式
      • 字符串匹配:若选择通过字符串匹配,则将应用于指定SQL语句。
      • SQL指纹匹配:若选择通过SQL指纹匹配,则应用于语句结构一致的SQL。
    • 输入白名单描述:用以提示该条白名单SQL的应用场景
    • 输入SQL语句

    执行结果

    成功添加白名单后,可以看到当前项目内所有的项目白名单及匹配模式

    whitelist

    后续步骤

    • 创建工单:添加白名单后,可继续创建工单,白名单中的语句将不会触发审核,请参见工单说明
    • 创建智能扫描任务:添加白名单后,审核将跳过白名单中的语句,请参见扫描任务说明

    更多操作

    • 编辑白名单:项目管理员/成员可修改已创建的白名单语句
    • 删除白名单:项目管理员/成员可删除已创建的白名单语句
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/workflow-template-manager/index.html b/docs/v2/user-manual/project/workflow-template-manager/index.html index ba73797c..40e393fe 100644 --- a/docs/v2/user-manual/project/workflow-template-manager/index.html +++ b/docs/v2/user-manual/project/workflow-template-manager/index.html @@ -4,7 +4,7 @@ 审核流程模板 | SQLE 文档 - + @@ -14,7 +14,7 @@ 一个项目有且仅有一个审核流程模板。

    提示

    每个项目对应使用一个流程模版,项目创建后会初始化一个默认模版,用户可根据实际情况调整

    提示

    工单审核步骤若选择匹配所有拥有审核权限的用户时对应的数据源没有对应的人员则默认指定管理员进行审批操作

    警告

    修改流程模版仅对之后的工单有效,之前的工单流程步骤不变

    使用场景

    一个业务团队中,开发需要在指定数据源上执行SQL,上线的SQL需要符合DBA约定了的安全以及性能规范。因此,SQLE为工单场景提供了不同人员之间的协作工作流,即审核流程。

    前置条件

    项目管理员进入指定的项目 项目管理员已添加项目成员/成员组

    配置审核流程

    项目管理员点击左侧导航栏流程模板菜单, 点击修改当前审批流程模板按钮

    设定模板的基本信息

    设置允许创建工单的最高审核等级

    当前提供四种审核等级,包括:

    • 普通
    • 提示
    • 告警
    • 错误

    若设置“运行查询的最高审核等级”为warn,则审核结果小于等于warn的SQL都可以执行.

    设置流程节点

    审核流程自工单发起开始,通过设置的审核步骤后,最后以执行上线结束

    第一步 工单发起

    这一步骤通常指代项目成员创建工单

    第二步 工单审核

    配置审核节点后,对应审核操作人在该步骤可以执行审核通过或驳回操作

    • 选择审核人类型,可以选择指定审核人或匹配拥有数据源审核权限的成员
    • 添加步骤描述:用以补充说明步骤信息
    • 添加审核步骤:审核流程模板最多可设置4个审核节点,也可不设置审核步骤
    提示
    • 若选择指定审核人
      • 需要项目管理员指定项目成员
      • 最少需要添加一个指定人,最多只能添加三个指定人
      • 指定的审核人可以没有工单审核权限
    • 若选择匹配拥有数据源审核权限的成员
      • 将按实例匹配数据源上拥有审核权限的成员
      • 如果创建工单时没有任何用户拥有此数据源工单审核权限, 则工单审核人将会被指定为项目管理员

    第三步 工单上线:执行人在该步骤可以执行上线或驳回操作。

    • 选择审核人类型,当前提供两种方式:指定上线人或匹配拥有数据源上线权限的成员
    • 添加步骤描述
    提示
    • 若选择指定审核人
      • 需要项目管理员指定项目成员
      • 最少需要添加一个指定人,最多只能添加三个指定人
      • 指定的上线人可以没有工单上线权限
    • 若选择匹配拥有数据源上线权限的成员
      • 将按实例匹配数据源上拥有上线权限的成员
      • 如果创建工单时没有任何用户拥有此数据源工单上线权限, 则工单上线人将会被指定为项目管理员

    第四步 提交审核流程模板

    提交审核流程后,流程修改之前创建的工单仍以提交工单时的审核流程执行,流程修改后的创建的工单将以当前的审核流程执行流转。

    执行结果

    提交审核流程模板后,可查看当前设置的审批流程模板涉及的步骤节点,及各步骤的审核人。 审核流程模板

    后续步骤

    创建工单:创建审核流程模板后,成员可进入项目中创建工单,请参见:创建工单

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/workflow/audit-workflow/index.html b/docs/v2/user-manual/project/workflow/audit-workflow/index.html index 64b03276..5f991e37 100644 --- a/docs/v2/user-manual/project/workflow/audit-workflow/index.html +++ b/docs/v2/user-manual/project/workflow/audit-workflow/index.html @@ -4,7 +4,7 @@ 审核工单 | SQLE 文档 - + @@ -13,7 +13,7 @@ 自动审核通常在创建工单时执行,本节主要介绍人工审核部分。

    使用场景

    实际生产中会存在业务变更、业务上线,比如初始化构建业务库、跑批等,当工单创建后,通常需要审核人员执行审批操作,审批过程中,审批用户可选择审核通过或全部驳回。

    前置条件

    工单已被创建

    操作步骤

    步骤一 查看待审核的工单

    提示
    • 入口一:可在dashboard中查看待自己审核的工单
    • 入口二:进入项目的工单列表,筛选工单状态为待审核,查看项目内待审核的工单

    步骤二 点击待审核的工单名称,进入查看工单详情

    工单详情页信息包含以下几个方面

    • 工单基础信息:包括工单名称、工单创建人、工单创建时间及工单描述
    • 工单进度:查看当前工单的执行进度,及工单整体流经的流程节点,流程节点与审核流程模板中设置的节点保持一致
    • 工单审核结果查看:
      • 概览:查看工单的整体概况信息,显示工单整体应用的数据源及审核情况
      • 按数据源查看:按数据源查看数据源上的SQL及其审核结果,并查看分析结果,也可下载审核报告、下载SQL语句、去重SQL

    步骤三 审核通过或驳回工单

    • 审核通过:成员查看工单详情后,若审核通过,可点击【审核通过】按钮,完成审核;
    • 全部驳回:若审核不通过,可点击【全部驳回】按钮,并填写驳回原因,工单将返回至工单创建人处

    执行结果

    • 审核通过:若点击【审核通过】,工单将按照审核流程模板流转至下一操作节点,状态变更为待审核或待上线 approve
    • 全部驳回:若点击【全部驳回】,工单状态将变更为已驳回,工单进度栏将提示提交的驳回原因,工单将返回至创建人重新修改,并重新提交工单审核,或直接关闭工单 deny

    后续步骤

    • 审核工单:若工单涉及其他审核流程节点,工单将继续流转至下一审核节点审核
    • 上线工单:若工单不涉及其他审核流程节点,工单将流转至上线人处执行上线,可参考上线工单
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/workflow/create-workflow/index.html b/docs/v2/user-manual/project/workflow/create-workflow/index.html index 7bd1ec12..295bef62 100644 --- a/docs/v2/user-manual/project/workflow/create-workflow/index.html +++ b/docs/v2/user-manual/project/workflow/create-workflow/index.html @@ -4,7 +4,7 @@ 创建工单 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    创建工单

    工单是SQLE提供的在线化SQL上线方式。研发人员可通过创建工单,提请需要审批的SQL语句。

    使用场景

    实际生产中会存在业务变更、业务上线,比如初始化构建业务库、跑批。此时,需要针对某个数据库执行一批SQL。用户可通过SQLE创建工单,输入SQL语句或者上传SQL脚本。

    前置条件

    • 项目管理员已添加数据源;

    操作步骤

    步骤一:填写工单基本信息

    创建工单前,需要为工单指定唯一的工单名称,并填写工单说明。

    • 填写工单名称:
      • 工单名称支持中英文,须以英文开头;
      • 工单名称可自行填写;若未填写,平台将根据使用的数据源及添加时间组合填充工单名称;
    • 填写工单描述:输入工单描述信息,限3000个字符;

    步骤二:上传SQL语句并审核

    需要填写工单中涉及的SQL语句,执行审核操作,SQLE会根据数据源配置的审核规则模板,自动进行SQL语句的规则审核,并在线反馈审核结果。

    • 选择数据源:表示当前SQL最终会应用到哪个数据源;
      • 社区版:一个工单内仅支持选择一个数据源;
      • 企业版:一个工单内支持添加多个数据源;
    • 是否选择相同SQL:当添加多个数据源时,可设置是否选择相同SQL;
      • 使用相同SQL模式,
        • 限制:数据源的数据库类型相同;
        • 效果:对不同数据源下发相同SQL;
      • 若不使用相同SQL模式
        • 效果:对不同数据源下发不同SQL;
    • 选择数据库:选择要执行的数据库,相当于执行 use 语句;
      • 若未选择数据库,工单上线后,将脱库执行下发的SQL;
    • 选择审核SQL语句上传方式:平台提供三种上传方式,包括在线输入SQL语句、上传SQL文件、上传MyBatis的XML文件;
      • 在线输入SQL语句:项目成员可在平台编辑器中直接输入SQL;
      • 上传SQL文件:项目成员可选择本地的SQL文件上传;
      • 上传Mybatis的XML文件:项目成员可选择本地的XML文件上传;
        • 限制:平台仅支持审核XML文件中上传的SQL语句,尚不支持对其创建工单;
    • 点击审核,显示平台审核结果;
    提示

    在线输入SQL的场景下,平台支持对输入框中的SQL进行美化,以此提高SQL可读性。

    注:当前支持SQL美化的数据源类型包括:

    • MySQL
    • DB2
    • SQL Server
    • Oceanbase For MySQL
    • Oracle
    • PostgreSQL

    步骤三:查看审核结果

    将根据数据源不同,展示不同数据源下的SQL审核结果。 审核结果由以下几部分组成:

    • 数据源标签:显示当前SQL操作的数据源,当有多个数据源时,可切换数据源标签,查看不同数据源上的审核情况;
    • 数据源上SQL的整体审核通过率、审核结果评分及操作的数据库;
    • 数据源上每条SQL的审核结果、SQL语句及执行状态,可分析SQL;
    • 功能区:
      • 下载审核报告:查看当前数据源下审核的sql语句及其审核结果;
      • 下载SQL语句:下载文件,可查看当前数据源下审核的SQL语句及其审核结果;
      • 设置是否去重:若SQL语句结构一致,去重后将仅显示去重后的SQL;
    审核通过率计算方式
    审核通过率=正常sql/sql总数
    审核结果等级为notice,warn,err的sql均为非正常sql
    审核结果评分计算方式
    1.Error以上级别SQL出现率 = Error级别SQL/SQL
    2.Warn以上级别SQL出现率 = (Error级别SQL+ Warn级别SQL) /SQL
    3.Warn以上级别SQL出现率 = (Error级别SQL+ Warn级别SQL+ Notice级别SQL) /SQL
    4.总分 = 审核通过率 x 30 +
    (1 - Error以上级别SQL出现率) x 15 +
    (1 - Warn以上级别SQL出现率) x 10 +
    (1 - Notice以上级别SQL出现率) x 5 +
    (Error以上级别SQL出现概率 == 0 ? 15 : 0) +
    (Warn以上级别SQL出现概率 == 0 ? 10 : 0) +
    (Notice以上级别SQL出现概率 == 0 ? 5 : 0) +
    (Error以上级别SQL出现概率 <0.1 ? 5 : 0) +
    (Warn以上级别SQL出现概率 <0.1? 3 : 0) +
    (Notice以上级别SQL出现概率 <0.1 ? 2 : 0)

    备注: 三元表达式 ==> ( 条件 ? 如果条件为真则为此值 : 如果条件为假则为此值 )

    步骤四:点击创建工单

    完成创建后,进入工单列表,即可看到该工单显示为待审核。

    执行结果

    创建工单后,可在工单列表查看已创建的所有工单。 list

    后续步骤

    • 审核工单:工单创建完成后,将依据审核流程模板的设定,流转至指定的审核成员处,审核成员需登录后进行审核操作,详情可参见审核工单
    • 导出工单:当用户需要审计当前已创建的工单时,可选择筛选条件后,点击工单列表的导出工单按钮,以csv格式导出满足条件的工单信息。
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/workflow/exec-workflow/index.html b/docs/v2/user-manual/project/workflow/exec-workflow/index.html index e80c7582..853d68a1 100644 --- a/docs/v2/user-manual/project/workflow/exec-workflow/index.html +++ b/docs/v2/user-manual/project/workflow/exec-workflow/index.html @@ -4,14 +4,14 @@ 上线工单 | SQLE 文档 - +
    版本:v2

    上线工单

    本章详细介绍用户如何进行上线。

    • 从数据源角度,支持多数据源同时上线、单数据源分别上线;
    • 从上线时间角度,支持立即上线、定时上线;
    • 从上线方式角度,支持平台直接上线,也支持后台执行后,线上标记为人工上线;

    使用场景

    实际生产中上线环节也会存在业务变更等诸多情况,除了对工单做整体上线操作外,还存在以下需求:

    • 需要根据数据源分别上线;
    • 需要避开业务高峰期,在指定时间上线;
    • 已在后台执行SQL,需要线上标记为人工上线;

    为此,SQLE平台也提供了多种上线方式,满足用户的上线需求。

    前置条件

    工单状态为待上线;

    操作步骤

    步骤一 进入待上线的工单

    • 方式一:上线操作人可在dashboard中点击“需上线”标签,查看当前需要上线的工单;
    • 方式二:上线操作人也可在项目的工单列表中,筛选工单状态为“待上线”的工单,查看当前需要上线的工单;

    步骤二 设置工单上线

    根据使用场景,区分为以下四种工单上线方式;

    1.批量立即上线

    针对一个工单内涉及多个数据源,且多个数据源需要同时立即上线的,点击批量上线,平台将对工单内涉及的所有数据源执行上线操作;

    2.单个数据源立即上线

    点击立即上线后,平台将立即连入指定数据源,并执行SQL变更;

    3.单个数据源定时上线

    点击定时上线,并设置上线时间,平台将于指定时间上线SQL; 用户也可取消定时上线,重新设置上线方式。

    4.标记为人工上线

    针对已经线下执行过的工单SQL,用户可点击标记为人工上线按钮,切换工单状态;

    提示

    上线人仍可选择全部驳回:用户判定工单中存在不合规、性能问题等SQL语句时,则可点击全部驳回,让工单创建人修正后再次进入审核流程。

    备注

    针对上线中的工单,用户可点击“中止上线”按钮,中断上线流程,以避免当前的上线操作影响正常业务。

    执行结果

    result

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/project/workflow/intro/index.html b/docs/v2/user-manual/project/workflow/intro/index.html index a6bf8871..75dba32d 100644 --- a/docs/v2/user-manual/project/workflow/intro/index.html +++ b/docs/v2/user-manual/project/workflow/intro/index.html @@ -4,14 +4,14 @@ 功能说明 | SQLE 文档 - +
    版本:v2

    功能说明

    很多公司通常设有 DBA(Database administrator) 这个职位,他们负责在系统上运行数据库,执行备份,执行安全策略等日常数据库运维的工作。其中,DBA一项重要的工作是规范研发人员在应用程序中使用的 SQL 语句。

    场景举例:

    产品在迭代过程中,某个表需要新增一个字段,这会涉及到改表操作。 当前处理方法:DBA 依据数据库规范评估SQL语句的合理性。如果评估没有问题,则将修改操作应用到线上数据库。如果公司对于这类操作比较严格,在上线前,可能还需要经过层层审批。所有上线流程中的人都同意后,再将修改操作应用到数据库。

    由此引出的问题:

    • SQL上线牵涉范围较广,缺乏规范化流程支撑
    • 工单运转节点不透明,需要DBA去手动通知

    定位

    SQLE审核工单的出现主要是为了解决上述整个过程中的规范化、流程化的问题。

    • 通过引入审核规则模板,在人工审核前,首先利用规范化的DBA审核经验进行平台预审,提高整体审核效率
    • 通过引入审核流程模板,将SQL语句的流程节点透明化,并明确操作权限归属,提供规范化流程支持

    流程

    process

    状态说明
    待审核创建完的工单自动进入「待审核」状态;该状态的工单将由项目流程设置的审核人进行审核。
    待上线工单的每一道审核流程均执行通过后,工单状态将由「待审核」状态变更为「待上线」状态;上线人此时可选择立即上线或批量驳回,或针对具体数据源进行立即上线或定时上线。设置定时上线后,工单状态仍为「待上线」,到达预设的上线时间后,变更为「正在上线」状态;设置定时上线但还未到达上线时间的工单,可以由上线人取消定时上线,可以再次对工单进关闭、定时上线/立即上线等操作。
    正在上线当上线人进行立即上线,工单会短暂的进入「正在上线」阶段,该阶段的时间取决于SQL是否上线完毕;当上线人选择定时上线,定时上线的工单到预设时间会自动执行SQL上线,此时工单也会由「待上线」状态变更为「正在上线」状态;SQL上线遇到阻塞的工单会一直处于「正在上线」状态。
    上线成功SQL上线成功的工单会进入「上线成功」状态;上线成功标志工单流转结束,无法再对工单进行操作。
    上线失败SQL上线失败的工单会进入「上线失败」状态;上线失败同样标志工单流转结束,无法再对工单进行操作
    已驳回「待审核」的工单可以由每级的审批人进行审核,若审核不通过,被驳回,工单将进入「已驳回」状态;此状态的工单可以由创建人或者超管用户进行修改并重新提交工单,流程将被重置。
    已关闭状态为「待审核」、「待上线」或「已驳回」的工单可以由创建人或者超管用户在任何时刻关闭工单,「已关闭」状态标志工单流转结束,无法再对工单进行操作;已经进入上线流程的工单无法关闭。
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sql-workbench/how-to-configure/index.html b/docs/v2/user-manual/sql-workbench/how-to-configure/index.html index 5c6f2e1d..65fff212 100644 --- a/docs/v2/user-manual/sql-workbench/how-to-configure/index.html +++ b/docs/v2/user-manual/sql-workbench/how-to-configure/index.html @@ -4,14 +4,14 @@ 配置方法 | SQLE 文档 - +
    版本:v2

    配置方法

    安装CloudBeaver

    提示

    SQLE目前支持的CloudBeaver版本包括22.2.0、22.2.1、22.2.3、22.3.1版本

    docker 部署:https://github.com/dbeaver/cloudbeaver/wiki/Run-Docker-Container

    源码安装:https://github.com/dbeaver/cloudbeaver/wiki/Build-and-deploy

    配置CloudBeaver

    步骤一 修改CloudBeaver配置文件cloudbeaver.conf

    cloudbeaver.conf配置文件通常在conf路径下

    配置文件名是否必须修改修改内容修改原因
    cloudbeaver.conf将server.rootURI的值改为'/sql_query';将server.serviceURI 的值改为 '/api/'(server.serviceURI默认就是/api/)SQLE目前只支持代理这个路由

    config

    步骤二 重启CloudBeaver

    配置cloudbeaver后,需要重启cloudbeaver以使配置项生效

    步骤三 初始化CloudBeaver

    • 使用 http://{IP}:8978/sql_query#/ 可以进入CloudBeaver即代表配置正确
    • 设置管理员用户名及密码:该用户名及密码将用于后续SQLE配置文件中
    • 确认security服务开启
    • 完成设置,登录管理员账号成功,则初始化成功

    步骤四 配置完成后检查

    • 确认角色正确:[访问管理] - [角色] 处应当只有admin和user两个角色

    • 确认没有冲突用户:[访问管理] - [用户] 处不应当有名称格式为 sqle-xxx的用户存在, 这会与SQLE自动创建的用户冲突

    提示

    用admin 跳转Cloudbeaver的时候,SQLE会在Cloudbeaver创建一个新的用户叫sqle-admin ,同时把这个用户缓存到数据库里,每次跳转先去数据库里找这个用户,如果已经存在,就会拿这个用户直接去登陆cb

    配置SQLE

    步骤一 修改SQLE配置文件, 增加SQL工作台参数

    打开SQLE配置文件,配置文件一般位于SQLE工作目录的etc目录下, 文件名一般为sqled.yml 配置文件新增参数sql_query_config

    参数字段参数说明
    sql_query_configsql工作台参数, 此参数与 sqle_config在同一级

    在sql_query_config参数下增加子参数,子参数在 sql_query_config 的下一级, 需要注意缩进

    参数字段参数说明
    cloud_beaver_hostcloudbeaver IP地址
    cloud_beaver_portcloudbeaver访问端口
    cloud_beaver_admin_usercloudbeaver管理员账户
    cloud_beaver_admin_passwordcloudbeaver管理员密码

    配置文件内容参考:

    sqleconfig

    步骤二 重启SQLE

    需要重启以使配置项生效。

    步骤三 检查SQLE是否已成功集成CloudBeaver

    SQLE重启后进入平台,点击打开SQL工作台,若成功跳转,则说明当前SQLE平台已成功集成CloudBeaver。

    提示
    • 平台管理员账户需要有 [添加/修改/删除][用户/实例/权限] 的权限
    • SQLE集成CloudBeaver后请勿使用CloudBeaver的管理员账户直接操作CloudBeaver的用户/实例/权限

    常见问题

    如果在配置CloudBeaver时,出现跳转不正确等问题,可参考如何解决CloudBeaver跳转不正确的问题

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sql-workbench/how-to-quick-deploy/index.html b/docs/v2/user-manual/sql-workbench/how-to-quick-deploy/index.html index ce61599b..60aeed47 100644 --- a/docs/v2/user-manual/sql-workbench/how-to-quick-deploy/index.html +++ b/docs/v2/user-manual/sql-workbench/how-to-quick-deploy/index.html @@ -4,13 +4,13 @@ 使用定制包快速搭建环境 | SQLE 文档 - +
    版本:v2

    使用定制包快速搭建环境

    SQLE在原有CloudBeaver release_22_2_0 分支的基础上, 增加了对OceanBase 和 TiDB 的支持, 用户无需再手动配置环境,可直接使用SQL工作台功能。

    cb

    定制分支与原分支区别详情

    • 支持并默认启用 OceanBase 驱动
    • 支持并默认启用 TiDB 驱动
    • 默认访问路由调整为 /sql_query, 便于与SQLE集成
    • 默认会话超时时间调整为12小时(之前是30分钟)
    • 移除了默认创建的 PG 演示实例和 SQLite 演示实例
    • docker镜像名调整为 actiontech/sqle-cloudbeaver:22_2_0
    • 优化打包方式, 大幅提高打包效率
    • 默认主题改为暗色

    项目地址

    定制包下载地址

    https://github.com/actiontech/cloudbeaver/releases/tag/sqle.22.2.0

    使用说明

    编译和运行项目

    与原项目编译运行方式保持一致

    编译docker镜像

    进入项目的 deploy/docker 目录, 然后执行 ./make-docker-container.sh

    运行docker镜像

    • 方式一: 进入项目的 deploy/docker 目录, 然后执行 ./run-docker-container.sh
    • 方式二: 手动启动镜像, 镜像参数和 原项目镜像参数 保持一致

    已有CloudBeaver环境升级为定制环境

    CloudBeaver程序目录下应当有以下几个文件

    cb

    将CloudBeaver程序目录下的conf目录和workspace目录移动到定制CloudBeaver程序目录下(覆盖原目录), 随后停止旧CloudBeaver, 运行新CloudBeaver即可

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sql-workbench/how-to-use/index.html b/docs/v2/user-manual/sql-workbench/how-to-use/index.html index b1b1c768..4831295b 100644 --- a/docs/v2/user-manual/sql-workbench/how-to-use/index.html +++ b/docs/v2/user-manual/sql-workbench/how-to-use/index.html @@ -4,13 +4,13 @@ 使用定制包快速搭建环境 | SQLE 文档 - +
    版本:v2

    使用定制包快速搭建环境

    SQLE在原有CloudBeaver release_22_2_0 分支的基础上, 增加了对OceanBase 和 TiDB 的支持, 用户无需再手动配置环境,可直接使用SQL工作台功能。

    cb

    定制分支与原分支区别详情

    • 支持并默认启用 OceanBase 驱动
    • 支持并默认启用 TiDB 驱动
    • 默认访问路由调整为 /sql_query, 便于与SQLE集成
    • 默认会话超时时间调整为12小时(之前是30分钟)
    • 移除了默认创建的 PG 演示实例和 SQLite 演示实例
    • docker镜像名调整为 actiontech/sqle-cloudbeaver:22_2_0
    • 优化打包方式, 大幅提高打包效率
    • 默认主题改为暗色

    项目地址

    定制包下载地址

    https://github.com/actiontech/cloudbeaver/releases/tag/sqle.22.2.0

    使用说明

    编译和运行项目

    与 原项目编译运行方式 保持一致

    编译docker镜像

    进入项目的 deploy/docker 目录, 然后执行 ./make-docker-container.sh

    运行docker镜像

    • 方式一: 进入项目的 deploy/docker 目录, 然后执行 ./run-docker-container.sh
    • 方式二: 手动启动镜像, 镜像参数和 原项目镜像参数 保持一致

    已有CloudBeaver环境升级为定制环境

    CloudBeaver程序目录下应当有以下几个文件

    cb

    将CloudBeaver程序目录下的conf目录和workspace目录移动到定制CloudBeaver程序目录下(覆盖原目录), 随后停止旧CloudBeaver, 运行新CloudBeaver即可

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sql-workbench/introduction/index.html b/docs/v2/user-manual/sql-workbench/introduction/index.html index 32d1aa19..f763cd58 100644 --- a/docs/v2/user-manual/sql-workbench/introduction/index.html +++ b/docs/v2/user-manual/sql-workbench/introduction/index.html @@ -4,7 +4,7 @@ 功能说明 | SQLE 文档 - + @@ -12,7 +12,7 @@
    版本:v2

    功能说明

    CloudBeaver Community 是一个开源的 Web 数据库可视化管理工具,支持 PostgreSQL, MySQL, MariaDB, SQL Server, Oracle, DB2, Firebird, H2, Trino 等数据库。

    SQLE通过集成CloudBeaver,使得SQLE具备数据库操作的能力,方便开发或DBA在SQLE中方便地操作数据库

    • SQL工作台会自动同步SQLE的用户信息和实例信息, 避免无权限的人进行操作
    • 可通过参数配置及SQL查询审核对SQL做限制和审核,有效避免不合规的查询

    使用场景

    当业务人员需要对数据库进行数据检索时,一些查询SQL可能会造成数据库性能问题甚至夯死。但在传统的使用场景中,DBA很难对业务人员的行为进行追踪和管控,无法限制有问题的SQL在生产环境执行。

    因而SQLE平台集成CloudBeaver数据库可视化管理工具,满足在线SQL查询需求的同时,进行业务人员的操作权限控制,并对业务人员的SQL进行审计,拒绝不合规的SQL运行。

    前置条件

    安装CloudBeaver并完成配置,参考SQL工作台配置方法

    操作步骤

    步骤一 SQLE平台配置用户

    • 创建一个有SQL查询权限的角色
    • 将成员关联至该角色

    步骤二 SQLE平台配置数据库实例审核等级

    创建/修改一个实例, 开启SQL查询,并设置运行查询的最高审核等级,并提交修改

    参数名参数含义
    SQL查询是否需要审核只有开启此项,才会在执行SQL查询时进行审核
    运行查询的最高审核等级如果审核等级低于或等于这个等级将会放行, 高于这个等级将无法执行

    步骤三 登录CloudBeaver

    自动登录说明:在登陆SQLE时会检测CloudBeaver是否处于登陆状态, SQLE将会自动使用当前SQLE用户登录CloudBeaver。

    警告

    若当前用户无SQL查询权限,则无权登录。

    步骤四 下发SQL

    选择需要操作的数据源,并输入SQL语句点击运行,可查看SQL查询结果

    操作结果

    审核失败的SQL将会被拦截, 并报出错误, 可以点击详情查看错误详情 error

    按要求修改SQL, 再次执行, 如果审核通过将会执行当前SQL success

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sys-configuration/configuration/index.html b/docs/v2/user-manual/sys-configuration/configuration/index.html index b8334c21..940dae8d 100644 --- a/docs/v2/user-manual/sys-configuration/configuration/index.html +++ b/docs/v2/user-manual/sys-configuration/configuration/index.html @@ -4,14 +4,14 @@ 全局配置 | SQLE 文档 - +
    版本:v2

    全局配置

    SQLE支持管理员对平台基础配置进行统一管理,目前支持修改的配置项包括:

    • 已完成的工单自动过期时间;
    • 操作记录过期时间;
    • URL地址前缀;

    已完成的工单自动过期时间

    使用场景

    SQLE会定时回收已完成的工单,目前该过期时间默认为30天。如果用户需要自定义过期时间,可在全局配置中修改。

    填写范例

    • 进入全局配置页面,点击修改
    • 点击已完成的工单过期时间输入框;
    • 输入预期的过期时间,例如:360小时;
    • 点击提交,保存配置;
    • 此时查看项目工单列表,已完成15天以上的工单将被删除;

    操作记录过期时间

    使用场景

    SQLE会定时回收已产生的操作记录,目前该过期时间默认为90天。如果用户需要自定义过期时间,可在全局配置中修改。

    填写范例

    • 进入全局配置页面,点击修改
    • 点击操作记录过期时间输入框;
    • 输入预期的过期时间,例如:2小时;
    • 点击提交,保存配置;
    • 此时查看平台操作记录,仅显示2个小时内产生的操作行为;

    URL地址前缀

    使用场景

    配置消息推送或流程对接后,用户可以从外部应用程序中直接查看待操作提示。此时,如果用户需要跳转到SQLE,进一步查看工单详细信息,则可以在全局配置中更改URL地址前缀,以满足访问需求。

    填写范例

    • 进入全局配置页面,点击修改
    • 点击URL地址前缀输入框;
    • 输入URL前缀,格式为http://ip:port,例如:http://localhost:10000 ;
    • 点击提交,保存配置;
    • 创建一条工单,待审批人在第三方应用中可查看工单链接,点击链接可快速跳转至SQLE平台; configuration-url
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sys-configuration/customize/index.html b/docs/v2/user-manual/sys-configuration/customize/index.html index 7d0cc12d..9237cce5 100644 --- a/docs/v2/user-manual/sys-configuration/customize/index.html +++ b/docs/v2/user-manual/sys-configuration/customize/index.html @@ -4,13 +4,13 @@ 个性化设置【企业版】 | SQLE 文档 - +
    版本:v2

    个性化设置【企业版】

    SQLE支持对网站logo及标题进行自定义设置,满足企业用户的个性化需求。

    使用场景

    若用户对企业一致性有需求,需要变更所使用的网站logo及标题,以增加企业辨识度时,可以使用平台的个性化设置进行变更。

    操作步骤

    • 用户点击系统设置,选择个性化设置
    • 编辑标题:用户点击个性化标题后的编辑icon,输入新名称test,回车键保存后,页面标题将变更为test
    • 编辑个性化logo:用户点击上传及更新icon,选择需要的图片,点击打开后,页面logo将变更为所选图片;
      • 限制:图片大小不可超过102,400 Bytes;

    customize

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sys-configuration/instance_syn/index.html b/docs/v2/user-manual/sys-configuration/instance_syn/index.html index 2d67dd35..3c428267 100644 --- a/docs/v2/user-manual/sys-configuration/instance_syn/index.html +++ b/docs/v2/user-manual/sys-configuration/instance_syn/index.html @@ -4,7 +4,7 @@ 外部数据源同步【企业版】 | SQLE 文档 - + @@ -14,7 +14,7 @@ sip

    3.针对需要同步的实例组添加项目标签

    SQLE同步时,将依据项目标签值,将实例同步至指定项目中 tag

    操作步骤

    • 进入SQLE平台,点击右上角菜单的“外部数据源同步”,进入同步任务页面
    • 添加同步任务,填写以下相关信息
      • 来源:目前仅支持DMP平台;
      • 地址:默认格式为http://ip:port;
      • 数据源类型:选择同步的数据源类型,如mysql;
      • 审核规则模板:选择数据源使用的规则模板;
      • 设置同步间隔:SQLE平台将按照指定的同步时间执行同步任务;
    • 点击“提交”按钮,SQLE会立即进行一次数据源同步。

    操作结果

    同步成功后进入对应项目,查看数据源列表页面,可以看到DMP上配置了SIP的数据源组已经被添加到SQLE平台,可以对这个数据源进行创建工单或创建扫描任务等操作。

    syn-result instance-syn

    后续操作

    管理员可编辑或删除同步任务,也可在同步周期之外,手动执行同步任务。

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sys-configuration/intro/index.html b/docs/v2/user-manual/sys-configuration/intro/index.html index eb467d6a..85c2bc20 100644 --- a/docs/v2/user-manual/sys-configuration/intro/index.html +++ b/docs/v2/user-manual/sys-configuration/intro/index.html @@ -4,13 +4,13 @@ 功能说明 | SQLE 文档 - +
    版本:v2

    功能说明

    系统设置中可配置的内容包括全局配置、登录对接、流程对接、消息推送。

    • 全局配置:当前可配置工单过期时间及url
      • 工单失效时间:平台会定期清理已完成的工单,管理员可自定义工单过期的时间
      • URL地址前缀:当使用流程对接时,通常由外部平台访问SQLE工单详情,需要配置url地址前缀,配置能访问SQLE的url地址信息
    • 登录对接:用户除使用SQLE账号登录平台,也可使用LDAP及oAuth2.0的方式实现对接登录,可参考登录对接
    • 流程对接:使用流程对接,可在外部工作平台审批工单,目前支持钉钉审批,可参考流程对接
    • 消息推送:使用消息推送,可将工单状态变更推送到外部工作平台,目前支持对接邮箱、企业微信、飞书的方式,可参考消息推送
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sys-configuration/login_syn/index.html b/docs/v2/user-manual/sys-configuration/login_syn/index.html index 8e85c965..d616f3c3 100644 --- a/docs/v2/user-manual/sys-configuration/login_syn/index.html +++ b/docs/v2/user-manual/sys-configuration/login_syn/index.html @@ -4,14 +4,14 @@ 登录对接 | SQLE 文档 - +
    版本:v2

    登录对接

    当前登录对接已实现LDAP方式及Oauth2.0方式

    入口

    管理员账号,点击更多按钮,点击系统设置,跳转系统设置页面后,点击“对接登录”标签

    推送方式

    LDAP

    功能说明

    SQLE中支持通过配置的方式接入LDAP系统, 如同其他系统一样接受统一的用户管理, 以便于管理员管理SQLE中的用户, 也使得员工无需在使用一套公司内通用账号密码的同时单独记录SQLE的账号密码。 在SQLE中, 如果正确配置并启用了LDAP功能, 用户就可以在登录界面使用LDAP中记录的账号密码进行登录, SQLE会在员工第一次登录时同步此员工的账号和邮箱, 并在以后的登录中均通过LDAP校验此账户

    使用场景

    当组织配置了LDAP对接登录系统时,平台管理员可进行相关配置。

    前置操作

    已配置LDAP

    操作步骤

    点击修改,选择启用LDAP

    • LDAP服务器地址:用于LDAP登陆时SQLE找到LDAP服务器的位置
    • LDAP服务器端口:用于LDAP登陆时SQLE找到LDAP服务的工作端口
    • 连接用户DN:当用户登录时需要先使用管理用户登录到LDAP中查找出登录用户在LDAP中的DN, 再使用查找出的DN和登录用户填写的密码进行LDAP登录校验
    • 连接用户密码:连接用户DN登录时的密码
    • 查询根DN:用于限定SQLE中LDAP登录的作用范围
    • 用户属性名:用于LDAP用户登录时查询登录用户的DN, LDAP中此属性对应的值也将用作此用户第一次登录SQLE自动注册时的用户名
    • 用户邮箱属性名:SQLE将根据此属性名从LDAP中获取到用户的邮箱, 并将此邮箱用于此用户第一次登录SQLE自动注册时的用户邮箱

    后续操作

    修改后用户即可通过LDAP账号登录SQLE平台

    OAuth 2.0【企业版】

    功能说明

    SQLE中支持通过配置的方式接入OAuth 2.0系统, 如同其他系统一样接受统一的用户管理, 以便于管理员管理SQLE中的用户, 也使得员工无需在使用一套公司内通用账号密码的同时单独记录SQLE的账号密码

    在SQLE中, 如果正确配置并启用了OAuth 2.0功能, 用户就可以在登录界面使用第三方登录, SQLE会在员工第一次登录时要求用户绑定或自动创建一个SQLE用户, 并在以后的登录中可以使用OAuth 2.0用户登录, 也可以用绑定的SQLE用户账号密码登录

    使用场景

    当组织配置了OAuth 2.0对接登录系统时,平台管理员可进行相关配置。

    前置操作

    已配置OAuth 2.0

    操作步骤

    点击修改,选择启用OAuth 2.0

    • 应用ID:应用的唯一标识, 从要对接的平台申请 , 在OAuth2.0认证过程中,appid的值即为oauth_consumer_key的值
    • 应用密钥:appid对应的密钥,访问用户资源时用来验证应用的合法性。在OAuth2.0认证过程中,appkey的值即为oauth_consumer_secret的值
    • 外部访问SQLE的地址:格式为 http(s)://ip:port
    • oauth2登录授权页面地址:格式类似于 http(s)://ip:port/xxx
    • oauth2 access_token 获取地址:格式类似于 http(s)://ip:port/xxx
    • oauth2 user id 获取地址:格式类似于 http(s)://ip:port/xxx
    • 请求资源范围:此范围由验证服务器定义
    • access_token放置位置:SQLE会在获取用户ID时将access_token放在这个key对应的value中, 此参数会作为get请求的参数发送给用户ID获取地址
    • 用户ID保存位置:SQLE会尝试使用此key从第三方平台的响应中解析出用户ID,用户ID应当为唯一ID
    • 登录按钮文字
    提示

    当仅允许内网访问SQLE服务时,请确保回调地址的后缀为"/v1/oauth2/callback"。

    后续操作

    启用后SQLE登录界面出现其他方式跳转登录入口,点击,可跳转至对应登录页面

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sys-configuration/message_syn/index.html b/docs/v2/user-manual/sys-configuration/message_syn/index.html index 2863c978..e08393b6 100644 --- a/docs/v2/user-manual/sys-configuration/message_syn/index.html +++ b/docs/v2/user-manual/sys-configuration/message_syn/index.html @@ -4,7 +4,7 @@ 消息推送 | SQLE 文档 - + @@ -18,7 +18,7 @@ example
  • 当t1审核通过后,成员admin作为待上线人, admin手机号绑定的飞书账号下,收到一则待上线的工单通知; example
  • 当admin上线成功后,工单创建人将收到一则工单上线成功的消息; example
  • 根据以上示例,用户可了解飞书消息推送的部分场景。

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sys-configuration/process_syn/index.html b/docs/v2/user-manual/sys-configuration/process_syn/index.html index a96ee170..e52ea3dc 100644 --- a/docs/v2/user-manual/sys-configuration/process_syn/index.html +++ b/docs/v2/user-manual/sys-configuration/process_syn/index.html @@ -4,7 +4,7 @@ 流程对接 | SQLE 文档 - + @@ -18,7 +18,7 @@ dingding-telconfig

    打开全局配置,配置SQLE的URL地址,配置URL地址后,用户可从钉钉跳转访问SQLE工单详情页面; globalurl

    4.利用钉钉进行审批

    当发生工单变化时,工单关联成员可在对应钉钉账号中收到通知,并进行相应的审批操作; dingding-flow

    - + \ No newline at end of file diff --git a/docs/v2/user-manual/sys-configuration/webhook/index.html b/docs/v2/user-manual/sys-configuration/webhook/index.html index 6fe49ec6..9d3b255f 100644 --- a/docs/v2/user-manual/sys-configuration/webhook/index.html +++ b/docs/v2/user-manual/sys-configuration/webhook/index.html @@ -4,14 +4,14 @@ webhook配置 | SQLE 文档 - +
    版本:v2

    webhook配置

    Webhook是用户定义的自定义HTTP回调。它们通常由事件触发,例如SQLE中存在工单状态的变化,则会自动向用户配置的webhook URL发送HTTP请求。

    使用场景

    当用户配置了自定义API服务,想要在API服务中实时获取工单执行状态时,可在系统设置中配置webhook服务。在SQLE中配置回调地址后,工单状态一旦发生变更,即可在API服务中获取状态通知信息,无需定时登录SQLE平台以查询结果。

    提示

    当前会触发通知的事件有:

    • 有新工单被创建
    • 工单审核被通过
    • 工单审核被驳回
    • 工单被成功上线
    • 工单上线失败

    前置操作

    用户需在使用的API服务中生成用于接收回调通知的webhook url。

    备注

    当前webhook url仅支持http格式。

    操作步骤

    1. 以平台管理员账号登录, 进入系统设置-消息推送,选择webhook配置,并点击修改;
    2. 选择启用webhook;
    3. 填写webhook url:用于工单消息推送的 API 地址;
    4. 填写最大重试次数:默认3次,取值范围0-5。如果推送存在失败,每一个事件请求将最多连续3次执行推送,如3次都失败,则不再推送本次事件;
    5. 填写重试间隔:默认1秒,取值范围1-5。如果推送存在失败,重试时将以1s的时间间隔进行重试;
    6. 填写Token:云服务在发送通知时使用的访问令牌,参考规范:https://datatracker.ietf.org/doc/html/rfc6750;
    7. 提交保存配置;

    后续步骤

    用户点击“测试”,如配置正确,能在API服务端收到正确的调用测试信息: "This is a SQLE test notification\nIf you receive this message, it only means that the message can be pushed".

    接口文档

    SQLE POST 请求格式
    POST / HTTP/1.1
    Host: 192.168.21.34:8000
    Accept-Encoding: gzip
    Authorization: Bearer test123
    Content-Length: 239
    User-Agent: Go-http-client/1.1

    {"event":"workflow","action":"create","timestamp":"2023-05-18T15:45:25+08:00","payload":{"workflow":{"project_name":"test_project","workflow_id":"1658637666259832832","workflow_subject":"test_workflow","workflow_status":"wait_for_audit"}}}
    • "event":当前取值恒为 "workflow"(目前SQLE只支持工单通知);
    • "action":可能的取值有 ["create", "approve", "reject", "exec_success", "exec_failed"]。分别对应「工单创建」、「审核通过」、「审核驳回」、「上线成功」、「上线失败」;
    • "timestamp":表示请求发出的时间,RFC3339 格式;
    • "payload":表示该请求的主要业务内容,目前仅支持工单;
    • "workflow":表示该工单的当前信息,与 sqle 后端数据库中记录保持一致;

    注意事项

    • 用户配置的 token 会被放置在请求 Header 中的 Authorization 字段。参考规范:https://datatracker.ietf.org/doc/html/rfc6750 。SQLE对token字段没有任何限制。需要接受端根据自身情况决定是否使用 token;
    • 接收请求的服务端在收到请求后,需要返回 200 响应。否则 sqle 会打印返回 body 中的文本信息。
    • 在发送测试请求时,请确保接收请求的服务端运行正常。否则可能出现如下问题:
    {
    "code": 0,
    "message": "ok",
    "data": {
    "send_error_message": "Post \"http://192.168.21.34:8000\": dial tcp 192.168.21.34:8000: connect: connection refused"
    }
    }
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/user-manager/intro/index.html b/docs/v2/user-manual/user-manager/intro/index.html index d4a15e56..34f1a393 100644 --- a/docs/v2/user-manual/user-manager/intro/index.html +++ b/docs/v2/user-manual/user-manager/intro/index.html @@ -4,13 +4,13 @@ 功能说明 | SQLE 文档 - +
    版本:v2

    功能说明

    用户中心包含用户管理、用户组管理及角色管理三个方面,由平台管理员操作,涉及用户、用户组的管理及角色权限的配置。

    • 用户管理:指平台用户的管理,由管理员创建用户或编辑用户基本信息,可参考用户管理
    • 用户组管理:当需要对一批用户赋予同样权限时,可由管理员创建用户组,将这批用户统一绑定至该用户组下,即可进行统一授权,可参考用户组管理
    • 角色管理:SQLE平台使用角色管理来实现操作权限组合,由管理员创建,可参考角色管理

    使用场景

    • 在添加项目成员、成员组之前,需要由管理员首先创建平台用户、用户组,项目管理员才可将该用户、用户组添加为项目成员、成员组
    • 为项目成员绑定数据源与角色操作权限前,需要由管理员创建相应权限的角色模板,项目管理员可为成员绑定配置的角色模板
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/user-manager/role/index.html b/docs/v2/user-manual/user-manager/role/index.html index 88004d97..be2a2d03 100644 --- a/docs/v2/user-manual/user-manager/role/index.html +++ b/docs/v2/user-manual/user-manager/role/index.html @@ -4,14 +4,14 @@ 角色管理 | SQLE 文档 - +
    版本:v2

    角色管理

    当需要为用户设置动作权限时,可使用角色管理配置动作组合。 如用户需要有创建工单、审核工单、SQL查询的动作权限,管理员可以在角色管理创建一个角色,并绑定创建工单、审核工单、SQL查询这三个动作,随后只需将此角色关联至指定成员,即可完成用户的动作权限设置。

    操作步骤

    • 点击顶部导航栏【更多】按钮,点击平台管理栏目下的【用户中心】选项,查看角色管理标签。
    • 点击列表右上角【创建角色】按钮,填写相关信息
      • 角色名
      • 角色描述
      • 选择动作权限:配置该角色所拥有的操作权限,SQLE平台支持的动作权限如下:
    权限名权限码权限说明
    查看他人工单20100当角色拥有该动作权限时,角色可以查看绑定的数据源上其他用户创建的工单
    创建/编辑工单20200当角色拥有该动作权限时,角色可以在绑定的数据源上创建工单
    工单审批20300当审核流程模版中的某个审核步骤指定为允许所有有权限的用户审批时, 拥有此权限的用户将可以审批对应工单
    审核任务查看30100拥有此权限的用户可以查看所有审核任务, 无此权限的用户只能查看自己创建审核任务
    审核任务创建30200拥有此权限的用户可以创建审核任务
    sql查询40100拥有此权限的用户可以上线工单

    执行结果

    可在角色列表查看创建的角色信息

    role

    后续步骤

    • 添加成员/成员组:项目管理员在项目中添加成员/成员组时,需要绑定成员/成员组在对应数据源上的角色权限,可参考成员/成员组管理

    更多操作

    • 编辑角色:点击角色列表的「编辑」按钮,编辑角色信息。角色名不可更改,可设置角色禁用,则对应权限不会生效。
    • 删除角色:点击角色列表的「删除」按钮,删除角色信息
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/user-manager/user-group/index.html b/docs/v2/user-manual/user-manager/user-group/index.html index b1377dea..e6552a8a 100644 --- a/docs/v2/user-manual/user-manager/user-group/index.html +++ b/docs/v2/user-manual/user-manager/user-group/index.html @@ -4,14 +4,14 @@ 用户组管理 | SQLE 文档 - +
    版本:v2

    用户组管理

    当管理员需要批量管理用户时,可以使用用户组来管理多个相同属性的用户。 比如依照「运维工程师」、「研发工程师」、「项目管理员」进行分别授权与管理。

    操作步骤

    • 点击顶部导航栏【更多】按钮,点击平台管理栏目下的【用户中心】选项,查看用户组管理标签。
    • 点击列表右上角【创建用户组】按钮,填写用户组相关信息
      • 用户组名:必填
      • 用户组描述
      • 绑定用户

    执行结果

    可在用户组列表中查看已创建的用户组列表 usergroup

    后续步骤

    • 添加项目成员组:项目管理员可进入指定项目,将创建的用户组添加为项目成员组,可参考成员/成员组管理

    更多操作

    • 编辑用户组:用户组名不可修改,其他均可修改。
      • 可设置禁用该用户组,当一个用户组被禁用,用户不会被禁用,但会失去该用户组所关联的数据源及对应角色权限。
    • 删除用户组:点击用户组列表的「删除」按钮,删除用户组信息
    - + \ No newline at end of file diff --git a/docs/v2/user-manual/user-manager/user/index.html b/docs/v2/user-manual/user-manager/user/index.html index 63396efd..479b0b49 100644 --- a/docs/v2/user-manual/user-manager/user/index.html +++ b/docs/v2/user-manual/user-manager/user/index.html @@ -4,13 +4,13 @@ 用户管理 | SQLE 文档 - +
    版本:v2

    用户管理

    当需要创建新的用户,或需要由管理员修改用户基本信息时,可以进行用户管理的相关操作。

    操作步骤

    • 点击顶部导航栏【更多】按钮,点击平台管理栏目下的【用户中心】选项,查看用户管理标签。
    • 点击列表右上角【创建用户】按钮,填写用户相关信息
      • 用户名
      • 密码
      • 确认密码
      • 邮箱:若开启邮件推送或飞书推送服务,则将会以邮件形式通知对应用户工单的流转状态
      • 微信id:若开启企业微信推送服务,则将通过企业微信通知对应用户工单的流转状态
      • 平台管理权限:当前可选项为创建项目,若选择该权限,则该用户将具有创建项目的权限
      • 所属用户组:可将用户关联至已创建的用户组中, 如当前还未创建用户组,可以在创建用户组后,通过编辑用户信息修改所属的用户组。
    • 点击提交,完成用户创建

    执行结果

    创建成功后,可在用户列表中查看已创建的用户信息

    userlist

    后续步骤

    • 创建用户组:创建用户后,可将多个用户绑定在一个用户组中,可参考用户组管理
    • 添加项目成员:项目管理员可进入指定项目,将创建的用户添加为项目成员,可参考成员/成员组管理

    更多操作

    • 编辑用户:点击用户列表的「编辑」按钮,编辑用户信息。其中,用户名不可更改,其他信息项均可更改。
    • 删除用户:点击用户列表的「删除」按钮,删除用户。
    • 修改用户密码:点击用户列表的「更多」按钮,下拉菜单中点击「更修改该用户密码」。
      提示

      管理员还可以对指定的用户进行「禁用」或者「启用」。 当用户被管理员禁用后,该用户将无法登录,也无法进行任何操作。 管理员用户永远无法禁用自己本身。

    - + \ No newline at end of file diff --git a/index.html b/index.html index fabd0dc2..08feb1b4 100644 --- a/index.html +++ b/index.html @@ -4,13 +4,13 @@ 首页 | SQLE 文档 - +
    Docusaurus with Keytar

    一个支持多种不同类型数据库,覆盖事前控制、事后监督、标准发布场景,帮助您建立质量规范的SQL全生命周期质量管理平台。每周发版,快速迭代中。

    快速开始

    更丰富的数据源支持

    1. 支持十余种主流商业和开源数据库
    2. 持续支持新的数据源类型,以满足您不同的需求

    更全面的审核规则

    1. 拥有规则 700+,并持续增加中
    2. 源自DBA运维专家团队多年的技术积累

    更智能的 SQL 采集

    1. 提供多种智能扫描任务
    2. 满足事前和事后 SQL 持续采集需求

    更高效的审批路径

    1. 提供标准化工作流
    2. 通过消息对接,及时了解更新进度

    更便捷的数据操作

    1. 集成在线数据库客户端 CloudBeaver
    2. 通过可视化界面进行数据库管理和查询

    全生命周期SQL管控

    1. 提供 SQL 全流程的管控视角
    2. 追踪问题SQL的解决进度

    - + \ No newline at end of file diff --git a/markdown-page/index.html b/markdown-page/index.html index edb2a353..d03b20ad 100644 --- a/markdown-page/index.html +++ b/markdown-page/index.html @@ -4,13 +4,13 @@ Markdown page example | SQLE 文档 - + - + \ No newline at end of file diff --git a/search/index.html b/search/index.html index 9af47143..33e512cd 100644 --- a/search/index.html +++ b/search/index.html @@ -4,13 +4,13 @@ 在文档中搜索 | SQLE 文档 - + - + \ No newline at end of file