Merge pull request #1137 from github/go-mysql-binlog-dead-code
Remove unused code in `go/mysql/binlog.go`
This commit is contained in:
commit
02258ac15d
@ -1,36 +1,21 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2015 Shlomi Noach, courtesy Booking.com
|
Copyright 2015 Shlomi Noach, courtesy Booking.com
|
||||||
|
Copyright 2022 GitHub Inc.
|
||||||
See https://github.com/github/gh-ost/blob/master/LICENSE
|
See https://github.com/github/gh-ost/blob/master/LICENSE
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package mysql
|
package mysql
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"regexp"
|
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
var detachPattern *regexp.Regexp
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
detachPattern, _ = regexp.Compile(`//([^/:]+):([\d]+)`) // e.g. `//binlog.01234:567890`
|
|
||||||
}
|
|
||||||
|
|
||||||
type BinlogType int
|
|
||||||
|
|
||||||
const (
|
|
||||||
BinaryLog BinlogType = iota
|
|
||||||
RelayLog
|
|
||||||
)
|
|
||||||
|
|
||||||
// BinlogCoordinates described binary log coordinates in the form of log file & log position.
|
// BinlogCoordinates described binary log coordinates in the form of log file & log position.
|
||||||
type BinlogCoordinates struct {
|
type BinlogCoordinates struct {
|
||||||
LogFile string
|
LogFile string
|
||||||
LogPos int64
|
LogPos int64
|
||||||
Type BinlogType
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ParseInstanceKey will parse an InstanceKey from a string representation such as 127.0.0.1:3306
|
// ParseInstanceKey will parse an InstanceKey from a string representation such as 127.0.0.1:3306
|
||||||
@ -62,7 +47,7 @@ func (this *BinlogCoordinates) Equals(other *BinlogCoordinates) bool {
|
|||||||
if other == nil {
|
if other == nil {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
return this.LogFile == other.LogFile && this.LogPos == other.LogPos && this.Type == other.Type
|
return this.LogFile == other.LogFile && this.LogPos == other.LogPos
|
||||||
}
|
}
|
||||||
|
|
||||||
// IsEmpty returns true if the log file is empty, unnamed
|
// IsEmpty returns true if the log file is empty, unnamed
|
||||||
@ -87,76 +72,5 @@ func (this *BinlogCoordinates) SmallerThanOrEquals(other *BinlogCoordinates) boo
|
|||||||
if this.SmallerThan(other) {
|
if this.SmallerThan(other) {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
return this.LogFile == other.LogFile && this.LogPos == other.LogPos // No Type comparison
|
return this.LogFile == other.LogFile && this.LogPos == other.LogPos
|
||||||
}
|
|
||||||
|
|
||||||
// FileSmallerThan returns true if this coordinate's file is strictly smaller than the other's.
|
|
||||||
func (this *BinlogCoordinates) FileSmallerThan(other *BinlogCoordinates) bool {
|
|
||||||
return this.LogFile < other.LogFile
|
|
||||||
}
|
|
||||||
|
|
||||||
// FileNumberDistance returns the numeric distance between this coordinate's file number and the other's.
|
|
||||||
// Effectively it means "how many rotates/FLUSHes would make these coordinates's file reach the other's"
|
|
||||||
func (this *BinlogCoordinates) FileNumberDistance(other *BinlogCoordinates) int {
|
|
||||||
thisNumber, _ := this.FileNumber()
|
|
||||||
otherNumber, _ := other.FileNumber()
|
|
||||||
return otherNumber - thisNumber
|
|
||||||
}
|
|
||||||
|
|
||||||
// FileNumber returns the numeric value of the file, and the length in characters representing the number in the filename.
|
|
||||||
// Example: FileNumber() of mysqld.log.000789 is (789, 6)
|
|
||||||
func (this *BinlogCoordinates) FileNumber() (int, int) {
|
|
||||||
tokens := strings.Split(this.LogFile, ".")
|
|
||||||
numPart := tokens[len(tokens)-1]
|
|
||||||
numLen := len(numPart)
|
|
||||||
fileNum, err := strconv.Atoi(numPart)
|
|
||||||
if err != nil {
|
|
||||||
return 0, 0
|
|
||||||
}
|
|
||||||
return fileNum, numLen
|
|
||||||
}
|
|
||||||
|
|
||||||
// PreviousFileCoordinatesBy guesses the filename of the previous binlog/relaylog, by given offset (number of files back)
|
|
||||||
func (this *BinlogCoordinates) PreviousFileCoordinatesBy(offset int) (BinlogCoordinates, error) {
|
|
||||||
result := BinlogCoordinates{LogPos: 0, Type: this.Type}
|
|
||||||
|
|
||||||
fileNum, numLen := this.FileNumber()
|
|
||||||
if fileNum == 0 {
|
|
||||||
return result, errors.New("Log file number is zero, cannot detect previous file")
|
|
||||||
}
|
|
||||||
newNumStr := fmt.Sprintf("%d", (fileNum - offset))
|
|
||||||
newNumStr = strings.Repeat("0", numLen-len(newNumStr)) + newNumStr
|
|
||||||
|
|
||||||
tokens := strings.Split(this.LogFile, ".")
|
|
||||||
tokens[len(tokens)-1] = newNumStr
|
|
||||||
result.LogFile = strings.Join(tokens, ".")
|
|
||||||
return result, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// PreviousFileCoordinates guesses the filename of the previous binlog/relaylog
|
|
||||||
func (this *BinlogCoordinates) PreviousFileCoordinates() (BinlogCoordinates, error) {
|
|
||||||
return this.PreviousFileCoordinatesBy(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
// PreviousFileCoordinates guesses the filename of the previous binlog/relaylog
|
|
||||||
func (this *BinlogCoordinates) NextFileCoordinates() (BinlogCoordinates, error) {
|
|
||||||
result := BinlogCoordinates{LogPos: 0, Type: this.Type}
|
|
||||||
|
|
||||||
fileNum, numLen := this.FileNumber()
|
|
||||||
newNumStr := fmt.Sprintf("%d", (fileNum + 1))
|
|
||||||
newNumStr = strings.Repeat("0", numLen-len(newNumStr)) + newNumStr
|
|
||||||
|
|
||||||
tokens := strings.Split(this.LogFile, ".")
|
|
||||||
tokens[len(tokens)-1] = newNumStr
|
|
||||||
result.LogFile = strings.Join(tokens, ".")
|
|
||||||
return result, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// FileSmallerThan returns true if this coordinate's file is strictly smaller than the other's.
|
|
||||||
func (this *BinlogCoordinates) DetachedCoordinates() (isDetached bool, detachedLogFile string, detachedLogPos string) {
|
|
||||||
detachedCoordinatesSubmatch := detachPattern.FindStringSubmatch(this.LogFile)
|
|
||||||
if len(detachedCoordinatesSubmatch) == 0 {
|
|
||||||
return false, "", ""
|
|
||||||
}
|
|
||||||
return true, detachedCoordinatesSubmatch[1], detachedCoordinatesSubmatch[2]
|
|
||||||
}
|
}
|
||||||
|
@ -37,57 +37,6 @@ func TestBinlogCoordinates(t *testing.T) {
|
|||||||
test.S(t).ExpectTrue(c1.SmallerThanOrEquals(&c3))
|
test.S(t).ExpectTrue(c1.SmallerThanOrEquals(&c3))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestBinlogNext(t *testing.T) {
|
|
||||||
c1 := BinlogCoordinates{LogFile: "mysql-bin.00017", LogPos: 104}
|
|
||||||
cres, err := c1.NextFileCoordinates()
|
|
||||||
|
|
||||||
test.S(t).ExpectNil(err)
|
|
||||||
test.S(t).ExpectEquals(c1.Type, cres.Type)
|
|
||||||
test.S(t).ExpectEquals(cres.LogFile, "mysql-bin.00018")
|
|
||||||
|
|
||||||
c2 := BinlogCoordinates{LogFile: "mysql-bin.00099", LogPos: 104}
|
|
||||||
cres, err = c2.NextFileCoordinates()
|
|
||||||
|
|
||||||
test.S(t).ExpectNil(err)
|
|
||||||
test.S(t).ExpectEquals(c1.Type, cres.Type)
|
|
||||||
test.S(t).ExpectEquals(cres.LogFile, "mysql-bin.00100")
|
|
||||||
|
|
||||||
c3 := BinlogCoordinates{LogFile: "mysql.00.prod.com.00099", LogPos: 104}
|
|
||||||
cres, err = c3.NextFileCoordinates()
|
|
||||||
|
|
||||||
test.S(t).ExpectNil(err)
|
|
||||||
test.S(t).ExpectEquals(c1.Type, cres.Type)
|
|
||||||
test.S(t).ExpectEquals(cres.LogFile, "mysql.00.prod.com.00100")
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestBinlogPrevious(t *testing.T) {
|
|
||||||
c1 := BinlogCoordinates{LogFile: "mysql-bin.00017", LogPos: 104}
|
|
||||||
cres, err := c1.PreviousFileCoordinates()
|
|
||||||
|
|
||||||
test.S(t).ExpectNil(err)
|
|
||||||
test.S(t).ExpectEquals(c1.Type, cres.Type)
|
|
||||||
test.S(t).ExpectEquals(cres.LogFile, "mysql-bin.00016")
|
|
||||||
|
|
||||||
c2 := BinlogCoordinates{LogFile: "mysql-bin.00100", LogPos: 104}
|
|
||||||
cres, err = c2.PreviousFileCoordinates()
|
|
||||||
|
|
||||||
test.S(t).ExpectNil(err)
|
|
||||||
test.S(t).ExpectEquals(c1.Type, cres.Type)
|
|
||||||
test.S(t).ExpectEquals(cres.LogFile, "mysql-bin.00099")
|
|
||||||
|
|
||||||
c3 := BinlogCoordinates{LogFile: "mysql.00.prod.com.00100", LogPos: 104}
|
|
||||||
cres, err = c3.PreviousFileCoordinates()
|
|
||||||
|
|
||||||
test.S(t).ExpectNil(err)
|
|
||||||
test.S(t).ExpectEquals(c1.Type, cres.Type)
|
|
||||||
test.S(t).ExpectEquals(cres.LogFile, "mysql.00.prod.com.00099")
|
|
||||||
|
|
||||||
c4 := BinlogCoordinates{LogFile: "mysql.00.prod.com.00000", LogPos: 104}
|
|
||||||
_, err = c4.PreviousFileCoordinates()
|
|
||||||
|
|
||||||
test.S(t).ExpectNotNil(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestBinlogCoordinatesAsKey(t *testing.T) {
|
func TestBinlogCoordinatesAsKey(t *testing.T) {
|
||||||
m := make(map[BinlogCoordinates]bool)
|
m := make(map[BinlogCoordinates]bool)
|
||||||
|
|
||||||
@ -103,20 +52,3 @@ func TestBinlogCoordinatesAsKey(t *testing.T) {
|
|||||||
|
|
||||||
test.S(t).ExpectEquals(len(m), 3)
|
test.S(t).ExpectEquals(len(m), 3)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestBinlogFileNumber(t *testing.T) {
|
|
||||||
c1 := BinlogCoordinates{LogFile: "mysql-bin.00017", LogPos: 104}
|
|
||||||
c2 := BinlogCoordinates{LogFile: "mysql-bin.00022", LogPos: 104}
|
|
||||||
|
|
||||||
test.S(t).ExpectEquals(c1.FileNumberDistance(&c1), 0)
|
|
||||||
test.S(t).ExpectEquals(c1.FileNumberDistance(&c2), 5)
|
|
||||||
test.S(t).ExpectEquals(c2.FileNumberDistance(&c1), -5)
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestBinlogFileNumberDistance(t *testing.T) {
|
|
||||||
c1 := BinlogCoordinates{LogFile: "mysql-bin.00017", LogPos: 104}
|
|
||||||
fileNum, numLen := c1.FileNumber()
|
|
||||||
|
|
||||||
test.S(t).ExpectEquals(fileNum, 17)
|
|
||||||
test.S(t).ExpectEquals(numLen, 5)
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user