怎么配置 Oracle 侦听器来使用SQL操作ST_Geometry [转]

转载:http://blog.csdn.net/linghe301/article/details/7102447

 

关于这个内容,其实从ArcSDE9.2推出ST_Geometry就让用户感到很有吸引力,而且特别是在ArcSDE9.3之后,用户使用SQL操作ST_geometry越来越多,但是在配置Oracle监听来说总是碰到这样那样的问题,以下就是总结一下配置 Oracle 侦听器来使用SQL操作ST_Geometry 。

 

首先说明一下:如果你的ArcSDE版本是9.2最好不要使用这种方式,因为Bug也是比较多的。

例如:http://support.esri.com/en/knowledgebase/techarticles/detail/33918

1:我们需要使用SQL操作ST_Geometry,那么我们的数据存储都应该以ST_Geometry,但是有一点容易被用户忽视的就是原来的数据可能是ArcSDE9.2他们都是以BLOB或者Long Raw进行存储,然后升级到ArcSDE9.3但是存储没有升级,这样怎么配置都不能SQL操作,这是往往被用户忽视的问题。

解决该问题:使用Migrate工具迁移一下存储。

 

2:查看一下Oracle的监听状态,extporc(CLRextproc)的状态必须为静态(Unknow),如果是Ready状态就有可能出现问题,而且Oracle监听必须同时监听TCP和IPC

 

  1. C:\Users\Administrator>lsnrctl status 
  2.  
  3. LSNRCTL for 64-bit Windows: Version 11.2.0.1.0 - Production on 26-12月-2011 10:2 
  4. 9:44 
  5.  
  6. Copyright (c) 1991, 2010, Oracle.  All rights reserved. 
  7.  
  8. 正在连接到 (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC1521))) 
  9. LISTENER 的 STATUS 
  10. ------------------------ 
  11. 别名                      LISTENER 
  12. 版本                      TNSLSNR for 64-bit Windows: Version 11.2.0.1.0 - Produ 
  13. ction 
  14. 启动日期                  26-12月-2011 10:28:14 
  15. 正常运行时间              0 天 0 小时 1 分 34 秒 
  16. 跟踪级别                  off 
  17. 安全性                    ON: Local OS Authentication 
  18. SNMP                      OFF 
  19. 监听程序参数文件          D:\app\Administrator\product\11.2.0\dbhome_1\network\a 
  20. dmin\listener.ora 
  21. 监听程序日志文件          d:\app\administrator\diag\tnslsnr\lish\listener\alert\ 
  22. log.xml 
  23. 监听端点概要... 
  24.   (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1521ipc))) 
  25.   (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=192.168.100.111)(PORT=1521))) 
  26. 服务摘要.. 
  27. 服务 "CLRExtProc" 包含 1 个实例。 
  28.   实例 "CLRExtProc", 状态 UNKNOWN, 包含此服务的 1 个处理程序... 
  29. 服务 "orcl" 包含 2 个实例。 
  30.   实例 "orcl", 状态 UNKNOWN, 包含此服务的 1 个处理程序... 
  31.   实例 "orcl", 状态 READY, 包含此服务的 1 个处理程序... 
  32. 服务 "orclXDB" 包含 1 个实例。 
  33.   实例 "orcl", 状态 READY, 包含此服务的 1 个处理程序... 
  34. 命令执行成功 
C:\Users\Administrator>lsnrctl status

LSNRCTL for 64-bit Windows: Version 11.2.0.1.0 - Production on 26-12月-2011 10:2
9:44

Copyright (c) 1991, 2010, Oracle.  All rights reserved.

正在连接到 (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC1521)))
LISTENER 的 STATUS
------------------------
别名                      LISTENER
版本                      TNSLSNR for 64-bit Windows: Version 11.2.0.1.0 - Produ
ction
启动日期                  26-12月-2011 10:28:14
正常运行时间              0 天 0 小时 1 分 34 秒
跟踪级别                  off
安全性                    ON: Local OS Authentication
SNMP                      OFF
监听程序参数文件          D:\app\Administrator\product\11.2.0\dbhome_1\network\a
dmin\listener.ora
监听程序日志文件          d:\app\administrator\diag\tnslsnr\lish\listener\alert\
log.xml
监听端点概要...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC1521ipc)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=192.168.100.111)(PORT=1521)))
服务摘要..
服务 "CLRExtProc" 包含 1 个实例。
  实例 "CLRExtProc", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
服务 "orcl" 包含 2 个实例。
  实例 "orcl", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
  实例 "orcl", 状态 READY, 包含此服务的 1 个处理程序...
