本文主要給大家介紹MySQL全量、增量備份與恢復的簡單方法,文章內容都是筆者用心摘選和編輯的,具有一定的針對性,對大家的參考意義還是比較大的,下面跟筆者一起了解下MySQL全量、增量備份與恢復的簡單方法吧。
創新互聯堅持“要么做到,要么別承諾”的工作理念,服務領域包括:網站設計制作、成都網站設計、企業官網、英文網站、手機端網站、網站推廣等服務,滿足客戶于互聯網時代的路南網站設計、移動媒體設計的需求,幫助企業找到有效的互聯網解決方案。努力成為您成熟可靠的網絡建設合作伙伴!1、在生產環境中,數據的安全性是至關重要的,任何數據的丟失都可能產生嚴重的后果
2、造成數據丟失的原因
程序錯誤
人為錯誤
計算機失敗
磁盤失敗
災難(如地震等)和偷竊
一、從物理與邏輯的角度,備份可分為:
1、物理備份:對數據庫操作系統的物理文件(如數據文件、日志文件等)的備份 物理備份又可以分為脫機備份(冷備份)和聯機備份(熱備份): -冷備份:是在關閉數據庫的時候進行的 -熱備份:數據庫處于運行狀態,這種備份方法依賴于數據庫的日志文件 2、邏輯備份:對數據庫邏輯組件(如表等數據庫對象)的備份
二、從數據庫的備份策略角度, 備份可分為:
1、完全備份:每次對數據進行完整的備份 2、差異備份:備份那些自從上次完全備份之后被修改過的文件 3、增量備份:只有那些在.上次完全備份或者增量備份后被修改的文件才會被備份 注意點:差異備份與增量備份相輔相成
1、完全備份是對整個數據庫的備份、數據庫結構和文件結構的備份 2、完全備份保存的是備份完成時刻的數據庫 3、完全備份是增量備份的基礎
完全備份的優點
備份與恢復操作簡單方便
完全備份的缺點
1.數據存在大量的重復 2.占用大量的備份空間 3.備份與恢復時間長
一、MySQL數據庫的備份可以采用用多種方式
1.直接打包數據庫文件夾,如/usr/local/mysql/data 2.使用專用備份工具mysqldump**
二、mysqldump命令
1.MySQL自帶的備份工具,相當方便對MySQL進行備份 2.通過該命令工具可以將指定的庫、表或全部的庫導出為SQL腳本,在需要恢復時可進行數據恢復
三、使用mysqldump命令對單個數據庫進行完全備份
mysqldump -u用戶名 -p [密碼] [選項] [數據庫名] > /備份路徑/備份文件名
四、使用mysqldump命令對多個庫進行完全備份
mysqldump -u 用戶名 -p [密碼] [選項] --databases 庫名1 [庫名2]... >/備份路徑/備份文件名
五、使用mysqldump命令對所有庫進行完全備份
mysqldump -u用戶名 -p [密碼] [選項] --all-databases > /備份路徑/備份文件名
在實際生產環境中,存在對某個特定表的維護操作,此時mysqldump同樣發揮重大作用
1.使用mysqldump備份表的操作
mysqldump -u 用戶名 -p [密碼] [選項] 數據庫名 表名 > /備份路徑/備份文件名
2.使用mysqldump備份表結構的操作
mysqldump -u 用戶名 -p [密碼] [選項] -d 數據庫名 表名 > /備份路徑/備份文件名
一、使用mysqldump命令導出的SQL備份腳本,在進行數據恢復時可使用以下方法導入
source命令 #數據庫模式中運行 mysql命令 #Linux模式中運行
1、使用source恢復數據庫的步驟
●登錄到MySQL數據庫 ●執行source備份sq|腳本的路徑(絕對路徑)
MySQL [(none)] > source /backup/all-data.sql #source命令恢復
2、使用mysql命令恢復數據
mysql -u用戶名 -p [密碼] < 庫備份腳本的路徑
mysql -u root -p < /backup/all-data.sql #mysql命令恢復
二、使用mysqldump進行完全備份的存在的問題
●備份數據中有重復數據 ●備份時間與恢復時間長
1、恢復表時同樣可以使用source或者mysql命令進行 2、source恢復表的操作與恢復庫的操作相同 3、當備份文件中只包含表的備份,而不包括創建庫的語句時,必須指定庫名,且目標庫必須存在.生產環境中,可以使用shell腳本自動實現定期備份 mysql -u用戶名-p [密碼] < 表備份腳本的路徑
mysql -u root -p mysql < /backup/mysql-user.sql #mysql命令恢復表
1、定期實施備份,制定備份計劃或者策略,并嚴格遵守 2、除了進行完全備份,開啟MySQL云服務器的日志功能是很重要的 ●完全備份加上日志,可以對MySQL進行大化還原 MySQL-bin:MySQL數據庫的二進制日志,用于記錄用戶對數據庫操作的SQL語句((除了數據查詢語句)信息。可以使用mysqlbin命令查看二進制日志的內容 3、使用統一的和易理解的備份文件名稱 ●不要使用backup1、backup2等這樣沒有意義的名字 ●推薦使用庫名或者表名加上時間的命名規則
增量備份就是備份自上一次備份之后增加或變化的文件或者內容
增量備份的特點
●沒有重復數據,備份量不大,時間短 ●恢復麻煩:需要上次完全備份及完全備份之后所有的增量備份才能恢復,而且要對所有增量備份進行逐個反推恢復
MySQL沒有提供直接的增量備份方法
可以通過MySQL提供的二進制日志(binary logs)間接實現增量備份
MySQL二進制日志對備份的意義
●二進制日志保存了所有更新或者可能更新數據庫的操作 ●二進制日志在啟動MySQL云服務器后開始記錄,并在文件達到max_ binlog_size所設置的大小或者接收到flush logs命令后重新創建新的日志文件 ●只需定時執行flush logs方法重新創建新的日志,生成二進制文件序列,并及時把這些舊的日志保存到安全的地方就完成了一個時間段的增量備份
mysqlbinlog --no-defaults --base64-output=decode-rows -V mysql-bin.000002 > /opt/ bak. txt
就是將某個起始時間的二進制日志導入數據庫中,從而跳過某個發生錯誤的時間點實現數據的恢復
使用基于時間點的恢復,可能會出現在一個時間點里既同時存在正確的操作又存在錯誤的操作,所以我們需要一種更為精確的恢復方式
1.一般恢復
mysqlbinlog [--no-defaults] 增量備份文件 | mysql -u用戶名 -p
2.基于位置的恢復
恢復數據到指定位置
mysqlbinlog --stop-position=操作'id' 進制日志 | mysql -u用戶名 -p 密碼
從指定的位置開始恢復數據
mysqlbinlog --start-position=操作'id' 二進制日志 | mysql -u用戶名 -p 密碼
3.基于時間點的恢復
從日志開頭截止到某個時間點的恢復
mysqlbinlog [--no-defaults] --stop-datetime='年-月-日 小時:分鐘:秒' 二進制日志 | mysql -u用戶名 -p 密碼
從某個時間點到日志結尾的恢復
mysqlbinlog [--no defaults] --start-datetime='年-月-日 小時:分鐘:秒' 二進制日志 | mysql -u用戶名 -p 密碼
從某個時間點到某個時間點的恢復
mysqlbinlog [--no defaults] --start-datetime='年-月-日 小時:分鐘:秒' --stop-datetime='年-月-日 小時:分鐘:秒' 二進制日志 | mysql -u用戶名 -p 密碼
看完以上關于MySQL全量、增量備份與恢復的簡單方法,很多讀者朋友肯定多少有一定的了解,如需獲取更多的行業知識信息 ,可以持續關注我們的行業資訊欄目的。
另外有需要云服務器可以了解下創新互聯cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
新聞名稱:MySQL全量、增量備份與恢復的簡單方法-創新互聯
轉載來源:http://vcdvsql.cn/article20/ddheco.html
成都網站建設公司_創新互聯,為您提供網站制作、做網站、靜態網站、營銷型網站建設、企業建站、Google
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