mirror of
https://github.com/TeaOSLab/EdgeAPI.git
synced 2025-11-03 23:20:26 +08:00
启动时自动设置binlog过期时间
This commit is contained in:
@@ -390,9 +390,9 @@ func (this *APINode) setupDB() error {
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
value := result.GetString("Value")
|
||||
var value = result.GetString("Value")
|
||||
if regexp.MustCompile(`^\d+$`).MatchString(value) {
|
||||
valueInt := types.Int(value)
|
||||
var valueInt = types.Int(value)
|
||||
if valueInt < 65535 {
|
||||
_, err := db.Exec("SET GLOBAL max_prepared_stmt_count=65535")
|
||||
if err != nil {
|
||||
@@ -405,6 +405,33 @@ then restart mysqld.`)
|
||||
}
|
||||
}
|
||||
|
||||
// 调整binlog过期时间
|
||||
{
|
||||
const binlogExpireDays = 7
|
||||
|
||||
version, err := db.FindCol(0, "SELECT VERSION()")
|
||||
if err == nil {
|
||||
var versionString = types.String(version)
|
||||
if strings.HasPrefix(versionString, "8.") {
|
||||
result, err := db.FindOne("SHOW VARIABLES WHERE variable_name='binlog_expire_logs_seconds'")
|
||||
if err == nil && result != nil {
|
||||
var oldValue = result.GetInt("Value")
|
||||
if oldValue > binlogExpireDays*86400 {
|
||||
_, _ = db.Exec("SET GLOBAL binlog_expire_logs_seconds=" + types.String(binlogExpireDays*86400))
|
||||
}
|
||||
}
|
||||
} else if strings.HasPrefix(versionString, "5.") {
|
||||
result, err := db.FindOne("SHOW VARIABLES WHERE variable_name='expire_logs_days'")
|
||||
if err == nil && result != nil {
|
||||
var oldValue = result.GetInt("Value")
|
||||
if oldValue > binlogExpireDays {
|
||||
_, _ = db.Exec("SET GLOBAL expire_logs_days=" + types.String(binlogExpireDays))
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user