可以从 ArcGIS 客户端连接到 DB2。为此,应在 ArcGIS 客户端计算机上安装 IBM DB2 客户端。可为 DB2 数据库配置数据源名称,并使用这一名称从 ArcGIS 客户端进行连接,或者也可以使用非 DSN 连接字符串进行连接。
配置好客户端后创建连接文件。要在发布到 ArcGIS Server 的服务中使用 DB2 数据,请将数据库或地理数据库注册到 GIS Server。
从 ArcMap 连接
要从 ArcMap 连接到 DB2 中的数据库或地理数据库,需在 ArcMap 计算机上安装一个 DB2 客户端,然后在目录树中创建一个连接文件。可使用数据源名称进行连接(在这种情况下,必须在创建此连接前将数据库编入目录),或者也可提供连接信息字符串。
配置数据源名称(可选)
可将 DB2 数据库编入目录,从而创建从 ArcGIS 连接到 DB2 时将使用到的数据源名称 (DSN)。按照 IBM DB2 信息中心的说明将 DB2 数据库编入目录。
如果不设置数据源名称,则可在从 ArcGIS 客户端进行连接时使用一个字符串,该字符串包含了客户端连接至数据库所需的所有信息。该字符串的格式为 HostName=<DB2 主机>;Port=<端口号>;Database=<数据库名称>。此类连接字符串称为非 DSN 连接。
安装 DB2 客户端
将 DB2 客户端安装在将连接到 DB2 数据库的任意计算机上。
您可以使用自己的 DB2 客户端安装程序,也可以从 My Esri 下载 IBM Data Server Run-time Client for DB2。如果要在 64 位的操作系统上安装此客户端,需运行 64 位 DB2 客户端可执行文件;这将同时安装 32 位和 64 位文件。
请按照随 DB2 客户端软件提供的说明进行安装。
连接到 DB2
您可以通过在 ArcMap 中目录树的“数据库连接”节点下添加数据库连接,或使用创建数据库连接工具连接到 DB2 中的数据库或地理数据库。以下步骤将介绍在目录树中创建连接的方法。
- 在 ArcMap 或 ArcCatalog 的目录树中,展开数据库连接,然后双击添加数据库连接。
- 如果要连接 Linux、UNIX 或 Windows 服务器上的 DB2,请从数据库平台下拉列表中选择 DB2。如果要连接 z 操作系统 (z/OS) 上的 DB2,请从数据库平台下拉列表中选择 DB2 for z/OS。
- 在数据源文本框中键入数据源名称。如果数据库(或数据库子系统)未编入目录,则可改用以下语法进行连接:
HostName=<主机>;Port=<端口号>;Database=<数据库名称>;
指定适合站点的信息。
例如,如果 DB2 数据库位于服务器 cube 上,通过 DBMS 端口 50000 进行通信,并且数据库名称是 spatialdata,则连接字符串如下所示:
HostName=cube;Port=50000;Database=spatialdata;
- 选择连接到数据库时使用的身份验证类型:数据库身份验证或操作系统身份验证。
- 如果选择操作系统身份验证,则不需要输入用户名和密码,系统会通过用于登录到操作系统的用户名和密码建立连接。如果操作系统使用的登录信息不能用作数据库的登录信息,连接将失败。
如果选择数据库身份验证,则必须分别在用户名和密码文本框中提供有效的用户名和密码。用户名最长为 30 个字符。
如果不希望将登录信息保存为连接的一部分,请取消选中保存用户名和密码;这样做有助于维护数据库的安全性。但是,如果执行此操作,则系统会在每次连接时提示您提供用户名和密码。另请注意,对于为 ArcGIS 服务提供数据库或地理数据库访问的连接文件,或想要通过此连接文件使用目录搜索来定位访问的数据,都必须选中保存用户名和密码。
在下例中,使用数据库身份验证连接到 DB2 实例中已编入目录的数据库 (spatialdata):
- 单击确定进行连接。
文件的创建位置为 \\<computer_name>\Users\<user_name>\AppData\Roaming\ESRI\Desktop<release#>\ArcCatalog。如遇到任何连接问题,请检查 %TEMP% 目录中的 sdedc_DB2.log 文件以获得更多的错误消息。
可以将连接移动到另一位置;只需确保需要建立连接的用户和应用程序有权读取放置连接文件的目录。
如果需要将此连接文件中的数据用作服务(如地理处理和地理编码服务)源,则可能需要将连接文件置于网络上的某个共享位置。有关共享连接文件的详细信息,请参阅准备要作为服务发布的资源。
连接到特定地理数据库版本
使用数据库连接对话框首次连接到地理数据库时,将连接至默认版本。如果使用地理数据库版本化,并想要连接到其他事务版本或历史版本,请使用地理数据库连接属性对话框更改版本。有关详细信息,请参阅连接到特定地理数据库版本。
从 ArcGIS for Server 创建连接
如果 DB2 和 ArcGIS for Server 在不同的服务器上运行,则应在 ArcGIS for Server 计算机上安装 DB2 客户端。
如果 Linux 服务器上安装了 ArcGIS for Server,则编辑 init_user_param.sh 脚本以包含 DB2 客户端和实例的相关信息,并重新启动 ArcGIS for Server。
如果希望发布到 ArcGIS Server 的服务使用 DB2 中数据库或地理数据库的数据,则必须将数据库注册到 ArcGIS Server。可在注册数据库时使用数据源名称(在这种情况下,必须在注册前将数据库编入目录),或者也可提供连接信息字符串(通常被称为非 DSN 连接)。
安装 DB2 客户端
如果在不同于 DB2 数据库的服务器上安装了 ArcGIS for Server,则应在 ArcGIS for Server 计算机上安装 DB2 客户端。
您可以使用自己的 DB2 客户端安装程序,也可以从 My Esri 下载 IBM Data Server Runtime Client for DB2。
请按照随 DB2 客户端软件提供的说明进行安装。
更改 init_user_param.sh 脚本(仅针对 Linux)
安装数据库客户端文件后,更改 init_user_param.sh 脚本以将其作为参考。可通过浏览至 <ArcGIS Server installation directory>/arcgis/server/usr 目录访问该脚本。
- 请确保 ArcGIS Server 安装程序所有者至少具有在数据库客户端库中读取和执行的权限。
- 在文本编辑器中打开 init_user_param.sh 脚本。
- 移除以 export 开头的行中的注释标记 (#)。
# # To connect to DB2 export DB2_CLIENT_HOME=<DB2_InstallDir> export DB2INSTANCE=<DB2_instance_name> export PATH=DB2_CLIENT_HOME/bin:$PATH export LD_LIBRARY_PATH=$DB2_CLIENT_HOME/lib64:$LD_LIBRARY_PATH
- 将 <DB2_InstallDir> 替换为 DB2 客户端安装目录的位置,并将 <DB2_instance_name> 替换为 DB2 实例的名称。
例如,如果将 DB2 客户端安装到 /home/db2prod,则 DB2 实例将被命名为 db2prod,文件显示如下:
# # To connect to DB2 export DB2_CLIENT_HOME=/home/db2prod export DB2INSTANCE=db2prod export PATH=DB2_CLIENT_HOME/bin:$PATH export LD_LIBRARY_PATH=$DB2_CLIENT_HOME/lib64:$LD_LIBRARY_PATH
- 保存并关闭脚本。
- 通过运行 startserver.sh 脚本重新启动 ArcGIS Server 部署中的每个 GIS 服务器。
./startserver.sh
配置数据源名称(可选)
可将 DB2 数据库编入目录,从而创建在将数据库注册到 ArcGIS Server 时要使用的数据源名称。请注意,如果 ArcGIS Server 安装在与所用 DB2 服务器无关的 Linux 计算机上,则必须先在客户端计算机上创建 DB2 客户端实例,才能编写 DB2 数据库目录。
注册数据库
如果希望 Web 服务使用 DB2 中数据库或地理数据库的数据,则需将其注册到 ArcGIS Server。针对 DB2 中的地理数据库,存在两种注册选项。有关注册选项和含注册数据库或地理数据库说明的主题链接的信息,请参阅关于将您的数据注册到服务器。