执行环境:windows server2003,sql
server2008 R2,数据库上布置CDC

 

用户反应系统报错是日志已满,系统不能执行。

查看日志文件时。发现日志文件已经达到15G,后来为了解决这个问题,干脆把数据库移到还有一个F盘,D盘专门放日志文件。空间有80G。

当时想这80G至少保证系统执行一周吧。谁知道系统刚执行两天。日志文件已爆涨到80G,D盘空间仅剩余10MB。数据库做不论什么动作都不能够。

重新为了应急把日志文件直接删除(先停掉服务,删除日所文件,再通过DBCC
CheckDB()命令检查数据库一致性问题),系统恢复了正常。

这时空间是有了,可是问题依然没有解决。可是日志文件依然猛涨。曾经用的截断和收缩日志方法全然不起作用?

 

解决方法:

步骤一:

查看日志信息,在查询分析器中执行例如以下代码来查看日志信息:

DBCC LOGINFO('数据库名称')

能够看到status=0的日志,代表已经备份到磁盘的日志文件;而status=2的日志还没有备份。当收缩日志文件时,收缩掉的空间事实上就是 status=0的空间,假设日志物理文件无法减小,这里一定能看到许多status=2的记录。

 

步骤二:

查看日志不能截断原因

活跃(active)的日志无法通过收缩来截断。有各种原因会使日志截断延迟,详细表现就是事务日志的物理文件无法通过截断、收缩来减小,通过以下的代码能够看到实例上每一个数据库的日志截断延迟原因:

usemaster

go

select*from
sys.databases

发现当前数据库的log_reuse_wait_desc的值为REPLICATION,其它数据库的log_reuse_wait_desc值为LOG_BACKUP、NOTHING…

 

 

log_reuse_wait_desc值的各种原因及解释例如以下:

NOTHING

当前有一个或多个可反复使用的虚拟日志文件。

 

CHECKPOINT

自上次日志截断之后。尚未出现检查点,或者日志头部尚未跨一个虚拟日志文件移动(全部恢复模式)。这是日志截断延迟的常见原因。

 

LOG_BACKUP

须要日志备份,以将日志的头部前移(仅适用于完整恢复模式或大容量日志恢复模式)。

注意:日志备份不会妨碍截断。

完毕日志备份后。日志的头部将前移。一些日志空间可能变为可反复使用。

 

ACTIVE_BACKUP_OR_RESTORE

数据备份或还原正在进行(全部恢复模式)。

数据备份与活动事务的执行方式同样。数据备份在执行时,将阻止截断。

 

ACTIVE_TRANSACTION

事务处于活动状态(全部恢复模式)。一个长时间执行的事务可能存在于日志备份的开头。

在这样的情况下,可能须要进行还有一个日志备份才干释放空间。

事务被延迟(仅适用于 SQL Server 2005 Enterprise Edition及更高版本号)。

“延迟的事务” 是有效的活动事务,由于某些资源不可用,其回滚受阻。

 

DATABASE_MIRRORING

数据库镜像暂停,或者在高性能模式下,镜像数据库明显滞后于主体数据库(仅限于完整恢复模式)。

 

REPLICATION

在事务复制过程中,与公布相关的事务仍未传递到分发数据库(仅限于完整恢复模式)。

 

DATABASE_SNAPSHOT_CREATION

正在创建数据库快照(全部恢复模式)。

这是日志截断延迟的常见原因,通常也是主要原因。

 

LOG_SCAN

正在进行日志扫描(全部恢复模式)。

这是日志截断延迟的常见原因。通常也是主要原因。

 

针对延迟日志截断原因的部分解决方式,

LOG_BACKUP

备份日志后再执行收缩就可以。

 

REPLICATION

这是我遇到的情况,但我根本没有启用过REPLICATION。是已离职同事原来创建一个复制数据库,后来没有删除干净而导致。还有还有一说法,这好像是SQLSERVER2008的一个BUG,解决方法是给标有“REPLICATION”的数据库随意一个表创建数据库事务复制(TRANSACTIONREPLICATION)。然后再删除,执行数据库与日志备份后,经常使用以下的日志收缩方法就能够完毕收缩:

USE [master]
GO
ALTER DATABASE 数据库名 SET RECOVERY SIMPLE WITH NO_WAIT
GO
ALTER DATABASE 数据库名 SET RECOVERY SIMPLE --简单模式
GO USE 数据库名
GO
DBCC SHRINKFILE (N'数据库名_Log' , 5, TRUNCATEONLY) -->參数二(5)就是压缩到指定大小
GO USE [master]
GO
ALTER DATABASE 数据库名 SET RECOVERY FULL WITH NO_WAIT
GO
ALTER DATABASE 数据库名 SET RECOVERY FULL --还原为全然模式
GO

 

附加:在创建数据库复制时,我也遇到了一个大麻烦,提示:在执行 xp_cmdshell 的过程中出错。调用 'CreateProcess' 失败,错误代码: '5'。使用了各种方法,均无效果。后来在网上找一个帖子说有可能是系统安装360的原因而导致,我就把把360先停掉,结果真的解决这个问题了。

 

 

