對(duì)于生產(chǎn)數(shù)據(jù)來(lái)講,數(shù)據(jù)的安全性是至關(guān)重要的,任何數(shù)據(jù)的丟失都可能產(chǎn)生嚴(yán)重的的后果。而備份作為數(shù)據(jù)的副本,可以在當(dāng)數(shù)據(jù)庫(kù)出現(xiàn)故障或者遭到破壞時(shí)可以根據(jù)備份的數(shù)據(jù)庫(kù)及事務(wù)日志文件還原到最近的時(shí)間點(diǎn)將損失降到最低點(diǎn)。
對(duì)于傳統(tǒng)的備份來(lái)講,一般都是使用數(shù)據(jù)庫(kù)自帶的備份或使用第三方的備份軟件將數(shù)據(jù)庫(kù)備份到本地的磁盤/磁帶存儲(chǔ),這種備份方式的前提是需要有一個(gè)大的存儲(chǔ)池用來(lái)按照備份文件的生命周期來(lái)存儲(chǔ)我們的備份文件。這就意味著我們需要準(zhǔn)備一個(gè)大的存儲(chǔ)池。考慮到準(zhǔn)備存儲(chǔ)池需要一定得資源,那么很多小伙伴肯定就會(huì)問(wèn)了,我能否將數(shù)據(jù)庫(kù)備份到云?答案是可以得。那么接下來(lái)我們就一起來(lái)聊聊如何將SQL Server數(shù)據(jù)庫(kù)備份到云端和備份到云端所帶來(lái)的好處。
將數(shù)據(jù)庫(kù)備份到azure storage的好處如下:
創(chuàng)新互聯(lián)建站堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的浚縣網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
但是需要注意將SQL Server備份到Azure Storage需要確保數(shù)據(jù)庫(kù)SQL Server 2012 SP1 CU2及以上版本。
說(shuō)了這么多,下面我們就一起來(lái)看一下,如何將數(shù)據(jù)庫(kù)備份到Azure Storage。
首先我們需要準(zhǔn)備一個(gè)存儲(chǔ)賬戶:
獲取access key,本次示例中我們使用access key的方式訪問(wèn)存儲(chǔ)賬戶:
使用如下T-SQL在SQL中創(chuàng)建賬戶:
IF NOT EXISTS(SELECT * FROM sys.credentials
WHERE credential_identity = ' bkuptour')
CREATE CREDENTIAL bkuptourl WITH IDENTITY = 'sql12bak', SECRET = '5amfZJpKLcR2lAfEBZod18VYbxZOPUbtKH9RowDQ3Ixv5sGMnSj5Lo/UbPb/zCCRKh/kAxnOaOS9oJELTVVoTg==';
創(chuàng)建完成后我們可以在存儲(chǔ)賬戶中創(chuàng)建一個(gè)container用來(lái)存儲(chǔ)備份文件:
創(chuàng)建完成以后可以使用如下T-SQL將數(shù)據(jù)庫(kù)備份到Storage Account中:
DECLARE @DB_name VARCHAR(50) -- database name
DECLARE @BackupLoc VARCHAR(256) -- path for backup files
DECLARE @BackupfileName VARCHAR(256) -- filename for backup
DECLARE @fileDate VARCHAR(20) -- used for file name
-- specify database backup container location
SET @BackupLoc = 'https://sql12bak.blob.core.chinacloudapi.cn/test/'
set @fileDate= replace(replace(convert(nvarchar(50),getdate()),' ','_'),':','_')
DECLARE db_cursor CURSOR FOR
SELECT name FROM master.sys.databases WHERE database_id <>2 and state=0
OPEN db_cursor
FETCH NEXT FROM db_cursor INTO @DB_name
WHILE @@FETCH_STATUS = 0
BEGIN
SET @BackupfileName = @BackupLoc + @DB_name + '_' + @fileDate + '.BAK'
BACKUP DATABASE @DB_name TO URL = @BackupfileName WITH CREDENTIAL = 'bkuptourl',COMPRESSION
print 'BACKUP DATABASE '+@DB_name+ ' TO URL ='''+ @BackupfileName +''' WITH CREDENTIAL = ''bkuptourl'',COMPRESSION '
FETCH NEXT FROM db_cursor INTO @DB_name
END
CLOSE db_cursor
DEALLOCATE db_cursor
備份完成,如下圖所示: