Template:SQWareProduction sqwmys GlobalVar.cfg content: Difference between revisions

From Wiki_dbSQWare
Jump to navigation Jump to search
m Updated by BatchUser
m Updated by BatchUser
 
(47 intermediate revisions by the same user not shown)
Line 2: Line 2:
File content:
File content:
<pre>
<pre>
#!/bin/ksh
#!/bin/bash
###################################################################
###################################################################
# SQWareProduction for Mysql module of dbSQWare is developped with GPL License 3.0 :
# SQWareProduction for Mysql module of dbSQWare
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#  
#  
# dbSQWare is distributed in the hope that it will be useful,
# dbSQWare is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
# CGU/CGA for more details.
#  
#  
# You should have received a copy of the GNU General Public License
# You should have received a copy of the CGU/CGA
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
# along with this program.  If not, see <http://www.dbsqware.com/licenses/>.
#  
#  
# For information : contact@dbsqware.com or www.dbsqware.com
# For information : contact@dbsqware.com or www.dbsqware.com
###################################################################
###################################################################
## @Synopsis Global var
## @Synopsis Global var for Mysql
## @Copyright Copyright 2010-2013, OctopusDBA
## @Copyright Copyright 2007-2025, dbSQWare (www.dbsqware.com)
## @License GPL v3
## SVN : $URL$
## SVN : $Id$


#global
#global
export gvsqw_EdtVersion=2.0.14
export gvsqw_SqwVersionDbms=2025.05
#Force a case for instance name parameter, put UpperCase or LowerCase or NoCase
if [ -r $MYSQL_HOME/tmp/$MYSQL_SID.sock ]
export gvsqw_InstanceNameForceCase='UpperCase'
then
export gvsqw_MysqlSock='$MYSQL_HOME/tmp/$MYSQL_SID.sock'
export gvsqw_MysqlSock='$MYSQL_HOME/tmp/$MYSQL_SID.sock'
export gvsqw_UserExec=`id| cut -d')' -f1| cut -d'(' -f2`
elif [ -r $MYSQL_DATA/tmp/$MYSQL_SID.sock ]
then
export gvsqw_MysqlSock='$MYSQL_DATA/tmp/$MYSQL_SID.sock'
elif [ -r /tmp/$MYSQL_SID.sock ]
then
export gvsqw_MysqlSock='/tmp/$MYSQL_SID.sock'
elif [ -r "/var/lib/mysql/mysql.sock" ]
then
export gvsqw_MysqlSock='/var/lib/mysql/mysql.sock'
elif [ -r "/var/lib/mysqld/mysql.sock" ]
then
export gvsqw_MysqlSock='/var/lib/mysqld/mysql.sock'
elif [ -r "/var/lib64/mysql/mysql.sock" ]
then
export gvsqw_MysqlSock='/var/lib64/mysql/mysql.sock'
elif [ -r "/var/lib64/mysqld/mysql.sock" ]
then
export gvsqw_MysqlSock='/var/lib64/mysqld/mysql.sock'
elif [ -r /tmp/mysql.sock ]
then
export gvsqw_MysqlSock='/tmp/mysql.sock'
elif [ -r /run/mysqld/mysqld.sock ]
then
export gvsqw_MysqlSock='/run/mysqld/mysqld.sock'
fi
 
