mysql重裝后數(shù)據(jù)恢復 Mysql實時備份實現(xiàn)方法?
Mysql實時備份實現(xiàn)方法?數(shù)據(jù)備份是數(shù)據(jù)容災的最后一道防線,就算是有著兩地三中心的架構,備份文件也依舊重要的是。要是備分出問題,軟件備份時影響不大了交易業(yè)務,備份數(shù)據(jù)不能重新恢復,這些都是企業(yè)難以承
Mysql實時備份實現(xiàn)方法?
數(shù)據(jù)備份是數(shù)據(jù)容災的最后一道防線,就算是有著兩地三中心的架構,備份文件也依舊重要的是。要是備分出問題,軟件備份時影響不大了交易業(yè)務,備份數(shù)據(jù)不能重新恢復,這些都是企業(yè)難以承受的。因此選擇類型適合的備份工具尤為重要。
每個企業(yè)級數(shù)據(jù)庫都會有教材的備份工具,MEB(MySQL Enterprise Backup)就是MySQL企業(yè)版中非常重要的工具之一,是為企業(yè)級客戶提供給的數(shù)據(jù)備份方案。
Xtrabackup總是作為MEB開源代碼版?zhèn)涮ザ嬖冢瑥腗ySQL8.0結束情況可能會會變得更加有所不同。
在MySQL8.0的BackupLock、Redo Log Archiving、Page Tracking等新特性的加持下,MEB備份文件/可以恢復想體驗會更好,目前xtrabackup還不支持這些特性。
MySQL企業(yè)版有哪些功能?
特性1:BackupLock
8.0之前不使用xtrabackup或MEB做物理備份文件,替只要備份文件時InnoDB引擎表與其他引擎數(shù)據(jù)文件、及binlog日志的一致性會上全局讀鎖,再拷入非InnoDB文件,這期間MySQL會都變成只讀,數(shù)據(jù)根本無法讀取。表數(shù)量一定,很可能另外時間越長,要是可以使用的xtrabackup一不小心沒加rsync參數(shù),輪流u盤拷貝frm文件,鎖定時間會更長,對業(yè)務影響較小。
我曾遇到過重新部署在虛擬機的實例有12000多張表,當時不使用的xtrabackup,備份腳本中沒加rsync參數(shù),可是鎖了十幾分鐘,而MEB就沒有這樣的問題。
MySQL8.0允許輕量級系統(tǒng)備份鎖LOCKINSTANCEafterBACKUP,數(shù)據(jù)字典也重構了由InnoDB存儲。若不修改非InnoDB表,MEB默認使用備份文件鎖資源binlog日志一致性位置,并阻止DDL操作,但不引響DML操作。
只能InnoDB表,僅上系統(tǒng)備份鎖
若有非InnoDB表,上全局鎖
特性2:RedoLogArchiving
MEB能你做到網熱備,備分時不影響大數(shù)據(jù)庫讀寫,這是借用了InnoDB事務日志,在軟件備份期間減弱監(jiān)視redolog的變化,無法讀取增量變化,中寫入到ibbackup_logfile,也就不要上鎖來保障備分一致性。(對非InnoDB的文件不需要上讀鎖拷貝)
如果沒有備份期間數(shù)據(jù)庫寫入文件負載最重要的大,而讀取ibbackup_logfile速度較慢,redologsize也不太大,很肯定會又出現(xiàn)ibbackup_logfile的中寫入速度跟不上腳步redolog記錄生成速度,redolog空間太少時不需要覆寫日志文件,這樣的話根本來不及寫入到ibbackup_logfile的記錄會丟失的,會造成軟件備份一次。
MEB4.1因此做了優(yōu)化,將redolog處理線程拆分成多線程分工合作,能提高如何處理redolog的效率,降底了redolog覆寫倒致備份失敗的概率,但redolog新增加速度和ibbackup_logfile寫入文件速度懸殊太大,問題依然會再一次發(fā)生。
MySQL8.0.17允許了redologarchiving全部解決的辦法了此問題,系統(tǒng)備份前系統(tǒng)設置innodb_redo_log_archive_dirs,委托redolog歸檔目錄。MEB備份時自動自動打開日志歸檔,當checkpoint時會將舊記錄歸檔到此處目錄,現(xiàn)從歸檔文件中讀取redo日志記錄,以免了覆寫可能會導致的redo有記錄丟了。
再注意:innodb_redo_log_archive_dirs肯定不能在數(shù)據(jù)目錄下,目錄權限要求是700
特性3:PageTracking
PageTracking是為優(yōu)化增量系統(tǒng)備份效率,會減少不必要的數(shù)據(jù)頁掃描。
增量備份當前有3種掃描模式:
page-track:依靠LSN計算精確潛進來剛才備分之后被如何修改頁面,僅不能復制這些頁面,效率快的話。
optimistic:掃描前段時間備分之后被修改的InnoDB數(shù)據(jù)文件中,找到什么并文件復制如何修改的頁面。依賴感系統(tǒng)時間,建議使用存在限制。
endless-scan:掃描后所有InnoDB數(shù)據(jù)文件,得出答案并拷貝自剛才系統(tǒng)備份之后如何修改的頁面,效率最慢
1、憑借page-track增量備分,需先直接安裝軟件備份組件
2、在全備前傳送page-track
3、全備之后,做增量軟件備份時重新指定若柯西-黎曼方程pagetracking條件,默認會在用page-track模式,否則不會不使用endless-scan模式,也可以重新指定--incrementalpage-track。
incremental-base有3種選擇
last_backup:基于組件前一次備份做增備,前三次軟件備份可能是增備,也很有可能是全備。這種全備之間可能會會有多個增備,隔一段時間增量可能都很小,但重新恢復時必須逐一單獨設置。
last_clear_backup:基于組件前一次全備做增備。這種增備會越往前體積很有可能越大,但完全恢復時只要合并最后一次增量備份。
dir:基于條件前一次的備份目錄,前兩次備份肯定是增備,也肯定是全備。
測試差不多l(xiāng)arge-scan和page-track,在進行變更頁小于等于總體50%的情況下,備份效率最起碼能有1倍的速度進階。
page-track模式磁盤讀寫均衡,那就證明讀寫的是如何修改頁面。
large-scan模式磁盤讀寫差別比較大,只能說明讀了很多未修改的頁面。
SQL server如何用語句備份和還原數(shù)據(jù)?
用SQL語句備份與恢復數(shù)據(jù)庫的步驟:
1.備分:mysqldump--quick--databaseondemand1--urootgtbacqup.sql那樣的話就能把數(shù)據(jù)庫中ondemand1的表完全備份文件不出來。
2.其中參數(shù)的格式是:--,兩橫杠,又不是我們正確的單橫杠。
3.quick是在數(shù)據(jù)比較多的時候,你不該參數(shù)的話,所有的數(shù)據(jù)都會先在內存緩存,隨即才導出來,這樣的話會導致服務器運行減慢。
4.--u需要要加一個用戶名,不然系統(tǒng)會不提示你進不了ODBC數(shù)據(jù)庫的。
則是你的軟件備份數(shù)據(jù)庫的目標文件名。
6.完全恢復:m1ysql-uroot-pdatabase_name?,在WIN下,路徑用path/filename.sql是不行啊的,那就用pathfilename.sql。sql語句:是對數(shù)據(jù)庫進行不能操作的一種語言。結構化查詢語言(StructuredQueryLanguage)西安北方光電有限公司SQL,結構化查詢語言是一種數(shù)據(jù)庫網站查詢和程序設計語言,主要是用于存取數(shù)據(jù)這些查詢、更新和管理關系數(shù)據(jù)庫系統(tǒng)。其他命令:如,還原系統(tǒng)命令:USEmasterGORESTOREDATABASEtest_wtFROMdiskc:test_wtGOMySQL。