百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Z投稿 | 如何通过ODBC对接Oracle获取相关数据?

ccwgpt 2024-11-23 12:11 38 浏览 0 评论

目录

1. 什么是ODBC及其主要功能

2. 安装Oracle-instantclient

3. 配置SQLPlus连接

4. 配置Zabbix监控项

1.什么是ODBC

ODBC数据源全称是开放数据库互连(Open Database Connectivity),在微软公司开放的数据库结构中的一部分,其实是一个应用程序的接口,主要用于提供数据库的编写应用程序的能力。因为是微软公司发布的软件,ODBC也提供了SQL语句的支持,用户可以通过ODBC提供的API接口来使用和调度ODBC驱动程序,然后ODBC驱动程序通过SQL语言与数据库管理系统进行联系。

ODBC数据源在每台计算机中基本都存在,以WIN10为例,打开控制面板—系统工具—数据源 (ODBC),很见到可以找到。双击打开ODBC数据源管理器,该管理器主要用于配置、添加、删除各种不同的数据源,ODBC数据源对此专门进行了简洁化,可以让用户更加方便的进行数据源的配置。

ODBC数据源管理器的主要功能如下:

1. 用户DSN:ODBC用户数据源存储了如何与指定数据提供者连接的信息。用户数据源只对当前的用户可见,而且只能应用在本机上。

2. 系统DSN:ODBC系统数据源存储了如何与指定数据提供者连接的信息。系统数据源对当前机器上的所有用户可见。

3. 文件DSN:ODBC文件数据源允许用户连接数据提供者。文件DSN可以由安装了相同驱动程序的用户共享。

4. 驱动程序:ODBC驱动程序允许那些支持ODBC的程序通过ODBC数据源获取信息。如果安装新的驱动程序,要使用其安装程序。

5. 跟踪:ODBC跟踪允许创建调用ODBC驱动程序的日志,以供技术人员查看;也可以辅助调试应用程序。Visual Studio跟踪启动Microsoft Visual Studio的ODBC跟踪。

6. 连接池:连接池允许应用程序重新打开连接句柄,此操作将往返过程存入服务器。

以上是ODBC数据源管理器的主要功能,用户也可以通过ODBC数据源管理器删除原有的DNS,或者对以前配置的数据源进行修改,操作起来也很简单快捷。今天介绍的是Zabbix如何通过ODBC对接Oracle获取相关数据。

Zabbix官方文档请查看链接:

https://www.zabbix.com/documentation/5.0/manual/config/items/itemtypes/odbc_checks

2.安装Oracle-instantclient

Instant Client Downloads for Linux x86-64 (64-bit)

[下载地址](https://www.oracle.com/database/technologies/instant-client/linux-x86-64-downloads.html)。

我这边的Oracle数据库环境是Oracle11GR2 v11.2.0.4;首先去Oracle的官方网站下载最新的Oracle客户端。并在Zabbix主机上进行安装:

# 我们先把需要用到的四个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连接

在设置环境变量之前,需要在/usr/lib/oracle/19.9/client64下创建 network/admin 文件夹,用来配置 tnsnames.ora :

# 创建 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)

)

)

注:这里也可以去创建 listener.ora和sqlnet.ora 配置文件。创建 sqlnet.ora 作用是配置解析顺序, name/password@xxxxx xxxx会先去tnsnames寻找这个名字,没有的话会解析为IP NAME_DIRECTORY_PATH=(TNSNAMES,EZCONNECT) 。感兴趣的小伙伴可以自定测试,这里不再演示。

还需要配置环境变量。环境变量必须配置,否则会造成 [01000] unixODBCCan’t open lib ‘/usr/lib64/lxxxxx.so’ : file not found (执行一次即可)

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


添加Oracle驱动

# 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


添加Oracle数据源

# 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测试

isql -v Oracle

# 检测是否可连接及中间如遇到报错的错误信息(这里的Oracle要和DSN名称一致)

[root@ZabbixServer]# isql -v Oracle

+---------------------------------------+

| Connected! |

| |

| sql-statement |

| help [tablename] |

| quit |

| |

+---------------------------------------+

SQL>


SQLPlus测试连接

# 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监控项

测试正常之后就可以去Zabbix里面添加数据库架监控项,需要填入键值、用户名称、密码、具体的SQL查询语句、更新时间;信息类型修改为文本。具体配置信息如下:

配置完成以后我们可以点击下方的测试按钮,如果在结果里能获取到Result converted to 文本 OPEN 信息就代表成功了;可以去检测-最新数据里面看到已经成功拿到的数据。

相关推荐

