众说周知,ArcSDE空间数据库引擎提供了两种连接数据库的方式。一是服务连接方式,一是直连方式。后者也是Esri所推崇的方式。但是,在客户的生产环境和开发商的开发环境中这两种方式都是有需求的。下面就以截图说明的形式跟大家分享下在ArcGIS10.0和10.1中安装和配置空间数据库引擎的一般流程和注意事项。
1.直连方式
Esri之所以推荐使用直连方式,就是因为直连方式有明显的优势,可以给客户带来更大的效率和价值。
a.直连方式的主要优势:
A.直连方式较服务连接方式卸载了20%-40%的负载;
B.直连方式降低了服务器端内存的需求;
C.直连方式处理速度更快,在客户机上执行处理;
D.不需要安装ArcSDE软件。
b.直连配置需求
上面也说过了,直连方式省去了ArcSDE软件的安装步骤。但是它却需要安装相应的数据库客户端,后面都以Oracle11gR2为例。确保Oracle数据安装配置正确后,需要知道sys用户密码、端口号、实例名、服务名。
c.配置流程
A.安装和配置Oracle客户端(32)
对于ArcGIS Desktop连接来说,目前都需要安装Oracle11gR2的客户端,当然可以使用对应版本的免安装客户端,只不过需要手动配置环境变量而已。
如果是安装完database后,再安装的client,那么环境变量不需要手动修改。其内容如下:
E:appweihuproduct11.2.0client_1in;E:appweihuproduct11.2.0dbhome_1in;%SystemRoot%system32;%SystemRoot%;%SystemRoot%System32Wbem;%SYSTEMROOT%System32WindowsPowerShellv1.0;C:Program FilesArcGISArcSDEora11gexein
然后,需要使用客户端的NetManager工具配置服务名,如下图的arcsde。
对于免安装的客户端,需要手动配置network/admin下的tnsnames.ora文件。 B.ArcGIS Desktop连接参数设置 完成Oracle客户端安装后,就可以在ArcGIS桌面中进行连接了,其设置参数和连接方式在ArcGIS Desktop不同版本稍有区别。 a.ArcGIS Desktop10.1 10.1中在ArcCatalog里面的数据库连接中添加空间数据库连接,如上图。指定参数数据类型、实例(\ip:portservicename 可以参考左下角的Abort Database Connections)、认证。 b.ArcGIS Desktop10.0
直连方式在10.1与10.0中差异较小,注意相关参数,主要是机器(ip)、服务(sde:oracle11g:服务名[arcsde:使用客户端配置的参数])、认证相同,如上图。 2.服务连接方式
a.服务连接优势
对于很多实施人员来说,他们的应用可能比较简单,需要考虑的主要是实施部署的便捷。那么服务连接的优势就体现出来了。不需要客户端安装和配置。b.软件安装与配置
对于服务连接方式,都需要安装ArcSDE for对应数据库版本的软件包。这个在ArcGIS10.1和ArcGIS10.0中差别较大。 A. ArcGIS10.1中ArcSDE的安装与配置: 找到对应数据类型和版本的软件安装包安装即可,没有Post Install的向导。在软件安装完成后来使用命令创建sde服务。 找到ArcSDE安装目录下的service.sde文件取消esri_sde 5151/tcp前面的#号注释。 同时,找到Windows中的service(system32/drivers/etc)文件添加一行esri_sde 5151/tcp。 然后使用命令sdeservice创建sde服务,如下图,参数包括数据库类型、实例名称、sde用户密码、服务名等。服务配置成功后,就可以在ArcGIS Desktop中连使用服务连接了。但是10.1中服务连接需要使用工具创建连接文件,然后连接,而不能像10.0中直接使用服务名或者5151连接。
使用Workspace工具箱中的Create ArcSDE Connection File工具来创建连接文件。 参数:连接文件存放位置、文件名、机器、服务名称(esri_sde)、数据库名、认证等。 上图双击或者使用添加数据按钮指定到该文件,就可在ArcGIS Desktop10.1中完成空间数据库的服务连接。 B.ArcGIS10.0中ArcSDE的安装与配置: 在ArcSDE10.0中提供了Post Install的向导,更能体现服务连接的便捷。向导可以完成的配置如下图:
初次安装选择全部,然后下一步可以实现Oracle数据库连接检查(确保实例运行正常)。
接下来,可以设置sde的用户名和密码,创建sde表空间。
然后,设置服务名、端口号、机器名,Oracle实例名等,如下图。 按照Post Inatall向导设置参数,最后完成授权,这样就完成10.0环境的服务连接安装与配置。不需要使用命令行创建服务,直接可以在ArcGIS Desktop中设置参数就可以连接了。
在ArcGIS10.0中服务方式连接和直连都可以使用ArcCatalog中空间数据库连接的节点,设置参数进行连接,唯一不同就是服务参数。服务连接输入esri_sde或者5151即可,直连需要输入sde:oracle11g:arcsde,具体可以对比相关截图。
3.ST_Geometry配置
ST_Geometry是一种遵循ISO和OGC规范的,可以通SQL直接读取的空间信息存储类型。采用这种存储方式能够更好的利用Oracle的资源,更好的兼容Oracle的特征。Esri的ArcSDE9.2开始支持这种存储类型。 A.ST_Geometry主要优势 ST_Geometry的优势主要体现在以下几个方面: A.可以通过SQL函数直接访问空间数据; B.使用SQL语句操作空间数据可以和其他类型数据一样便捷; C.可以通过存储过程来进行复杂的空间数据检索和分享; D.其他业务系统可以通过SQL语句来访问Geodatabase中的数据; ST_Geometry配置的方式 值得注意的是在配置ST_Geometry时,需要根据数据库的版本和位数来安装对应版本的ArcSDE软件(比如Oracle是Win64_11gR2_database,就需要安装ArcSDE for Oracle 11g64位软件)。主要是包括配置需要引用的动态库(st_shapelib.dll、pe.dll、sg.dll)。 官网给出了两种配置方式: http://support.esri.com/en/knowledgebase/techarticles/detail/38043 相关信息: http://help.arcgis.com/zh-cn/arcgisserver/10.0/help/arcgis_server_dotnet_help/index.html#/na/0093000015qp000000/ A. 配置listener.ora和tnsnames.ora文件方式; 在保证数据库监听配置正常的情况下,添加以下信息。 首先,在Oracle的安装目录下(%ORACLE_HOME%NetworkAdmin)找到tnsnames.ora文件;添加EXTPROC_CONNECTION_DATA信息如下: EXTPROC_CONNECTION_DATA = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521)) ) (CONNECT_DATA = (SID = CLRExtProc) (PRESENTATION = RO) ) ) 其次,找到(%ORACLE_HOME%NetworkAdmin)下的listener.ora在SID_LIST_LISTENER下添加: (SID_DESC = (SID_NAME = CLRExtProc) (ORACLE_HOME = C:appAdministratorproduct11.2.0dbhome_1) (PROGRAM = EXTPROC)(ENVS = "EXTPROC_DLLS=C:ArcSDEora11gexeinst_shapelib.dll,PATH=C:ArcSDEora11gexein") 注: A.路径中最好不要有空格; B.以上配置需要注意两个文件listener.ora和tnsnames.ora中的SID和KEY一致。 不然会出现如下错误提示:
确保配置正确后,重启Oracle监听(lsnrctl stop、 lsnrctl start); 最后,通过命令测试ST_Geometry配置是否正常。 SQL> select * from user_libraries;来检查st_shapelib.dll的位置配置。
如果不是正确的dll路径(还有对应位数64/32)可以通过以下命令修改:create or replace library ST_SHAPELIB as 。 以上命令仅能说明dll位置配置是否正确,能否正常工作应该通过SQL函数来判断: 如上图,ST_ASTEXT函数能够正确输出信息,说明ST_Geometry配置成功。
- 配置extproc.ora方式;