热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

代理警报和操作员

如我们在这个系列的文章里所见,SQLServer代理作业由一些列的作业步骤组成,每个步骤是需要执行的不同类型工作。另外在每个步骤里要进行的工作ÿ

如我们在这个系列的文章里所见,SQL Server代理作业由一些列的作业步骤组成,每个步骤是需要执行的不同类型工作。另外在每个步骤里要进行的工作,你会发送特定作业成功或失败的消息给DBA(或其他人) 。当系统发生故障时,特定性能问题发生或某个阀值达到系统值时,你也会对这些消息感兴趣。SQL Server代理提供创建警报的能力,可以发消息给指定的操作员作为提胸,来帮助你处理这些问题。

什么是SQL Server代理警报?

SQL Server警报是在你的SQL Server系统上,对特定条件的自动响应。警报可以由下列条件触发:

  • SQL Server系统信息生成
  • 最低程度的系统错误侦测到
  • 在SQL Server性能计数器达到特定阀值
  • 符合WMI查询结果

一旦警报触发,在警报里定义的响应会发生。这些响应要么执行特定的SQL Server代理作业,要么通知一个或多个操作员。你也有可以指定触发错误信息的选项,包括在任何发送的提醒里。

什么是SQL Server代理操作员?

SQL Server代理操作可以是简单的一个邮箱地址。也有其他选项,例如一个net send地址或一个“寻呼机”邮件名,但事实上“寻呼机”选项直接作为邮件发送。

备注:

对于SQL Server警报,”Net Send“还是个选项,但实际上这个功能并不用,已经正式从产品里剥离,意味着在后续的SQL Server版本里移除。对于警报唯一可行的选项是通过邮件提醒。

当一个操作员被定义,你可以使用操作员来接收邮件(例如通过邮件发送文本信息)到定义的邮件别名。那个邮件别名会可能是一组或更多为系统问题待命的DBA。对于重要的提醒,你会想要使用升级的操作员,例如直接发短信给手机。

创建一个操作员

创建一个操作员,打开SSMS,在SQL Server代理文件夹下找到操作员。右击【操作员】,选择【新建操作员】,你会打开如插图1的界面。

插图1——新建操作员对话框

如你在插图1所见,我对操作员已指定了一个姓名,还有邮件地址。请确保已启用已经选择,不然对这个操作员的任何警报都不会发生。

当你选择了【通知】页,我们可以看到已经分配给这个操作员的警报列表。对新建的操作员,如插图2所示,列表是空的。点击【确定】,操作员已经创建。

插图2——新建操作员通知页

在运行的系统上,我们会期望至少存在2个操作员——一个作为紧急系统提醒(例如,我们刚定义的服务器警报操作员),另一个在SQL Server代理作业或常规错误上你会有的各自分工。

操作员当然也可以通过T-SQL脚本来创建。你可以使用sp_add_operator系统存储过程来创建操作员。语法上的帮助,可以参考在线帮助:https://msdn.microsoft.com/zh-cn/library/ms186747.aspx

备注:

关于操作员一个常见的问题是你如何发送警报给多个人。你实现这个的方法是通过你的邮件系统的邮件发布列表,因为SQL Server代理只能给单个操作员发送警报。因此你在SQL Server代理可以定义操作员为发布列表,那么在列表上的每个人都会收到相关的警报。

防故障(Fail-Safe)操作员

防故障操作员定义为:如果所有其他操作员提醒失败而启用的。这样的失败有很多的可能(例如,你邮件系统出问题了,这个在下篇文章我们会谈到),但在任何情况下有一个防故障操作员比较好。一旦你定义一个或多个操作员,你就定义防故障操作员。防故障操作员是你指定的最后一个联系的。

你在SQL Server代理属性对话框里定义防故障安全员(右击SQL Server代理,选择属性),在警报系统页。勾选启用防故障操作员,然后从列表里选择系统已经定义的操作员,如插图3所示。当完成选择后,点击【确定】。注意这页的其它选项会在下一篇的数据库邮件里谈到。

插图3——配置防故障操作员

创建警报

