zabbix web监测

web monitoring(监测)属于业务监控,用来监控Web站点多方面的可用性,能够监控Web站点的下载速度、返回码和响应时间。Zabbix可以检测HTML中包含的预先定义的字符串,也能够模拟登陆网站和鼠标的动做,对特定的结果进行比较,例如特定字符串、返回码等,从而判断站点服务的可用性。Zabbix支持HTTP和HTTPS协议,并在完成每一步模拟访问时会对cookie进行保存。 前端

在zabbix中设置Web监控时,须要先定义web scenarios(场景),一个webscenarios是由多个HTTP请求(steps)组成,这些steps(步骤)会按照预先定义的顺序执行。和定义监控项同样,web scenarios也能够在主机或模板级别定义。 ios

一、web监控项 web

Web 监控项主要有两种:Scenario items 和Scenario step items。这些监控项默认历史保存时间为30天,趋势保存时间为90天。 正则表达式

1.1 Scenario items express

Web Scenario建立完成后Zabbix会自动添加下面的监控项,并链接它们到已经选中的应用。 浏览器

※ Download speed for scenario<Scenario>:该监控项收集整个Scenario有关的平均下载速度数据,单位为bytes per second。监控项的key是:web.test.in[Scenario,,bps],类型是:Numeric(float)。 服务器

※ Failed step of scenario<Scenario>:该监控项将显示整个Scenario中失败的step的数量,若是全部step都执行成功返回0。监控项的key是:web.test.fail[Scenario],类型是: Numeric(unsigned)。 cookie

※ Last error message of scenario<Scenario>:该监控项返回Scenario的最后的错误信息文本,若是Scenario中有失败的step时会保存一个新的值,若是全部step都成功执行时没有新的值被保存。监控项的key是:web.test.error[Scenario],类型是: Character。 网络

Scenario items也能够用来建立触发器和定义通知条件。 app

例如:

※ 建立一个Web ScenarioFailed的触发器时, 触发器表达式能够定义为: {host:web.test.fail[Scenario].last()}<>0

※ 建立一个Web ScenarioFailed的触发器时,在触发器名称中使用问题的描述信息。触发器名称能够定义为:

Web scenario "Scenario" failed: {ITEM.VALUE}

触发器表达式能够定义为:

{host:web.test.error[Scenario].strlen()}>0 and{host:web.test.fail[Scenario].min()}>0

※ 建立一个Webapplication is slow的触发器时,触发器表达式能够定义为:

{host:web.test.in[Scenario,,bps].last()}<10000

在实际环境中,请把Scenario 替换成你定义的场景的实际名称。

1.2 Scenario step items

在Scenario中每一个step建立完成后Zabbix会自动添加下面的监控项,并链接它们到选中的应用。

※ Download speed for step<Step> of scenario <Scenario>:该监控项收集step有关的平均下载速度数据,单位为 bytesper second。监控项的key是: web.test.in[Scenario,Step,bps],类型是: Numeric(float)。

※ Response time for step<Step> of scenario <Scenario>:该监控项收集step有关的响应时间的数据,单位为秒。响应时间是从请求开始计时,直到全部信息传输完毕。监控项的key是:web.test.time[Scenario,Step,resp],类型是:Numeric(float)。

※ Response code for step <Step>of scenario <Scenario>:该监控项显示step的返回代码,如50x、40x等在实际环境中应该重点监控。监控项的key是:web.test.rspcode[Scenario,Step],类型是:Numeric(unsigned)。

在建立触发器时也可使用这些Scenario step item。例如,建立一个ZabbixGUI login is too slow的触发器时,触发器表达式能够定义为:

{zabbix:web.test.time[ZABBIX GUI,Login,resp].last()}>3

 

二、使用变量

配置Web 监控时在Scenario或step级别均可以使用Variables(变量),实际上就是用户自定义的宏变量。在scenario级别定义的变量能够在steps中引用,例如URL、Post变量等。在step级别定义的宏变量能够在GET或POST函数中使用,step级别定义的变量能够覆盖scenario级别的变量或上一个step中定义的变量。

变量定义的格式为:

{macro1}=value1

{macro2}=value2

{macro3}=regex:<regular expression>。

例如{username}=Alexei,{password}=kj3h5kJ34bd,{sid}=regex:name="sid"value="([0-9a-z]{16})" 等。若是是以regex开始,那它的后面是一个正则表达式,会在web页面中搜索,若是发现,会将匹配的值保存到变量中。在step中应用macros时,例如{username}、{password}、{hostid}等,Zabbix会自动替换成实际的值。

在配置变量时,还可使用Host.* 宏变量和用户自定义的宏变量。须要注意的是变量不能通过URL编码处理。

 

三、配置web监控

在配置–> 主机/模板页面中,点击须要建立web 监控的主机或模板中的web连接,在web监测页面的右上角点击 建立web场景按钮,进入web 监控配置页面

场景标签中各配置参数的含义以下:

名称:惟一的场景名称

应用集:选择一个场景归属的监控项组

新的应用集:输入一个场景归属的新监控项组的名称

数据更新间隔:执行的时间间隔

