-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
118 lines (104 loc) · 2.83 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
package main
import (
"bytes"
"errors"
"fmt"
"log"
"os"
"os/exec"
"strings"
"github.com/aws/aws-sdk-go/aws"
awsSess "github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/dynamodb"
)
func main() {
dynamodbTable := os.Getenv("DYNAMODB_TABLE")
dynamodbRecordID := os.Getenv("DYNAMODB_RECORD_ID")
sourceDB := os.Getenv("SOURCE_DB")
destDB := os.Getenv("DEST_DB")
region := os.Getenv("AWS_REGION")
sess, err := awsSess.NewSession()
if err != nil {
log.Printf("cannot create new aws session, error: %v", err)
return
}
dynamodbSvc := dynamodb.New(sess, &aws.Config{
Region: aws.String(region),
})
item, err := dynamodbSvc.GetItem(&dynamodb.GetItemInput{
TableName: aws.String(dynamodbTable),
Key: map[string]*dynamodb.AttributeValue{
"ID": {
S: aws.String(dynamodbRecordID),
},
},
})
if err != nil {
log.Printf("cannot get item: error %v", err)
return
}
if item.Item == nil {
log.Println("no flag reset db, do nothing")
return
}
log.Printf("Drop all tables of %v\n", destDB)
err = executeInShell("echo \"SET FOREIGN_KEY_CHECKS = 0;\" > /tmp/temp.sql")
if err != nil {
log.Println(err)
return
}
err = executeInShell(fmt.Sprintf("mysqldump --defaults-file=/mnt/MYSQL_CNF --add-drop-table --set-gtid-purged=OFF --no-data %v | grep 'DROP TABLE' >> /tmp/temp.sql", destDB))
if err != nil {
log.Println(err)
if !strings.HasPrefix(err.Error(), "Warning") {
log.Println("EXIT")
return
}
}
err = executeInShell("echo \"SET FOREIGN_KEY_CHECKS = 1;\" >> /tmp/temp.sql")
if err != nil {
log.Println(err)
return
}
err = executeInShell(fmt.Sprintf("mysql --defaults-file=/mnt/MYSQL_CNF %v < /tmp/temp.sql", destDB))
if err != nil {
log.Println(err)
if !strings.HasPrefix(err.Error(), "Warning") {
log.Println("EXIT")
return
}
}
b, err := os.ReadFile("/tmp/temp.sql")
if err == nil {
log.Printf("Droped all tables with SQL scripts:\n%v\n", string(b))
}
log.Println("Begin clone DB")
err = executeInShell(fmt.Sprintf("mysqldump --defaults-file=/mnt/MYSQL_CNF --set-gtid-purged=OFF --column-statistics=0 --routines --no-tablespaces %v | sed -e 's/DEFINER[ ]*=[ ]*[^*]*\\*/\\*/' | mysql --defaults-file=/mnt/MYSQL_CNF %v", sourceDB, destDB))
if err != nil {
log.Printf("Clone DB %v to %v has err: %v\n", sourceDB, destDB, err.Error())
} else {
log.Printf("Finish clone DB %v to %v", sourceDB, destDB)
}
dynamodbSvc.DeleteItem(&dynamodb.DeleteItemInput{
TableName: aws.String(dynamodbTable),
Key: map[string]*dynamodb.AttributeValue{
"ID": {
S: aws.String(dynamodbRecordID),
},
},
})
}
func executeInShell(c string) error {
cmd := exec.Command("/bin/sh", "-c", c)
var stderr bytes.Buffer
cmd.Stderr = &stderr
err := cmd.Run()
if err != nil {
return err
}
errMsg := stderr.String()
if errMsg != "" {
return errors.New(errMsg)
}
return nil
}