2011-02-09 18 views
2

,我發現了以下情況例外,當我嘗試使用服務帳戶憑據啓動nservicebus.host.exe:服務帳戶上NServiceBus啓動投擲SQLiteException

Database was not configured through Database method. 
System.Data.SQLite.SQLiteException: Unable to open the database file 
at System.Data.SQLite.SQLite3.Open(String strFilename, SQLiteOpenFlagsEnum flags, Int32 maxPoolSize, Boolean usePool) 
at System.Data.SQLite.SQLiteConnection.Open() 
at NHibernate.Connection.DriverConnectionProvider.GetConnection() in :line 0 
at NHibernate.Tool.hbm2ddl.SuppliedConnectionProviderConnectionHelper.Prepare() in :line 0 
at NHibernate.Tool.hbm2ddl.SchemaMetadataUpdater.GetReservedWords(Dialect dialect, IConnectionHelper connectionHelper) in :line 0 
at NHibernate.Tool.hbm2ddl.SchemaMetadataUpdater.Update(ISessionFactory sessionFactory) in :line 0 
at NHibernate.Impl.SessionFactoryImpl..ctor(Configuration cfg, IMapping mapping, Settings settings, EventListeners listeners) in :line 0 
at FluentNHibernate.Cfg.FluentConfiguration.BuildSessionFactory() in D:\dev\fluent-nhibernate\src\FluentNHibernate\Cfg\FluentConfiguration.cs:line 93 
--- End of inner exception stack trace --- 
at FluentNHibernate.Cfg.FluentConfiguration.BuildSessionFactory() in D:\dev\fluent-nhibernate\src\FluentNHibernate\Cfg\FluentConfiguration.cs:line 100 
at NServiceBus.SagaPersisters.NHibernate.Config.Internal.SessionFactoryBuilder.Build(IDictionary^2 nhibernateProperties, Boolean updateSchema) in c:\Dev\DotNet\NServiceBus\src\impl\SagaPersisters\NHibernateSagaPersister\NServiceBus.SagaPersisters.NHibernate.Config\Internal\SessionFactoryBuilder.cs:line 48 
--- End of inner exception stack trace --- 
at NServiceBus.SagaPersisters.NHibernate.Config.Internal.SessionFactoryBuilder.Build(IDictionary^2 nhibernateProperties, Boolean updateSchema) in c:\Dev\DotNet\NServiceBus\src\impl\SagaPersisters\NHibernateSagaPersister\NServiceBus.SagaPersisters.NHibernate.Config\Internal\SessionFactoryBuilder.cs:line 55 
at NServiceBus.ConfigureNHibernateSagaPersister.NHibernateSagaPersister(Configure config, IDictionary^2 nhibernateProperties, Boolean autoUpdateSchema) in c:\Dev\DotNet\NServiceBus\src\impl\SagaPersisters\NHibernateSagaPersister\NServiceBus.SagaPersisters.NHibernate.Config\ConfigureNHibernateSagaPersister.cs:line 80 
at Ibfx.BackOffice.Services.NewAccounts.NewAccountsEndpoint.Init() in C:\Dev\TFS\Omega\Src\Svcs\NewAccounts\Src\Service\NewAccountsEndpoint.cs:line 67 
at NServiceBus.Host.Internal.GenericHost.Start() in c:\Dev\DotNet\NServiceBus\src\host\NServiceBus.Host\Internal\GenericHost.cs:line 56 

一切工作正常,如果我用我自己的運行主機帳戶,但是如果我使用域憑據將主機作爲服務運行,或者使用RunAs命令使用相同憑據,則會出現上述異常。我需要配置什麼權限才能使服務起作用?

這裏是我的配置:

 var configure = NServiceBus.Configure.With() 
      .Log4Net<Log4NetLoggerAdapter>(a => { }) 
      .UnityBuilder(container) 
      .XmlSerializer() 
      .RijndaelEncryptionService() 
      .MsmqTransport() 
       .IsTransactional(false) 
       .PurgeOnStartup(false) 
       .MsmqSubscriptionStorage(); 

     configure.Configurer.ConfigureComponent<MsmqSubscriptionStorage>(
        ComponentCallModelEnum.None).ConfigureProperty(p => p.DontUseExternalTransaction 
        , true 
       ); 

     IBus bus = configure.UnicastBus() 
      .ImpersonateSender(true) 
      .LoadMessageHandlers() 
      .Sagas() 
      .NHibernateSagaPersister() 
     .CreateBus() 
     .Start(); 

而且我有以下內容的NServiceBus.Host.exe.config文件:

< XML版本= 「1.0」 編碼= 「UTF-8」 ? > <配置> <啓動useLegacyV2RuntimeActivationPolicy = 「真」 > < supportedRuntime版本= 「V4.0」/ > < /啓動> < /配置>

+0

絕對是一個權限問題,我將服務帳戶添加到本地管理員組,一切正常。任何人都知道我需要設置什麼權限? – 2011-02-09 23:58:07

+0

當我撤銷管理員權限,但授予完全控制文件夾上的用戶我得到「嘗試寫入只讀數據庫」錯誤。順便說一句,該服務安裝在「程序文件夾」目錄中。但是,它被安裝爲作爲服務運行,並且我已檢查它是否具有「以服務身份登錄」的權限。 – 2011-02-10 00:24:32

回答

2

會發生什麼事,當你暫時給大家,並匿名登錄完全控制指定的目錄?如果解決了這個例外,那絕對是一個安全問題。你在使用| DataDirectory |在你的連接字符串?您確定該流程實際上是在查看您認爲正在查看的目錄嗎?

在此之後,我會嘗試使用內存連接字符串設置SQLite的,看它是否能夠至少創建一個數據庫,並使用它:

":memory:;Version=3;New=True;Pooling=True;Max Pool Size=1;"

上面的字符串在內存中的SQLite但保持打開單個連接,以便表和數據繼續存在,直到進程退出。

我將使用的另一個策略是將saga persister更改爲另一個SQL flavor,例如MS SQL,以查看是否可以解決此問題。