export gvsqw_DbaUser="$gvsqw_UserExec"
export gvsqw_DbaUser="$gvsqw_UserExec"
export gvsqw_ConnectString='-S $gvsqw_MysqlSock -u $gvsqw_DbaUser'
export gvsqw_ConnectString='-S $gvsqw_MysqlSock -u $gvsqw_DbaUser'
export gvsqw_DistPasswdFile="$HOME/.passwd_mysql"
export gvsqw_DistConnectString='-h $gvsqw_MysqlHost -P $gvsqw_MysqlPort -u$gvsqw_DbaUser -p$gvsqw_DbaUserPasswd'
export gvsqw_DistConnectString='-h $gvsqw_MysqlHost -P $gvsqw_MysqlPort -u$gvsqw_DbaUser -p$gvsqw_DbaUserPasswd'
export gvsqw_ConnectDb=Enable
export gvsqw_Hostname=$(hostname|cut -d '.' -f1)
export gvsqw_MailMsg_mysql="TrtMysAuto$gvsqw_Env"
#Put NoNail in gvsqw_Mail_mysql if you don't want to send mail on error
export gvsqw_Mail_mysql='default@dbsqware.com'
#Put disable in gvsqw_SendmailHtmlFormat if you don't want to send mail in html format
export gvsqw_SendmailHtmlFormat=enable
export gvsqw_PreFormatHtlml=enable
#Put disable in gvsqw_Colors if you don't want to print in color
export gvsqw_Colors=enable
#Put disable in gvsqw_TraceJobDb if you don't want to trace job execution in SQWareRepository
export gvsqw_TraceJobDb=enable
#Put disable in gvsqw_UploadLogFile if you don't want to upload log of job execution in SQWareRepository
export gvsqw_UploadLogFile=enable
#Put disable in gvsqw_TraceBackup if you don't want to backup execution in SQWareRepository
export gvsqw_TraceBackup=enable
export gvsqw_UploadLogFileMaxLine=200
export gvsqw_EgrepIvFs='Filesystem|Disponible'
export gvsqw_SuppLogsHisto=30
export gvsqw_GzipLogsHisto=7
export gvsqw_SuppArchAlert=30
export gvsqw_SuppArchSlow=30
export gvsqw_SuppArchSlow=30
export gvsqw_RootAdmin='$HOME/${MYSQL_SID}'
export gvsqw_RootAdmin='$HOME/${MYSQL_SID}'
export gvsqw_RootAdminDisable='$HOME'
export gvsqw_RootAdminDist='$HOME/admin/mysql/${MYSQL_SID}'
export gvsqw_RootAdminDist='$HOME/admin/mysql/${MYSQL_SID}'
export gvsqw_RootCfg='$gvsqw_RootAdmin/edtConfig'
export gvsqw_RootCfg='$gvsqw_RootAdmin/sqwConfig'
export gvsqw_RootDbf='/$(echo ${HOME}|cut -d/ -f2)/data/${MYSQL_SID}'
export gvsqw_RootDbf='/$(echo ${HOME}|cut -d/ -f2)/data/${MYSQL_SID}'
export gvsqw_InitInstanceSourceCommand='. ./.profile'
export gvsqw_GenExcludeDatabasesWhereClause="and SCHEMA_NAME not in ('SQWareProduction','${MYSQL_SID}','tmp','logs') and SCHEMA_NAME not like '%#%' and SCHEMA_NAME not like '% %' and SCHEMA_NAME != 'performance_schema' and SCHEMA_NAME != 'sys'"
export gvsqw_NbThread=2
#export gvsqw_GenExcludeDatabasesWhereClause="and table_schema not like '%#%' and table_schema not like '% %' and table_schema != 'performance_schema' and table_schema != 'sys'"
export gvsqw_DbAlias='$MYSQL_SID'
export gvsqw_NbThreadOptimize=2
export gvsqw_NbThreadOptimize=2
export gvsqw_NbThreadAnalyze=2
export gvsqw_NbThreadAnalyze=2
export gvsqw_NbThreadDump=2
export gvsqw_NbThreadDump=2
export gvsqw_MysqlErrorMsg="^ERROR |^FAILED "
export gvsqw_NbThreadCopyDump=2
export gvsqw_SshOptions="-q -o BatchMode=yes -o StrictHostKeyChecking=no"
export gvsqw_NbThreadRestore=2
export gvsqw_ScpOptions="-o BatchMode=yes -o StrictHostKeyChecking=no"
export gvsqw_NbThreadCheck=2
 
