《Mysql實例如何恢復(fù)Mysql數(shù)據(jù)庫的詳細介紹》要點:
本文介紹了Mysql實例如何恢復(fù)Mysql數(shù)據(jù)庫的詳細介紹,希望對您有用。如果有疑問,可以聯(lián)系我們。
MYSQL必讀由于在一臺測試機器上打算重新安裝Mysql數(shù)據(jù)庫,由于簡單粗暴的直接卸載了,沒有備份公司Discuz和Redmine使用的Mysql數(shù)據(jù)庫,過程可想的悲涼.
MYSQL必讀還好的是只是卸載掉了Mysql的法式,所有的數(shù)據(jù)文件還是存在的.
MYSQL必讀下面是在規(guī)復(fù)數(shù)據(jù)庫的過程
MYSQL必讀1. Discuz數(shù)據(jù)庫
MYSQL必讀Discuz數(shù)據(jù)庫的恢復(fù)非常順利, 在安裝好新版本的Mysql后,直接將本來的數(shù)據(jù)庫文件copy到新的數(shù)據(jù)目錄中,重新啟動mysql, 就能看到恢復(fù)的數(shù)據(jù)庫了
MYSQL必讀2. Redmine數(shù)據(jù)庫
MYSQL必讀本打算直接使用上面的經(jīng)驗,也能看到所有的表,但是便是執(zhí)行查詢的時候,總是報錯"表不存在".
MYSQL必讀后來查了一些資料,發(fā)現(xiàn),原因應(yīng)該是Discuz和Redmine使用的Mysql引擎紛歧樣導(dǎo)致的.
MYSQL必讀Discuz使用的是MyISAM, 而Redmine使用的是InnoDB.
MYSQL必讀解決的方法是,
MYSQL必讀除了要copy數(shù)據(jù)目錄外,還要記得覆蓋ibdata1文件.
以表”Table”為例: 如類型是MyISAM, 數(shù)據(jù)文件則以”Table.frm””Table.MYD””Table.MYI””三個文件存儲于”/data/$databasename/”目錄中. 如類型是InnoDB, 數(shù)據(jù)文件則存儲在”$innodb_data_home_dir/″中的ibdata1文件中(一般情況),結(jié)構(gòu)文件存在于table_name.frm中. MySQL的數(shù)據(jù)庫文件直接復(fù)制便可以使用,但是那是指“MyISAM”類型的表. 而使用MySQL-Front直接創(chuàng)建表,默認是“InnoDB”類型,這種類型的一個表在磁盤上只對應(yīng)一個“*.frm”文件,不像MyISAM那樣還“*.MYD,*.MYI”文件. MyISAM類型的表直接拷到另一個數(shù)據(jù)庫就可以直接使用,但是InnoDB類型的表卻不行.解決辦法就是:
MYSQL必讀同時拷貝innodb數(shù)據(jù)庫表“*.frm”文件和innodb數(shù)據(jù)“ibdata1”文件到合適的位置.啟動MySQL的Windows服務(wù) 由于MySQL這樣數(shù)據(jù)混雜的形式, 往往很容易讓使用者在備份時忘記了備份InnoDB, 從而導(dǎo)致了上述差錯.
MYSQL必讀意思就是說在數(shù)據(jù)庫引擎類型為InnoDB時,拷貝數(shù)據(jù)文件的同時還必要拷貝ibdata1,于是把ibdata1也拷貝過去覆蓋,發(fā)現(xiàn)還是有點問題,于是停止mysql服務(wù),將目錄下的ib_logfile*文件全部刪除掉,重新啟動mysql服務(wù),well done,可以了
MYSQL必讀高興啊,于是稍微總結(jié)了,希望以后遇到相同的問題,能夠快速辦理.
MYSQL必讀1,在進行mysql數(shù)據(jù)庫備份的或遷移的時候,盡量備份完成所必要的數(shù)據(jù);
MYSQL必讀2,如果直接拷貝原有數(shù)據(jù)庫文件"*.frm"、"*.MYD"、"*.MYI"等文件時候,如果原數(shù)據(jù)庫引擎是InnoDB,牢記還需拷貝ibdata1文件
MYSQL必讀3,備份數(shù)據(jù)庫的時候,最好是用相關(guān)的對象進行備份或是導(dǎo)出sql文件,以免浪費時間在數(shù)據(jù)庫恢復(fù)上
MYSQL必讀4,msyql版本或是備份工具的版本分歧,也可能引起數(shù)據(jù)恢復(fù)有問題.
MYSQL必讀實踐證明以上問題是存在的,辦理方案是可行的,哈哈,為了以后方便,寫了這篇博客隨筆,希望大牛看到了不要鄙視,歡迎拍磚.
MYSQL必讀?1:MyISAM類型的數(shù)據(jù)文件可以在不同操作系統(tǒng)中COPY,這點很重要,布署的時候方便點.(只必要拷貝 數(shù)據(jù)庫名字文件夾下面的文件,這樣數(shù)據(jù)庫就拷貝完了)
MYSQL必讀2:? InnoDB類型的 要注意多拷貝 ibdata1 , 最好不要是間接復(fù)制文件夾,而是應(yīng)該用sql導(dǎo)入導(dǎo)出
歡迎參與《Mysql實例如何恢復(fù)Mysql數(shù)據(jù)庫的詳細介紹》討論,分享您的想法,維易PHP學院為您提供專業(yè)教程。
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/9546.html