Merge branch 'master' of git.b612.me:b612/mysqlbinlog
This commit is contained in:
commit
61d231f6b6
43
parse.go
43
parse.go
@ -332,20 +332,44 @@ func ParseBinlogEvent(ev *replication.BinlogEvent) []BinlogEvent {
|
||||
}
|
||||
|
||||
type BinlogFilter struct {
|
||||
IncludeGtid string
|
||||
ExcludeGtid string
|
||||
StartPos int
|
||||
EndPos int
|
||||
StartDate time.Time
|
||||
EndDate time.Time
|
||||
BigThan int
|
||||
SmallThan int
|
||||
OnlyShowGtid bool
|
||||
IncludeGtid string
|
||||
ExcludeGtid string
|
||||
IncludeTables []string
|
||||
ExcludeTables []string
|
||||
StartPos int
|
||||
EndPos int
|
||||
StartDate time.Time
|
||||
EndDate time.Time
|
||||
BigThan int
|
||||
SmallThan int
|
||||
OnlyShowGtid bool
|
||||
}
|
||||
|
||||
func parseBinlogWithFilter(r io.Reader, parse *replication.BinlogParser, filter BinlogFilter, fn func(Transaction) bool) error {
|
||||
var subGtid, inGtid, exGtid *gtid.Gtid
|
||||
var err error
|
||||
var includeMap = make(map[string]bool)
|
||||
var excludeMap = make(map[string]bool)
|
||||
if len(filter.IncludeTables) != 0 {
|
||||
for _, v := range filter.IncludeTables {
|
||||
if len(strings.Split(v, ".")) != 2 {
|
||||
return fmt.Errorf("IncludeTable Name Is Invalid:%s", v)
|
||||
}
|
||||
includeMap[v] = true
|
||||
}
|
||||
} else {
|
||||
includeMap["*.*"] = true
|
||||
}
|
||||
if len(filter.ExcludeTables) != 0 {
|
||||
for _, v := range filter.ExcludeTables {
|
||||
if len(strings.Split(v, ".")) != 2 {
|
||||
return fmt.Errorf("ExcludeTable Name Is Invalid:%s", v)
|
||||
}
|
||||
excludeMap[v] = true
|
||||
}
|
||||
} else {
|
||||
excludeMap["*.*"] = true
|
||||
}
|
||||
if filter.IncludeGtid != "" {
|
||||
inGtid, err = gtid.Parse(filter.IncludeGtid)
|
||||
if err != nil {
|
||||
@ -359,7 +383,6 @@ func parseBinlogWithFilter(r io.Reader, parse *replication.BinlogParser, filter
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
// process: 0, continue: 1, break: 2, EOF: 3
|
||||
var (
|
||||
n int64
|
||||
|
Loading…
x
Reference in New Issue
Block a user