SQL Server自动化运维系列——关于邮件通知那点事(.Net开发人员的福利)

需求描述

在我们的生产环境中,大部分情况下需要有自己的运维体制,包括自己健康状态的检测等。如果发生异常,需要提前预警的,通知形式一般为发邮件告知。

邮件作为一种非常便利的预警实现方式,在及时性和易用性方面也有着不可替代的优点。

所以,在本篇中将详细的分析下在SQL Server中的邮件通知功能及使用方式等。 

本篇实现

1、通过SQL Server自带的邮件功能实现运维的预警及检测

2、利用数据库邮件组件代替传统的C#发送邮件的弊端

3、实现Job任务运行状态的检测

4、利用PowerShell实现Job任务计划的检测

<1>基础配置

首先,我们来配置下SQL Server中的邮件组件的基础服务项。SQL Server自从05版本起,邮件功能就不需要开启外配配置管理器了,它有着自己的组件,实现邮件发送的功能。

如果,没使用过,可以按照以下步骤进行配置,步骤很简单。

右键,配置数据库邮件

然后直接下一步就行,然后新建一个账户

然后,下一步完成就可以,步骤很简单,这里面有几个概念需要理清楚,对于SQL Server的邮件账户是由权限控制的,目的是实现不同的人使用不同的邮件账户,比如大型数据库的管理一般有好几个DBA负责运维,分职责之后的运行,发 送预警邮件也就产生了区分,总不能模块中出现了任何问题都发送给一个人。

跟你一毛钱关系都没有的异常,天天给你发邮件,是不是很不爽??....这种管理方式是灰常暴力的!

为了解决上述问题,SQL Server对邮件的账户进行了分类:

 

分为公共账户和专用账户。

一般如果管理人员少,就配置一个公共账户就可以,有问题都发送到该邮箱就可以。

至此,你已经完成了数据库邮件模块的配置,步骤很简单。这里可以发送一封测试邮件,来测试下邮件的连通性。

提示:SQL Server邮件组件的运行需呀SQL Server Age运行执行,所以需要确保此服务正在运行。

在“数据库邮件”上右键,发送测试电子邮件,输入目标邮箱的地址,然后单击发送就可以。

 

至此,你的SQL Server已经完成邮件组件的基础配置,然后剩下的工作就是如何利用该组件进行部分工作的完成了。

 

<2>c#调用数据库邮件组件进行邮件的发送 

还记得当年刚毕业的时候,对于发送邮件这块功能当时是异常的痴迷,各种的研究和各种的调试。

后来的终归在废了九牛二虎之力之后,终于在一个午夜梦回之时看到了我梦寐以求的测试邮件发送通知,想想一个字描述:草!

大体我记得需要引用以下几个命名空间:using System.Net;  using System.Net.Mail; 

然后利用C#提供的SmtpClient类进行组装成邮件实体,而后一个Send()方法,这其中的痛苦点在于各种编码规范等。

我相信现在也有很多程序猿依然再采用着这种方式。

今天提供另外一种灵活的实现方式,利用SQL Server数据库的邮件组件进行邮件的发送。

关于上面第一个步骤提供的邮件组件的调用,其实在SQL Server中是提供系统自带的存储过程进行实现的。方法如下:

该存储过程提供了发送邮件的的各种参数,完全满足发送邮件的各种需求,比如:主题、内容、附件、CC、秘密CC....等等吧

调用该存储过程的方法如下:

复制代码
    --存储过程调用发邮件EXEC msdb.dbo.sp_send_dbmail@profile_name = 'testMail',@recipients = '787449667@qq.com', @body = '这是测试邮件', @subject = '我发的', @file_attachments='C:\temp\3-26-2015-16-20-21.png'
复制代码

上面一个简单的方法执行既可以实现,邮件的发送。

然后,你需要的就是c#调用该存储过程了。

关于写C#代码通过Ado.net调用存储过程的过程这里就不赘述了,我相信这是入门级别的小白也能搞定的事情了。

而后,这里捎带分析一下邮件组件的原理和性能问题。我相信这是很多人关心的,其实SQL Server的邮件发送时通过一个底层的JOB轮询执行的,所以根本不用担心其执行顺序和性能问题。

并且SQL Server为此还提供了几个系统的视图来查看历史运行状态和当前邮件的队列状态:

    --邮件内容SELECT * FROM msdb.dbo.sysmail_allitems

    --邮件发送日志SELECT * FROM msdb.dbo.sysmail_event_log

并且SQL Server提供了邮件重新发送的功能以及其它默认参数,具体设置参照此画面:

至此,已经完成了利用C#进行发送邮件的功能。

我相信基本上用C#就会搭配微软自己的SQL Server数据库,而使用它之后就可以少量的代码实现邮件发送的功能。

 

 <3>实现Job任务运行状态的检测 

在我们使用SQL Server的时候,很多情况下都需要自定义Job进行部分功能的实现,而大部分时间是采取凌晨或者非业务期进行工作。

而此Job的运行结果的检测便形成了一个需要跟踪的问题,比如有时候N个Job的运行,只有几个出现问题,并且不确定的此Job发生在那个机器上,所以自动化运维的重要性就不言而喻了。

