环境

CentOS7.5 + Zabbix 5.0 LTS

agent2方式监控

前提

官方提供的agent2支持的Oracle版本需要满足Oralce12C(12.2)及以上,低版本不支持,可能会报如下错

 

服务端导入模板

可以从官方下载对应版本的模板文件,比如这里下载5.0的模板:https://git.zabbix.com/projects/ZBX/repos/zabbix/browse/templates/db/oracle_agent2?at=release%2F5.0

注意:zabbix5.0及以前模板是用的xml格式,之后的版本模板用的是yml格式。

客户端安装agent2

安装官方源

# rpm -Uvh https://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
# yum clean all

安装agent2

# yum install zabbix-agent2 zabbix-agent2-plugin-*

修改配置

# vim /etc/zabbix/zabbix_agent2.conf
#设置服务端白名单
Server=192.168.15.122,192.168.15.96
#设置主动主动监控的服务端地址
ServerActive=192.168.15.122

启动agent2,设置开机启动

# systemctl restart zabbix-agent2
# systemctl enable zabbix-agent2

安装Oralce客户端

instantclient安装,根据实际需要安装sqlplus(若被监控端已有Oralce则最好不要安装)

wget https://download.oracle.com/otn_software/linux/instantclient/199000/oracle-instantclient19.9-basic-19.9.0.0.0-1.x86_64.rpm
wget https://download.oracle.com/otn_software/linux/instantclient/199000/oracle-instantclient19.9-sqlplus-19.9.0.0.0-1.x86_64.rpm
wget https://download.oracle.com/otn_software/linux/instantclient/199000/oracle-instantclient19.9-devel-19.9.0.0.0-1.x86_64.rpm
wget https://download.oracle.com/otn_software/linux/instantclient/199000/oracle-instantclient19.9-odbc-19.9.0.0.0-1.x86_64.rpm
yum localinstall oracle-instantclient19.9-*

环境变量配置

vim /etc/sysconfig/zabbix-agent2
LD_LIBRARY_PATH=/usr/lib/oracle/19.9/client64/lib:$LD_LIBRARY_PATH

监控账号配置

CREATE USER zabbix_mon IDENTIFIED BY zabbix_mon;
-- Grant access to the zabbix_mon user.
GRANT CONNECT, CREATE SESSION TO zabbix_mon;
GRANT SELECT ON DBA_TABLESPACE_USAGE_METRICS TO zabbix_mon;
GRANT SELECT ON DBA_TABLESPACES TO zabbix_mon;
GRANT SELECT ON DBA_FREE_SPACE TO zabbix_mon;
GRANT SELECT ON DBA_USERS TO zabbix_mon;
GRANT SELECT ON SYS.DBA_DATA_FILES TO zabbix_mon;
GRANT SELECT ON SYS.DBA_TEMP_FILES TO zabbix_mon;
GRANT SELECT ON GV_$SORT_SEGMENT TO zabbix_mon;
GRANT SELECT ON V_$ACTIVE_SESSION_HISTORY TO zabbix_mon;
GRANT SELECT ON V_$ARCHIVE_DEST TO zabbix_mon;
GRANT SELECT ON V_$ASM_DISKGROUP TO zabbix_mon;
GRANT SELECT ON V_$DATABASE TO zabbix_mon;
GRANT SELECT ON V_$DATAFILE TO zabbix_mon;
GRANT SELECT ON V_$INSTANCE TO zabbix_mon;
GRANT SELECT ON V_$LOG TO zabbix_mon;
GRANT SELECT ON V_$OSSTAT TO zabbix_mon;
GRANT SELECT ON V_$PGASTAT TO zabbix_mon;
GRANT SELECT ON V_$PROCESS TO zabbix_mon;
GRANT SELECT ON V_$RECOVERY_FILE_DEST TO zabbix_mon;
GRANT SELECT ON V_$RESTORE_POINT TO zabbix_mon;
GRANT SELECT ON V_$SESSION TO zabbix_mon;
GRANT SELECT ON V_$SGASTAT TO zabbix_mon;
GRANT SELECT ON V_$SYSMETRIC TO zabbix_mon;
GRANT SELECT ON V_$SYSTEM_PARAMETER TO zabbix_mon;
GRANT SELECT ON V_$PARAMETER TO zabbix_mon;
GRANT SELECT_CATALOG_ROLE TO zabbix_mon;

测试监控

 

ODBC监控方式

odbc监控方式是从Server端直接访问目标数据库进行数据采集,不需要经过目标服务器的agent,故下面的操作均是在Zabbix Server端操作。

安装odbc及client

这里可参考上面安装Oralce客户端的部分,安装相应的rpm包即可。

另外还有一些依赖包和ODBC连接器需要安装,比如libaio、libaio-devel、unixODBC unixODBC-devel,已经安装的就忽略。

配置LD路径(默认一般都有,不用手动配置)

#文件不存在,就手动创建,增加下面一行内容
vim /etc/ld.so.conf.d/oracle-instantclient.conf
/usr/lib/oracle/12.2/client64/lib

#执行命令
ldconfig

