镜像数据库日志截断方法

镜像数据库如果主体数据库日志过大,可以在主体数据库上定时作日志备份(比如每天1次)
备份日志可以截断日志,让日志空间可以循环使用,这样可以使日志文件的大小不再增长。
具体步骤,在主体数据库上设置job,每天执行一次sql(不是镜像数据库):
BACKUP LOG 数据库名 TO DISK = 'h:\log20111122.bak'

执行完成后,日志文件大小并不会变小,只是文件使用率会下降


相关知识:
1、查看日志文件大小和使用率的sql
USE 数据库名
GO
SELECT name, data_space_id 文件组id, size/128 [文件大小(兆)],
    FILEPROPERTY(name, 'SpaceUsed')/128 [已用空间(兆)],
    size/128 - FILEPROPERTY(name, 'SpaceUsed')/128 [未用空间(兆)],
    FILEPROPERTY(name, 'SpaceUsed')*100.0/size [使用率(%)],
    max_size/128 [最大值(兆)], growth 增长值, is_percent_growth 是否百分比增长, physical_name 物理路径
FROM sys.database_files a

也可以用下面的sql查看日志文件使用率(注:要管理员才有权限,需要技术部去执行)
DBCC SQLPERF(LOGSPACE)
得到结果列如下:
Database Name    Log Size (MB)    Log Space Used (%)
数据库名         日志文件大小    日志文件使用率
这个使用率越小越好,备份日志后,使用率会降低,今天Newresourcedb数据库的日志变化情况:
09点 271385M   99.98%
执行日志备份,耗时3小时后变成
14点 272685M   47.93%
再执行日志备份,耗时1分钟后变成
15点 272685M   1.13%

2、镜像数据库选项的相关知识
数据库镜像概述
http://msdn.microsoft.com/zh-cn/library/ms189852.aspx
异步数据库镜像(高性能模式)
http://msdn.microsoft.com/zh-cn/library/ms187110(v=SQL.90).aspx
同步数据库镜像(高安全性模式)
http://msdn.microsoft.com/zh-cn/library/ms179344(v=SQL.90).aspx
同步和异步的主要区别就是
同步时,主数据库要等镜像数据库日志也写入磁盘后,才返回告诉我们成功
而异步,则是主数据库把日志发给镜像数据库,不等镜像响应,就返回告诉我们成功
 
3、 查表结构
 

create table #t(name varchar(255), rows bigint, reserved varchar(20), data varchar(20), index_size varchar(20), unused varchar(20))
exec sp_MSforeachtable "insert into #t exec sp_spaceused '?'"
select name as 表名,rows as  行数,
ltrim(str(convert(decimal(18,2),replace(reserved,' KB',''))/1024)) + 'MB' as 总分配磁盘空间,
ltrim(str(convert(decimal(18,2),replace(data,' KB',''))/1024)) + 'MB' as 数据占用磁盘空间,
ltrim(str(convert(decimal(18,2),replace(index_size,' KB',''))/1024)) + 'MB' as 索引占用磁盘空间,
unused as 可用空间
from #t  ORDER BY 行数 desc
select count(1) as 表数量,sum(rows) as 总行数,sum(convert(int,replace(reserved,' KB',''))/1024) as '总占用空间(MB)',sum(convert(int,replace(data,' KB',''))/1024) as '数据总占用空间(MB)',sum(convert(int,replace(index_size,' KB',''))/1024) as '索引总占用空间(MB)' from #t

 

 

转载于:https://www.cnblogs.com/llbofchina/p/3689367.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值