成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

MySQL不同存儲引擎的數據備份與恢復

存儲 容災備份 MySQL
數據備份的目的很直接也很簡單,就是為了避免因不可預測、偶然的事件而導致的慘重損失,所以數據越重要、變化越頻繁,就越要進行數據備份。

數據備份的目的很直接也很簡單,就是為了避免因不可預測、偶然的事件而導致的慘重損失,所以數據越重要、變化越頻繁,就越要進行數據備份。我們以MySQL為例對數據備份進行了粗略的解讀,本文我們依然以MySQL為例,講講面對不同的存儲引擎如何做數據備份與恢復。

為了應對不同的數據處理,MySQL提供了十幾種不同的存儲引擎,不過,我們沒有必要一一去了解,因為熟悉使用MySQL的人都知道,比較常用的存儲引擎有兩個,分別是MyISAM和InnoDB。

  • MyISAM是MySQL的ISAM擴展格式和缺省的數據庫引擎,不支持事務、也不支持外鍵,但其優勢在于訪問速度快,對事務完整性沒有要求,以select,insert為主的應用基本上可以用這個引擎來創建表。常用于高讀取的應用場景數據庫,支持三種不同類型的存儲結構:靜態型、動態型、壓縮型。
  • InnoDB提供了具有提交、回滾和崩潰恢復能力的事務安全,支持自動增長列,支持外鍵約束。對比MyISAM引擎,InnoDB寫的處理效率會差一些,并且會占用更多的磁盤空間以保留數據和索引。

 

 

了解了MySQL常用的兩種存儲引擎之后,我們就來看看在這兩種引擎中如何進行數據備份和恢復。

MyISAM數據備份

因為MyISAM是保存成文件的形式,所以在備份時有多種方法可以使用,并且大多數虛擬主機提供商和INTERNET平臺提供商只允許使用MyISAM格式,掌握MyISAM數據備份就格外重要了。

方法1:文件拷貝

為了保持數據備份的一致性,我們可以對相關表執行LOCK TABLES操作,對表執行FLUSH TABLES。當然,你只需要限制寫操作,這樣能夠保證在復制數據時,其它操作仍然可以查詢表,而FLUSH TABLES是用來確保開始備份前將所有激活的索引頁寫入硬盤。

標準流程:鎖表、刷新表到磁盤、拷貝文件、解鎖。

方法2:SQL語句備份

SELECT INTO ...OUTFILE或BACKUP TABLE都可以進行SQL級別的表備份,需要注意的是這兩種方法如果有重名文件,***是先移除重名文件。另外,BACKUP TABLE備份需要注意輸出目錄的權限,改方法只是備份MYD和frm文件,不備份索引。

方法3: mysqlhotcopy 備份

mysqlhotcopy 是一個 Perl腳本,使用LOCK TABLES、FLUSH TABLES和cp或scp來快速備份數據庫,但其只能運行在數據庫目錄所在的機器上,且只用于備份MyISAM。

  1. shell> mysqlhotcopy db_name [/path/to/new_directory ] 
  2. shell> mysqlhotcopy db_name_1 ... db_name_n /path/to/new_directory 

方法4: mysqldump 備份

Mysqldump既可以備份表結構和數據,也可以備份單個表、單個庫或者所有庫,輸出是SQL語句文件或者是其它數據庫兼容的格式。在之前的文章中,我們較詳細的介紹了Mysqldump,本文就不再贅述了。

  1. shell> mysqldump [options] db_name [tables]  
  2. shell> mysqldump [options] ---database DB1 [DB2 DB3...] 
  3. shell> mysqldump [options] --all—database 

方法5:冷備份

冷備份的方法就很簡單粗暴了,在MySQL服務器停止服務時,復制所有表文件。

MyISAM數據備份恢復

不同的備份方式有相應的恢復方法:

  • 如果是mysqldump備份,恢復方法是mysql –u root < 備份文件名;
  • 如果是mysqlhotcopy或文件冷/熱拷貝備份,恢復方法是停止MySQL服務,并用備份文件覆蓋現有文件;
  • 如果是BACKUP TABLE備份,使用restore table來恢復;
  • 如果是SELECT INTO ...OUTFILE備份,使用load data恢復數據或mysqlimport命令。

