我得到一个InvalidOperationException对下面的代码。我确信我对autofac和Rebus缺乏了解,导致了这个错误。
系统。InvalidOperationException未处理
Message=No Message context available - MessageContext实例将只在处理消息期间设置,并且它只在工作线程上可用。
部分的StackTrace:
at Rebus.MessageContext.GetCurrent()
at Rebus.Autofac.AutofacContainerAdapter.GetHandlerInstancesFor[T]()
at RebusAutofacDemo.Program.Main(String[] args) in c:RebusAutofacDemoProgram.cs:line 45
[cut]
所以当我在控制台应用程序中使用下面的代码时,我得到了上面的错误。
class Program
{
static void Main(string[] args)
{
var builder = new Autofac.ContainerBuilder();
builder.RegisterType<MyHandler>();
var container = builder.Build();
var adapter = new AutofacContainerAdapter(container);
var bus = Configure.With(adapter)
.Transport(t => t.UseAzureServiceBus("myConnectionstring", "my_input_queue", "error"))
.CreateBus()
.Start();
adapter.GetHandlerInstancesFor<MyHandler>(); // THIS IS THE LINE WITH THE ERROR
var timer = new System.Timers.Timer();
timer.Elapsed += delegate { bus.SendLocal(new MyMessage{ Body = DateTime.Now.ToString()}); };
timer.Interval = 1000;
timer.Start();
Console.ReadLine();
}
}
public class MyMessage
{
public string Body { get; set; }
}
public class MyHandler : IHandleMessages<MyMessage>
{
private readonly IBus _bus;
public MyHandler(IBus bus)
{
_bus = bus;
}
public void Handle(MyMessage message)
{
Console.WriteLine(message);
}
}
为了完整起见,这被添加到app.config:
<configSections>
<section name="rebus" type="Rebus.Configuration.RebusConfigurationSection, Rebus" />
</configSections>
<rebus inputQueue="my-app.input" errorQueue="my-app.error" workers="1">
<endpoints>
<!-- <add messages="SomeAssembly" endpoint="another-app.input"/> -->
</endpoints>
</rebus>
你得到错误,因为你正在调用GetHandlerInstances
,这意味着由Rebus在处理消息时调用。
试着删除这一行,然后你会看到你的消息得到处理。
PS: MyHandler
必须在容器中注册为IHandleMessages<MyMessage>
的实现-我不是Autofac专家,但我不认为你在代码中这样做…?