开发者社区> 小新的蜡笔> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

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

简介: 1.      背景 直连方式比使用SDE方式更加稳定,特别是在大数据量处理的应用中,不易出场由SDE连接进程造成的gsvr错误。
+关注继续查看

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

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

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
oracle数据库的使用
1.用Navicat连接Oracle数据库 填写完成后,点下链接测试,成功就可以用了 2.oracle创建一张 id自增,带注释的表的实例 --创建表 create table T_SWEB_WU_HEAD (...
671 0
java 连接oracle数据库
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; public class oracleTest {public static Connection testOracle(){Connec
1078 0
C#连接oracle数据库步骤
1、  确认操作系统类型,操作系统是64位还是32位; 2、  按对应版本安装oralce客户端版本(64位还是32位); 3、  安装oralce管理员模块,同时赋予安装目录权限 4、  注册oldb regsvr32C:\oracle\product\10.
962 0
修改Oracle数据库的连接数
测试了这个,不错。   摘(一)   1. 查看processes和sessions参数   SQL> show parameter processes   NAME TYPE VALUE   db_writer_processes integer 1   gcs_server_processes integer 0   job_queue_processes inte
1039 0
java连接Oracle数据库获取数据
            一直弄.NET开发,这次由于项目需要,需要对一个使用Java开发的短信平台进行二次开发,然后第一天就用eclipse来连接Oracle数据获取数据,这期间遇到一个问题,...
975 0
+关注
小新的蜡笔
专业从事地理信息系统(GIS)技术工作7~8年。具有丰富的GIS架构、地图展示方面的经验。喜欢探索以及与小伙伴们探讨、分享技术。
134
文章
1
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载