服务 "orclXDB" 包含 1 个实例。
  实例 "orcl", 状态 READY, 包含此服务的 1 个处理程序...
命令执行成功

 

3:如果是分布式安装情况下

 

a:比如服务器安装的64Bit的Oracle服务器端,ArcSDE机器安装的32Bit的软件,两者都是Windows操作系统

b:比如服务器安装的64Bit的Oracle服务器端,AIX操作系统,ArcSDE机器安装的32Bit的软件,Windows操作系统

那么这就需要根据服务器端的Oracle的位数以及所以的操作系统来定相关的dll或者so的位数,也就是说这个配置必须跟Oracle的服务器端打交道,我们根据服务器的操作系统和位数来定

 

解决:

a:在服务器端安装一个64Bit的ArcSDE软件即可,其实最主要的就是需要64Bit的相关dll

b:在服务器端安装一个64Bit的适用于AIX操作系统的ArcSDE软件,一样道理

 

4:引用相关的dll以Windows为例,不仅仅只有一个st_shapelib.dll,还包括pe.dll,sg.dll,所以在使用过程中需要注意是否这三个dll都存在,在非windows环境下更是如此,此外还需要注意对这三个文件的读写操作。

 

5:配置完毕,我们可以使用以下命令来检查

注意:这个是在sde用户下

 

  1. SQL> select * from user_libraries; 
  2.  
  3. LIBRARY_NAME 
  4. ------------------------------ 
  5. FILE_SPEC 
  6. ------------------------------------------------------------------------------ 
  7. -------------------- 
  8. D STATUS 
  9. - ------- 
  10. ST_SHAPELIB 
  11. C:\Program Files\ArcGIS\ArcSDE\ora11gexe\bin\st_shapelib.dll 
  12. Y VALID 
SQL> select * from user_libraries;

LIBRARY_NAME
------------------------------
FILE_SPEC
------------------------------------------------------------------------------
--------------------
D STATUS
- -------
ST_SHAPELIB
C:\Program Files\ArcGIS\ArcSDE\ora11gexe\bin\st_shapelib.dll
Y VALID

如果没有的话

 

  1. SQL> create or replace library ST_SHAPELIB 
  2.   2  as 'D:\Oracle\product\11.2.0\dbhome_1\BIN\st_shapelib.dll'; 
  3.   3  / 
  4.  
  5. 库已创建。 
  6.  
  7. SQL> alter package sde.st_geometry_shapelib_pkg compile reuse settings; 
  8.  
  9. 程序包已变更。 
SQL> create or replace library ST_SHAPELIB
  2  as 'D:\Oracle\product\11.2.0\dbhome_1\BIN\st_shapelib.dll';
  3  /

库已创建。

SQL> alter package sde.st_geometry_shapelib_pkg compile reuse settings;

程序包已变更。

 

6:其实配置来说,也就是对listener.ora和TNSName.ora文件的配置

 

listener.ora:文件主要对相关St_shapelib.dll的引用,用户也可以将我所讲到的三个dll拷贝到ORACLE_HOME/bin文件夹里面,注意相关的权限,然后EXTPROC_DLLS=ANY,这种方法也可以可以的。

  1. # listener.ora Network Configuration File: D:\app\Administrator\product\11.2.0\dbhome_1\network\admin\listener.ora 
  2. # Generated by Oracle configuration tools. 
  3.  
  4. SID_LIST_LISTENER
  5.   (SID_LIST
  6.     (SID_DESC
  7.       (SID_NAME = CLRExtProc
  8.       (ORACLE_HOME = D:\app\Administrator\product\11.2.0\dbhome_1) 
  9.       (PROGRAM = extproc
  10.       (ENVS = "EXTPROC_DLLS=ANY"
  11.     ) 
  12.     (SID_DESC
  13.       (GLOBAL_DBANAME = orcl
  14.       (ORACLE_HOME = D:\app\Administrator\product\11.2.0\dbhome_1) 
  15.       (SID_NAME = orcl
  16.     ) 
  17.   ) 
  18.  
  19. LISTENER
  20.   (DESCRIPTION_LIST
  21.     (DESCRIPTION
  22.       (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521)) 
  23.       (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.111)(PORT = 1521)) 
  24.     ) 
  25.   ) 
  26.  
  27. ADR_BASE_LISTENER = D:\app\Administrator 
# listener.ora Network Configuration File: D:\app\Administrator\product\11.2.0\dbhome_1\network\admin\listener.ora
# Generated by Oracle configuration tools.

SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = CLRExtProc)
      (ORACLE_HOME = D:\app\Administrator\product\11.2.0\dbhome_1)
      (PROGRAM = extproc)
      (ENVS = "EXTPROC_DLLS=ANY")
    )
    (SID_DESC =
      (GLOBAL_DBANAME = orcl)
      (ORACLE_HOME = D:\app\Administrator\product\11.2.0\dbhome_1)
      (SID_NAME = orcl)
    )
  )

LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.111)(PORT = 1521))
    )
  )

ADR_BASE_LISTENER = D:\app\Administrator
7:TNSName.ora文件来说就是两个文件都有KEY值,保证这两个文件的KEY值一致就可以了,还有就是以我的经验,安装最新版本的Oracle比如现在我机器的环境就是oracle 11.2.0.1,他的TNSNAME文件并不会出现EXTPROC_CONNECTION_DATA关键字,所以我们需要修改为这个关键字即可。
 
Esri也有关于Oracle11gR2相关配置ST_Geometry的文章:http://support.esri.com/en/knowledgebase/techarticles/detail/38043
  1. # tnsnames.ora Network Configuration File: D:\app\Administrator\product\11.2.0\dbhome_1\network\admin\tnsnames.ora 
  2. # Generated by Oracle configuration tools. 
  3.  
  4. LISTENER_ORCL
  5.   (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.111)(PORT = 1521)) 
  6.  
  7.  
  8. EXTPROC_CONNECTION_DATA
  9.   (DESCRIPTION
  10.     (ADDRESS_LIST
  11.       (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521)) 
  12.     ) 
  13.     (CONNECT_DATA
  14.       (SID = CLRExtProc
  15.       (PRESENTATION = RO
  16.     ) 
  17.   ) 
  18.  
  19. ORCL
  20.   (DESCRIPTION
  21.     (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.111)(PORT = 1521)) 
  22.     (CONNECT_DATA
  23.       (SERVER = DEDICATED
  24.       (SERVICE_NAME = orcl
  25.     ) 
  26.   ) 
# tnsnames.ora Network Configuration File: D:\app\Administrator\product\11.2.0\dbhome_1\network\admin\tnsnames.ora
# Generated by Oracle configuration tools.

LISTENER_ORCL =
  (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.111)(PORT = 1521))


EXTPROC_CONNECTION_DATA =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
    )
    (CONNECT_DATA =
      (SID = CLRExtProc)
      (PRESENTATION = RO)
    )
  )

ORCL =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.111)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = orcl)
    )
  )
如果环境跟我一致,也可以将这两个文件复制,将用户的相关参数进行修改即可。
相关参数参考
  1. <spanstyle="font-size: 13px;">SID_LIST_LISTENER 
  2. 此标注是名为 LISTENER(默认侦听器名称)的侦听器要处理的 SID 列表的开头。 
  3.  
  4. SID_LIST 和 SID_DESC 
  5. 标题 SID_LIST 下的 SID_DESC 条目用于定义服务。列表中的第一个?跄看? extproc 请求,第二个条目处理客户端会话。 
  6.  
  7. SID_NAME 
  8. 其值必须与在文件 tnsnames.ora 中为 extproc 指定的 SID 对应。 
  9.  
  10. ORACLE_HOME 
  11. 定义此项服务的 Oracle 主页的位置。从此位置下的文件夹加载 extproc 程序文件。 
  12.  
  13. PROGRAM 
  14. 指定 extproc 可执行文件的文件名。此区分大小写的名称可能是 extproc 或 extproc.exe,具体取决于操作系统的类型。文件位于 ORACLE_HOME/bin。 
  15.  
  16. ENVS 
  17. 这是 extproc 在运行时所使用的环境变量的列表。列表用冒号分隔。此列表必须包括环境变量 EXTPROC_DLLS 以及 extproc 在运行时需要的任何其他环境变量的定义,其他环境变量通常包括 UNIX 和 Linux 系统中的 LD_LIBRARY_PATH、SHLIB_PATH 或 LIBPATH,或者 Windows 服务器上的 PATH。路径变量通常包括几何与投影引擎库的位置。 
  18.  
  19. EXTPROC_DLLS 
  20. 此环境变量用于定义 extproc 可直接从中加载和调用函数的库的列表。包含 ST_SHAPELIB 和 LIBST_RASTER 库的文件的路径必须在此指定。 
  21.  
  22. 对于安装在 UNIX 上的 Oracle 服务器,列表用冒号分隔,对于安装在 Windows 上的 Oracle 服务器,列表用分号分隔。所有路径都必须是绝对路径并且指向本地目录,或者是 Oracle 系统用户可访问的 UNC 路径。这也意味着如果已将 ArcSDE 安装在非 Oracle 服务器上,则必须将形状和栅格库复制到 Oracle 服务器。有关详细信息,请参阅在不同的服务器上安装 Oracle 和 ArcSDE。 
  23.  
  24. 不存在环境变量替换。 
  25.  
  26. 可选关键字 ANY 和 ONLY 可用于放宽或限制 extproc 使用库文件的方式。如果将 ANY 放在路径前面,Oracle 可从指定路径加载任何库并且不必提供库名称。如果将 ONLY 放在路径前面,Oracle 将仅使用路径中提供的特定库。 
  27.  
  28. KEY 
  29. 为此条目设置的值将此侦听器链接到文件 tnsnames.ora 中的对应服务条目。该值将此侦听器与可能存在于同一数据库服务器的其他 IPC 侦听器区分开来。key 可为任何短名称,但在文件 listener.ora 和 tnsnames.ora 中必须相同。key 区分大小写。</span><spanstyle="font-size: 18px;"> 
  30. </span> 