export gvsqw_NotMysqlErrorMsg="_ERROR |_FAILED |_ERREUR |_ECHEC |_ERROR_|_FAILED_|_ERREUR_|_ECHEC_|'ERROR |'FAILED |'ERREUR |'ECHEC "
#Html tags
#To ignore mysqldump errors, example : gvsqw_NotMysqldumpErrorMsg="mysqldump: Error 1412" to ignore "mysqldump: Error 1412: Table definition has changed, please retry transaction when dumping table ..."
export gvsqw_CHtmlError='<font color="#FF0000">'
export gvsqw_NotMysqldumpErrorMsg="mysqldump: Error ToBeCustomize"
export gvsqw_CHtmlOk='<font color="#00FF00">'
export gvsqw_CHtmlInfo='<font color="#0000FF">'
export gvsqw_CHtmlEnd='</font>'
export gvsqw_THtmlBegin='<table  class="edt">'
export gvsqw_THtmlEnd='</table>'
export gvsqw_THtmlThBegin='<tr class="edtth"><th>'
export gvsqw_THtmlThEnd='</th></tr>'
export gvsqw_THtmlThInter='</th><th>'
export gvsqw_THtmlTdBegin1='<tr class="edtnc"><td>'
export gvsqw_THtmlTdBegin2='<tr class="sqwc_"><td>'
export gvsqw_THtmlTdEnd='</td></tr>'
export gvsqw_THtmlTdInter='</td><td>'
export gvsqw_THtmlPre="pre class='edt'>"
export gvsqw_THtmlPreEnd="/pre>"
export gvsqw_HtmlCss="<html><head>
<style type='text/css'>
body.edt {font:10pt Arial,Helvetica,Geneva,sans-serif;color:black; background:White;}
pre.edt {font:10pt Courier;color:black; background:White;}
pre.edtfoot {font:8pt Courier;color:#2E8B57; background:White;}
h1.edt {font:bold 12pt Courier New, Courier, mono;color:#0000FF;background-color:White;border-bottom:1px solid #cccc99;margin-top:0pt; margin-bottom:0pt;padding:0px 0px 0px 0px;}
h2.edt {font:bold 10pt Courier New, Courier, mono ; text-decoration:underline;color:#000000;background-color:White;margin-top:4pt; margin-bottom:0pt;}
h3.edt {font:10pt Courier New, Courier, mono ; text-decoration:underline;color:#000000;background-color:White;margin-top:4pt; margin-bottom:0pt;}
li.edt {font:10pt Arial,Helvetica,Geneva,sans-serif; color:black; background:White;}
table.edt {border-width:1px; border-style:solid; border-color:black; width:50%;border-collapse: separate;}
tr.edtth {font:bold 10pt Arial,Helvetica,Geneva,sans-serif; color:black; background:#C0C0C0;padding-left:4px; padding-right:4px;padding-bottom:2px}
tr.edtnc {font:10pt Arial,Helvetica,Geneva,sans-serif;color:black;background:White;vertical-align:top;}
tr.sqwc_    {font:10pt Arial,Helvetica,Geneva,sans-serif;color:black;background:#eee; vertical-align:top;}
a.edt {font:bold 8pt Arial,Helvetica,sans-serif;color:#663300; vertical-align:top;margin-top:0pt; margin-bottom:0pt;}
a:link { color :black ; text-decoration:underline ; }
a:visited { color: purple ; }
a:hover { color: red ; }
</style>
</head>
<body class='edt'>
"


#for indicators
#for indicators
export gvsqw_SizeMinTableIndicators=1
export gvsqw_SizeMinTableIndicators=10
export gvsqw_GenExcludeDatabasesObjects="and TABLES.TABLE_SCHEMA not in ('performance_schema','mysql','information_schema','sys')"
export gvsqw_GenExcludeDatabasesObjectsExtra=""
export gvsqw_PathList="HOME;gvsqw_RootAdmin;gvsqw_RootCfg;gvsqw_RootDump;gvsqw_RootXtraBackup;gvsqw_RootMariaBackup"
export gvsqw_PathListExtra=""
export gvsqw_CommandPathVersionList="$gvsqw_CommandPathVersionList mysql;--version"


#for dump scripts
#for Dump scripts
export gvsqw_RootDump='/$(echo ${HOME}|cut -d/ -f2)/mys_dump/$MYSQL_SID'
export gvsqw_RootDump='$HOME/mys_dump/$MYSQL_SID'
export gvsqw_RootDumpSource='$HOME/mys_dump/$lvsqw_InstanceSource'
export gvsqw_ExcludeDatabasesCopy='^mysql$|^information_schema$|^performance_schema$'
export gvsqw_DumpNbGeneration=2
export gvsqw_DumpNbGeneration=2
export gvsqw_ConsistentInnoDb="--single-transaction"
export gvsqw_DumpCompressorExt=gz
export gvsqw_DefCopyDumpNbGeneration=1
export gvsqw_ConsistentInnoDb="--single-transaction --skip-lock-tables"
export gvsqw_ConsistentOthers="--lock-tables"
export gvsqw_ConsistentOthers="--lock-tables"
export gvsqw_MysqlDumpOpt='$gvsqw_ConnectString --create-options -f --max_allowed_packet=1000000000 --net_buffer_length=16M ${lfsqw_SqlOpt}${lvsqw_AdditionalOption} -R -q --databases ${lvsqw_DbName}'
export gvsqw_MysqlDumpOpt='$gvsqw_ConnectString --create-options -f --max_allowed_packet=1000000000 --net_buffer_length=16M ${lfsqw_SqlOpt}${lvsqw_AdditionalOption} -R -q --databases ${lvsqw_DbName}'
#Put disable in gvsqw_TraceBackup if you don't want to trace backup execution in SQWareRepository
export gvsqw_RsyncDefaultSourceDir='$HOME/mys_dump/$MYSQL_SID'
export gvsqw_TraceBackup=enable
#for Restore scripts
export gvsqw_DropDb=Enable
export gvsqw_CreateDb=Enable
##Additional options before mysql command, ex : "SET sql_log_bin=OFF;" (put the ; caracter !!!)
export gvsqw_OptionsBeforeMySQL=""
##Additional options during mysql command, ex : "--init-command='SET sql_log_bin=OFF'"
export gvsqw_OptionsMySQL=""
 
#for XtraBackup scripts
export gvsqw_RootXtraBackup='$HOME/XtraBackup/$MYSQL_SID'
export gvsqw_RootXtraBackupSource='$HOME/XtraBackup/$lvsqw_InstanceSource'
export gvsqw_XtraBackupNbGeneration=2
export gvsqw_XtraBackupWaitTimeOut=900
export gvsqw_DefCopyXtraBackupNbGeneration=1
 
#for MariaBackup scripts
export gvsqw_RootMariaBackup='$HOME/MariaBackup/$MYSQL_SID'
export gvsqw_RootMariaBackupSource='$HOME/MariaBackup/$lvsqw_InstanceSource'
export gvsqw_MariaBackupNbGeneration=2
export gvsqw_MariaBackupWaitTimeOut=900
export gvsqw_DefCopyMariaBackupNbGeneration=1
 
#for copy scripts
export gvsqw_NbThreadScp=2
export gvsqw_DefAGR_Scp=10
export gvsqw_DefAGE_Scp=30
 
#for rotate slowquery (put yes to no copy to webdba)
export gvsqw_LocalSlowQuery=no
#at: average query time
export gvsqw_MysqlDumpSlowOption1='at'
#al: average lock time
export gvsqw_MysqlDumpSlowOption2='al'
#ae: aggregated rows examined
export gvsqw_MysqlDumpSlowOption3='ae'


##Globaly forcing return code for scripts
##Globaly forcing return code for scripts
#export gvsqw_ForcedReturnCodeScript_sqwmys_DumpDatabase=0
#export gvsqw_ForcedReturnCodeScript_sqwmys_DumpDatabase=0


#for webdba
#for SQWareWeb
export gvsqw_WebDbaURL="http://webdba"
#export gvsqw_WebDbaUserConn='Connection string ssh user@hostname'
#export gvsqw_WebDbaDirSlowQuery='Directory to store SlowQuery files'
#export gvsqw_WebDbaDirSlowQuery='Directory to store SlowQuery files'
# Source custom
[ -r $gvsqw_MysBin/../etc_cust/sqwmys_GlobalVar.cfg ] && . $gvsqw_MysBin/../etc_cust/sqwmys_GlobalVar.cfg
# For not normed environnement
[ -r $HOME/edtConfig/sqwmys_GlobalVar.cfg ] && . $HOME/edtConfig/sqwmys_GlobalVar.cfg
</pre>
</pre>

Latest revision as of 18:15, 20 May 2025


File content:

#!/bin/bash
###################################################################
# SQWareProduction for Mysql module of dbSQWare
# 
# dbSQWare is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# CGU/CGA for more details.
# 
# You should have received a copy of the CGU/CGA
# along with this program.  If not, see <http://www.dbsqware.com/licenses/>.
# 
# For information : contact@dbsqware.com or www.dbsqware.com
###################################################################
## @Synopsis	Global var for Mysql
## @Copyright	Copyright 2007-2025, dbSQWare (www.dbsqware.com)

#global
export gvsqw_SqwVersionDbms=2025.05
if [ -r $MYSQL_HOME/tmp/$MYSQL_SID.sock ]
then
	export gvsqw_MysqlSock='$MYSQL_HOME/tmp/$MYSQL_SID.sock'
elif [ -r $MYSQL_DATA/tmp/$MYSQL_SID.sock ]
then
	export gvsqw_MysqlSock='$MYSQL_DATA/tmp/$MYSQL_SID.sock'
elif [ -r /tmp/$MYSQL_SID.sock ]
then
	export gvsqw_MysqlSock='/tmp/$MYSQL_SID.sock'
elif [ -r "/var/lib/mysql/mysql.sock" ]
then
	export gvsqw_MysqlSock='/var/lib/mysql/mysql.sock'
elif [ -r "/var/lib/mysqld/mysql.sock" ]
then
	export gvsqw_MysqlSock='/var/lib/mysqld/mysql.sock'
elif [ -r "/var/lib64/mysql/mysql.sock" ]
then
	export gvsqw_MysqlSock='/var/lib64/mysql/mysql.sock'
elif [ -r "/var/lib64/mysqld/mysql.sock" ]
then
	export gvsqw_MysqlSock='/var/lib64/mysqld/mysql.sock'
elif [ -r /tmp/mysql.sock ]
then
	export gvsqw_MysqlSock='/tmp/mysql.sock'
elif [ -r /run/mysqld/mysqld.sock ]
then
	export gvsqw_MysqlSock='/run/mysqld/mysqld.sock'
fi

export gvsqw_DbaUser="$gvsqw_UserExec"
export gvsqw_ConnectString='-S $gvsqw_MysqlSock -u $gvsqw_DbaUser'
export gvsqw_DistConnectString='-h $gvsqw_MysqlHost -P $gvsqw_MysqlPort -u$gvsqw_DbaUser -p$gvsqw_DbaUserPasswd'
export gvsqw_SuppArchSlow=30
export gvsqw_RootAdmin='$HOME/${MYSQL_SID}'
export gvsqw_RootAdminDisable='$HOME'
export gvsqw_RootAdminDist='$HOME/admin/mysql/${MYSQL_SID}'
export gvsqw_RootCfg='$gvsqw_RootAdmin/sqwConfig'
export gvsqw_RootDbf='/$(echo ${HOME}|cut -d/ -f2)/data/${MYSQL_SID}'
export gvsqw_GenExcludeDatabasesWhereClause="and SCHEMA_NAME not in ('SQWareProduction','${MYSQL_SID}','tmp','logs') and SCHEMA_NAME not like '%#%' and SCHEMA_NAME not like '% %' and SCHEMA_NAME != 'performance_schema' and SCHEMA_NAME != 'sys'"
#export gvsqw_GenExcludeDatabasesWhereClause="and table_schema not like '%#%' and table_schema not like '% %' and table_schema != 'performance_schema' and table_schema != 'sys'"
export gvsqw_DbAlias='$MYSQL_SID'
export gvsqw_NbThreadOptimize=2
export gvsqw_NbThreadAnalyze=2
export gvsqw_NbThreadDump=2
export gvsqw_NbThreadCopyDump=2
export gvsqw_NbThreadRestore=2
export gvsqw_NbThreadCheck=2
export gvsqw_NotMysqlErrorMsg="_ERROR |_FAILED |_ERREUR |_ECHEC |_ERROR_|_FAILED_|_ERREUR_|_ECHEC_|'ERROR |'FAILED |'ERREUR |'ECHEC "
#To ignore mysqldump errors, example : gvsqw_NotMysqldumpErrorMsg="mysqldump: Error 1412" to ignore "mysqldump: Error 1412: Table definition has changed, please retry transaction when dumping table ..."
export gvsqw_NotMysqldumpErrorMsg="mysqldump: Error ToBeCustomize"

#for indicators
export gvsqw_SizeMinTableIndicators=10
export gvsqw_GenExcludeDatabasesObjects="and TABLES.TABLE_SCHEMA not in ('performance_schema','mysql','information_schema','sys')"
export gvsqw_GenExcludeDatabasesObjectsExtra=""
export gvsqw_PathList="HOME;gvsqw_RootAdmin;gvsqw_RootCfg;gvsqw_RootDump;gvsqw_RootXtraBackup;gvsqw_RootMariaBackup"
export gvsqw_PathListExtra=""
export gvsqw_CommandPathVersionList="$gvsqw_CommandPathVersionList mysql;--version"

#for Dump scripts
export gvsqw_RootDump='$HOME/mys_dump/$MYSQL_SID'
export gvsqw_RootDumpSource='$HOME/mys_dump/$lvsqw_InstanceSource'
export gvsqw_ExcludeDatabasesCopy='^mysql$|^information_schema$|^performance_schema$'
export gvsqw_DumpNbGeneration=2
export gvsqw_DumpCompressorExt=gz
export gvsqw_DefCopyDumpNbGeneration=1
export gvsqw_ConsistentInnoDb="--single-transaction --skip-lock-tables"
export gvsqw_ConsistentOthers="--lock-tables"
export gvsqw_MysqlDumpOpt='$gvsqw_ConnectString --create-options -f --max_allowed_packet=1000000000 --net_buffer_length=16M ${lfsqw_SqlOpt}${lvsqw_AdditionalOption} -R -q --databases ${lvsqw_DbName}'
export gvsqw_RsyncDefaultSourceDir='$HOME/mys_dump/$MYSQL_SID'
#for Restore scripts
export gvsqw_DropDb=Enable
export gvsqw_CreateDb=Enable
##Additional options before mysql command, ex : "SET sql_log_bin=OFF;" (put the ; caracter !!!)
export gvsqw_OptionsBeforeMySQL=""
##Additional options during mysql command, ex : "--init-command='SET sql_log_bin=OFF'"
export gvsqw_OptionsMySQL=""

#for XtraBackup scripts
export gvsqw_RootXtraBackup='$HOME/XtraBackup/$MYSQL_SID'
export gvsqw_RootXtraBackupSource='$HOME/XtraBackup/$lvsqw_InstanceSource'
export gvsqw_XtraBackupNbGeneration=2
export gvsqw_XtraBackupWaitTimeOut=900
export gvsqw_DefCopyXtraBackupNbGeneration=1

#for MariaBackup scripts
export gvsqw_RootMariaBackup='$HOME/MariaBackup/$MYSQL_SID'
export gvsqw_RootMariaBackupSource='$HOME/MariaBackup/$lvsqw_InstanceSource'
export gvsqw_MariaBackupNbGeneration=2
export gvsqw_MariaBackupWaitTimeOut=900
export gvsqw_DefCopyMariaBackupNbGeneration=1

#for copy scripts
export gvsqw_NbThreadScp=2
export gvsqw_DefAGR_Scp=10
export gvsqw_DefAGE_Scp=30

#for rotate slowquery (put yes to no copy to webdba)
export gvsqw_LocalSlowQuery=no
#at: average query time
export gvsqw_MysqlDumpSlowOption1='at'
#al: average lock time
export gvsqw_MysqlDumpSlowOption2='al'
#ae: aggregated rows examined
export gvsqw_MysqlDumpSlowOption3='ae'

##Globaly forcing return code for scripts
#export gvsqw_ForcedReturnCodeScript_sqwmys_DumpDatabase=0

#for SQWareWeb
#export gvsqw_WebDbaDirSlowQuery='Directory to store SlowQuery files'