跳至主要内容

利用zabbix监控域名到期日期

 公司因为业务原因,注册了各种域名,大约有50多个吧。


因为域名后缀不同,分别注册在不同的域名服务商。

注册的时间和时长也各不相同,为避免出现域名过期而忘记续费,想出用zabbix来监控域名还剩多少天到期,以提醒续费。


比较好的域名信息查询工具是whois命令,whois + 要查询的域名就能得到相关信息。


因为.com、.cn还有.tw的域名信息都是不一样的,我不会写代码能力有限,所以分成三个脚本来分别处理。


切换到zabbix默认的外部检查脚本目录下

cd /usr/lib/zabbix/externalscripts/

新增com域名监控脚本

sudo nano domaincheck-com.sh

填入如下内容

#!/bin/bash

DOMAINS=$1

current_epoch=`date '+%s'`

expiry_date=`whois $1 | egrep -i "Expiration Date:|Expires on"| head -1 | awk '{print $NF}'`

expiry_epoch=`date --date="$expiry_date" '+%s'`

epoch_diff=`expr $expiry_epoch - $current_epoch`

echo `expr $epoch_diff / 86400`


然后赋予可执行权限

sudo chmod +x domaincheck-com.sh

测试一下是否可以获取剩余天数

./domaincheck-com.sh baidu.com

如正常这里会返回域名到期天数


然后新增一个模板,在监控项中填写键值:domaincheck-com.sh["{HOST.CONN}"]

类型:外部检查

信息类型:浮点数

单位:days

更新间隔:12h


然后根据需求填写相应的报警触发机制


另外两个模板制作方法类似,这里就不做复述了。

这里附上.cn和.tw获取域名剩余天数的脚本


CN域名的脚本domaincheck-cn.sh内容:

#!/bin/bash

DOMAINS=$1

current_epoch=`date '+%s'`

expiry_date=`whois $1 | egrep -i "Expiration Time:|Expires on"| head -1 | awk '{print $NF2}'`

d1=${expiry_date#*:}

expiry_epoch=`date --date="$d1" '+%s'`

epoch_diff=`expr $expiry_epoch - $current_epoch`

echo `expr $epoch_diff / 86400`


TW域名的脚本domaincheck-tw.sh内容:

#!/bin/bash

DOMAINS=$1

current_epoch=`date '+%s'`

expiry_date=`whois $1 | egrep -i "Record expires on:|Expires on"| head -1 | awk '{print $NF2}'`

d1=${expiry_date#*on}

expiry_epoch=`date --date="$d1" '+%s'`

epoch_diff=`expr $expiry_epoch - $current_epoch`

echo `expr $epoch_diff / 86400`

评论

此博客中的热门博文

PVE安装Windows 11虚拟机 step by step

Win 11已经发布有两周多了,因为引进了tpm机制,只支持较新的设备安装,对于虚拟机的支持不高。 目前各个虚拟化平台针对win 11已经有对应的方案,今天来介绍一下PVE 7.0安装win 11虚拟机。 提前下载win11和virtio win 11的镜像。 win 11镜像下载这里就不说了,很多途径。 virtio的镜像在这里下载https://github.com/virtio-win/virtio-win-pkg-scripts,下载最新的virtio win iso。 新建和配置虚拟机 点击新建虚拟机 给虚拟机起名,然后下一步。 选择加载win 11镜像文件,系统类型选择windows。 系统配置这里: bios选择OVMF(UEFI);机器选择q35;勾选TPM,并选择TPM版本为v2.0;然后存储的位置选择同一个存储。 硬盘设备选择VirtIO,磁盘大小选择64G,32G其实也可以,但是微软要求最低64G。 设置CPU和内存,微软要求最低2核8G,这里我们给4核8G,因为是单节点,所以CPU类型勾选host。 配置网卡信息后继续。 这里不要勾选自动创建后启动,确认配置信息后点击完成。 到新建的虚拟机这里,新建光驱。 选择下载的驱动镜像,点击创建。 完成后点击启动。 启动后进入windows安装界面,这里照一般操作进行。 到安装类型这里选择 自定义安装。 到选择安装位置这里会无法显示硬盘信息,因为缺少驱动,点击加载驱动程序。 然后点击浏览。 选择驱动镜像下的amd64下的w10文件夹,点击确定。 加载驱动后磁盘控制器能够显示,点击下一页。 选中显示的磁盘后点击下一步进行安装。 文件复制完后会重启几次。 安装完成后会启动第一次配置界面。 输入账户信息后进行系统配置。 配置完成后进入桌面。 在设备管理器中有一些设备未能正确识别。 进入驱动镜像,运行virtio-win-ge-x64安装文件安装驱动。 安装完成后,所有设备都能正确识别。 至此win11虚拟机安装完成。

搭建cups服务,并提供云打印服务。

Google的云打印服务已经在2020年底结束,所以不得不寻找新的解决方案。 之前家里使用一台windows虚拟机内置的打印服务,使用windows单单作为一台打印服务器实在是太过浪费。 因为家里有ubuntu的虚拟机跑plex服务,计划在ubuntu上运行打印服务。 linux上最为成熟的打印服务就是cups了,然后在软路由上搭建open vpn,即可实现任何地方打印文档。 一.cups服务安装。     首先安装cups服务     sudo apt install cups     修改配置文件     sudo  cp /etc/cups/cupsd.conf /etc/cups/cupsd.conf.bak     sudo nano  /etc/cups/cupsd.conf     新增监听地址     Listen 192.168.1.x:631      BrowseAllow all      BrowseAddress All      <Location />            Order allow,deny            Allow all      </Location>      <Location /admin>          Order allow,deny          Allow all     </Location>      <Location /admin/conf>     ...

安装部署JumpServer

 最近遭遇一起云主机因安全防护措施不到位被安装挖矿程序的情况。 为提高云主机的安全性和考虑搭建一台跳板机来访问云主机以提高安全性。 目前主流且还在维护的JumpServer是比较好的解决方案,搭建一台JumpServer做测试。 这里使用ubuntu 20.04 lts作为OS。 安装操作系统后先修改软件仓库为国内163源。 sudo cp /etc/apt/sources.list    /etc/apt/sources.list.bak sudo nano /etc/apt/sources.list 注释掉原来的内容 添加网易源 #网易源 deb http://mirrors.163.com/ubuntu/ focal main restricted universe multiverse deb-src http://mirrors.163.com/ubuntu/ focal main restricted universe multiverse deb http://mirrors.163.com/ubuntu/ focal-security main restricted universe multiverse deb-src http://mirrors.163.com/ubuntu/ focal-security main restricted universe multiverse deb http://mirrors.163.com/ubuntu/ focal-updates main restricted universe multiverse deb-src http://mirrors.163.com/ubuntu/ focal-updates main restricted universe multiverse deb http://mirrors.163.com/ubuntu/ focal-backports main restricted universe multiverse deb-src http://mirrors.163.com/ubuntu/ focal-backports main restricted universe multiverse 执行更新 sudo apt-g...