尝试次数:用于执行web 场景步骤尝试的次数。有时候会由于网络出现问题(超时、链接丢失等)的状况下能够重复执行步骤几回,该设置会影响场景中的每个步骤。最多能够指定10次,默认值为1。须要注意的是zabbix不会由于一个错误响应代码或一个必须的字符串不匹配而重复执行步骤

客户端:选择一个浏览器客户端,当一个网站针对不一样的浏览器返回不一样的内容时很是有用。在这里也可使用用户定义的宏变量

HTTP代理:指定一个HTTP 代理。使用的格式为:http://[username[:password]@]proxy.mycompany.com[:port],默认使用端口1080。若是指定http_proxy、HTTPS_PROXY等代理环境变量,将会覆盖proxy相关的环境变量。须要注意的是HTTP代理只支持简单的认证。在这里也可使用用户定义的宏变量

变量:场景级别的变量列表

头:当执行请求时HTTP头将被发送。Headers使用HTTP协议的语法列出,这将设置cURL选项CURLOPT_HTTPHEADER。例如:Accept-Charset:utf-8,Accept-Language: en-US,Content-Type: application/xml; charset=utf-8。在这里可使用Host.*和用户定义的宏变量

已启用:勾选此项为启用该Web场景

步骤标签配置页面以下所示,步骤配置页面中各参数的含义以下

名称:惟一的步骤名称

URL:须要监控的URL,支持HTTP或HTTPS协议。GET参数能够直接写在URL中,也可使用宏变量,长度不能超过2048个字符

Post:HTTP请求中的 POST变量。例如id=2345&userid={user},若是 {user} 是在web scenario中定义的宏变量,在step执行时会自动替换相应的值。这个变量会原样发送,不会进行URL编码

变量:步骤级别的变量列表

头(Headers):当执行请求时HTTP headers将被发送。Headers使用HTTP协议的语法列出。步骤级别上定义的Headers会覆盖scenario级别的Headers。在这里可使用HOST.*和用户定义的宏变量。这将设置cURL选项CURLOPT_HTTPHEADER

跟随跳转:勾选此项容许HTTP redirects(重定向)。这将设置cURL选项CURLOPT_FOLLOWLOCATION

仅获取头信息:勾选此项仅接收HTTP响应的headers。这将设置cURL选项CURLOPT_NOBODY

超时:超过设置的秒数后Zabbix不会再处理URL。实际上这个参数定义了最大的链接时间和完成HTTP请求的最大时间。所以Zabbix在步骤中处理URL不会超出2倍的设置时间

要求的字串:须要的正则表达式。除非接收的HTML中的内容匹配正则表达式,不然step将执行失败。若是该字段为空时不执行检测。这里须要注意不能引用在Zabbix 前端页面中建立的正则表达式。在这里也可使用宏变量

要求的状态码:设置指望的HTTP状态码列表,例如200,201,202-229。若是Zabbix收集的状态码在这个列表中没有时step将执行失败。若是该字段为空时不执行检测。在这里也可使用宏变量

配置第一个步骤:

配置第二个步骤:

认证标签配置页面以下所示,认证标签配置页面中各参数的含义以下:

HTTP 认证:身份验证选项。包括:

无:不使用身份验证。

基础的:使用基自己份验证。

NTLM:使用NTLM(Windows NT LAN Manager)身份验证。

选择基础的或NTLM时页面会出现用户名和密码的输入字段,在用户名和密码字段中可使用宏变量

SSL验证对端:勾选此项为验证web服务器的SSL证书。服务器证书会自动从系统CA的存储位置得到。你可使用Zabbixserver或 proxy server的配置文件中设置参数SSLCALocation保存证书。这将设置cURL选项CURLOPT_SSL_VERIFYPEER。

SSL 验证主机:勾选此项为验证web服务器证书匹配的Common Name 字段或Subject Alternate Name 字段。这将设置cURL选项CURLOPT_SSL_VERIFYHOST。

SSL 证书文件:用于客户端身份验证的 SSL 证书文件的名称。证书文件必须是 PEM1 格式。若是证书文件还包含私钥,则将 SSL Key文件字段留空。若是对密钥进行加密,在 SSL Key密码字段中指定密码。Zabbixserver或 proxy server的配置文件中设置参数SSLCALocation保存证书文件。在这里可使用HOST.*和用户定义的宏变量。这将设置cURL选项CURLOPT_SSLCERT。

SSL 秘钥文件:用于客户端身份验证 SSL 私钥文件的名称。私钥文件必须是PEM1格式。Zabbix server或 proxy server的配置文件中设置参数SSLCALocation保存证书文件。在这里可使用HOST.*和用户定义的宏变量。这将设置cURL选项CURLOPT_SSLKEY。

SSL 秘钥密码:SSL 私钥文件密码。在这里可使用用户定义的宏变量。这将设置cURL选项CURLOPT_KEYPASSWD。

这里的例子选择认证无

当全部的步骤添加后,点击添加按钮保存全部的配置。而后到监测中–> 最新数据页面中浏览items的数据以及图形

 

 

部份内容参考来源:https://www.ixdba.net/archives/2018/04/1138.htm

相关文章
相关标签/搜索