设为首页 收藏本站
查看: 650|回复: 0

[经验分享] SQL SERVER 日志已满的处理方法

[复制链接]

尚未签到

发表于 2018-10-12 06:33:18 | 显示全部楼层 |阅读模式
事务日志文件Transaction Log File是用来记录数据库更新情况的文件,扩展名为ldf。  在 SQL Server 7.0 和 SQL Server 2000 中,如果设置了自动增长功能,事务日志文件将会自动扩展。
  一般情况下,在能够容纳两次事务日志截断之间发生的最大数量的事务时,事务日志的大小是稳定的,事务日志截断由检查点或者事务日志备份触发。
  然而,在某些情况下,事务日志可能会变得非常大,以致用尽空间或变满。通常,在事务日志文件占尽可用磁盘空间且不能再扩展时,您将收到如下错误消息:
  Error:9002, Severity:17, State:2
  The log file for database ’%.*ls’ is full.
  除了出现此错误消息之外,SQL Server 还可能因为缺少事务日志扩展空间而将数据库标记为 SUSPECT。有关如何从此情形中恢复的其他信息,请参见 SQL Server 联机帮助中的“磁盘空间不足”主题。
  另外,事务日志扩展可能导致下列情形:
  · 非常大的事务日志文件。
  · 事务可能会失败并可能开始回滚。
  · 事务可能会用很长时间才能完成。
  · 可能发生性能问题。
  · 可能发生阻塞现象。
  原因
  事务日志扩展可能由于以下原因或情形而发生:
  · 未提交的事务
  · 非常大的事务
  · 操作:DBCC DBREINDEX 和 CREATE INDEX
  · 在从事务日志备份还原时
  · 客户端应用程序不处理所有结果
  · 查询在事务日志完成扩展之前超时,您收到假的“Log Full”错误消息
  · 未复制的事务
  解决方法
  日志文件满而造成SQL数据库无法写入文件时,可用两种方法:
  一种方法:清空日志。
  1.打开查询分析器,输入命令
  DUMP TRANSACTION 数据库名 WITH NO_LOG
  2.再打开企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了。
  另一种方法有一定的风险性,因为SQL SERVER的日志文件不是即时写入数据库主文件的,如处理不当,会造成数据的损失。
  1: 删除LOG
  分离数据库 企业管理器->服务器->数据库->右键->分离数据库
  2:删除LOG文件
  附加数据库 企业管理器->服务器->数据库->右键->附加数据库
  此法生成新的LOG,大小只有500多K。
  注意:建议使用第一种方法。
  如果以后,不想要它变大。
  SQL2000下使用:
  在数据库上点右键->属性->选项->故障恢复-模型-选择-简单模型。
  或用SQL语句:
  alter database 数据库名 set recovery simple
  另外,如上图中数据库属性有两个选项,与事务日志的增长有关:
  Truncate log on checkpoint
  (此选项用于SQL7.0,SQL 2000中即故障恢复模型选择为简单模型)
  当执行CHECKPOINT 命令时如果事务日志文件超过其大小的70% 则将其内容清除在开发数据库时时常将此选项设置为True
  Auto shrink
  定期对数据库进行检查当数据库文件或日志文件的未用空间超过其大小的25%时,系统将会自动缩减文件使其未用空间等于25% 当文件大小没有超过其建立时的初始大小时不会缩减文件缩减后的文件也必须大于或等于其初始大小对事务日志文件的缩减只有在对其作备份时或将Truncate log on checkpoint 选项设为True 时才能进行。
  注意:一般新建立的数据库默认属性已设好,但碰到意外情况使数据库属性被更改,请用户清空日志后,检查数据库的以上属性,以防事务日志再次充满。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-620480-1-1.html 上篇帖子: SQL Server2014 Cluster 安装及配置 下篇帖子: SQL Server 2000中的SQL语言2
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表