zabbix企业应用之监控域名过期时间与ssl证书过期时间

简介:

如果各位维护过n多个域名,可能会对备案与续费有所了解,备案是十分麻烦,各种流程,而续费的话,虽然比较简单,但如果你没有提前续费,可能导致域名不可用,甚至被他人给恶意注册,为了解决这样的问他,我今天给各位分享一下,如何使用zabbix监控域名过期时间与ssl证书过期时间,默认的触发器是在域名或ssl证书要过期前60天通知。

下面是监控域名过期时间的效果图

wKiom1TIOHeTYbIlAARFBuMm5aY078.jpg

下面是监控ssl证书过期时间效果图

wKioL1TIOabg9BotAAKsOUQWSlM422.jpg

如何实现:

一、客户端

1、修改zabbix_agentd.conf文件

在zabbix_agentd.conf最后添加以下内容

1
2
UserParameter=check_domain_beian[*],python  /usr/local/zabbix_server/bin/check_domain_beian .py $1
UserParameter=check_ssl_cert_expire[*], /bin/bash  usr /local/zabbix_server/bin/check_ssl_cert_expire .sh $1 $2

其中check_domain_beian是监控域名过期时间,check_ssl_cert_expire是监控ssl证书过期时间

2、把下面脚本放入客户端的bin里(我的是放在/usr/local/zabbix_server/bin)

监控域名过期时间的脚本/usr/local/zabbix_server/bin/check_domain_beian.py内容为

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#/usr/bin/env python
#author:denglei
#email:dl528888@gmail.com
import  urllib2
import  urllib
import  sys
import  datetime
import  time
import  re
check_api= 'http://whomsy.com/api/%s?output=json' %sys.argv[1]
header={ "User-Agent" "Mozilla-Firefox5.0" }
result = urllib2.urlopen(check_api)
check_result = result. read ()
print check_result
c=re.findall( "GODADDY.COM*" ,check_result)
cc=re.findall( "GoDaddy*" ,check_result)
if  len(c) == 0 and len(cc) == 0:
     c=re.findall( "Registrar Registration Expiration Date.*" ,check_result)
     if  len(c) == 0:
         c=re.findall( "Expiration Date.*" ,check_result)
     m=re.search( "\d+-\d+-\d+..\d+:\d+:\d+" ,c[0])
     d=m.group()
     e=re.sub( 'T' , ' ' ,d)
elif  len(c) ==0 and len(cc) != 0:
     c=re.findall( "Record expires on.*" ,check_result)
     m=re.search( "\d+-\d+-\d+" ,c[0])
     d=m.group()
     e= time .strftime( "%Y-%m-%d %T" , time .strptime(d, '%Y-%m-%d' ))
else :
     c=re.findall( "Expiration Date.*" ,check_result)
     m=re.search( "\d+-\w+-\d+" ,c[0])
     if  m is None:
         m=re.search( "\w+ \w+ \d+ \d+:\d+:\d+ \w+ \d+" ,c[0])
         d=m.group()
         e= time .strftime( "%Y-%m-%d %T" , time .strptime(d, '%a %b %d %H:%M:%S %Z %Y' ))
     else :
         d=m.group()
         e= time .strftime( "%Y-%m-%d %T" , time .strptime(d, '%d-%b-%Y' ))
if  len(c) == 0:
     e= ''
def conver_time(start_time):
     start_time=start_time
     now_time= time .strftime( '%Y-%m-%d %H:%M:%S' )
     warn_start=datetime.datetime.strptime(start_time, "%Y-%m-%d %H:%M:%S" )
     warn_finish=datetime.datetime.strptime(now_time, "%Y-%m-%d %H:%M:%S" )
     #td=warn_finish - warn_start
     td=warn_start - warn_finish
     warn_continue=(td.microseconds + (td.seconds + td.days * 24 * 3600) * 10**6) / 10**6
     if  warn_continue >= 86400 :
     day = warn_continue  //  86400
     return  day
if   len(e) != 0:
     print conver_time(e)
else :
     print  '1'

我是使用python来实现,使用whomsy接口获取信息,然后通过正则过滤出结果。

ps:网上虽然有很多接口可以使用,但好多都是过期或者需要花钱的,免费的话,也限制了监控的频率,我的域名比较多所以只能自己弄了。

下面是监控ssl证书的脚本check_ssl_cert_expire.sh内容

1
2
3
4
5
6
7
8
9
10
11
12
13
14
#/bin/bash
host=$1
port=$2
end_date=`openssl s_client -host $host -port $port -showcerts < /dev/null  2> /dev/null  |
           sed  -n  '/BEGIN CERTIFICATE/,/END CERT/p'  |
       openssl x509 -text 2> /dev/null  |
       sed  -n  's/ *Not After : *//p' `
