测试环境:

ip 数据库版本
192.168.254.135 oracle 11g
192.168.254.137 V008R006C005B0023

通过oracle官网得知,Oracle使用DG4ODBC作为连接到其他非Oracle数据库的数据网关。其原理图如下:



所以我们需要在Oracle服务器安装unixODBC和KingbaseES的ODBC驱动。

1.root用户登录到oracle数据库服务器。

2.安装unixODBC

yum install unixODBC.x86_64 注:unixODBC可能默认装系统的时候就已经安装上了。

[root@oracledb ~]# odbcinst -j
unixODBC 2.3.1
DRIVERS............: /etc/odbcinst.ini
SYSTEM DATA SOURCES: /etc/odbc.ini
FILE DATA SOURCES..: /etc/ODBCDataSources
USER DATA SOURCES..: /root/.odbc.ini
SQLULEN Size.......: 8
SQLLEN Size........: 8
SQLSETPOSIROW Size.: 8

注意:由于不同版本之间存在差异,为了保证能读取正确的配置,强烈建议统一使用用户主目录下 .odbc.ini 文件。

3.安装KingbaseES的ODBC驱动

KingbaseES 安装完成后在数据库安装目录下的 Interface/odbc 中就有odbc驱动,所以这里只要将文件拷贝到oracle主机上即可。

scp 192.168.254.137://home/kingbase/kdb/Interface/odbc/* /usr/local/lib/

