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

百度的账号不能登录了,密码怎么也找不回来,真想诅咒下百度。发在这儿,方便自己看吧。

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

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

7.      适应环境

ArcGIS产品体系中,ArcGIS server部署在Solaris系统下不支持Oracle直连。

ArcGIS DesktTop产品由于只能安装在Windows下,只能支持Windows下Oracle直连。

产品名称

Windows

Linux

Solaris

ArcGIS server

支持

支持

不支持

ArcGIS DesktTop

支持

不支持

不支持

ArcGIS Engine

支持

支持

不支持

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值