From 867d4ccaf6014d09e94b147191531b09de0f2a2a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dani=C3=ABl=20van=20Eeden?= Date: Fri, 8 Nov 2024 09:16:20 +0100 Subject: [PATCH] go-mysqldump: Add option to skip binlog position (#941) When running against MariaDB 11.4 without binlogs enabled: - `mysqldump` 9.1.0 fails to dump when called with `--source-data` due to the `SHOW BINARY LOG STATUS` not being supported by MariaDB. - `mariadb-dump` 11.4 fails to dump when called with `--master-data` due to binlogs not being enabled. Other situations where this can be useful: - Permission issues --- cmd/go-mysqldump/main.go | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/cmd/go-mysqldump/main.go b/cmd/go-mysqldump/main.go index b49f0c1ef..ea2d81bd2 100644 --- a/cmd/go-mysqldump/main.go +++ b/cmd/go-mysqldump/main.go @@ -18,10 +18,11 @@ var ( execution = flag.String("exec", "mysqldump", "mysqldump execution path") output = flag.String("o", "", "dump output, empty for stdout") - dbs = flag.String("dbs", "", "dump databases, separated by comma") - tables = flag.String("tables", "", "dump tables, separated by comma, will overwrite dbs") - tableDB = flag.String("table_db", "", "database for dump tables") - ignoreTables = flag.String("ignore_tables", "", "ignore tables, must be database.table format, separated by comma") + dbs = flag.String("dbs", "", "dump databases, separated by comma") + tables = flag.String("tables", "", "dump tables, separated by comma, will overwrite dbs") + tableDB = flag.String("table_db", "", "database for dump tables") + ignoreTables = flag.String("ignore_tables", "", "ignore tables, must be database.table format, separated by comma") + skipBinlogPos = flag.Bool("skip-binlog-pos", false, "skip fetching binlog position via --master-data/--source-data") ) func main() { @@ -33,6 +34,8 @@ func main() { os.Exit(1) } + d.SkipMasterData(*skipBinlogPos) + if len(*ignoreTables) > 0 { subs := strings.Split(*ignoreTables, ",") for _, sub := range subs {