一些就绪,现在我们可以开始创建警报,我们刚才已经提过,是在你的SQL Server系统里对于一些情况的自动响应。为了定义一个新的警报,在SSMS里点击SQL Server代理文件夹,然后点击【警报】文件夹,右击并选择【新建警报】打开新建警报对话框。你会看到如插图4的对话框。对于在系统上的第一个警报,我们创建一个提醒DBA任何系统错误的警报(严重级别19或更高)。

插图4——创建新的警报

SQL Server事件警报

和操作员一样,警报必须启用才会工作。注意在这个例子里,警报的”类型“是”SQL Server事件警报“。你也可以选择”SQL Server 性能条件警报“,它会提供对于关联的SQL Server实例,会看到很多SQL Server特定的性能计数器。在下一部分,我们会看到一个性能条件警报。最后,还有一个”WMI事件警报“,允许你写WMI查询并用警报响应它们。关于WMI你可以在在线帮助里进一步学习:https://msdn.microsoft.com/en-us/library/aa394582%28v=VS.85%29.aspx

在新建警报对话框里的下拉框里的严重级别只是对于SQL Server所有可能错误的可用严重级别(查看RAISERROR命令文档来了解更多:https://msdn.microsoft.com/zh-cn/library/ms178592.aspx )这些在19或更高级别的错误,需要DBA干预调查为什么会发生这个级别的错误。

一旦你选择了如插图4所示界面的选项,点击【响应】来查看对这个警报可以采取的行动(如插图5所示)。你会可能到你可以执行一个SQL Server代理作业,或通知一个操作员(例如,我们刚才定义的操作员)。在这个例子里,我们选择给我们的”服务器警报“发送一个邮件,当警报发生的时候。

插图5——新建警报响应

选择想要的操作员后,你可以切换到【选项】页看下对一个这个警报一些有趣的选择,如插图6所示。选择包含警告信息的选项,如果你想知道为什么这个警报被发送(不然的话很难理解警报为什么会发送)。这个页面也允许你指定额外的提醒信息,非常用于在早上3点提醒你,为什么你会因这个信息而醒来,或作为帮助的搜素字符,当查看来子SQL Server的邮件时。如果这个是普通的警报条件,你可以只选择默认提醒信息不需要额外你专有的备注。

延迟选项用来指定当警报触发时,是否需要重复提醒,可以指定几分钟或几秒。在这个例子里,5分钟的延迟已经设置,因此你的邮箱收件箱会持续收到一些列的邮件,所有都提示同样的问题。

插图6——新建报警选项

当你完成对这个对话框的选择,点击【确定】来创建新的警报。

当然你也可以通过sp_add_alert的系统存储过程来创建。关于这个存储过程的文档在这里:https://msdn.microsoft.com/zh-cn/library/ms189531.aspx 或者直接从SSMS里创建,如插图7所示。

插图7——通过脚本新建一个警报

警报条款

有意思的是你可以指定特定的错误信息从不触发。为了定义这样的错误,你必须人为更新服务器上的注册表。注册表是你特定实例上的。在HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER下,你会找到SQLServerAgent,如插图8所示。

插图8:注册表编辑器配置NonAlertableErrors

默认情况下,错误号是1204(不能获得锁)和4002(登录失败)。如果你真的想要这些错误号的警报,你会需要编辑下这个键值,从列表里移除这些数字。相反的,你可以增加额外的从不警告错误号,你可以加这些错误号到列表。

当然,当你编辑注册表时,这些不正常的警告号你要特别仔细。

性能条件警报

警报的第2个类型是 SQL Server性能条件警报。你可以给予性能计数器配置很多种类的警报。遗憾的是,你只能设置SQL Server的计数器,但这已经能让你自动监控你的系统。例如,在插图9里,当AdvantureWorks数据库的事务日志超过90%满时,你后收到警告的警报。一但你选择如插图4的选项,点击【响应】页来配置对这个警报对应采取的行动(如插图5所示)。你会看到你可以执行SQL Server代理作业(例如刚才提到的日志空间增长,或开始备份数据库),或提醒对应的操作员(例如我们刚才定义的操作员)。在这个例子里,当警报触发的时候,我们选择给“服务器警报”操作发送邮件。

插图9:性能条件警报

警报系统进阶

除了这篇文章里创建的高严重级别的警报,你应该研究下警报的其他方面。在性能计数器和WMI查询上设置警报功能就非常强大。当然这里只限制SQL Server特定的计数器,没有例如CPU这样的系统计数器。这个要注意,你还是设置这样的警报,当SQL Server登录到特定的阈值,或达到SQL Server特定的内存条件,或当超过I/O阈值时。

另外,当警报触发时可以执行作业意味着你可以通过自动化操作修正很多常规错误,而不需要每次都人为干预错误发生。对于要执行的作业没有特定的要求:任何SQL Server代理作业都会被调用。



本文转自Woodytu博客园博客,原文链接:http://www.cnblogs.com/woodytu/p/5152117.html,如需转载请自行联系原作者



推荐阅读
  • 基于iSCSI的SQL Server 2012群集测试(一)SQL群集安装
    一、测试需求介绍与准备公司计划服务器迁移过程计划同时上线SQLServer2012,引入SQLServer2012群集提高高可用性,需要对SQLServ ... [详细]
  • 用阿里云的免费 SSL 证书让网站从 HTTP 换成 HTTPS
    HTTP协议是不加密传输数据的,也就是用户跟你的网站之间传递数据有可能在途中被截获,破解传递的真实内容,所以使用不加密的HTTP的网站是不 ... [详细]
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • 大家好,我是李白。本文将分享一个从零开始的全栈项目,涵盖了设计、前端、后端和服务端的全面学习过程。通过这个项目,我希望能够帮助初学者更好地理解和掌握全栈开发的技术栈。 ... [详细]
  • 在开发过程中,我最初也依赖于功能全面但操作繁琐的集成开发环境(IDE),如Borland Delphi 和 Microsoft Visual Studio。然而,随着对高效开发的追求,我逐渐转向了更加轻量级和灵活的工具组合。通过 CLIfe,我构建了一个高度定制化的开发环境,不仅提高了代码编写效率,还简化了项目管理流程。这一配置结合了多种强大的命令行工具和插件,使我在日常开发中能够更加得心应手。 ... [详细]
  • 开机自启动的几种方式
    0x01快速自启动目录快速启动目录自启动方式源于Windows中的一个目录,这个目录一般叫启动或者Startup。位于该目录下的PE文件会在开机后进行自启动 ... [详细]
  • 本文介绍了如何通过Sybase Central连接到示例数据库,并查看其中的表和其他对象。主要内容包括启动Sybase Central、建立连接、查看表列表及表的具体信息。 ... [详细]
  • 本文深入解析了 Kubernetes 控制平面(特别是 API 服务器)与集群节点之间的通信机制,并对其通信路径进行了详细分类。旨在帮助用户更好地理解和定制其安装配置,从而增强网络安全性,确保集群的稳定运行。 ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • XAMPP 遇到 404 错误:无法找到请求的对象
    在使用 XAMPP 时遇到 404 错误,表示请求的对象未找到。通过详细分析发现,该问题可能由以下原因引起:1. `httpd-vhosts.conf` 文件中的配置路径错误;2. `public` 目录下缺少 `.htaccess` 文件。建议检查并修正这些配置,以确保服务器能够正确识别和访问所需的文件路径。 ... [详细]
  • 本文是Java并发编程系列的开篇之作,将详细解析Java 1.5及以上版本中提供的并发工具。文章假设读者已经具备同步和易失性关键字的基本知识,重点介绍信号量机制的内部工作原理及其在实际开发中的应用。 ... [详细]
  • 技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统
    技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统 ... [详细]
  • PHP 各版本对比:标准版与最新顶级版的详细分析 ... [详细]
  • 性能测试中的关键监控指标与深入分析
    在软件性能测试中,关键监控指标的选取至关重要。主要目的包括:1. 评估系统的当前性能,确保其符合预期的性能标准;2. 发现软件性能瓶颈,定位潜在问题;3. 优化系统性能,提高用户体验。通过综合分析这些指标,可以全面了解系统的运行状态,为后续的性能改进提供科学依据。 ... [详细]
  • 本文探讨了如何通过编程手段在Linux系统中禁用硬件预取功能。基于Intel® Core™微架构的应用性能优化需求,文章详细介绍了相关配置方法和代码实现,旨在帮助开发人员有效控制硬件预取行为,提升应用程序的运行效率。 ... [详细]
author-avatar
手机用户2502905891
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有