跳至主要内容

zabbix监控AD同步抄写

公司在各地分公司都有多台域控制器,相互之间同步抄写数据。
偶然发现发现有一台没怎么用的域控制器长期同步失败,因为这个同步检查很少出问题,就算出现问题也很难察觉。



查询了一下ad 同步检查工具Repadmin的用法。
比较直观的就是repadmin /replsum可以得出最近的同步结果。
这个总体统计,查看错误和失败的数量,以及错误原因。


找了一下其他命令的用法,找到一个参数 /showrepl,会返回林中每个域控制器最近一次同步的结果。

成功会显示为successful,失败或错误会显示failed和error。
那么只需要统计失败和错误的计数,就可以知道同步是否出错。

接下来准备监控的脚本。

一,zabbix客户端上。
    1.在域控制器上写两个bat脚本,内容为repadmin /showrepl和repadmin /replsum。
    将这两个bat脚本的路径加入系统path以执行。

    2.然后在zabbix agent上添加脚本和查询参数。
    编辑C:\Program Files\Zabbix Agent\zabbix_agent.conf末尾加入
    Include=C:\Program Files\Zabbix          Agent\scripts\ADReplication\repadmin_showrepl.conf

    3.编辑Include=C:\Program Files\Zabbix                        Agent\scripts\ADReplication\repadmin_showrepl.conf内容为:
#查找同步失败的计数
UserParameter=repadmin.showreplfailed,repadmin_showrepl.bat | find /C "failed"
#查找同步错误的计数。
UserParameter=repadmin.showreplerror,repadmin_showrepl.bat | find /C "error"
#统计合计信息。
UserParameter=repadmin.replsum,repadmin_replsum.bat

    4.在域控制器上重启zabbix agent。


二,zabbix服务端。
    1.新增AD repadmin的模板。
    2.在模板中新增应用级AD repadmin。
    3.在模板中加入三个监控项。
        a.replication sum
            键值:repadmin.replsum
            信息类型:文本





        b.Replication error
            键值:repadmin.showreplerror
            信息类型:数字




        c.Replication failed
            键值:repadmin.showreplfailed
            信息类型:数字


    
    4.新增触发器。
        a.Replication error
            表达式:{AD repadmin:repadmin.showreplerror.last()}<>0
            严重性:一般严重。
        b.Replication failed
            表达式:{AD repadmin:repadmin.showreplfailed.last()}<>0
            严重性:一般严重。
    
刚好周末有一个site机房搬迁,设备会关机,验证该脚本可以达到效果。



监控项确定正常运作后,加入trigger,发送报警通知。



评论

此博客中的热门博文

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>          Order allow,deny          Allow all     </Location>     然后用浏览器访问https://192.168.1.x:631/admin     添加打印机     add printer     选择local printer里本地的打印机 然后点击下一步     勾选share this printer然后点击下一步     在model里寻找打印机型号,如果没有需要安装打印机     我的打印机是epson入门型号l310,需要手动安装。     去epson的网站https://download.ebz.epson.net/dsc/search/01/search/searchModule寻

利用Nextcloud搭建私有云盘

最近有同学的手机丢了,幸运的是手机最后有找回来。 大部分人手机里有非常多的照片,手机丢了可以买新的,照片丢了就再也找不回来了。因此数据的备份显得非常重要。 因为家里有NAS做raid 1,并且定期做异地备份,数据的安全性还是蛮高的。就有搭建私有云盘的想法。 上网搜索了一下,发现nextcloud是用得比较多的。此次就选用nextcloud来搭建我们的私有云盘。 首先在家里的服务器上新建一台vm,这里选用debian 11,装系统的过程就不讲了。 安装完成后,利用nfs挂载nas的存储 新建挂载目录 mkdir /mnt/nextcloud 编辑/etc/fstab,加入如下一行 192.168.x.x:/volume1/NextCloud /mnt/nextcloud nfs defaults 0 0 这里ip地址和nas存储路径用自己的配置替代 然后sudo mount -a测试一下 接下来开始安装依赖件 安装mariadb sudo apt update sudo apt -y install mariadb-server mariadb-client 配置数据库 sudo mysql_secure_installation  sudo mysql -u root -p 输入配置的密码以登录 配置nextcloud的数据库和用户 CREATE USER 'nextcloud'@'localhost' IDENTIFIED BY '密码'; CREATE DATABASE nextcloud; GRANT ALL PRIVILEGES ON nextcloud.* TO 'nextcloud'@'localhost'; FLUSH PRIVILEGES; QUIT 安装php和apache2 sudo apt -y install php php-{cli,xml,zip,curl,gd,cgi,mysql,mbstring} sudo apt -y install apache2 libapache2-mod-php 修改php配置 sudo vim /etc/php/*/apache2/php.ini date.timezone = Asia/Shanghai memory_lim