设置文件权限为755。chmod 755 /usr/local/lib/* 我的/usr/local/lib/目录原来是空目录,这里直接用*了。

4.配置ODBC

[root@oracledb lib]# cat /etc/odbcinst.ini
# Example driver definitions # Driver from the postgresql-odbc package
# Setup from the unixODBC package
[kdb]
Description = ODBC for kingbase
Driver64 = /usr/local/lib/kdbodbcw.so
Setup64 = /usr/lib64/libodbcpsqlS.so
FileUsage = 1 kdbodbcw.so是KingbaseES ODBC驱动的库。
libodbcpsqlS.so 是unixODBC的库。 [root@oracledb ~]# cat .odbc.ini
[V8]
Description = kdb test
Driver = kdb
Database = test
Servername = 192.168.254.137
UserName = system
Password = system
Port = 54321
ReadOnly = 0
ConnSettings = set client_encoding to UTF8

这里Driver与odbcinst.ini中的[kdb]对应,可以取任何名字,但两者需要相同。

[V8]是一个自定义的连接数据库的配置名称,其它应用程序就是引用这个名称访问数据库。

5.验证ODBC连接

[root@oracledb ~]# isql -v V8
+---------------------------------------+
| Connected! |
| |
| sql-statement |
| help [tablename] |
| quit |
| |
+---------------------------------------+
SQL> select version();
+--------------------------------------------------------------------------------------------------------------------------+
| version |
+--------------------------------------------------------------------------------------------------------------------------+
| KingbaseES V008R006C005B0023 on x86_64-pc-linux-gnu, compiled by gcc (GCC) 4.1.2 20080704 (Red Hat 4.1.2-46), 64-bit |
+--------------------------------------------------------------------------------------------------------------------------+
SQLRowCount returns 1
1 rows fetched

测试能够正常连接数据库并查询。

将.odbc.ini 配置文件拷贝一份到oracle用户的home目录下,确认文件属性是否正确。

下面来配置 oracle 透明网关部分,使用oracle用户来操作,共涉及3个文件。

$ORACLE_HOME/network/admin/listener.ora

$ORACLE_HOME/hs/admin/init<SID_NAME>.ora

$ORACLE_HOME/network/admin/tnsnames.ora

在 cd $ORACLE_HOME/hs/admin 目录下有 监听和tns配置的示例文件。

1.配置listener.ora

SID_LIST_LISTENER=
(SID_LIST=
(SID_DESC=
(SID_NAME=KINGBASE)
(ORACLE_HOME=/home/oracle/app/oracle/product/11.2.0/dbhome_1)
(PROGRAM=dg4odbc)
)
)
在listener.ora文件中添加上面这段内容。
其中SID_LIST_LISTENER后面的这个LISTENER是监听器的名字,默认的都是这个。
SID_NAME=KINGBASE KINGBASE为自定义名称。这个名称将决定init<SID_NAME>.ora这个文件的名称(大小写要一致)

2.创建init<SID_NAME>.ora

cd $ORACLE_HOME/hs/admin/initKINGBASE.ora
根据监听的配置,这里创建initKINGBASE.ora
[oracle@oracledb admin]$ cat initKINGBASE.ora
HS_FDS_CONNECT_INFO = V8
HS_FDS_TRACE_LEVEL = 0
HS_FDS_SHAREABLE_NAME = /usr/local/lib/kdbodbcw.so
HS_NLS_NCHAR=UCS2
HS_LANGUAGE=AMERICAN_AMERICA.AL32UTF8
set ODBCINI= /home/oracle/.odbc.ini

3.配置 tnsnames.ora

KINGBASE  =
(DESCRIPTION=
(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))
(CONNECT_DATA=(SID=KINGBASE))
(HS=OK)
) SID=KINGBASE 这个listener.ora文件中的sid设置一样。
第一行的KINGBASE = 可设置为任意名称,供后续创建数据库链时使用。

4.重启或者重载监听。

5.连接oracle创建数据库链,测试。

create database link to_kingbase connect to "system" identified by "system" using 'KINGBASE';

在KingbaseES数据库中创建表并插入数据

在oracle数据库中进行查询

Oracle通过数据库链连接KingbaseES的更多相关文章

  1. Oracle之数据库的连接

    Oracle 默认用户 数据库创建完毕后,需要设置数据库的默认用户.Oracle中为管理员预置了两个用户分别是SYS和SYSTEM.SYS的初始密码为Oracle安装时设置的数据库口令 admin,在 ...

  2. Tomcat7中配置Oracle 11g数据库DBCP连接池

    将       ojdbc6.jar       tomcat-jdbc-7.0.37.jar            拷贝到工程的WEB-INF\lib  下面 一.在Tomcat的配置文件Tomca ...

  3. Oracle远程数据库一直连接不上的原因:多了个空格

  4. DBCP连接Oracle,数据库重启后现OALL8 is in an inconsistent state异常

    最近,DBCP连接Oracle,数据库重启后现OALL8 is in an inconsistent state异常. 版本说明 commons-dbcp-1.4.jar commons-pool-1 ...

  5. plsql通过instantclient连接oracle数据库报连接超时

    配置:数据库oracle10.2;服务器操作系统centos5.5:客户机操作系统win7 32位:plsql版本10.0.5 配置前提必须关闭客户机与服务器操作系统的防火墙,否则会出现“连接超时”的 ...

  6. 涂抹Oracle笔记2:数据库的连接-启动-关闭

    一.数据库的连接sqlplus <username>[/<password>][@<connect_idertifier>]|/[as sysdba| as sys ...

  7. Oracle 连接 另一个Oracle数据库 服务器连接

    一.场景   两台不同的服务器A.B分别装有不同业务的oracle数据库,因业务需要,现需要将B中test表的数据,定时同步到A中. 二.实现   根据以上场景,我想到了oracle中的dblink, ...

  8. oracle数据库无法连接 The Network Adapter could not establish

    Caused by: java.sql.SQLException: Io 异常: The Network Adapter could not establish the connection 这个错误 ...

  9. Java连接Oracle/MySQL数据库教程

    一.下载 oracle java驱动下载地址:http://www.oracle.com/technetwork/database/enterprise-edition/jdbc-112010-090 ...

  10. java oracle thin 和 oci 连接方式实现多数据库的故障切换

    java oracle thin 和 oci 连接方式实现多数据库的故障切换 一.thin方式 该种方式简便易用非经常见. 当中URL为 jdbc:oracle:thin:@(DESCRIPTION= ...

随机推荐

  1. Rollup的基本使用

    Rollup的基本使用 rollup.js是一个模块打包工具,可以使项目从一个入口文件开始,将所有使用到的模块文件都打包到一个最终的发布文件中,Rollup极其适合构建一个工具库,Vue.js源码就是 ...

  2. Annotation-specified bean name conflicts with existing

    问题说明 Annotation-specified bean name conflicts with existing,non-compatible bean definition of same n ...

  3. Springboot实现remember-me记住我功能

    1.什么是remeber-me? remeber-me即记住我功能,是我们在登录web系统时的常见勾选项.当我们登录一个web系统时除了输入常规的用户名.密码后还可以勾选记住我选项(假设该系统提供了该 ...

  4. Spring Boot图书管理系统项目实战-6.图书管理

    导航: pre:  5.读者管理 next:7.借阅图书 只挑重点的讲,具体的请看项目源码. 1.项目源码 需要源码的朋友,请捐赠任意金额后留下邮箱发送:) 2.页面设计 2.1 book.html ...

  5. Docker实践之10-图形化管理

    lazydocker https://github.com/jesseduffield/lazydocker 一个基于命令行终端的,支持Docker和Docker Compose的图形化界面,支持鼠标 ...

  6. Vue.beforeEach is not a function报错

    使用导航守卫改变页面的title时报错了,明明在beaforeEach的参数中写了箭头函数也报下面的错误 后面发现我的问题在于直接导出了export.default new Router({--})中 ...

  7. 【Azure 云服务】云服务(经典)迁移到云服务(外延支持)的八个问题

    问题一:云服务( 经典)迁移到外延支持云服务是否需要停机? 通过平台的迁移工具(即验证.准备.提交)进行迁移没有停机时间.但是如果需要准备满足迁移条件,如删除对等互联,使用其他vnet资源则需要额外的 ...

  8. 【Azure 应用服务】App Service For Linux 环境中,如何修改 Nginx 配置中 server_name的默认值 example.com

    问题描述 在App Service for Linux环境中,部署PHP应用,使用Nginx服务器.因为PHP应用中所有静态资源的URL使用的默认域名为 https://example.com:808 ...

  9. 2024年,提升Windows开发和使用体验实践 - 小工具篇

    前言 本来是一篇文章的,不知不觉写成了系列. 其实开工那几天就已经写好了长文,这几天一忙就没连着发了. 本文介绍一些 Windows 上用的小工具. 美化/折腾/小工具 虽然这是在用 Windows ...

  10. curator-framework 使用采坑记之org.apache.zookeeper.ClientCnxn - Opening socket connection to server..........Will not attempt to authenticate using SASL (unknown error)报错解决

    一.curator-framework  简介 curator-framework 是对zookeeper做的分二次分布式封装处理,目前代码也是apache 开源社区维护,如下所示. github地址 ...