对于上面问题的解决,SQL Server提供了很简单的配置就可以实现。

(1)首先,需要定义几个操作员,说到底就是几个人值班运维此数据库的

 

上面,我就定义了一个人,其实可以定义多个人,几个运维人员几个...

(2)其次,需要定义警报,说到底就是将产生的预警发送给上面的几个运维人员。

这里面的严重性选项其实是一个很重要的功能,一些简单的问题警告有时候是不需要及时关注的,或者说不需要暂时处理的。

但是有些问题则需要里面去解决,比如服务器宕机....

然后,我们来将此预警关联之操作员

到此,我们已经完成了预警的检测配置,然后需要的就是关联下Job代理的任务属性值。

经过上面的配置,任何我们自定义的Job工作状态都可以进行自动化检测了。

比如:某个Job跑批成功了,某个Job跑批失败了。我们来新建一个自定义的Job来测试下:

 

然后设置警告

然后,在运行此Job出现异常的时候,就可以自动的报告到相应的运维人员了。

这里我们就设置了一个运维人员,所以这里只发送给一个人。

我们来手动运行下,来测试一下效果

嘿嘿,果然,发出了警报,看起来很贴心的样子

 

至此,此功能已经配置完成,自己可以灵活的实现。

 

 <4>利用PowerShell实现Job任务计划的检测

关于Job的明细日志,请参照如下文章:

SQL Server自动化运维系列——监控跑批Job运行状态(Power Shell)

 

结语 

本来打算将利用Power Shell脚本检测的功能实现方式也加上的,但文章已经稍有点篇幅了,后续再完成吧。此篇的关于SQL Server的邮件功能算作抛砖引玉了,自己另有需求可以自己灵活实现。

其实,在本篇所介绍的Job任务的检测在几台服务器上存在还问题不大,但是如果多台服务器,如果每台服务器上都有几个Job异常的话,每天早上打开邮件多的估计会令你头皮发麻,并且在自带的异常报警中,没有给出详细的错误信息,其实这是一个很不爽弊端。

所以,为了优雅的进行自动化运维的工作,我们将会每次将我们所有检测的服务器Job运行状态进行扫描,而后将其汇总至一封邮件,然后按照重要性发送至固定的运维人员。

听起来是不是还有点小激动的样子,下一篇我们来实现此功能。有兴趣的童鞋,可以提前关注。

关于SQL Server自动化运维和检测的内容很广泛,其中很多都是从日常的经验中出发,一步步的从手动到自动的过程。

 

如果您看了本篇博客,觉得对您有所收获,请不要吝啬您的“推荐”。 

转载于:https://www.cnblogs.com/lykbk/p/fgsdfsf345435454.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/375113.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

So easy Webservice 1.Socket建设web服务

socket 是用来进行网络通讯的&#xff0c;简单来说&#xff0c;远程机器和本地机器各建一个socket&#xff0c;然后通过该socket进行连接通讯 socket简单模型图&#xff1a; socket的原理图&#xff1a; 代码实现&#xff1a; 1.创建socket服务端&#xff1a;用于处理客户端发送…

Java 自带MD5 校验文件

http://www.iteye.com/topic/1127319 前天第一次发表博客到论坛&#xff0c;关于Java文件监控一文&#xff0c;帖子地址在&#xff1a;http://www.iteye.com/topic/1127281 评论的朋友很多&#xff0c;下载代码的朋友很不少&#xff0c;感谢在论坛上看我帖子的朋友&#xff0c;…

决策树资料汇总

2012年8月26日决策树&#xff08;Decision tree&#xff09;决策树是以实例为基础的归纳学习算法。它从一组无次序、无规则的元组中推理出决策树表示形式的分类规则。它采用自顶向下的递归方式&#xff0c;在决策树的内部结点进行属性值的比较&#xff0c;并根据不同的属性值从…

metasploitable2渗透测试

一、系统弱密码登录 1、在kali上执行命令行telnet 192.168.26.129 2、Login和password都输入msfadmin 3、登录成功&#xff0c;进入系统 4、测试如下&#xff1a; 二、MySQL弱密码登录&#xff1a; 1、在kali上执行mysql –h 192.168.26.129 –u root 2、登录成功&#…

Portainer.io:让容器管理变得更加直观

在现代软件开发和部署中&#xff0c;容器化技术已经变得越来越流行。Docker 是其中一种领先的容器化平台&#xff0c;而 Portainer.io 则是一个优秀的管理工具&#xff0c;使得 Docker 的使用变得更加简单和可视化。本文将介绍 Portainer.io 的基本功能和如何在 Docker 上安装和…

python开发的一些tips

1. Notepad编写python脚本 1&#xff09;新建文件&#xff0c;编写代码 2&#xff09;点击菜单栏&#xff0c;“语言”—>“P”—>“Python”&#xff0c;设置脚本为Python语言的高亮&#xff08;这样保存文本的时候&#xff0c;Notepad也可以自动识别文件类型为.py&…

metasploitable3渗透测试

