国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区

掃一掃
關(guān)注微信公眾號(hào)

數(shù)據(jù)庫安全:當(dāng)SQL Server數(shù)據(jù)庫崩潰時(shí)如何恢復(fù)
2008-04-24   

任何數(shù)據(jù)庫系統(tǒng)都無法避免崩潰的狀況,即使你使用了Clustered,雙機(jī)熱備……仍然無法完全根除系統(tǒng)中的單點(diǎn)故障,何況對(duì)于大部分用戶來說,無法承受這樣昂貴的硬件投資。所以,在系統(tǒng)崩潰的時(shí)候,如何恢復(fù)原有的寶貴數(shù)據(jù)就成為一個(gè)極其重要的問題了。

在恢復(fù)的時(shí)候,最理想的情況就是你的數(shù)據(jù)文件和日志文件都完好無損了,這樣只需要sp_attach_db,把數(shù)據(jù)文件附加到新的數(shù)據(jù)庫上即可,或者在停機(jī)的時(shí)候把所有數(shù)據(jù)文件(一定要有master等)都copy到原有路徑下也行,不過一般不推薦這樣的做法,sp_attach_db比較好,雖然麻煩許多。

但是呢,一般數(shù)據(jù)庫崩潰的時(shí)候系統(tǒng)是未必能有時(shí)間把未完成的事務(wù)和臟頁等寫入磁盤的,這樣的情況sp_attach_db就會(huì)失敗。那么,寄期望于DBA制定了一個(gè)良好的災(zāi)難恢復(fù)計(jì)劃吧。按照你的恢復(fù)計(jì)劃,還原最新的完全備份,增量備份或者事務(wù)日志備份,然后如果你的活動(dòng)事務(wù)日志還能讀得出來的話,恭喜你!你可以還原到崩潰前的狀態(tài)。

一般的單位都是沒有專職的DBA的,如果沒有可用的備份,更可能是最近一次備份的時(shí)間過于久遠(yuǎn)而導(dǎo)致不可接受的數(shù)據(jù)損失,而且你的活動(dòng)事務(wù)日志也處于不可用的狀態(tài),那就是最麻煩的情況了。

不幸的很的是,一般數(shù)據(jù)庫崩潰都是由于存儲(chǔ)子系統(tǒng)引起的,而這樣的情況是幾乎不可能有可用的日志用于恢復(fù)的。

那么就只好試一下這些方案了。當(dāng)然,是要求至少你的數(shù)據(jù)文件是存在的,要是數(shù)據(jù)文件、日志文件和備份都沒有了的話,別找我,你可以到樓頂上去唱“神啊,救救我吧”。

首先,你可以試一下sp_attach_single_file_db,試著恢復(fù)一下你的數(shù)據(jù)文件?淙荒芑指吹目贍芐圓淮螅?還?偃繒飧鍪?菘飧蘸彌蔥辛艘桓鯿heckpoint的話,還是有可能成功的。

如果你沒有好到有摸彩票的手氣,最重要的數(shù)據(jù)庫沒有像你期盼的那樣attach上去,不要?dú)怵H,還是有別的方案的。

我們可以試著重新建立一個(gè)log,先把數(shù)據(jù)庫設(shè)置為emergency mode,sysdatabases的status為32768 就表示數(shù)據(jù)庫處于此狀態(tài)。

不過系統(tǒng)表是不能隨便改的,設(shè)置一下先 Use Master Go sp_configure allow updates, 1 reconfigure with override Go 然后 update sysdatabases set status = 32768 where name =

現(xiàn)在,祈求滿天神佛的保佑吧,重新建立一個(gè)log文件。成功的機(jī)會(huì)還是相當(dāng)大的,系統(tǒng)一般都會(huì)認(rèn)可你新建立的日志。如果沒有報(bào)告什么錯(cuò)誤,現(xiàn)在就可以松一口氣了。

雖然數(shù)據(jù)是恢復(fù)了,可是別以為事情就算完成了,正在進(jìn)行的事務(wù)肯定是丟失了,原來的數(shù)據(jù)也可能受到一些損壞。

先把SQL Server 重新啟動(dòng)一下,然后檢查你的數(shù)據(jù)庫吧。 先設(shè)置成單用戶模式,然后做dbcc sp_dboption , single user, true DBCC CHECKDB()

如果沒有什么大問題就可以把數(shù)據(jù)庫狀態(tài)改回去了,記得別忘了把系統(tǒng)表的修改選項(xiàng)關(guān)掉。 update sysdatabases set status = 28 where name = --當(dāng)然你的數(shù)據(jù)庫狀態(tài)可能不是這個(gè),自己改為合適的值吧。也可以用sp_resetstatus go sp_configure allow updates, 0 reconfigure with override Go

checkdb的時(shí)候可能報(bào)告有一些錯(cuò)誤,這些錯(cuò)誤的數(shù)據(jù)你可能就只好丟棄了。

checkdb有幾種修復(fù)選項(xiàng),自己看著用吧,不過最后你可能還是得REPAIR_ALLOW_DATA_LOSS,完成所有修復(fù)。

chekcdb并不能完成所有的修復(fù),我們需要更進(jìn)一步的修復(fù),用DBCC CHECKTABLE對(duì)每一個(gè)表做檢查吧。

表的列表可以用sysobjects里面得到,把OBJECTPROPERTY是IsTable的全部找出來檢查一下吧,這樣能夠基本上解決問題了,如果還報(bào)告錯(cuò)誤,試著把數(shù)據(jù)select into到另一張表檢查一下。

 

熱詞搜索:

上一篇:防范SQL指令植入式攻擊
下一篇:MySQL中密碼及訪問限制設(shè)置

分享到: 收藏
主站蜘蛛池模板: 交城县| 修武县| 鹤庆县| 阿瓦提县| 塔城市| 夹江县| 留坝县| 永平县| 新河县| 广州市| 利辛县| 濉溪县| 青浦区| 隆昌县| 永顺县| 磴口县| 读书| 马尔康县| 二连浩特市| 江津市| 宽城| 桃江县| 扬州市| 汉源县| 宜阳县| 扎兰屯市| 花莲县| 民乐县| 恩施市| 白水县| 双牌县| 青海省| 奉化市| 全椒县| 乐安县| 长垣县| 孟连| 锡林浩特市| 东源县| 齐齐哈尔市| 增城市|