怎么在SQLServer数据库创建多个ArcSDE服务

怎么在SQLServer数据库创建多个ArcSDE服务,第1张

概述在现在的开发过程当中,开发人员可能面临多个数据源,那么在一台服务器上部署多个ArcSDE服务就显得比较常见了,对Oracle数据库来说,一个ArcSDE服务是对应一个数据库实例,那么在建立过程是比较简单的,但是对SQLServer数据库来说就比较特殊了,因为我们可以在SQLServer数据库的同一个实例但是对应不同的Database,但是SQLServer数据库特殊在于如果的默认Database不

在现在的开发过程当中,开发人员可能面临多个数据源,那么在一台服务器上部署多个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\sqlexe"Successfully 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\sqlexe"Successfully 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服务了

-------------------------------------------------------------------------------------------------------
版权所有,文章允许转载,但必须以链接方式注明源地址,否则追究法律责任!


Blog:               http://blog.csdn.net/linghe301
Weibo:            http://www.weibo.com/linghe301
------------------------------------------------------------------------------------------------------

总结

以上是内存溢出为你收集整理的怎么在SQLServer数据库创建多个ArcSDE服务全部内容,希望文章能够帮你解决怎么在SQLServer数据库创建多个ArcSDE服务所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1177694.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存