Transparent Gateway的使用方法
前言
使用Transparent Gateway(透明网关),建立ORACLE与SQLServer的连接。
实现功能:在ORACLE中查询SQLServer数据库的内容。
注:网上有ORACLE和SQLServer不在同一服务器中的安装步骤。本文是ORACLE、SQLServer、透明网关都在同一服务器的场景。
一、环境信息
SQLServer2008(Window server 2008 R2)
| 标题 | 内容 |
|---|---|
| IP地址 | 162.16.161.98 |
Oracle11g(Window server 2008 R2)
| 标题 | 内容 |
|---|---|
| IP地址 | 162.16.161.98 |
| Oracle端口 | 1521 |
Oracle gateway (Window server 2008 R2)
| 标题 | 内容 |
|---|---|
| IP地址 | 162.16.161.98 |
| Gateway根目录 | E:\app\Administrator\product\11.1.0\tg_2 |
| Gateway端口 | 1522(默认是1521,因为本机Oracle数据库已使用此端口,所以需要改一下) |
| SID | Demo0707 |
二、Transparent Gateway安装
启动安装程序:

指定安装目录:

选择组件:

填写SQL Server数据库详细信息:
主机名填写SQL Server数据库IP地址,若SQL Server数据库和透明网关安装在同一台服务器上,可以填【.】。
数据库名称填写需要连接的SQL Server数据库名称。
注:【本页可以不填,之后在配置文件进行配置】

点击安装:

安装完Gateway后,会自动弹出配置监听界面。我们不配置监听,点击取消后安装完毕。
三、修改配置文件
指明要访问的MSSQL数据库(修改initdg4msql.ora)
在网关安装目录(E:\app\Administrator\product\11.1.0\tg_2\dg4msql\admin)
找到initdg4msql.ora文件。
该文件是Gateway的初始参数文件,描述的是连接哪个SQL Server数据库。该文件的格式是init【SID】.ora,SID可以根据需要自定义。
系统默认的SID为dg4msql(Oracle Database Gateway for MS SQL Server)。
这里我们将SID改为Demo0707,则修改后的文件名为initDemo0707.ora。
我们将文件内容修改为:
HS_FDS_CONNECT_INFO=[162.16.161.98]//Demo0707
HS_FDS_TRACE_LEVEL=OFF
HS_FDS_RECOVERY_ACCOUNT=RECOVER
HS_FDS_RECOVERY_PWD=RECOVER
注意:HS_FDS_CONNECT_INFO为之前安装网关时配置的SQL Server数据库信息,若之前没有填写配置信息,此时需要手动配置。
格式为:
HS_FDS_CONNECT_INFO =
[数据库IP地址,端口号(默认1433)]/实例名称(可空)/ 数据库名称
配置监听器,处理oracle的查询请求(修改listener.ora)
配置监听器,处理oracle的查询请求(修改listener.ora)
在网关安装目录下(E:\app\Administrator\product\11.1.0\tg_2\NETWORK\ADMIN)
找到listener.ora文件。
该文件是监听器配置文件。修改为:
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBNAME = Demo0707)
(PROGRAM = dg4msql)
(SID_NAME = Demo0707)
(ORACLE_HOME = E:\app\Administrator\product\11.1.0\tg_2)
)
)
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 162.16.161.98)(PORT = 1522))
)
)
参数说明
1.PROGRAM:
因为实例配置文件在E:\app\Administrator\product\11.1.0\tg_2\dg4msql\admin\initdg4msql.ora,所以PROGRAM不能改变。
2.SID_NAME:
就是我们前面init.ora文件名里指定的SID。
3.GLOBAL_DBNAME:
和SID_NAME保持一致即可。
4.ORACLE_HOME:
透明网关安装路径。
5.LISTENER段:
(ADDRESS = (PROTOCOL = TCP)(HOST = 162.16.161.98)(PORT = 1522))
此处配置安装网关时未配置的监听端口和协议。
这里使用TCP协议,1522端口。(默认是1521,因为本机Oracle数据库已使用此端口,所以需要改一下)。
Oracle服务器配置tns文件
打开Oracle的tnsnames.ora文件
E:\app\Administrator\product\11.2.0\dbhome_2\NETWORK\ADMIN\tnsnames.ora
增加:
Demo0707=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST = 162.16.161.98)(PORT =1522)))(CONNECT_DATA =(SID=Demo0707))(HS=OK))
四、启动监听器
通过命令行启动
开始菜单>运行>cmd,输入
C:\Users\Administrator>lsnrctl start
通过可执行文件启动
透明网关根目录BIN文件夹内,执行LSNRCTL.exe。

执行start命令,出现如下界面,说明成功启动:

