sqlite - 服务帐户在NServiceBus启动时抛出SQLiteException

标签 sqlite nservicebus

尝试使用服务帐户凭据启动nservicebus.host.exe时,出现以下异常:

    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 version =“ 1.0” encoding =“ utf-8”吗?>
<配置>



最佳答案

如果您暂时对指定的目录给予“所有人”和“匿名登录”完全控制权,会发生什么情况?如果这样可以解决异常,则绝对是安全问题。您是否正在使用| DataDirectory |在您的连接字符串中?您确定该过程实际上正在查看您认为正在查看的目录吗?

之后,我将尝试在内存连接字符串设置中使用SQLite,以查看它是否至少能够创建数据库并使用它:

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

上面的字符串使用内存中的SQLite,但保持单个连接打开,以便表和数据继续存在,直到进程退出。

我要使用的另一种策略是将saga持久程序更改为另一种SQL风格,例如MS SQL,以查看是否可以解决该问题。

关于sqlite - 服务帐户在NServiceBus启动时抛出SQLiteException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4951431/

相关文章:

c# - 我们真正在寻找哪种 mvc3/c# 技术/体系结构 - nservicebus、WCF 或其他?

amazon-sqs - 新的 SQS 订阅有 "Subscription Principal"导致问题

android - 在多个 Android Activity 之间共享 sqlite 数据库

python - QDataWidgetMapper-在pyqt中查找sql​​ite数据库行的索引

Java SQLite execSQL 语法错误

node.js - 在node.js中安装sqlite3时出现问题

NServiceBus: "ArgumentNullException"被 NServiceBus 抛出

.net - 从 2.6 升级到 3.0 后出现 NServiceBus 模拟问题

nservicebus - 在 NServiceBus 3+ 中将超时管理器与分配器一起使用的正确方法是什么?

sqlite - SQLite触发器:仅当查询中未包含某个字段时,触发器才会执行操作吗?