VUE3前端开发入门系列教程二:使用iView框架辅助开发

1、安装iView新框架,支持VUE3npminstallview-ui-plus2、编辑src/main.js,添加以下内容,导入js和css到项目importViewUIPlusfrom...

万能前端框架uni app初探03:底部导航开发

前言本节我们使用uniapp的底部导航功能,点击不同tab会显示不同页面,这个功能在实际项目开发中几乎是必备的。一、基础知识1.tabBar如果应用是一个多tab应用,可以通过tabBar配...

Rust Web 开发框架,前端你可以选择哪个?

Rust构建一切。在如今流行的语言中,Rust可谓是将构建和高效作为自己优美的身姿在大众视野中脱颖而出。它是一门赋予每个人构建可靠且高效软件能力的语言。它有什么特性呢?高性能。Rust速度惊人且内...

连载:前端开发中纠结的Javascript框架(上)

如今,前端开发有着许许多多的框架和库。其中一些好用,一些却不尽人意。通常我们会习惯性运用某一概念,模块或句法。事实上,并没有什么万能工具。这篇文章是关于未来框架的发展趋势——那就是没有框架!我从以下几...

前端开发框架的演进架构:提升用户体验和开发效率

前端开发框架是现代Web应用开发的重要工具,它不仅可以帮助开发者构建复杂的用户界面,还能够提升用户体验和开发效率。随着Web技术的不断发展,前端开发框架也在不断演进,为开发者提供了更丰富、更高效的工具...

Google应用Mesh-TensorFlow框架,让CNN也能处理超高分辨率图像

为了要处理超高分辨率医疗图像数据,Google开发了一种空间数据分区(SpatialPartition)技术,在不牺牲图像分辨率的条件下,分析超高分辨率图像。Google使用Mesh-TensorF...

大模型安全挑战加剧:框架层漏洞成新靶心

近日,360数字安全集团发布了一份关于大模型安全漏洞的报告,揭示了当前大模型及围绕其构建的框架和应用中存在的严重安全问题。报告显示,360近期研究发现了近40个大模型相关的安全漏洞,其中既包括二进制内...

Keras 3.0正式发布:可用于TensorFlow、JAX和PyTorch

机器之心报道编辑:陈萍经过5个月的更新迭代,Keras3.0终于来了。「大新闻:我们刚刚发布了Keras3.0版本!」Keras之父FrancoisChollet在X上激动的...

TensorFlow和Keras入门必读教程(tensorflow与keras版本对应)

导读:本文对TensorFlow的框架和基本示例进行简要介绍。作者:本杰明·普朗什(BenjaminPlanche)艾略特·安德烈斯(EliotAndres)来源:华章科技01TensorFlo...

谷歌官方回应“TensorFlow遭弃”:还在投资开发,将与JAX并肩作战

鱼羊发自凹非寺量子位|公众号QbitAI终于,谷歌出面回应“TensorFlow遭弃”传闻:我们将继续致力于将TensorFlow打造为一流机器学习平台,与JAX并肩推动机器学习研究。这段时...

2025 年的PHP :现代 Web 开发的强大引擎

程序员还在吐槽PHP过时?2025年的PHP8.4直接封神了。看看最近更新的属性钩子、强类型系统,加上Laravel这些框架,老语言早就脱胎换骨。十年前说PHP弱类型容易崩代码的,现在脸疼不?联合类...

前端内卷终结者?htmx如何让开发者告别200行JS只做一个按钮

当你用React写一个点赞按钮需要引入3个状态管理库、编写80行JSX和120行钩子函数时,htmx只需要一行HTML:<buttonhx-post="/like"hx-sw...

NativePHP桌面版V1.0正式发布(元气桌面电脑版下载)

导读:各位小伙伴,使用PHP构建桌面级系统的利器,NativePHP来了。概述NativePHP是一个用于使用PHP构建桌面应用的框架。它允许PHP开发人员使用熟悉的工具和技术创建跨平台的原生应用...

PHP Laravel框架底层机制(php基本框架)

当然可以,Laravel是最受欢迎的PHP框架之一,以优雅的语法和丰富的生态而闻名。尽管开发体验非常“高端”,它的底层其实是由一系列结构清晰、职责分明的组件构成的。下面我从整体架构、核心流程、...

PHP框架之Laravel框架教程:2. 控制器、路由、视图简单介绍

2.控制器、路由、视图简单介绍我们先建立控制器,目录是:app/Http/Controllers,新建控制器Ding.php,代码如下:Ding.php:<?phpnamespaceA...

取消回复欢迎 发表评论: