diff --git a/sqle/driver/mysql/mysql.go b/sqle/driver/mysql/mysql.go index ef6b141aa9..c228e5d5b9 100644 --- a/sqle/driver/mysql/mysql.go +++ b/sqle/driver/mysql/mysql.go @@ -6,6 +6,7 @@ import ( _driver "database/sql/driver" "fmt" "strings" + "time" "github.com/actiontech/sqle/sqle/driver" "github.com/actiontech/sqle/sqle/driver/mysql/executor" @@ -355,7 +356,7 @@ func (i *MysqlDriverImpl) audit(ctx context.Context, sql string) (*driverV2.Audi Res: i.result, Node: nodes[0], } - + startTime := time.Now() if err := handler.Func(input); err != nil { // todo #1630 临时跳过解析建表语句失败导致的规则 if session.IsParseShowCreateTableContentErr(err) { @@ -364,9 +365,13 @@ func (i *MysqlDriverImpl) audit(ctx context.Context, sql string) (*driverV2.Audi } return nil, err } + if isExceedMaximum(startTime) { + i.Logger().Warnf("[audit_rule]rule: %v,total time: %v", rule.Desc, time.Since(startTime)) + } } if i.cnf.optimizeIndexEnabled && index.CanOptimize(i.log, i.Ctx, nodes[0]) { + startTime := time.Now() optimizer := index.NewOptimizer( i.log, i.Ctx, index.WithCalculateCardinalityMaxRow(i.cnf.calculateCardinalityMaxRow), @@ -387,6 +392,9 @@ func (i *MysqlDriverImpl) audit(ctx context.Context, sql string) (*driverV2.Audi } } i.result.Add(driverV2.RuleLevelNotice, rulepkg.ConfigOptimizeIndexEnabled, buf.String()) + if isExceedMaximum(startTime) { + i.Logger().Warnf("[audit_rule]rule: %v,total time: %v", rulepkg.ConfigOptimizeIndexEnabled, time.Since(startTime)) + } } // dry run gh-ost @@ -420,6 +428,10 @@ func (i *MysqlDriverImpl) audit(ctx context.Context, sql string) (*driverV2.Audi return i.result, nil } +func isExceedMaximum(startTime time.Time) bool { + return time.Since(startTime).Seconds() > log.MaxRuleExecutionSeconds +} + func (i *MysqlDriverImpl) GenRollbackSQL(ctx context.Context, sql string) (string, string, error) { if i.IsOfflineAudit() { return "", "", nil diff --git a/sqle/log/logger.go b/sqle/log/logger.go index 7e0962041a..b87b1d53ad 100644 --- a/sqle/log/logger.go +++ b/sqle/log/logger.go @@ -2,16 +2,19 @@ package log import ( "fmt" - "github.com/sirupsen/logrus" - rotate "gopkg.in/natefinch/lumberjack.v2" "io" "math/rand" "os" "strings" + + "github.com/sirupsen/logrus" + rotate "gopkg.in/natefinch/lumberjack.v2" ) var std *logrus.Logger +const MaxRuleExecutionSeconds = 5 + func Logger() *logrus.Logger { return std }