在ArcGIS中如何使用直连方式连接Oracle数据库

21 篇文章 0 订阅

1.      背景

直连方式比使用SDE方式更加稳定,特别是在大数据量处理的应用中,不易出场由SDE连接进程造成的gsvr错误。同时直连方式由于采用Orale客户端连接数据库,在数据库双机部署或集群部署时可以直接利用数据库的负载机制,如RAC,勿需额外的负载均衡服务器。

2.      方法

在ArcGIS中使用直连,最简单和常用的工具莫过于ArcCatalog。

打开ArcCatalog,找到Database connections,选择添加空间数据库连接项:

双击后如下,填写连接参数。

使用SDE连接与直连的参数对比如下:

 

SDE连接

直连

server

192.168.0.39

192.168.0.39

service

5151

Sde:oracle10g

username

sde

sde

password

sde

sde@orcl

表中IP当采用SDE连接方式为SDE服务所在的IP。

3.      遇到问题

在本机测试的过程中遇到一个离奇的问题,即直连本机好用,直连远程服务器不好使了。

采用直连方式可以连通本机39上的oracle服务器,其它连接参数不变把IP修改为192.168.0.81后,连上的仍然是本机(39)的数据库。

考虑到81上的数据库为11g ,将service参数修改为sde:oracle11g直连81的Oracle,此时居然报错,连接服务器失败。

这个问题一直搹浅了很久,也没有找到原因。后来请教了专业人员,才知道还是对ArcGIS直连Oracle的原理不清楚。

4.      分析直连原理

ArcGIS直连Oracle的原理见下图。首先ArcGIS直连Oracle是通过在ArcGIS所在客户端上安装一个oracle client实现的。oracle client去连接oracle database,而不是采用SDE方式中的SDE服务去连接。

其次,ArcGIS客户端如ArcCatalog将连接请求发给oracleclient时必须有一个与所请求的服务器对应的监听服务(Net lisenter)。监听服务可以使用oracle client的Net Manager管理工具配置。配置后的监听服务信息记录在一个Tnsnames.ora文件中,用过Oracle客户端的人对这个文件应该都不陌生,这个文件存储在“安装目录\db_1\NETWORK\ADMIN”下,因此高手也可以不用Net Manager管理工具配置,直接修改这个文件即可。

配置完成保存后,在文件Tnsnames.ora应该可以看到新加的监听服务,如下图:

可以使用Sqlplus检测监听服务是否成功启动。在cmd中运行sqlplus sde/sde@orcl81,如显示成功连接,则监听服务配置成功,可以继续在ArcGIS中的直连操作。

5.      解决问题

现在再来解决前面提到的直连本机好用,直连远程服务器不好使的问题。

修改连接参数如下:

 

直连

server

192.168.0.39

service

Sde:oracle10g

username

sde

password

sde@orcl81

成功连接81的远程服务器。

再修改连接参数如下后进行连接测试:

 

直连

server

 

service

Sde:oracle10g

username

sde

password

sde@orcl81

仍然可以成功连接81的远程服务器,说明IP在直连中不是必须参数。

再修改连接参数如下后进行连接测试:

 

直连

server

 

service

Sde:oracle11g

username

sde

password

sde@orcl81

连接失败,说明Oracle版本信息不是填服务器版本,而是本机客户端版本,测试中本机为10g的数据库,服务器端为11g的数据库。

6.      几个关键点

最后总结一下,在ArcGIS中使用直连的方式连接Oracle数据库时几个必须注意事的关键点。

第一个是建立可正常运行的监听服务,监听向所需连接数据库发出的请求。本文中所遇到的问题是因为数据库是本机的,本机数据库监听服务在安装时已配置好,而远程数据库的监听服务没有配置,所以才出现本机好使,远程不好使的情况。使用工具连接Oracle时,如sqlplus,sqldeveloper等不需要配置监听服务才能联通。

第二个再明确下各项直连参数的解释:

参数名

直连

说明

server

 

不需要

service

Sde:oracle11g

Oracle版本输入本机客户端版本,而不是服务器数据库版本

username

sde

 

password

sde@orcl81

@后面的字符指监听服务的名字,而不是数据库实例的名字

 

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值