InnoDB數據備份

MyISAM不支持事務和外鍵,這使得MySQL使用者往往會面臨一些挑戰,所以,理所當然的當InnoDB支持事務和外鍵時,即使它的速度較慢,也還是獲得了MySQL使用者的青睞。

方法1:mysqldump

是不是看著很眼熟,沒錯兒,上面MyISAM數據備份的方法其中之一就是它。Mysqldump也可以對InnoDB提供非物理的在線邏輯熱備份,使用方法和MyISAM類似。

方法2:copy file

InnoDB底層存儲的時候會將數據和元信息存在ibdata*, *.ibd, *.frm, *.ib_logfile*等文件中,所以備份了這些文件就相當于備份了InnoDB數據。

方法3:select into

與MyISAM用法一樣。

方法4:商業工具

InnoDB數據備份有很多商業工具可以使用,例如InnoDB Hotbackup,這是一個在線備份工具,即可以在InnoDB數據庫運行時備份InnoDB數據庫; ibbackup,將線上的my.cnf所指向的的數據內容備份到my.backup.cnf指向的數據目錄。

InnoDB數據備份恢復

在使用特定的恢復方法之前,InnoDB數據備份恢復還有兩個通用的方法,分別是InnoDB的日志自動恢復功能,即重啟mysql服務和“***大法”——重啟計算機。

  • 如果是mysqldump完全備份,先恢復完全備份,然后再恢復完全備份后的增量日志備份。
  • 如果是select into備份表,則采用load data或mysqlimport恢復。
  • 如果是copy file,那么就停止MySQL服務,備份文件覆蓋當前文件,并執行上次完全備份后的增量日志備份。
責任編輯:武曉燕 來源: 今日頭條
相關推薦

2010-05-21 15:53:30

2011-04-11 13:46:17

Oracle數據庫備份

2010-05-21 10:58:19

MySQL存儲引擎

2010-06-13 13:50:02

MySQL存儲引擎

2010-05-14 17:44:47

MySQL數據庫

2018-04-20 08:37:23

災難恢復數據備份

2011-03-25 13:43:56

CactiEZ備份

2025-04-17 03:30:00

MySQL數據備份

2017-07-10 14:26:03

Mysql數據備份數據恢復

2019-02-28 21:20:50

MySQL備份與恢復數據庫

2019-01-14 14:25:25

MySQL存儲邏輯架構

2018-06-14 10:44:59

MySQLMyISAMInnoDB

2010-05-21 16:10:28

2016-11-18 15:42:06

存儲

2016-10-19 16:50:43

大數據

2011-07-26 13:55:01

MongoDB備份與恢復

2017-09-06 08:23:01

數據備份恢復過程正確姿勢

2023-09-12 09:45:54

Java數據庫

2010-05-26 10:25:50

MySQLdump增量

2010-03-02 09:47:03

Fedora MySQ
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品99久久久久久人 | 亚洲成人精品影院 | 国产精品视频一区二区三区 | 国产精品亚洲精品日韩已方 | 欧美日韩电影一区 | 97色在线视频 | 欧美成人精品一区二区男人看 | 欧美日韩国产在线观看 | 亚洲综合电影 | 国产成人精品免高潮在线观看 | 玖玖综合在线 | 人成在线视频 | 一级全黄视频 | 天堂一区在线观看 | 精品在线一区二区 | 国产在线网址 | 久久久久国产一区二区三区四区 | 911网站大全在线观看 | 国产高潮av | 91在线一区二区 | 久久久久中文字幕 | 久久99精品视频 | 成人免费大片黄在线播放 | 日韩色在线 | 久久伊| 国产精品黄 | 久久精品一级 | 国产一区二区久久 | 精品一区二区免费视频 | 久久久久久久久久久福利观看 | 日本成人在线观看网站 | 亚洲二区在线 | 蜜桃精品噜噜噜成人av | 国产日韩欧美在线 | 亚洲一二视频 | 免费在线观看91 | 日韩在线视频免费观看 | 午夜精品久久久久久久星辰影院 | 91精品国产一区二区三区 | 一级毛片大全免费播放 | 亚洲国产精品99久久久久久久久 |