如何優(yōu)雅安全的備份MySQL數(shù)據(jù)
1. 為什么要備份數(shù)據(jù)
先說一下為什么需要備份MySQL數(shù)據(jù)?
一句話總結(jié)就是:為了保證數(shù)據(jù)的安全性。
如果我們把數(shù)據(jù)只存儲(chǔ)在一個(gè)地方,如果物理機(jī)器損壞,會(huì)導(dǎo)致數(shù)據(jù)丟失,無法恢復(fù)。
還有就是我們每次手動(dòng)修改線上數(shù)據(jù)之前,為了安全起見,都需要先備份數(shù)據(jù)。防止人為的誤操作,導(dǎo)致弄臟數(shù)據(jù)或弄丟數(shù)據(jù)。
2. 怎樣備份MySQL數(shù)據(jù)?
想要快速簡(jiǎn)單粗暴備份MySQL數(shù)據(jù),可以使用mysqldump命令:
# 備份test數(shù)據(jù)庫 mysqldump -uroot -p test > backup.db
但是這樣備份的可能包含臟數(shù)據(jù),比如在我們備份數(shù)據(jù)的過程中,有個(gè)下單的操作正在執(zhí)行。
下單之后,還沒有來得及扣款,就開始執(zhí)行備份數(shù)據(jù)的命令,就會(huì)出現(xiàn)臟數(shù)據(jù)。
下單,保存訂單表
備份數(shù)據(jù)
扣款
3. 怎么安全的備份數(shù)據(jù)?
mysqldump命令也提供了以事務(wù)的形式備份的參數(shù):
# 開啟一個(gè)事務(wù)備份test數(shù)據(jù)庫 mysqldump -uroot -p --single-transaction test > backup.db
開啟事務(wù)后,會(huì)跟正常業(yè)務(wù)操作產(chǎn)生鎖資源競(jìng)爭(zhēng),可能會(huì)阻塞其他的業(yè)務(wù)操作,嚴(yán)重的可能會(huì)導(dǎo)致服務(wù)宕機(jī),所以備份操作盡量在業(yè)務(wù)低峰期執(zhí)行。
還有一個(gè)問題,只有InnoDB引擎支持事務(wù)命令,對(duì)于不支持的事務(wù)MyISAM引擎,備份數(shù)據(jù)的時(shí)候怎么保證數(shù)據(jù)的安全性呢?
有一個(gè)粗暴的辦法就是設(shè)置全庫只讀,禁止寫操作,這樣備份的時(shí)候不就能保證數(shù)據(jù)安全性啦。
先用命令查看一下數(shù)據(jù)庫的只讀狀態(tài):
show variables like 'read_only';
OFF表示只讀模式關(guān)閉,ON表示開啟只讀模式。
set global read_only=1;

這樣設(shè)置其實(shí)是非常危險(xiǎn)的,如果客戶端連接斷開,整個(gè)數(shù)據(jù)庫也會(huì)一直處于只讀模式,無法進(jìn)行寫操作。
更推薦的辦法是設(shè)置全局鎖 FTWRL(flush tables with read lock)。
# 設(shè)置全局鎖,禁止寫操作 flush tables with read lock; # 釋放鎖 unlock tables;
設(shè)置全局鎖之后,如果客戶端斷開,會(huì)自動(dòng)釋放鎖,更安全。
4. 怎么恢復(fù)數(shù)據(jù)?
通過備份文件恢復(fù)數(shù)據(jù)也非常簡(jiǎn)單:
# 把備份文件數(shù)據(jù)導(dǎo)入到test數(shù)據(jù)庫 mysqldump -uroot -p test < backup.db
到此這篇關(guān)于如何優(yōu)雅安全的備份MySQL數(shù)據(jù)的文章就介紹到這了,更多相關(guān)備份MySQL數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql的語句查詢順序、耗時(shí)分析以及查詢調(diào)優(yōu)技巧分享
文章詳細(xì)介紹了MySQL中SQL查詢語句的執(zhí)行順序、耗時(shí)分析及查詢調(diào)優(yōu)方法,包括使用EXPLAIN、SHOW PROFILE和慢查詢?nèi)罩镜裙ぞ哌M(jìn)行耗時(shí)分析,以及使用索引、避免全表掃描、優(yōu)化查詢語句、分區(qū)表和調(diào)整服務(wù)器配置等技巧進(jìn)行性能優(yōu)化2025-02-02
Mysql?刪除重復(fù)數(shù)據(jù)保留一條有效數(shù)據(jù)(最新推薦)
這篇文章主要介紹了Mysql?刪除重復(fù)數(shù)據(jù)保留一條有效數(shù)據(jù),實(shí)現(xiàn)原理也很簡(jiǎn)單,mysql刪除重復(fù)數(shù)據(jù),多個(gè)字段分組操作,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
MySQL中SQL分頁查詢的幾種實(shí)現(xiàn)方法及優(yōu)缺點(diǎn)
這篇文章主要介紹了MySQL中SQL分頁查詢的幾種實(shí)現(xiàn)方法及優(yōu)缺點(diǎn), 分頁查詢就是在滿足條件的一堆有序數(shù)據(jù)中截取當(dāng)前所需要展示的那部分。對(duì)此感興趣的可以來了解一下2020-07-07
MySQL單表百萬數(shù)據(jù)記錄分頁性能優(yōu)化技巧
自己的一個(gè)網(wǎng)站,由于單表的數(shù)據(jù)記錄高達(dá)了一百萬條,造成數(shù)據(jù)訪問很慢,Google分析的后臺(tái)經(jīng)常報(bào)告超時(shí),尤其是頁碼大的頁面更是慢的不行2016-08-08
mysql大數(shù)據(jù)查詢優(yōu)化經(jīng)驗(yàn)分享(推薦)
這篇文章主要介紹了mysql大數(shù)據(jù)查詢優(yōu)化經(jīng)驗(yàn)分享,真的是正兒八經(jīng)的mysql優(yōu)化技巧,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-03-03