五、在ORACLE数据库中建立连接
打开PL/SQL或其他工具,连接ORACLE数据库后,执行:
create public database link dbkink connect to "SQL用户名" identified by "密码" using 'Demo0707';
参数说明:
1.dbkink:我们建立的与SQL Server数据库的连接名称。
2.Demo0707:我们之前配置的SID。
测试连接是否建立:
执行select 1 from dual@dbkink
若执行成功则说明连接已经建立。
六、出现的问题及解决方法
监听器启动失败
可能的原因是listener.ora配置文件格式有问题。查看是否有多余的空格,或左右括号数量。
最稳妥的方法是取消换行,分别把LISTENER段和SID_LIST_LISTENER段写在一行里,去除多余的空格。
监听器启动了但测试连接时报错
ORACLE数据库和透明网关配置在一台机器上时可能出现这个问题。
原因是命令行启动监听器时,lsnrctl命令的系统路径为ORACLE安装目录下的。导致我们配置的网关监听器设置没有生效。
解决方法是:使用4.2中的方法,执行网关目录下的LSNRCTL.exe文件,启动监听器。
Transparent Gateway的使用方法的更多相关文章
- Activity透明/半透明效果的设置transparent(两种实现方法)
两种方法实现Activity透明/半透明效果的设置,代码思路很有调理,感兴趣的朋友可以参考下,希望本文可以帮助到你 方法一:res/values文件夹下建立styles.xml: 复制代码代码如下 ...
- discuz用户登录不响应,提示nginx gateway timeout解决方法
在使用nginx+php-cgi搭建discuz论坛过程中,出现论坛登录不响应,一直提示nginx gateway timeout504网关超时,单单采用php方式登录无问题.但因需要使用nginx把 ...
- Linux的Transparent Hugepage与关闭方法
Transparent HugePages是在运行时动态分配内存的,而标准的HugePages是在系统启动时预先分配内存,并在系统运行时不再改变. 因为Transparent HugePages是在运 ...
- Nginx错误提示:504 Gateway Time-out解决方法
朋友说504 Gateway Time-out的错误提示与nginx本身是没有任何关系的我们可以通过fastcgi配置参数的调整进行解 决. 修改 php-fpm 配置文件: 1.把 max_chil ...
- nginx+php测试时显示 502 bad gateway的解决方法
http://www.apelearn.com/study_v2/chapter18.html 由于阿铭老师的PHP版本是 5.3的 我装了 5.5 测试出现了 502 错误 查看日志 借助 ...
- Nginx 502 Bad Gateway 错误的解决方法
502 bad gateway 的解决方法 通用配置 proxy_buffer_size 4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小 proxy_buffers 4 32k; # ...
- paho_c_pub 使用方法
Latest Paho Status (2) 摘自:http://modelbasedtesting.co.uk/ I last wrote about the state of Paho in Oc ...
- 解决 504 Gateway Time-out和502 Bad Gateway(nginx)
504 Gateway Time-out 问题所在: 所请求的网关没有请求到,简单来说就是没有请求到可以执行的PHP-CGI. 一般看来, 这种情况可能是由于nginx默认的fastcgi进程响应的缓 ...
- 【AS3】Flash与后台数据交换四种方法整理
随着Flash Player 9的普及,AS3编程也越来越多了,所以这次重新整理AS3下几种与后台数据交换方法.1.URLLoader(URLStream)2.FlashRemoting3.XMLSo ...
随机推荐
- Raft算法系列教程2:状态机复制 (State Machine Replication)
分区容错如何保证? 在分布式系统设计中,需要遵循CAP理论,如果我们要让一个服务具有容错能力,那么最常用最直接的办法就是让一个服务的多个副本同时运行在不同的节点上.但是,当一个服务的多个副本都在运行的 ...
- C# 队列Queue,ConcurrentQueue,BlockingCollection 并发控制lock,Monitor,信号量Semaphore
什么是队列? 队列Queues,是一种遵循先进先出的原则的集合,在.netCore中微软给我们提供了很多个类,就目前本人所知的有三种,分别是标题提到的:Queue.ConcurrentQueue.Bl ...
- C# Attribute特性 泛型<T> 方法的out ref this(扩展方法) Equals与==
out ref out和ref的使用场景其实不一样.out适合在方法内返回一个额外的结果参数,而ref适合直接改变一个在方法外面的值,方法改变外部就改变,无需重新定义接住返回值再使用. out可以在方 ...
- 【进程/作业】篇章一:Linux进程及其管理(进程的管理基础)
概述:监控系统各方面的性能,保障各类服务的有序运行,是运维工作的重要组成部分,本篇就介绍一次常用的系统监控命令和相关的参数说明 具体包含以下几部分: 1.进程的管理基础 ,主要是讲一下概念性的东西 2 ...
- (十四)、shell脚本之shell基础(上)
一.shell脚本介绍 1.使用脚本的原因 其中使用脚本的一个最主要的原因是因为一个字"懒",在处理自动循环或者大的任务方面可以偷懒且省时间,如果有处理一个任务的命令清单,一个任务 ...
- java 去掉html标签 使用正则表达式删除HTML标签。
import java.util.regex.Matcher; import java.util.regex.Pattern; public class HTMLSpirit{ public stat ...
- Plugin 插件体系
Solon 的插件也可以叫扩展组件,相当于Spring 的 starter.Solon已经提供了大量的基础插件,但对第三方的框架适配目前较少. 插件 说明 boot插件:: 说明 org.noear: ...
- MongoDb学习三(spring-data-mongodb)
本文采用2个种配置方式.xml配置 代码配置方式进行数据库的连接.实现简单的增删该查等一些操作.代码都有注释官方文档如下https://docs.spring.io/spring-data/mongo ...
- CyclicBarrier(栅栏)的用法详解及与countDownLatch用法区别
CyclicBarrier适用于这样的情况:你希望创建一组任务,它们并行的执行工作,然后在进行下一步步骤之前等待,直至所有任务都完成,它使得所有的并行任务都将在删栏出列队,因此可以一致的向前移动. 当 ...
- 一个坑,bootstrap selectpicker 重置下拉列表时遇到的问题
需求是这样的:点击右侧三个按钮中的任意一个,如果执行成功,左侧的版本信息就需要重新获取列表.挺简单的需求,但是遇到了一个坑, 在使用$('#id').html('')清空下拉选项并且重新赋值的时候,始 ...