为什么我的 WCF 错误异常未处理
本文关键字:异常 未处理 错误 WCF 我的 为什么 | 更新日期: 2024-10-31 20:15:35
我有一个基于以下合同的服务(删节):
[ServiceContract]
public interface ISchedulerService
{
[OperationContract]
void Process(bool isForced);
}
实现的密切相关(恕我直言)部分是:
[ServiceBehavior(InstanceContextMode = InstanceContextMode.Single, UseSynchronizationContext = false)]
public class SchedulerService : ISchedulerService
{
public async void Process(bool isForced)
{
try
{
var prevStatus = Status;
Status = SchedulerStatus.Processing;
await ProcessListings();
Status = prevStatus;
}
catch (Exception ex)
{
throw new FaultException(ex.Message);
}
}
private static Task ProcessListings()
{
throw new Exception("ProcessListings failed.");
return Task.Delay(5000);
}
}
该服务当前托管在一个小型控制台应用程序中:
class Program
{
private static readonly SchedulerService Scheduler = SchedulerService.Instance;
private static ServiceHost schedulerHost;
protected static void OnStart()
{
try
{
if (schedulerHost != null)
{
schedulerHost.Close();
schedulerHost = null;
}
schedulerHost = new ServiceHost(Scheduler);
schedulerHost.Open();
Scheduler.Start();
}
catch (Exception ex)
{
//EventLog.WriteEntry("Exception: " + ex.Message);
throw;
}
}
}
最后,客户:
private readonly SchedulerServiceClient _proxy= new SchedulerServiceClient();
...
void ExecuteProcessNowCommand()
{
try
{
_proxy.Process(true);
}
catch (Exception ex)
{
if (exception is SchedulerException)
{
MessageBoxFacility.ProcessingError((SchedulerException)exception);
}
}
}
其中SchedulerServiceClient
是添加服务引用时生成的代理。到目前为止,我已经成功地在实时 Windows 服务中承载了 WCF,并测试了非异常功能。一切都很好,直到我添加了异常处理。我知道这是一个复杂的场景,但我看到的大多数示例都表明,FaultException
至少会被客户端中的常规Exception
处理程序捕获。我的调试器让我猜测异常甚至没有进入代理,并且在 MVC 代码中仍未处理。当我点击"继续"足够多时,我最终会出现一个屏幕,告诉我堆栈仅包含外部代码。这是该外部代码的堆栈跟踪:
at System.Runtime.CompilerServices.AsyncMethodBuilderCore.<ThrowAsync>b__1(Object state)
at System.Threading.QueueUserWorkItemCallback.WaitCallback_Context(Object state)
at System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
at System.Threading.QueueUserWorkItemCallback.System.Threading.IThreadPoolWorkItem.ExecuteWorkItem()
at System.Threading.ThreadPoolWorkQueue.Dispatch()
at System.Threading._ThreadPoolWaitCallback.PerformWaitCallback()</ExceptionString></Exception></TraceRecord>
这让我觉得我在 MCV 服务中使用async
可能我扮演了一个角色,但也许它只是一个无辜的中间人。请帮助我尝试并确定为什么异常甚至没有传播到客户端。
async
方法中的异常存储在返回的任务中。 async void
方法不返回任务,因此在ThreadPool
线程上引发异常,从而破坏AppDomain
。
不要在事件处理程序以外的任何地方使用 async void
。
如果返回任务,则可以await
该任务,并且将重新引发异常。