使用 redis 集成的公共交通传奇导致异常
Masstransit saga using redis integration cause exception
我想在使用 RedisSagaRepository 的应用程序中使用 MassTransit sagas。
初始化看起来像
var machine = new CreditTransactionStateMachine();
var redisOptions = new ConfigurationOptions
{
EndPoints =
{
"link-to-redis:6379",
},
ClientName = "login",
Password = "pass",
};
var redis = ConnectionMultiplexer.Connect(redisOptions);
var repo = new Lazy<ISagaRepository<CreditTransactionSaga>>(
() => new RedisSagaRepository<CreditTransactionSaga>(() => redis.GetDatabase()));
var busControl = Bus.Factory.CreateUsingRabbitMq(x =>
{
IRabbitMqHost host = x.Host(new Uri("rabbitmq://link-to-rabbit"), h =>
{
h.Username("guest");
h.Password("guest");
});
x.ReceiveEndpoint(host, "queueName", e =>
{
e.PrefetchCount = 8;
e.StateMachineSaga(machine, repo.Value);
});
});
busControl.Start();
Console.Out.WriteLine("Bus started.");
所以当我在队列中收到一条消息时,状态机开始处理它,但随后出现 NotImplementedByDesignException.
完整的堆栈跟踪是
Redis saga repository does not support
queriesMassTransit.NotImplementedByDesignException: Redis saga
repository does not support queries в
MassTransit.RedisIntegration.RedisSagaRepository1.SendQuery[T](SagaQueryConsumeContext
2
context, ISagaPolicy2 policy, IPipe
1 next) в
MassTransit.Saga.Pipeline.Filters.QuerySagaFilter`2.>-Send>d__6.MoveNext()---
看起来 RedisSagaRepository 不应该使用 SendQuery 方法,但在 QuerySagaFilter 中它显式调用,我看不到解决这个问题的方法。
是否有任何 RedisSagaRepository 初始化的工作示例或如何在不调用 SendQuery 的情况下使用它的建议?
我发现避免RedisSagaRepository.SendQuery方法的唯一方法是
在配置状态机事件时使用 EventCorrelationConfigurator.CorrelateById 方法而不是 EventCorrelationConfigurator.CorrelateBy。
所以它应该在你的所有模型中都有一个相关的 Guid,由状态机使用。希望对大家有帮助。
我想在使用 RedisSagaRepository 的应用程序中使用 MassTransit sagas。 初始化看起来像
var machine = new CreditTransactionStateMachine();
var redisOptions = new ConfigurationOptions
{
EndPoints =
{
"link-to-redis:6379",
},
ClientName = "login",
Password = "pass",
};
var redis = ConnectionMultiplexer.Connect(redisOptions);
var repo = new Lazy<ISagaRepository<CreditTransactionSaga>>(
() => new RedisSagaRepository<CreditTransactionSaga>(() => redis.GetDatabase()));
var busControl = Bus.Factory.CreateUsingRabbitMq(x =>
{
IRabbitMqHost host = x.Host(new Uri("rabbitmq://link-to-rabbit"), h =>
{
h.Username("guest");
h.Password("guest");
});
x.ReceiveEndpoint(host, "queueName", e =>
{
e.PrefetchCount = 8;
e.StateMachineSaga(machine, repo.Value);
});
});
busControl.Start();
Console.Out.WriteLine("Bus started.");
所以当我在队列中收到一条消息时,状态机开始处理它,但随后出现 NotImplementedByDesignException.
完整的堆栈跟踪是
Redis saga repository does not support queriesMassTransit.NotImplementedByDesignException: Redis saga repository does not support queries в MassTransit.RedisIntegration.RedisSagaRepository
1.SendQuery[T](SagaQueryConsumeContext
2 context, ISagaPolicy2 policy, IPipe
1 next) в MassTransit.Saga.Pipeline.Filters.QuerySagaFilter`2.>-Send>d__6.MoveNext()---
看起来 RedisSagaRepository 不应该使用 SendQuery 方法,但在 QuerySagaFilter 中它显式调用,我看不到解决这个问题的方法。
是否有任何 RedisSagaRepository 初始化的工作示例或如何在不调用 SendQuery 的情况下使用它的建议?
我发现避免RedisSagaRepository.SendQuery方法的唯一方法是 在配置状态机事件时使用 EventCorrelationConfigurator.CorrelateById 方法而不是 EventCorrelationConfigurator.CorrelateBy。
所以它应该在你的所有模型中都有一个相关的 Guid,由状态机使用。希望对大家有帮助。