SQL SERVER BACKUP DATABASE 加快备份速度方法(压缩-Compression)
来源:互联网 发布:sql随机生成递增 编辑:程序博客网 时间:2024/04/28 02:50
很多SQL SERVER DBA 在备份的时候,一般的撰写格式,都是如下
BACKUP DATABASE AdventureWorks
TO DISK = 'Z:\SQLServerBackups\AdvWorksData.bak'
WITH FORMAT,CHECKSUM;
对于比较大的数据库,备份时间比较长,
最近在研究了BACKUP DATABASE 参数后,发现可以通过设置一下参数,加快备份速度:
1.备份的时候,设置多个备份集,比如
TO DISK = N'd:/1.bak',DISK = N'd:/2.bak',DISK = N'd:/3.bak',DISK = N'd:/4.bak'
2.使用BUFFERCOUNT 和MAXTRANSFERSIZE 选项。
- BUFFERCOUNT :指定用于备份操作的 I/O 缓冲区总数。可以指定任何正整数;但是,较大的缓冲区数可能导致由于 Sqlservr.exe 进程中的虚拟地址空间不足而发生“内存不足”错误。
缓冲区使用的总计空间由下面公式确定:buffercount*maxtransfersize。
- MAXTRANSFERSIZE :指定要在 SQL Server 和备份介质之间使用的最大传输单元(字节)。可能的值是 65536 字节 (64 KB) 的倍数,最多可到 4194304 字节 (4 MB)。
3.启用备份压缩选项(COMPRESSION)
该选项只在SQL Server 2008 Enterprise版本和SQL Server 2008 R2 Standard 以及所有更高版本都支持。
注意:压缩选项会需要额外的CPU资源,因此建议不要在系统繁忙时候使用。
4。做为DBA,你可能需要保证数据的安全,一般会加上校验和参数(CHECKSUM),保证数据安全。
测试比较:
数据库大小:53282.19 MB(包含日志文件)
数据文件大小是:32GB左右
使用标准备份方法:
BACKUP DATABASE [test]
TO DISK = N'd:/1.bak' WITH CHECKSUM;
需要用时04:08
使用优化参数的备份命令
BACKUP DATABASE [test]
TO DISK = N'D:\test_FULL_20110311_050001_1.bak',
DISK = N'D:\test_FULL_20110311_050001_2.bak',
DISK = N'D:\test_FULL_20110311_050001_3.bak',
DISK = N'D:\test_FULL_20110311_050001_4.bak'
WITH CHECKSUM, COMPRESSION, BUFFERCOUNT = 50, MAXTRANSFERSIZE = 4194304
备份用时:110.350 秒
速度提高了50%
如果不使用CHECKSUM参数,备份速度还可以更快,但是做为DBA,数据的安全是第一位的,因此推荐加上CHECKSUM参数。
以上提起的参数只适用于SQL SERVER 2005和SQL SERVER 2008
RESTORE DATABASE 语句也可以使用
BUFFERCOUNT和MAXTRANSFERSIZE 参数
- SQL SERVER BACKUP DATABASE 加快备份速度方法(压缩-Compression)
- SQL SERVER BACKUP DATABASE 加快备份速度方法(压缩-Compression)
- SQL SERVER BACKUP DATABASE 加快备份速度方法
- SAP SQL 压缩 Database compression for SQL Server
- 7.2 Database Backup Methods 数据备份方法:
- SQL Server 2005新特性,部分备份(partial backup)
- SQL Server 备份压缩
- 查看或配置 backup compression default 服务器配置选项(默认是否压缩备份)
- Javascript(加快脚本加载速度的方法:压缩脚本文件。)
- sql server BACKUP LOG database WITH NO_LOG Clean log
- How to backup and restore database in SQL Server
- SQL SERVER 2008 压缩备份
- 【SQL Server备份恢复】提高SQL Server备份速度
- 关于SQL Server还原错误:The backup set holds a backup of a database other than the existing database.
- 在MSDB中清除SQL Server 还原备份历史数据(Purging MSDB Backup and Restore History from SQL Server)
- SQL SERVER – Get Database Backup History for a Single Database
- 备份所有数据库 Backup all database
- sql server 2008中的备份压缩特性
- UINavigationController和UITabBarController合用。
- 如何启动到Windows 8安全模式
- 查询数据库大小
- 揭秘SQL Server 2000中的Bookmark Lookup--书签查找
- Beginning Jailbroken iOS Development - Building And Deployment
- SQL SERVER BACKUP DATABASE 加快备份速度方法(压缩-Compression)
- MABDlg.cpp : 实现文件 (QueryInterface,IMarkupServices,IMarkupPointer,IMarkupPointer2)
- flash调用js函数,IE6不执行的问题
- 保罗·格雷厄姆:如何获得创业点子?
- 悠着点,慢着点 ——“贫富与欲望”漫谈
- Web工程师必备的18款工具
- Beginning Jailbroken iOS Development - Your First Tweak
- 写给现在迷茫的自己
- STD map易错之下标插入元素