01-日志文件自动增长导致数据库响应变慢的问题
Posted jialanyu
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了01-日志文件自动增长导致数据库响应变慢的问题相关的知识,希望对你有一定的参考价值。
一、现象
1、前台页面不能显示,报出连接数据库超时的错误,查看SQLServer数据库当前访问,发现有一个update的session非常耗时,和开发交流说每次访问页面的时候,会先更新一张表的数据,然后才能正常显示页面,查看这张表只有970条数据,没有主键和索引,查看数据库访问情况,没有其他session占用资源,也没有其他session锁这张表,然后更新了一下这张表的统计信息,就好了,业务先恢复了。
2、查看这个update语句,有inner join操作,查看这张join的表,也只有1021条数据,连接列没有索引,按理来说应该和更新统计信息没有关系。
二、问题分析
1、查看ERRORLOG日志,发现有一个错误是关于数据库的日志文件自增长的,内容如下:
Autogrow of file ‘xxxx_log‘ in database ‘xxxxx‘ was cancelled by user or timed out after 30124 milliseconds.
Use ALTER DATABASE to set a smaller FILEGROWTH value for this file or to explicitly set a new file size
意思就是说日志文件出现自增长操作,而响应时间比较慢,所有在ERRORLOG里做了这么一条记录
2、查看数据库的日志文件大小达到40G,而增长模式也是按10%的百分比增长,所有在事物日志自动增长机制发生时,会产生闩锁等待(LATCH_EX),造成阻塞,因此在有其他操作写入事物日志时,会进入挂起状态,知道他们获得需要的闩锁,只有在日志自动增长完成时,才能获得相应的资源,执行正常
3、在事物日志自动扩展空间时,数据库的性能是会下降的,所以事物日志增长要按MB增长。
4、对应的等待事件WRITELOG,表示正在等待写入日志,意味着写入日志可能出现了问题,或者是磁盘IO问题,或者是像我们这种情况,日志正在自动扩展,产生了锁。
三、解决办法
1、修改数据库的日志自增长模式为按MB增长。
2、添加数据库日志备份计划,定期备份数据库。
3、如果数据库日志太大的话,还需要收缩一下事物日志。
参考网址:
https://blog.csdn.net/jiankunking/article/details/48321317
以上是关于01-日志文件自动增长导致数据库响应变慢的问题的主要内容,如果未能解决你的问题,请参考以下文章