zabbix通过ODBC监控sybase举例

≯℡__Kan透↙ 提交于 2020-02-28 11:10:42

本文用到的ODBC和freetds,请参考一下两个网址,进行安装:
https://www.zabbix.com/documentation/4.0/zh/manual/config/items/itemtypes/odbc_checks
https://www.zabbix.com/documentation/4.0/zh/manual/config/items/itemtypes/odbc_checks/unixodbc_mssql
ODBC自动发现规则理论知识:
https://www.zabbix.com/documentation/4.0/zh/manual/config/items/itemtypes/odbc_checks/unixodbc_mssql
说明:
用ODBC的freetds模板,能从zabbix服务器上远程监控sybase的一些信息,但是需要sybase的sql查询语句,同时仅通过zabbix的odbc监控,无法执行一些sp_命令,如sp_helpdb 。如需要使用sp_的命令监控,可以用python的pexpect模块模拟执行isql命令远程登录,然后执行查询sql语句。

1.在sybase数据上新建用于监控的普通用户

在sybase服务器上:

(1).查看sybase进程
[size=12.0000pt]ps -ef | grep sybase

zabbix通过ODBC监控sybase举例

(2).新建监控用户
su - sybase
isql -Usa -Psybase -H192.168.2.6:5000 [size=12.0000pt]-SLOCALHOST
sp_addlogin zabbix,zabbix
go
[size=12.0000pt]
sp_adduser zabbix,zabbix
go
[size=12.0000pt]
sp_role 'grant',mon_role,zabbix
go

(3).查看用户信息:
sp_helpuser zabbix
go
zabbix通过ODBC监控sybase举例

(4).查看用户zabbix的权限
sp_helprotect zabbix
go

有些版本的sybase需要重启数据库使新建用户生效,生产环境需要 谨慎重启!!!!
测试监控用户是否能正常登录:
isql -Uzabbix -Pzabbix -H192.168.2.6:5000 -SLOCALHOST
能登录即配置完成。

2.在zabbix服务器上配置odbc远程登录信息

vi /etc/freetds.conf
文件最下面加上以下内容:
[192.168.2.6]
host = 192.168.2.6
port = 5000
tds version = 4.2
client chaeset = UTF-8

说明:
[192.168.2.6]是可以自定义的名字。
host是主机名称或IP
port是sybase数据的监听端口
tds version保持默认,有4.2,5.0,7.0,8.0。连接失败可以试下换一个版本
client chaeset客户端软件可识别的字符集,保持默认

测试连通性
tsql -S 192.168.2.6 -U 'zabbix'
如果输入密码无报错后出现“ 1> ”,则表示配置成功。(密码:zabbix)

配置添加ODBC数据源
vi /etc/odbc.ini
[192.168.2.6]
Driver = FreeTDS
Description = 192.168.2.6
Trace = NO
Servername = 192.168.2.6

参数说明:
[LOCALHOSTODBC]是数据源的名字,可以自定义
Driver 是/etc/odbcinst.ini里定义的名称(保持默认)
Description 使用在 freetds.conf中定义的名称(instance替换“-”)
Servername 使用在 freetds.conf中定义的名称
注:odbc.ini这个文件的每行行首和行尾不能有一个空格,有空格会出现报错:
[S1000][unixODBC][FreeTDS][SQL Server]Unable to connect to data source
[ISQL]ERROR: Could not SQLConnect

vi /etc/odbcinst.ini
确认是否有下面这段:
[FreeTDS]
Description=ODBC of FreeTDS for SQL Server
Driver=/usr/lib/libtdsodbc.so.0
Setup=/usr/lib/libtdsS.so
Driver64=/usr/lib64/libtdsodbc.so.0
Setup64=/usr/lib64/libtdsS.so
FileUsage=1

测试远程登录
isql -v 192.168.2.6 'zabbix' 'zabbix[size=12.0000pt]'
说明:isql -v DSN名称 '用户名' '密码'

3.在zabbix网页端建立syabse的odbc监控模板

新建3个宏值 {$ODBC} 、 {$USER} 、 {$PASSWORD}

zabbix通过ODBC监控sybase举例

新建监控项例子:

(1).当前连接数
zabbix通过ODBC监控sybase举例
名称:当前连接数
类型:数据库监控
键值:db.odbc.select[connections,{$ODBC}]
用户名称:{$USER}
密码:{$PASSWORD}
SQL查询:select count(*) from master.dbo.sysprocesses where ipaddr!=NULL
信息类型:数字(无正负)
更新间隔:300
zabbix通过ODBC监控sybase举例

(2).最大连接数
zabbix通过ODBC监控sybase举例
名称:最大连接数
类型:数据库监控
键值:db.odbc.select[max_connections,{$ODBC}]
用户名称:{$USER}
密码:{$PASSWORD}
SQL查询:select @@max_connections
信息类型:浮点数
更新间隔:3600
zabbix通过ODBC监控sybase举例

(3).数据库版本
zabbix通过ODBC监控sybase举例
名称:数据库版本
类型:数据库监控
键值:db.odbc.select[version,{$ODBC}]
用户名称:{$USER}
密码:{$PASSWORD}
SQL查询:select @@version
信息类型:浮点数
更新间隔:3600
zabbix通过ODBC监控sybase举例

新建自动发现规则例子:
zabbix通过ODBC监控sybase举例
zabbix通过ODBC监控sybase举例

名称:master表空间
类型:数据库监控
键值:db.odbc.discovery[tablespace,{$ODBC}]
用户名称:{$USER}
密码:{$PASSWORD}
SQL查询:select name = object_name(sysindexes.id) from sysindexes, sysobjects where sysindexes.id = sysobjects.id and sysindexes.id > 100 and indid =0
更新间隔:3600
过滤器: {#NAME} 匹配 @sybase table space
zabbix通过ODBC监控sybase举例
监控项原型:
zabbix通过ODBC监控sybase举例
名称:表{#NAME}分配的空间大小
类型:数据库监控
键值:db.odbc.select[{#NAME}reserved,{$ODBC}]
用户名称:{$USER}
密码:{$PASSWORD}
SQL查询:select reserved_pages(db_id(),id)/(1024.0 / @@maxpagesize)*1024 from sysobjects where name = '{#NAME}'
信息类型:数字(无正负)
单位:B
更新间隔:300

已使用空间查询语句:
select used_pages(db_id(),id)/(1024.0 / @@maxpagesize)*1024 from sysobjects where name = '{#NAME}'
行数查询语句:
select row_count(db_id(), id) from sysobjects where name = '{#NAME}'

更多技术问题,欢迎交流

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!