利用Zabbix ODBC monitoring监控SQL Server

1. 创建群组ODBC Templates

 

2. 创建Template SQL Server和Template MySQL

 

3. 在Zabbbix上安装unixODBC

shell> yum -y install unixODBC unixODBC-devel

 

4. 在Zabbix上安装对应数据库的unixODBC驱动

unixODBC有一个支持的数据库和驱动列表:

 

对于SQL Server:

 

a) 安装unixODBC驱动

shell> yum install freetds

 

b) 配置unixODBC

我们通过编辑odbcinst.ini和odbc.ini文件来完成ODBC的配置。首先,通过如下命令来验证配置文件的位置:

shell> odbcinst -j

 

可以使用如下命令来查找ODBC驱动的的位置:

shell> find / -name 'libtdsodbc*'

 

在/etc/odbcinst.ini添加SQL Server驱动FreeTDS:

shell> vim /etc/odbcinst.ini

[FreeTDS]

Description = ODBC for SQL Server

Driver = /usr/lib64/libtdsodbc.so.0

Setup = /usr/lib64/libtdsS.so

FileUsage = 1

 

FreeTDS驱动有个命令行工具tsql也可以连SQL Server,它也可一个文件/etc/freetds.conf可以配置连接SQL Server的DSN。

 

SQL Server各版本对应的TDS协议版本:

 

配置odbc连接信息:

shell> vim /etc/odbc.ini

[szsql01]

Driver = FreeTDS

Server = 192.168.137.6

Port = 1433

Database = DBAdmin

TDS_Version = 8.0

 

这次,我们不在文件里设置用户名密码,而在页面设置。

 

来检查是否驱动看到了你的数据源:

shell> odbcinst -q –s

 

c) 在被监控的SQL Server 2016服务器szsql01上创建用户并授权。

 

d) 在Zabbix上连接数据库测试。

shell> isql -v szsql01 数据库用户名 密码

 

e) 在szsql01上安装zabbix 3.2代理。

以管理员方式打开Powershell,下载安装包。

解压缩后,将zabbix_agents_3.2.0.win重命名为zabbix,将conf目录下的配置文件拷贝一份到上级目录下,并重命名为zabbix_agentd.conf,编辑并更新以下值。

#Server=[zabbix server ip]

#Hostname=[Hostname of client system]

Server=192.168.137.5

ServerActive=192.168.137.5

Hostname=192.168.137.6

 

注意:Hostname要和创建Host时填写的一样。

 

将zabbix agent安装为服务,并启动服务:

检查代理启动的错误日志c:\zabbix_agentd.log,看是否正常。

 

f) 在Zabbix新建的Template SQL Server模板添加监控项

 

g) 将被监控服务器szlinux01连接该模板,并查看数据:

参考: