解决.Net WebAPI应用程序中AutoFac键值注册服务异常的排查过程

作者: 2024-06-20 16:04:01
标签:

异常描述:This service descriptor is keyed. Your service provider may not support keyed services.

场景:.Net8  WebAPI应用程序中使用AutoFac替代了默认的DI容器

当使用键值注册服务后:

builder.Services.AddKeyedSingleton<ICache, BigCache>( "big");

builder.Services.AddKeyedSingleton<ICache, SmallCache>( "small");

程序启动运行到:

var app = builder.Build(); 出现上述异常。

异常排查过程:

1.根据提示,由于键值服务注册前,使用了Autofac的程序集注册方式 RegisterAssemblyTypes ,一开始以为是服务已被注册导致的。在程序集外部重写了样例服务,添加注册后问题重现。

2.进一步怀疑是默认的容器键值注册方式版本问题,于是切换使用了AutoFac容器的键值注册方式:

ContainerBuilder.RegisterType<TImplements>().Keyed<TInterface>(key);

程序启动后,不报错了。以为问题解决了,结果在使用key获取服务时 IServiceProvider.GetKeyedService<T>(key) ,获取不到。感觉应该还是没有注册成功。

3.上面已经开始怀疑DI容器版本问题,于是进一步排查。看了下默认容器DI版本 Microsoft.Extensions.DependencyInjection 是8.0没啥问题。然后看了下Autofac-DI版本是8.0并且依赖的默认DI也是8.0。

也没看出啥问题,但是nuget包管理器中Autofac-DI已经支持9.0,侥幸心理升级了一下。重新启动程序,重试一下竟然可以了。。。

回过头来想了一下,其实在第二步中使用Autofac键值注册时,未出现异常,只是未注册成功,这里应该就说明Autofac-DI有问题了。

这里也给了自己一个警醒,由于项目中引用的很多第三方组件,出现问题时往往对组件内部不太熟悉,无从下手解决,这个时候不妨先看下引用版本,有可能出现的问题已经被打补丁解决了,这样至少可以少走很多弯路。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。

相关阅读

最新游戏 更多