您好,登錄后才能下訂單哦!
本篇內容介紹了“MySQL5.7中的mysqlpump備份工具說明”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
MySQL5.7之后多了一個備份工具:mysqlpump。它是mysqldump的一個衍生,mysqldump就不多說明了,現在看看mysqlpump到底有了哪些提升,可以查看 官方文檔 ,這里針對如何使用做下說明。
mysqlpump和mysqldump一樣,屬于邏輯備份,備份以SQL形式的文本保存。邏輯備份相對物理備份的好處是不關心undo log的大小,直接備份數據即可。它最主要的特點是:
并行備份數據庫和數據庫中的對象的,加快備份過程。
更好的控制數據庫和數據庫對象(表,存儲過程,用戶帳戶)的備份。
備份用戶賬號作為帳戶管理語句(CREATE USER,GRANT),而不是直接插入到MySQL的系統數據庫。
備份出來直接生成壓縮后的備份文件。
備份進度指示(估計值)。
重新加載(還原)備份文件,先建表后插入數據最后建立索引,減少了索引維護開銷,加快了還原速度。
備份可以排除或則指定數據庫。
參數:絕大部分參數和mysqldump一致,順便復習一下。對于mysqlpump參數會用背景色 標記出來。
1: --add-drop-database :在建立庫之前先執行刪庫操作。
DROP DATABASE IF EXISTS `...`;
2: --add-drop-table :在建表之前先執行刪表操作。
DROP TABLE IF EXISTS `...`.`...`;
3:--add-drop-user:在CREATE USER語句之前增加DROP USER,注意:這個參數需要和--users一起使用,否者不生效。
DROP USER 'backup'@'192.168.123.%';
4: --add-locks :備份表時,使用LOCK TABLES和UNLOCK TABLES。注意:這個參數不支持并行備份,需要關閉并行備份功能:--default-parallelism=0
LOCK TABLES `...`.`...` WRITE; ... UNLOCK TABLES;
5: --all-databases :備份所有庫,-A。
6: --bind-address :指定通過哪個網絡接口來連接Mysql服務器(一臺服務器可能有多個IP),防止同一個網卡出去影響業務。
7: --complete-insert :dump出包含所有列的完整insert語句。
8: --compress : 壓縮客戶端和服務器傳輸的所有的數據,-C。
9:--compress-output:默認不壓縮輸出,目前可以使用的壓縮算法有LZ4和ZLIB。
shell> mysqlpump --compress-output=LZ4 > dump.lz4 shell> lz4_decompress dump.lz4 dump.txt shell> mysqlpump --compress-output=ZLIB > dump.zlib shell> zlib_decompress dump.zlib dump.txt
10:
--databases
:手動指定要備份的庫,支持多個數據庫,用空格分隔,-B。
11: --default-character-set :指定備份的字符集。
12:--default-parallelism:指定并行線程數,默認是2,如果設置成0,表示不使用并行備份。注意:每個線程的備份步驟是:先create table但不建立二級索引(主鍵會在create table時候建立),再寫入數據,最后建立二級索引。
13:--defer-table-indexes:延遲創建索引,直到所有數據都加載完之后,再創建索引,默認開啟。若關閉則會和mysqldump一樣:先創建一個表和所有索引,再導入數據,因為在加載還原數據的時候要維護二級索引的開銷,導致效率比較低。關閉使用參數: --skip--defer-table-indexes 。
14: --events :備份數據庫的事件,默認開啟,關閉使用--skip-events參數。
15:--exclude-databases:備份排除該參數指定的數據庫,多個用逗號分隔。類似的還有--exclude-events、--exclude-routines、--exclude-tables、--exclude-triggers、--exclude-users。
mysqlpump --exclude-databases=mysql,sys #備份過濾mysql和sys數據庫mysqlpump --exclude-tables=rr,tt #備份過濾所有數據庫中rr、tt表mysqlpump -B test --exclude-tables=tmp_ifulltext,tt #備份過濾test庫中的rr、tt表...
注意:要是只備份數據庫的賬號,需要添加參數 --users ,并且需要過濾掉所有的數據庫,如:
mysqlpump --users --exclude-databases=sys,mysql,db1,db2 --exclude-users=dba,backup #備份除dba和backup的所有賬號。
16:--include-databases:指定備份數據庫,多個用逗號分隔,類似的還有--include-events、--include-routines、--include-tables、--include-triggers、--include-users,大致方法使用同15。
17: --insert-ignore :備份用insert ignore語句代替insert語句。
18: --log-error-file :備份出現的warnings和erros信息輸出到一個指定的文件。
19: --max-allowed-packet :備份時用于client/server直接通信的最大buffer包的大小。
20: --net-buffer-length :備份時用于client/server通信的初始buffer大小,當創建多行插入語句的時候,mysqlpump 創建行到N個字節長。
21: --no-create-db :備份不寫CREATE DATABASE語句。要是備份多個庫,需要使用參數-B,而使用-B的時候會出現create database語句,該參數可以屏蔽create database 語句。
22: --no-create-info :備份不寫建表語句,即不備份表結構,只備份數據,-t。
23: --hex-blob : 備份binary字段的時候使用十六進制計數法,受影響的字段類型有BINARY、VARBINARY、BLOB、BIT。
24: --host :備份指定的數據庫地址,-h。
25:--parallel-schemas=[
:指定并行備份的庫,多個庫用逗號分隔,如果指定了N,將使用N個線程的地隊列,如果N不指定,將由 --default-parallelism才確認N的值,可以設置多個N
:]db_list
--parallel-schemas
。
mysqlpump --parallel-schemas=4:vs,aa --parallel-schemas=3:pt #4個線程備份vs和aa,3個線程備份pt。通過show processlist 可以看到有7個線程。mysqlpump --parallel-schemas=vs,abc --parallel-schemas=pt #默認2個線程,即2個線程備份vs和abc,2個線程備份pt ####當然要是硬盤IO不允許的話,可以少開幾個線程和數據庫進行并行備份
26: --password :備份需要的密碼。
27: --port :備份數據庫的端口。
28:--protocol={TCP|SOCKET|PIPE|MEMORY}
:指定連接服務器的協議。
29:
--replace
:備份出來replace into語句。
30:
--routines
:備份出來包含存儲過程和函數,默認開啟,需要對 mysql.proc表有查看權限。生成的文件中會包含CREATE PROCEDURE 和 CREATE FUNCTION語句以用于恢復,關閉則需要用--skip-routines參數。
31:
--triggers
:備份出來包含觸發器,默認開啟,使用--skip-triggers
來關閉。
31:
--set-charset
:備份文件里寫SET NAMES default_character_set 到輸出,此參默認開啟。 -- skip-set-charset禁用此參數,不會在備份文件里面寫出set names...
32: --single-transaction :該參數在事務隔離級別設置成Repeatable Read,并在dump之前發送start transaction 語句給服務端。這在使用innodb時很有用,因為在發出start transaction時,保證了在不阻塞任何應用下的一致性狀態。對myisam和memory等非事務表,還是會改變狀態的,當使用此參的時候要確保沒有其他連接在使用ALTER TABLE、CREATE TABLE、DROP TABLE、RENAME TABLE、TRUNCATE TABLE等語句,否則會出現不正確的內容或則失敗。--add-locks和此參互斥,在mysql5.7.11之前,--default-parallelism大于1的時候和此參也互斥,必須使用--default-parallelism=0。5.7.11之后解決了--single-transaction和--default-parallelism的互斥問題。
33:--skip-definer:忽略那些創建視圖和存儲過程用到的 DEFINER 和 SQL SECURITY 語句,恢復的時候,會使用默認值,否則會在還原的時候看到沒有DEFINER定義時的賬號而報錯。
34:--skip-dump-rows:只備份表結構,不備份數據,-d。注意:mysqldump支持--no-data,mysqlpump不支持--no-data
35: --socket :對于連接到localhost,Unix使用套接字文件,在Windows上是命名管道的名稱使用,-S。
36:
--ssl
:--ssl參數將要被去除,用
--ssl-mode
取代。關于ssl相關的備份,請看
官方文檔
。
37:
--tz-utc
:備份時會在備份文件的最前幾行添加SET TIME_ZONE='+00:00'。注意:如果還原的服務器不在同一個時區并且還原表中的列有timestamp字段,會導致還原出來的結果不一致。默認開啟該參數,用 --skip-tz-utc
來關閉參數。
38: --user :備份時候的用戶名,-u。
39:--users:備份數據庫用戶,備份的形式是CREATE USER...,GRANT...,只備份數據庫賬號可以通過如下命令:
mysqlpump --exclude-databases=% --users #過濾掉所有數據庫
40:--watch-progress:定期顯示進度的完成,包括總數表、行和其他對象。該參數默認開啟,用--skip-watch-progress
來關閉。
使用說明:
mysqlpump支持基于庫和表的并行導出,mysqlpump的并行導出功能的架構為:隊列+線程,允許有多個隊列(--parallel-schemas
?
),每個隊列下有多個線程(N?),而一個隊列可以綁定1個或者多個數據庫(逗號分隔)。mysqlpump的備份是基于表并行的,對于每張表的導出只能是單個線程的,這里會有個限制是如果某個數據庫有一張表非常大,可能大部分的時間都是消耗在這個表的備份上面,并行備份的效果可能就不明顯。這里可以利用mydumper其是以chunk的方式批量導出,即mydumper支持一張表多個線程以chunk的方式批量導出。但是相對于mysqldump還是有了很大的提升。
“MySQL5.7中的mysqlpump備份工具說明”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。