#检查全局的dll链接库配置是否正确
ldconfig -p | grep oracle
        libsqora.so.19.1 (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libsqora.so.19.1
        liboramysql19.so (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/liboramysql19.so
        libocijdbc19.so (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libocijdbc19.so
        libociei.so (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libociei.so
        libocci.so.19.1 (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libocci.so.19.1
        libnnz19.so (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libnnz19.so
        libmql1.so (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libmql1.so
        libipc1.so (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libipc1.so
        libclntshcore.so.19.1 (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libclntshcore.so.19.1
        libclntshcore.so (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libclntshcore.so
        libclntsh.so.19.1 (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libclntsh.so.19.1
        libclntsh.so (libc6,x86-64) => /usr/lib/oracle/19.9/client64/lib/libclntsh.so

配置环境变量

vi /etc/profile

export ORACLE_HOME=/usr/lib/oracle/19.9/client64
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/usr/lib64:$LD_LIBRARY_PATH
export TNS_ADMIN=$ORACLE_HOME/network/admin
export PATH=$PATH:$ORACLE_HOME/bin:$HOME/bin

#配置生效
source /etc/profile
#赋予可执行权限(若已有则跳过)
chmod +x /usr/lib/oracle/19.9/client64/lib/libsqora.so.19.1

添加Oralce驱动

vi /etc/odbcinst.ini

[Oracle]
Description     = ODBC for Oracle
Driver          = /usr/lib/oracle/19.9/client64/lib/libsqora.so.19.1

添加ODBC DSN

vi /etc/odbc.ini

[12c]
Driver = Oracle                        #刚才添加的驱动名称
ServerName = 10.11.100.211:1523/oracle12c    #ip:port/sid
UserID = zabbix_mon 
Password = zabbix_mon


#下面的内容可以不做,这里只是为了如果后续测试tnsnames的连接可以方便使用,不做也没关系
# mkdir -p $ORACLE_HOME/network/admin/
# vi $ORACLE_HOME/network/admin/tnsnames.ora
test=
   (DESCRIPTION =
     (ADDRESS = (PROTOCOL = TCP)(HOST = 10.11.100.211)(PORT = 1523))
     (CONNECT_DATA =
        (SERVER = DEDICATED)
        (SERVICE_NAME = oracle12c)   
     )
    )

检查数据库连接

首先确保,Zabbix Server到目标数据库的网络是通的。

# isql -v 12c
+---------------------------------------+
| Connected!                            |
|                                       |
| sql-statement                         |
| help [tablename]                      |
| quit                                  |
|                                       |
+---------------------------------------+
SQL> select * from dual;
+------+
| DUMMY|
+------+
| X    |
+------+
SQLRowCount returns -1
1 rows fetched
SQL> quit

 

配置监控模板

这里可以参考上面服务端导入模板部分的操作,然后就可以应用到主机上,在主机的宏里面配置好三个宏变量:

{$ORACLE.DSN}        =    12c     ##这里就是在odbc.ini文件配置的名字
{$ORACLE.PASSWORD}   =  zabbix_mon
{$ORACLE.USER}       =  zabbix_mon

遇到的问题

权限问题

官方提供的监控账号赋权语句不全,会导致在进行监控SQL查询获取数据的时候报表不存在、权限不足等错误,故增加了部分赋权语句,完整的赋权语句参见前面监控账号配置部分。

ERROR at line 1:
ORA-00942: table or view does not exist


select * from V$RESTORE_POINT where rownum<2
*
ERROR at line 1:
ORA-01031: insufficient privileges

SQL语句问题

因为官网的监控模板支持的数据库版本是12C及以上,所以在应用到低版本数据库的时候就会出现一些表或视图没有相应的字段,或不存在对应的表或视图的情况,这个时候根据实际情况进行调整即可。

在11g环境测试遇到的有两个地方需要做调整:

Oracle: Get instance state

监控语句如下:

--官方语句
SELECT
INSTANCE_NAME,
HOST_NAME,
VERSION || '-' || EDITION AS VERSION,
floor((SYSDATE - startup_time)*60*60*24) AS UPTIME,
decode(status,'STARTED',1,'MOUNTED',2,'OPEN',3,'OPEN MIGRATE',4, 0) AS STATUS,
decode(archiver,'STOPPED',1,'STARTED',2,'FAILED',3, 0) AS  ARCHIVER,
decode(instance_role,'PRIMARY_INSTANCE',1,'SECONDARY_INSTANCE',2, 0) AS  INSTANCE_ROLE
FROM v$instance;

--因为11g没有EDITION字段,故修改后如下
SELECT
INSTANCE_NAME,
HOST_NAME,
VERSION,
floor((SYSDATE - startup_time)*60*60*24) AS UPTIME,
decode(status,'STARTED',1,'MOUNTED',2,'OPEN',3,'OPEN MIGRATE',4, 0) AS STATUS,
decode(archiver,'STOPPED',1,'STARTED',2,'FAILED',3, 0) AS  ARCHIVER,
decode(instance_role,'PRIMARY_INSTANCE',1,'SECONDARY_INSTANCE',2, 0) AS  INSTANCE_ROLE
FROM v$instance;

自动发现项PDB discovery

因PDB是12C引入的特性,故11g不需要该项的监控,禁用掉即可。

posted on 2023-03-22 18:24  lzc_jack  阅读(1613)  评论(0编辑  收藏  举报