if  [ -n  "$end_date"  ]
then
     end_date_seconds=` date  '+%s'  -- date  "$end_date" `
# date指令format字符串时间。
     now_seconds=` date  '+%s' `
     echo  "($end_date_seconds-$now_seconds)/24/3600"  bc
fi

ps:这个脚本是我在网上找的,非原创

重要:如果想使用这个脚本监控ssl证书,需要ssl证书在服务器里使用,否则没办法监控的。

3、重启zabbix客户端服务

1
2
ps  -ef| grep  zabbix| grep  - v  grep | awk  '{print $2}' | xargs  kill  -9
/usr/local/zabbix/sbin/zabbix_agentd  -c  /usr/local/zabbix/conf/zabbix_agentd .conf

二、服务端

1、域名过期时间的项目

wKioL1TIPKCiG389AAG3HUfmekU299.jpg

我是1小时监控一次,大家可以设置更长,但别大于一天。

2、监控域名过期时间的触发器

wKioL1TIPTmh-AzRAADoX_K7z_Q100.jpg

只要还有60天就过期报警,报警级别是“一般严重”,我这里报警级别为”一般严重“为短信或邮件通知,”严重“报警为语音报警通知。

3、监控ssl证书过期时间项目

wKioL1TIPe6hA11OAAGuFZu2fbY466.jpg

4、监控ssl证书过期时间的触发器

wKioL1TIPi-DEIwDAADP5D4izzU170.jpg

我监控的话,是一个主机监控多个域名或者ssl证书,所以我没有弄成模板,如果你想一个主机监控一个域名,可以弄成模板。有问题留言,我会及时反馈。







 本文转自 reinxu 51CTO博客,原文链接:http://blog.51cto.com/dl528888/1609028,如需转载请自行联系原作者

相关实践学习
基于函数计算快速搭建Hexo博客系统
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
相关文章
|
2月前
|
域名解析 应用服务中间件 Linux
【服务器】使用域名解析服务器的IP地址并配置SSL证书
【服务器】使用域名解析服务器的IP地址并配置SSL证书
438 0
|
3月前
|
存储 SQL 监控
修改Zabbix源码实现监控数据双写,满足业务需求!
虽然对接Elasticsearch后有诸多好处,但是它不往数据库写历史数据了,同时还不再计算趋势数据了。有这么一个场景...
修改Zabbix源码实现监控数据双写,满足业务需求!
|
4月前
|
数据采集 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
77 4
|
4月前
|
监控 关系型数据库 机器人
小白带你学习linux的监控平台zabbix
小白带你学习linux的监控平台zabbix
137 0
|
30天前
|
安全 网络安全 数据安全/隐私保护
SSL证书过期后网站还能正常访问吗
SSL证书过期后,网站仍可访问,但浏览器会出现警告,降低用户信任度,增加数据安全风险。过期可能导致安全性下降、信任问题、浏览器限制及合规性风险。管理员需关注证书有效期,及时续费或更换,并选择可靠提供商。
SSL证书过期后网站还能正常访问吗
|
1月前
|
数据采集 监控 数据库
请问OceanBase社区版能否通过zabbix监控,然后将报错信息展现到grafana?
【2月更文挑战第25天】请问OceanBase社区版能否通过zabbix监控,然后将报错信息展现到grafana?
25 2
|
2月前
|
监控 Cloud Native 关系型数据库
使用 Grafana 统一监控展示 - 对接 Zabbix
使用 Grafana 统一监控展示 - 对接 Zabbix
|
4月前
|
监控 Docker 容器
Zabbix【部署 03】zabbix-agent2安装配置使用(zabbix-agent2监控docker实例分享)
Zabbix【部署 03】zabbix-agent2安装配置使用(zabbix-agent2监控docker实例分享)
241 0
|
4月前
|
监控 Java
Zabbix【部署 02】Zabbix-Java-Gateway安装配置使用(使用Zabbix-Java-Gateway通过JMX监控Java应用程序实例分享)
Zabbix【部署 02】Zabbix-Java-Gateway安装配置使用(使用Zabbix-Java-Gateway通过JMX监控Java应用程序实例分享)
90 0
|
17天前
|
监控 关系型数据库 应用服务中间件
zabbix自定义监控、钉钉、邮箱报警
zabbix自定义监控、钉钉、邮箱报警,实验准备,安装,添加监控对象,添加自定义监控项,监控mariadb,监控NGINX,钉钉报警设置,邮件报警
136 0

推荐镜像

更多