在现在的开发过程当中,开发人员可能面临多个数据源,那么在一台服务器上部署多个arcsde服务就显得比较常见了,对oracle数据库来说,一个arcsde服务是对应一个数据库实例,那么在建立过程是比较简单的,但是对sqlserver数据库来说就比较特殊了,因为我们可以
在现在的开发过程当中,开发人员可能面临多个数据源,那么在一台服务器上部署多个arcsde服务就显得比较常见了,对oracle数据库来说,一个arcsde服务是对应一个数据库实例,那么在建立过程是比较简单的,但是对sqlserver数据库来说就比较特殊了,因为我们可以在sqlserver数据库的同一个实例但是对应不同的database,但是sqlserver数据库特殊在于如果的默认database不是sde的话,你需要指定你的默认数据库,那么我在创建服务过程中就需要进行特殊的指定设置。
假设我们已经存在了一个针对sde数据库的arcsde服务,那么我们又建立了一个sde931的库,我们新设定的sdehome是c:\arcsde\sqlexe,那么大家都知道,我们需要使用sdeservice命令来创建相关的服务
c:\users\administrator>sdeservice -o create -d sqlserver -p super123 -s sde931 -i esri_sde2 -h c:\arcsde\sqlexesuccessfully created and registered esri_sde2 service
但是,如果我们对创建好的arcsde服务启动,我们可以看到会报如下错误
-------------------------------------------------------arcsde 9.3.1 for sql server build 1632 thu feb 26 12:05:37 2009-------------------------------------------------------idbinitialize::initialize faileddb_open_instance() pcc_connect error: -2147217871init_db db_instance_open_as_dba: -51dbms error code: -2147217871microsoft sql server native client 10.0: 登录超时已过期
这就是我上提到的我们需要注册默认数据库。我们可以看看帮助是怎么说的
it is assumed the arcsde administrator user for which you are providing the password (-p) is sde. it is also assumed that the name of the database to which the service applies is sde. if your arcsde administrator user is not sde, such as when you use a dbo schema in sql server, you must set the sde_dba_user registry key to the login name of the dbo user using sdeservice -o register. if the name of your database is not sde, you must set the admin_database registry key to the name of your database using the sdeservice -o register command.
也可以参考相关的帮助文档:http://support.esri.com/en/knowledgebase/techarticles/detail/29575
那么我们第一个,就是需要将我们的默认数据库和默认sde用户注册一下
c:\users\administrator>sdeservice -o register -r admin_database -v sde931 -d sqlserver -p super123 -i esri_sde2 -h c:\arcsde\sqlexesuccessfully registered 'admin_database' key for esri_sde2 instancec:\users\administrator>sdeservice -o register -r sde_dba_user -v sde -d sqlserver -p super123 -i esri_sde2 -h c:\arcsde\sqlexesuccessfully registered 'sde_dba_user' key for esri_sde2 instance
另外我们需要进入注册表,添加对sqlserver服务的依赖项,默认是没有的
hkey_local_machine——system——currentcontrolset——services——esri_sde2(自己定义的sde实例名)
需要在该实例添加
类型:reg_multi_sz
名称:dependonservice
数据:mssqlserver(这个根据用户的实例名称)也可以参考另外一个sde实例的写法
我们也可以查看以下节点,验证是否填写正确
hkey_local_machine——software——esri——arcinfo——arcsde——arcsde for sqlserver——esri_sde2(你的sde实例名)
来查看是否已经添加好
admin_database
datasource:该项对应的应该是数据库的机器名或者ip
sde_dba_user
这样的话,我们就可以启动arcsde服务了
更多教程请访问 mysql视频教程