- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在寻找一种在数据库或日志剩余空间达到 10% 时发送警报的方法。
让我先说明这个问题,我故意没有在问题中包含"file"这个词。虽然我研究了这个问题,但似乎大多数人都将他们的数据库设置为自动增长,然后努力在文件系统级别管理他们的数据库。有大量示例介绍如何发送磁盘空间警报。这不是我的问题!我的数据库都设置为固定大小的文件。这意味着文件因此在创建文件或需要扩展数据库时全部从文件系统中预先分配。作为一项政策,我不允许任何数据库不受控制地增长到由于一个行为不当的应用程序而导致整个服务器崩溃的程度。每个数据库都在其预先分配的空间内进行管理,并根据需要手动增长以满足不断增长的需求。
也就是说,我正在寻找当数据库“扩容空间”低于 10% 时发送警报的最佳方式,例如 - 从技术上讲,我可能会设置一个警告和警报阈值。到目前为止,我还没有找到关于这个主题的任何信息,因为大多数人似乎都专注于磁盘空间,这使得这有点像大海捞针。
我有点希望 SQL Server 有简单的警报机制来做这样一个简单、明显、开箱即用的事情,但看起来警报主要是为了捕获错误消息而设计的,这在我的书中有点晚了- 我希望更积极一些。
因此,再次希望在数据库“剩余空间”低于各种阈值时发送警报。有人做过或看过吗?
谢谢!
最佳答案
的确如此。我已经做到了。
可以通过对系统表的查询来设置计数器。一种可能性包括确定日志或数据文件中可用空间的百分比。然后,可以创建 SQL 警报以通过电子邮件将消息发送给运算符(operator),告知计数器已达到特定阈值,例如数据库文件中仅剩余 5% 的空间。该解决方案需要几个步骤,但可以使用现有功能。
要确定文件名和空间信息,可以使用以下查询。
SELECT name AS 'File Name' ,
physical_name AS 'Physical Name',
size/128 AS 'Total Size in MB',
size/128.0 - CAST(FILEPROPERTY(name, 'SpaceUsed') AS int)/128.0 AS 'Available Space In MB',
round((CAST(FILEPROPERTY(name, 'SpaceUsed') AS float)/size)* 100 ,2) AS 'Percentage Used',
*
FROM sys.database_files;
以下是针对给定文件的可用空间百分比设置警报的步骤。
创建用值设置计数器的程序。此示例设置计数器编号 10。
DECLARE @FreePercent int
SELECT @FreePercent = 100 - round((CAST(FILEPROPERTY(name, 'SpaceUsed') AS float)/size)* 100 ,2)
FROM sys.database_files
WHERE sys.database_files.name = 'NameOfYourLogOrDataFileHere';
EXEC sp_user_counter10 @FreePercent
创建计划作业以运行上述过程
创建带计数器的 SQL 代理警报,以便在可用百分比低于特定阈值(即 5%)时执行
配置数据库邮件,测试,至少创建一个operator
启用SQL server agent alert E-mail(agent属性),并重启agent
关于sql-server-2008-r2 - SQL Server "Space Available"警报?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10145760/
本周我将在 Windows Server 2008 上设置一个专用的 SQL Server 2005 机器,并希望将其精简为尽可能简单,同时仍能发挥全部功能。 为此,“服务器核心”选项听起来很有吸引力
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 已关闭 8 年前。 Improve
我获取了 2014 版本数据库的备份,并尝试在另一台服务器中将其恢复到具有相同名称和登录名的数据库中。此 SQL Server 版本是 2016。 恢复备份文件时,出现此错误: TITLE: Micr
我获取了 2014 版本数据库的备份,并尝试在另一台服务器中将其恢复到具有相同名称和登录名的数据库中。此 SQL Server 版本是 2016。 恢复备份文件时,出现此错误: TITLE: Micr
TFS 是否提供任何增强的方法来存储对 sql server 数据库所做的更改,而不是使用它来对在数据库上执行的 sql 语句的文本文件进行版本控制? 或者我正在寻找的功能是否仅在第 3 方工具(如
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我即将将我的 SQL Server 2012 实例升级到 SQL Server 2014。 我已经克隆了主机 Windows VM 并将其重命名为 foo-2012至 foo-2014 . 重新启动时
我想为 SQL Server 登录授予对数据库的访问权限。我知道 sp_grantdbaccess,但它已被弃用。我可以改用什么以及如何检查登录名是否还没有访问数据库的权限? 场景:UserA 创建数
客户别无选择,只能在接下来的几天内从 sql server 2000 迁移到 2008。测试显示 2005 年的重要功能出现了 Not Acceptable 性能下降,但 2008 年却没有。好消息是
我有一个测试数据库,我需要将其导出到我们客户的测试环境中。 这将是一次性的工作。 我正在使用 SQL Server 2005(我的测试数据库是 SQL Server 2005 Express) 执行此
我需要将一个 CSV 文件导入到 mongoDB 不幸的是我遇到了以下错误: error connecting to host: could not connect to server: se
我以为 R2 是一个补丁/服务包。我一直在寻找下载,但没有看到。因此,我假设 R2 是一个新版本,并且我需要 sqlserver 2008 r2 的安装介质来进行升级? 另外,我需要为新许可证付费吗?
我无法使用 SQL Server Management Studio 连接到 SQL Server。 我有一个连接字符串: 我尝试通过在服务器名中输入 myIP、在登录名中输入 MyID、在密码中
我们希望使用 SQL Server 加密来加密数据库中的几个列。我们还需要在生产和测试环境之间传输数据。看来最好的解决方案是在生产和测试服务器上使用相同的主 key 、证书和对称 key ,以便我可以
有没有可以分析 SQL Server 数据库潜在问题的工具? 例如: a foreign key column that is not indexed 没有 FILL FACTOR 的 uniquei
我正在尝试从我的 SQL 2012 BI 版本建立复制,但我收到一条奇怪的错误消息! "You cannot create a publication from server 'X' because
如果您使用 SQL Server 身份验证 (2005),登录详细信息是否以明文形式通过网络发送? 最佳答案 如您所愿,安全无忧... 您可以相当轻松地配置 SSL,如果您没有受信任的证书,如果您强制
我想将数据从一个表复制到不同服务器之间的另一个表。 如果是在同一服务器和不同的数据库中,我使用了以下 SELECT * INTO DB1..TBL1 FROM DB2..TBL1 (to copy w
我希望得到一些帮助,因为我在这个问题上已经被困了 2 天了! 场景:我可以从我的开发计算机(和其他同事)连接到 SERVER\INSTANCE,但无法从另一个 SQL Server 连接。我得到的错误
我正在尝试从我的 SQL 2012 BI 版本建立复制,但我收到一条奇怪的错误消息! "You cannot create a publication from server 'X' because
我是一名优秀的程序员,十分优秀!