SQL 2008 R2数据库变为REPLICATION,日志不断增长并且不能截断和收缩的解决方式的更多相关文章

  1. SQL 2008 R2 数据库镜像操作

    镜像操作请参考:http://blog.csdn.net/dba_huangzj/article/details/35995083 应用程序数据库连接字符串(带见证服务器即自动故障转移): DBHel ...

  2. sql 2008 R2添加对MySql的远程服务器链接

    (1).我的sql 2008 R2所在的系统为Windows server 2008 *64 (2).MySQL所在的系统为Windows server 2003 *86 我想要实现的是在sql 20 ...

  3. SQL Server 2008 R2数据库镜像部署

    概述 “数据库镜像”是一种针对数据库高可用性的基于软件的解决方案.其维护着一个数据库的两个相同的副本,这两个副本分别放置在不同的SQL Server数据库实例中.建议使用不同位置的两台服务器来承载.在 ...

  4. SQL Server 2008 R2数据库镜像部署图文教程

    数据库镜像是一种针对数据库高可用性的基于软件的解决方案.其维护着一个数据库的两个相同的副本,这两个副本分别放置在不同的SQL Server数据库实例中 概述 “数据库镜像”是一种针对数据库高可用性的基 ...

  5. SQL Server 2008 R2 数据库安装

    操作系统    Windows server 2008 R2 数据库      SQL Server 2008 R2 注意:SQL Server 2008 R2需要操作系统首先安装.NET Frame ...

  6. Vcenter虚拟化三部曲----SQL Server 2008 R2 数据库安装

    操作系统    Windows server 2008 R2 数据库      SQL Server 2008 R2 注意:SQL Server 2008 R2需要操作系统首先安装.NET Frame ...

  7. 如何修改SQL Server 2008 R2数据库的内存

    本篇经验将和大家介绍如何修改SQL Server 2008 R2数据库的内存,希望对大家的工作和学习有所帮助! 工具/原料   SQL Sever 2008 R2数据库已安装 方法/步骤   1 打开 ...

  8. SQL Server2008 R2 数据库镜像实施手册(双机)SQL Server2014同样适用

    这篇文章主要介绍了SQL Server2008 R2 数据库镜像实施手册(双机)SQL Server2014同样适用,需要的朋友可以参考下 一.配置主备机 1. 服务器基本信息 主机名称为:HOST_ ...

  9. SQL 2008升级SQL 2008 R2完全教程或者10.00.1600升级10.50.1600

    http://blog.csdn.net/feng19821209/article/details/8571571 SQL 2008升级SQL 2008 R2完全教程或者10.00.1600升级10. ...

随机推荐

  1. CentOS 7挂载磁盘提示: mount: unknown filesystem type 'LVM2_member'

    说明:CentOS 7采用新的分区格式xfs以及LVM的模式,造成挂载硬盘的方式有变化. 解决: 使用lvdisplay命令查看LVM最终的卷路径,然后再进行挂载. 比如: mount /dev/Vo ...

  2. ZOJ3673:1729

    1729 is the natural number following 1728 and preceding 1730. It is also known as the Hardy-Ramanuja ...

  3. 配置NGINX支持中文URL 中文文件名称或文件夹404无法訪问的解决方法

    NGINX不须要象apache那样要单独载入支持中文模块. # cat /etc/sysconfig/i18n  LANG="en_US.UTF-8" SYSFONT=" ...

  4. linux系统负载相关的概念和度量

    系统负载有 CPU利用率 和 LoadAverage这2个概念. cpu利用率:cpu utilization,是进程(task)被内核调度进程实际分配了CPU资源后,在时间片内使用CPU进行工作运算 ...

  5. UI----------------Toggle

    Is On:是否已经勾选上了 Toggle Transition:渐变效果 Graphic:勾选标志的图,就是那个勾 Group:多选组 On Value Changed:当选项改变时,触发事件 多选 ...

  6. POPSpring动画参数详解

    POPSpring动画参数详解 效果 源码 https://github.com/YouXianMing/Animations // // POPSpringParameterController.m ...

  7. [转]C++之运算符重载(1)

    在前一节中曾提到过,C++中运行时的多态性主要是通过虚函数来实现的,而编译时的多态性是由函数重载和运算符重载来实现的.这一系列我将主要讲解C++中有关运算符重载方面的内容.在每一个系列讲解之前,都会有 ...

  8. 线程池的corePoolSize、maximumPoolSize和poolSize

    什么是线程池: 为了避免系统频繁的创建和销毁线程,我们可以将创建的线程进行复用.在线程池中总有那么几个活跃的线程,也有一定的最大值限制,一个业务使用完线程之后,不是立即销毁而是将其放入到线程池中,从而 ...

  9. C++用iconv进行页面字符转换

    在对HTML页面进行爬取时,总会遇到一些不同的编码,而我们通常都不会一一对这些编码进行处理,而是集体转换成相同的编码,也易于装入数据库.此时,iconv便成为一个很方便的工具. iconv 头文件&q ...

  10. Informatica 常用组件Lookup之十 创建查找转换

    在 Mapping Designer 中选择"转换-创建".选择查找转换.输入转换名称.查找转换的命名惯例是 LKP_TransformationName.单击"确定&q ...