1、攻击windows服务器漏洞 用nmap对网段进行扫描nmap -sP 192.168.123 在进行IP扫描 发现Windows服务器漏洞 步骤: msfconsole---进入渗透模块

以前写的一个下载小说的工具

因为当时发现只有一个站点有。但是时时联网的要求太让人不爽。就写了一个给全下下来了。 用到了: 1. 正则表达式&#xff0c;分析章节和内容&#xff1b; 2. 线程池下载&#xff0c;并且对下载中的相关超时做了一些处理&#xff1b; 3. 文件生成与写入&#xff0c;注意格式问题…

数学之路-python计算实战(14)-机器视觉-图像增强(直方图均衡化)

我们来看一个灰度图像&#xff0c;让表示灰度出现的次数&#xff0c;这样图像中灰度为 的像素的出现概率是是图像中全部的灰度数&#xff0c; 是图像中全部的像素数, 实际上是图像的直方图&#xff0c;归一化到 。把 作为相应于 的累计概率函数, 定义为&#xff1a;是图像的…

Windows2008的安装

点击下一步 点击安装 选择第三个&#xff0c;点击下一步 点击下一步 点自定义安装 我在这里分两个盘并格式化 接下来就是等待安装完成即可

redhat linux7.0的安装

选择第一个 我选择中文 点击开始安装 设置root用户密码 完成如上图所示 我在网上找了一个redhat7.0镜像供大家使用 链接&#xff1a;https://pan.baidu.com/s/1WhG8BGZTZawDKTNlaAvzRg 提取码&#xff1a;uzpd

VMware虚拟机安装

创建新的虚拟机&#xff1a;在 VMWare 中创建虚拟机&#xff0c;要求设置内存大小为 1G&#xff0c;CPU 为 2&#xff0c;硬盘大小自行选择&#xff0c;网络连接采用 NAT 模式&#xff0c;其他保持默认即可 上面是安装啥系统就选啥系统 下一步 下一步 磁盘大小按自己需求来

二叉树算法:中序、后序推导先序(数组递归实现 【*模板】)

中根序列和后根序列重建二叉树 描述我们知道如何按照三种深度优先次序来周游一棵二叉树&#xff0c;来得到中根序列、前根序列和后根序列。反过来&#xff0c;如果给定二叉树的中根序列和后根序 列&#xff0c;或者给定中根序列和前根序列&#xff0c;可以重建一二叉树。本题输…

Windows主机安全加固

Windows主机安全加固 账户安全 更名administrator本地用户并禁用guest账户步骤: 点击“开始”,找到“管理工具”,点击里面的“计算机管理”,找到“本地用户和组”

JS笔记 入门第四

小测试:注意:取消所有的设定可以直接使用document.getElementById("txt").removeAttribute("style");这个是个神奇的东西.<!DOCTYPE HTML><html><head><meta http-equiv"Content-Type" Content"text/html; charsetutf…

数论神题——进击的羊角兽

数论神题 进击的羊角兽 题目描述&#xff1a; 求满足 \(ab|ab(a,b \leq n,a \neq b)\)的有序数对\((a,b)\)的个数。 solution 设\((a,b)d , (a < b \leq n)\),则$ axd , byd , ( x < y )$ \(ab|ab\) \((xy)d|xyd^2\) \(\because (xy, x)1,(xy, y)1\) \(\therefore (xy)|d…

靶场练习第一天~vulnhub靶场之Me-and-My-Girlfriend-1

兄弟们第一天打vulnhub靶场&#xff0c;我kali连靶场ip都扫不到&#xff0c;泪奔了&#xff0c;不说了开整 注意&#xff1a; vm虚拟机里面的编辑下面的虚拟机网络编辑器&#xff0c;把除了NAT模式外的模式&#xff0c;其他模式不启动。 至于为什么要这样操作&#xff0c;感觉…

靶场练习第二天~vulnhub靶场之 THE PLANETS: EARTH

前期准备&#xff1a; 靶机下载链接: https://pan.baidu.com/s/1_w8OZOPVsQaojq2rnKcdRA 提取码: gguw kali攻击机ip&#xff1a;192.168.101.10 靶机地址&#xff1a;192.168.101.101 一、信息收集 1.nmap扫描 因为kali与靶机在同一个网段下&#xff0c;使用nmap 192.168…

测试与封装5.1

我的队友是52吴舒婷&#xff0c;博客内容主要是白盒黑盒的测试数据分析 我们通过简单的四则运算来进行程序的测试与封装 我们主要完成的是事情 &#xff08;1&#xff09;封装&#xff1a;将运算要运用的方法进行封装 文件主要有三个&#xff1a;Calculate&#xff08;存放运算…

springmvc学习笔记--mybatis--使用插件自动生成实体和mapper

由于表对象在开发过程中会增删字段&#xff0c;有时候需要重新生成实体和对应的mapper&#xff0c;这时候可以通过mybatis的插件的生成。 优点是快速简洁&#xff0c;缺点同样很明显&#xff1a;覆盖。因此&#xff0c;通常是在第一次搭建框架的时候使用&#xff0c;因为开发过…