记一次SQL Server磁盘突然满了导致数据库锁死事件is full due to ‘LOG_BACKUP‘.

背景

最近我们的sql server 数据库磁盘在80左右,需要新增磁盘空间。还是处以目前可控的范围内,但是昨天晚上告警是80%,凌晨2:56分告警是90%,今天早上磁盘就满了。

经过

通过阿里云后台查看,磁盘已经占据99%,主要是日志空间的增长。

正常的日志空间在10%左右

问题

通过对后台日志的分析,应该是有脚本在用各种用户在测试外网链接,应该属于攻击手段了。想要获取数据库的数据。

解决方式

解决的途径有两个,一个是通过对外网链接配置白名单,限制其他IP的访问,使日志下降。这一块通过阿里云的配置就可以实现。

另一个是需要解除sql server 的服务器锁,能够自由插入数据和删除数据。现在这种情况下,无法做正常的业务操作。

经过咨询以后,得到下面的脚本。下面的是查看现在数据库中磁盘占有量。

sql 复制代码
USE yy_BI;
SELECT SUM(unallocated_extent_page_count) AS [free pages],
       (SUM(unallocated_extent_page_count)*1.0/128) AS [free space in MB]
FROM sys.dm_db_file_space_usage;
sql 复制代码
-- 查询数据库服务器各数据库日志文件的大小及利用率
DBCC SQLPERF(LOGSPACE)

使用下面的语句,会对数据库中的事务日志进行收缩,达到减少存储空间的目的。

sql 复制代码
DBCC SHRINKDATABASE(yy_BMS_DataWarehouse);

经过一段时间的日志处理,现在磁盘已经降下来了。

相关推荐
重生之绝世牛码19 分钟前
Linux软件安装 —— PostgreSQL高可用集群安装(postgreSQL + repmgr主从复制 + keepalived故障转移)
大数据·linux·运维·数据库·postgresql·软件安装·postgresql高可用
数据知道20 分钟前
PostgreSQL 实战:详解 UPSERT(INSERT ON CONFLICT)
数据库·python·postgresql
源力祁老师42 分钟前
Odoo日志系统核心组件_logger
网络·数据库·php
洋不写bug2 小时前
数据库基础核心操作——CRUD,超详细解析,搭配表格讲解和需求的实现。
数据库
马猴烧酒.2 小时前
JAVA后端用户登录与鉴权详解
java·数据库·sql
heartbeat..2 小时前
Redis 常用命令全解析:基础、进阶与场景化实战
java·数据库·redis·缓存
数据知道2 小时前
PostgreSQL 实战:一文掌握如何优雅的进行递归查询?
大数据·数据库·postgresql
陌上丨3 小时前
MySQL8.0高可用集群架构实战
数据库·mysql·架构
重生之绝世牛码3 小时前
Linux软件安装 —— ClickHouse单节点安装(rpm安装、tar安装两种安装方式)
大数据·linux·运维·数据库·clickhouse·软件安装·clickhouse单节点
一只自律的鸡3 小时前
【MySQL】第十一章 存储过程和存储函数
数据库·mysql