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 |
@后面的字符指监听服务的名字,而不是数据库实例的名字 |