SID_LIST_LISTENER
此标注是名为 LISTENER(默认侦听器名称)的侦听器要处理的 SID 列表的开头。

SID_LIST 和 SID_DESC
标题 SID_LIST 下的 SID_DESC 条目用于定义服务。列表中的第一个?跄看? extproc 请求,第二个条目处理客户端会话。

SID_NAME
其值必须与在文件 tnsnames.ora 中为 extproc 指定的 SID 对应。

ORACLE_HOME
定义此项服务的 Oracle 主页的位置。从此位置下的文件夹加载 extproc 程序文件。

PROGRAM
指定 extproc 可执行文件的文件名。此区分大小写的名称可能是 extproc 或 extproc.exe,具体取决于操作系统的类型。文件位于 ORACLE_HOME/bin。

ENVS
这是 extproc 在运行时所使用的环境变量的列表。列表用冒号分隔。此列表必须包括环境变量 EXTPROC_DLLS 以及 extproc 在运行时需要的任何其他环境变量的定义,其他环境变量通常包括 UNIX 和 Linux 系统中的 LD_LIBRARY_PATH、SHLIB_PATH 或 LIBPATH,或者 Windows 服务器上的 PATH。路径变量通常包括几何与投影引擎库的位置。

EXTPROC_DLLS
此环境变量用于定义 extproc 可直接从中加载和调用函数的库的列表。包含 ST_SHAPELIB 和 LIBST_RASTER 库的文件的路径必须在此指定。

对于安装在 UNIX 上的 Oracle 服务器,列表用冒号分隔,对于安装在 Windows 上的 Oracle 服务器,列表用分号分隔。所有路径都必须是绝对路径并且指向本地目录,或者是 Oracle 系统用户可访问的 UNC 路径。这也意味着如果已将 ArcSDE 安装在非 Oracle 服务器上,则必须将形状和栅格库复制到 Oracle 服务器。有关详细信息,请参阅在不同的服务器上安装 Oracle 和 ArcSDE。

不存在环境变量替换。

可选关键字 ANY 和 ONLY 可用于放宽或限制 extproc 使用库文件的方式。如果将 ANY 放在路径前面,Oracle 可从指定路径加载任何库并且不必提供库名称。如果将 ONLY 放在路径前面,Oracle 将仅使用路径中提供的特定库。

KEY
为此条目设置的值将此侦听器链接到文件 tnsnames.ora 中的对应服务条目。该值将此侦听器与可能存在于同一数据库服务器的其他 IPC 侦听器区分开来。key 可为任何短名称,但在文件 listener.ora 和 tnsnames.ora 中必须相同。key 区分大小写。

 

8:测试是否正常

 

  1. SQL> select sde.st_astext(shape) from  aa where objectid<3
  2.  
  3. SDE.ST_ASTEXT(SHAPE) 
  4. ------------------------------------------------------------------ 
  5.  
  6. POINT  ( -13625889.61620000 4541020.47880000) 
  7. POINT  ( -13627070.41230000 4548787.04140000) 
SQL> select sde.st_astext(shape) from  aa where objectid<3;

SDE.ST_ASTEXT(SHAPE)
------------------------------------------------------------------

POINT  ( -13625889.61620000 4541020.47880000)
POINT  ( -13627070.41230000 4548787.04140000)
posted @ 2013-04-09 10:32  zhh  阅读(617)  评论(0编辑  收藏  举报