您好,登錄后才能下訂單哦!
對于生產數據來講,數據的安全性是至關重要的,任何數據的丟失都可能產生嚴重的的后果。而備份作為數據的副本,可以在當數據庫出現故障或者遭到破壞時可以根據備份的數據庫及事務日志文件還原到最近的時間點將損失降到最低點。
對于傳統的備份來講,一般都是使用數據庫自帶的備份或使用第三方的備份軟件將數據庫備份到本地的磁盤/磁帶存儲,這種備份方式的前提是需要有一個大的存儲池用來按照備份文件的生命周期來存儲我們的備份文件。這就意味著我們需要準備一個大的存儲池。考慮到準備存儲池需要一定得資源,那么很多小伙伴肯定就會問了,我能否將數據庫備份到云?答案是可以得。那么接下來我們就一起來聊聊如何將SQL Server數據庫備份到云端和備份到云端所帶來的好處。
將數據庫備份到azure storage的好處如下:
但是需要注意將SQL Server備份到Azure Storage需要確保數據庫SQL Server 2012 SP1 CU2及以上版本。
說了這么多,下面我們就一起來看一下,如何將數據庫備份到Azure Storage。
首先我們需要準備一個存儲賬戶:
獲取access key,本次示例中我們使用access key的方式訪問存儲賬戶:
使用如下T-SQL在SQL中創建賬戶:
IF NOT EXISTS(SELECT * FROM sys.credentials
WHERE credential_identity = ' bkuptour')
CREATE CREDENTIAL bkuptourl WITH IDENTITY = 'sql12bak', SECRET = '5amfZJpKLcR2lAfEBZod18VYbxZOPUbtKH9RowDQ3Ixv5sGMnSj5Lo/UbPb/zCCRKh/kAxnOaOS9oJELTVVoTg==';
創建完成后我們可以在存儲賬戶中創建一個container用來存儲備份文件:
創建完成以后可以使用如下T-SQL將數據庫備份到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
備份完成,如下圖所示:
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。