NServiceBus 4.6.5 NHibernate Saga Persister не сохраняет данные Saga

Я использую NServiceBus с NHibernate и размещаю шину в своем собственном процессе. Конфигурация, которую я использую:

Configure.ScaleOut(s => s.UseSingleBrokerQueue());
        Configure.Transactions.Enable();
        Configure.Features.Enable<Sagas>();
        Configure.Serialization.Xml();

        return
            Configure.With()
                     .DefaultBuilder()
                     .DefiningCommandsAs(type => type.Namespace != null && type.Namespace.EndsWith("Contracts.Commands"))
                     .DefiningEventsAs(type => type.Namespace != null && type.Namespace.EndsWith("Contracts.Events"))
                     .DefiningMessagesAs(type => type.Namespace != null && type.Namespace.EndsWith("Contracts.Messages"))
                     .RijndaelEncryptionService()
                     .UseTransport<RabbitMQ>()
                     .PurgeOnStartup(false)
                     .UnicastBus()
                     .RunHandlersUnderIncomingPrincipal(false)
                     .ImpersonateSender(false)
                     .LoadMessageHandlers()
                     .UseNHibernateSubscriptionPersister()
                     .UseNHibernateSagaPersister()
                     .UseNHibernateTimeoutPersister()
                     .DisableTimeoutManager()
                     .CreateBus()
                     .Start
                (() => {
                     Configure.Instance.LicensePath(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "NServiceBus-Licence.xml"));
                     Configure.Instance.ForInstallationOn<Windows>().Install();
                 });

с участием:

<connectionStrings>
    <add name="NServiceBus/Transport" connectionString="host=localhost" />
    <add name="NServiceBus/Persistence" connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=testdb;Persist Security Info=True; Connect Timeout=200; Pooling=True; Max Pool Size=5000; Async=true; Integrated Security=SSPI;" providerName="System.Data.SqlClient" />
</connectionStrings>
<appSettings>
    <add key="NServiceBus/Persistence/NHibernate/dialect" value="NHibernate.Dialect.MsSql2012Dialect" />
    <add key="NServiceBus/Persistence/NHibernate/connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />
    <add key="NServiceBus/Persistence/NHibernate/connection.driver_class" value="NHibernate.Driver.Sql2008ClientDriver" />
</appSettings>

Эта конфигурация создает таблицы для моих саг в моей базе данных SQL Server с полями, которые я указал в своей саге, и это здорово.

Однако, когда моя сага запускается и завершается, NServiceBus, похоже, не вставляет записи в мои таблицы саги.

Таблицы есть, а данных нет.

Этого следует ожидать? Удаляет ли NServiceBus записи саги в постоянстве после успешного завершения саги?


person Anish Patel    schedule 23.09.2014    source источник


Ответы (1)


Ответ на мой собственный вопрос - да.

NServiceBus удаляет записи в таблицах данных саги после завершения саги.

person Anish Patel    schedule 23.09.2014