Azure Backup (1) 将SQL Server 2012虚拟机中数据库备份到Azure Storage

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
简介:

 《Windows Azure Platform 系列文章目录

 

  本文介绍的是由国内世纪互联运维的China Azure,相比国外的Global Azure。主要区别是存储账号的DNS地址不同,请读者注意区别。

 

  最近有一个客户想了解,如何将SQL Server 2012虚拟机中的数据库备份到Azure Storage存储账号中,笔者研究了一下,分享给大家。

  前提要求:

  1.需要1台安装了SQL Server 2012 SP1 CU4以上的Windows Server虚拟机

  2.需要有Azure China的账户和订阅

 

  注意事项:

  1.保存到Azure Storage的数据库备份BAK文件,最大不能超过200GB,是单个Block Blob的最大容量限制

  2.如果数据库备份BAK文件超过了200GB,可以考虑后续做差异备份

  3.在同一个存储账号下的所有BAK文件,数量是没有上限的,但是所有的BAK总容量不能超过500TB,这是Azure Storage Account存储账号的容量限制

  

  实现方式:

  1.创建Azure Storage Account存储账号和Container

  2.执行相应的T-SQL语句,进行数据库的全备份

  3.设置SQL Server Job

 

  接下来我们详细介绍一下:

  1.首先我们登陆Azure China管理界面 https://manage.windowsazure.cn

  2.创建新的存储账号,命名为leidbbak,如下图:

  

  注意上面的存储账号所在的位置,最好和SQL Server虚拟机所在的数据中心位置保持一致,加快数据库文件备份速度。

 

  3.在该存储账号下,创建Container,命名为dbcontainer。注意设置Access为Private,不允许匿名访问

  

  4.然后我们通过远程桌面连接,连接到安装了SQL Server 2012 SP1 CU4以上的Windows Server虚拟机

  打开本地的SQL Server Management  Studio。首先创建credentials。命令如下:

IF NOT EXISTS
(SELECT * FROM sys.credentials 
WHERE credential_identity = 'BackupDBtoAzureStorageCredential')
CREATE CREDENTIAL BackupDBtoAzureStorageCredential WITH IDENTITY = '[存储账号名称]'
,SECRET = '[存储账号密钥]' ;

  执行完毕后,我们可以通过命令:

SELECT * FROM sys.credentials 

  查看在sys.credentials表中,创建的Credential。

  如果需要删除Credential,我们可以通过命令:

DROP CREDENTIAL [CredentialName]

  删除不需要的Credential

 

  5.然后我们执行以下T-SQL语句,如下:

复制代码
declare @url varchar(256) 
set @url= 'https://leidbbak.blob.core.chinacloudapi.cn/dbcontainer/'+ CONVERT(nvarchar(8), GETDATE(), 112)+ '-AdventureWorks2008.bak'

BACKUP DATABASE AdventureWorks2008
TO URL = @url
      WITH CREDENTIAL = 'BackupDBtoAzureStorageCredential' 
     ,COMPRESSION
     ,STATS = 5;
GO 
复制代码

  我们备份本地数据库名字为AdventureWorks2008

  注意上面的@url这个参数,我们保存到之前步骤3中创建的Container。

  并且通过CONVERT(nvarchar(8), GETDATE(), 112),将bak文件名,按照YYYYMMDD的格式进行重命名

 

  6.执行上面的T-SQL语句后,可以查看到T-SQL执行成功。

  我们回到Azure管理界面,查看存储账号,可以看到数据库备份成功。

  

  

  7.最后我们将步骤5中的T-SQL语句,通过SQL Server Job,每天执行一次。这样每天就可以自动把数据库备份到Azure Storage Account,并且重命名。

 

  8.读者可以根据需要,修改步骤5中的T-SQL语句,可以按照一定规律,将差异备份、或者是日志备份,保存到Azure Storage中。

 

  9.最后一步,如果我们定期备份数据以后,希望把老旧的数据删除的话,可以用Azure Automation实现,具体参考这篇blog:

      Azure Automation (2) 定期删除存储账号中的文件

 

  参考资料:https://msdn.microsoft.com/en-us/library/jj919148(v=sql.110).aspx 

 


本文转自Lei Zhang博客园博客,原文链接:http://www.cnblogs.com/threestone/p/4668608.html,如需转载请自行联系原作者

目录
相关文章
|
存储 关系型数据库 MySQL
mysql数据库备份与恢复
MySQL数据库的备份与恢复是确保数据安全性和业务连续性的关键操作。
576 4
|
8月前
|
SQL 自然语言处理 数据库
【Azure Developer】分享两段Python代码处理表格(CSV格式)数据 : 根据每列的内容生成SQL语句
本文介绍了使用Python Pandas处理数据收集任务中格式不统一的问题。针对两种情况:服务名对应多人拥有状态(1/0表示),以及服务名与人名重复列的情况,分别采用双层for循环和字典数据结构实现数据转换,最终生成Name对应的Services列表(逗号分隔)。此方法高效解决大量数据的人工处理难题,减少错误并提升效率。文中附带代码示例及执行结果截图,便于理解和实践。
223 4
|
9月前
|
存储 关系型数据库 分布式数据库
PolarDB开源数据库进阶课5 在线备份
本文介绍了如何在PolarDB RAC一写多读集群中进行在线备份,特别针对共享存储模式。通过使用`polar_basebackup`工具,可以将实例的本地数据和共享数据备份到本地盘中。实验环境依赖于Docker容器中用loop设备模拟的共享存储。
268 1
|
7月前
|
存储 关系型数据库 MySQL
利用Cron表达式实现MySQL数据库的定时备份
以上就是如何使用Cron表达式和mysqldump命令实现MySQL数据库的定时备份。这种方法的优点是简单易用,而且可以根据需要定制备份的时间和频率。但是,它也有一些限制,例如,它不能备份MySQL服务器的配置文件和用户账户信息,也不能实现增量备份。如果需要更复杂的备份策略,可能需要使用专门的备份工具或服务。
193 15
|
8月前
|
关系型数据库 Shell 网络安全
定期备份数据库:基于 Shell 脚本的自动化方案
本篇文章分享一个简单的 Shell 脚本,用于定期备份 MySQL 数据库,并自动将备份传输到远程服务器,帮助防止数据丢失。
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
715 3
|
监控 关系型数据库 MySQL
Linux环境下MySQL数据库自动定时备份策略
在Linux环境下,MySQL数据库的自动定时备份是确保数据安全和可靠性的重要措施。通过设置定时任务,我们可以每天自动执行数据库备份,从而减少人为错误和提高数据恢复的效率。本文将详细介绍如何在Linux下实现MySQL数据库的自动定时备份。
343 3
|
存储 定位技术 数据库
介绍一下数据库的备份和恢复策略
【10月更文挑战第21】介绍一下数据库的备份和恢复策略
|
关系型数据库 MySQL 数据库
Navicat备份数据库
涵盖`Navicat`数据库备份、数据安全及备份策略等主题。文库采用精美主题,提升阅读体验。
293 1
Navicat备份数据库
|
数据库
【赵渝强老师】数据库的备份方式
备份数据库是指将数据库中的数据及相关信息保存起来,以便在系统故障时恢复。备份对象不仅限于数据本身,还包括数据库对象、用户权限等。根据备份策略、类型和模式的不同,可分为整体/部分备份、完全/增量备份、一致/非一致备份。文中还附有相关视频讲解。
178 0