感谢作者邹坤投稿!
其个人博客:https://blog.z0ukun.com/。
目 录
1. 什么是ODBC及其主要功能
2. 安装Oracle-instantclient
3. 配置SQLPlus连接
4. 配置Zabbix监控项
1. 什么是ODBC


2. 安装Oracle-instantclient
# 我们先把需要用到的四个rpm离线包下载到本地
mkdir -p oracle
cd oracle
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
# 在安装客户端之前我们还需要在zabbix上安装unixODBC和unixODBC-devel(这两个包我们直接在线安装即可)
yum -y install unixODBC unixODBC-devel
# 安装完成之后我们直接通过下面的命令安装 oracle-instantclient
yum localinstall oracle-instantclient19.9-*
# oracle-instantclient的安装位置如下
/usr/lib/oracle/19.9/client64
/usr/share/oracle/19.9/client64
/usr/include/oracle/19.9/client64复制
3. 配置SQLPlus连接
# 创建 network/admin 文件夹
mkdir /usr/lib/oracle/19.9/client64/network/admin -p
# 配置 tnsnames.ora 文件
Oracle=
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.16.200.110)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = 数据库SID)
)
)复制
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复制
chmod +x /usr/lib/oracle/19.9/client64/lib/libsqora.so.19.1
cd /usr/lib64/
ln -s libodbcinst.so.2.0.0 libodbcinst.so.1复制
# Example driver definitions
# vi /etc/odbcinst.ini
[Oracle]
Description = Oracle ODBC driver for Oracle 11g
Driver = /usr/lib/oracle/19.9/client64/lib/libsqora.so.19.1复制
# vi /etc/odbc.ini
# 配置示例
[DSN名称] 将在zabbix item key中使用
Driver = oracle tnsnames.ini 配置的驱动名称
ServerName = ip:port/sid ip:port/sid
UserID = 用户名 用户名
Password = 密码 密码
# 具体配置
[Oracle]
Driver = Oracle
ServerName = 172.16.200.241:1521/数据库SID
UserID = XXX
Password = XXX复制
isql -v Oracle
# 检测是否可连接及中间如遇到报错的错误信息(这里的Oracle要和DSN名称一致)
[root@ZabbixServer]# isql -v Oracle
+---------------------------------------+
| Connected! |
| |
| sql-statement |
| help [tablename] |
| quit |
| |
+---------------------------------------+
SQL>复制
# sqlplus 用户名/密码@tnsnames.ora中配置的连接名称
[root@ZabbixServer ~]# sqlplus 用户名/用户密码@DSN名称
SQL*Plus: Release 19.0.0.0.0 - Production on Sun Dec 6 11:34:11 2020
Version 19.9.0.0.0
Copyright (c) 1982, 2020, Oracle. All rights reserved.
???:
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
SQL>复制
4. 配置Zabbix监控项




延伸阅读
Z投稿|12000nvps下Zabbix性能维护—某支付平台经验分享
欢迎投稿分享你的经验,请以md格式发至小Z,审核通过后发布。
2021在线课本周四晚8点:告警的调用和处理!
最实用的课程,由社区专家张世宏毫无保留授课,还可以向老师交流日常疑问。点此报名本节课。



关注Zabbix开源社区
干货满满
加“小Z“入群
3000+Zabbixer已加入
文章转载自Zabbix开源社区,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。