多次构建 Autofac Singleton Decorator
Posted
技术标签:
【中文标题】多次构建 Autofac Singleton Decorator【英文标题】:Autofac Singleton Decorator constructed multiple times 【发布时间】:2018-04-28 15:31:05 【问题描述】:我正在尝试为某些服务创建一个简单的内存缓存机制。我正在使用装饰器模式,创建一个服务的缓存版本来装饰它的具体实现。 通过使用 Autofac,我将缓存装饰器注册为 SingleInstance(),以确保数据保留在内存中。
builder.RegisterDecorator<IBackendOperatorServiceProxy>(
(c, inner) => new CachedBackendOperatorServiceProxy(inner),
fromKey: "BackendOperatorService")
.SingleInstance();
我会将具体实现注册为
builder.RegisterType<BackendOperatorServiceProxy>().Named<IBackendOperatorServiceProxy>("BackendOperatorService");
我遇到的问题是,当在 webApi 控制器中解决时,这个单例装饰器总是被重新创建(每个请求一次)。
我(希望)为 autofac 正确设置了 owin 管道(事实上,服务被注入到控制器调用的 BL 类中)。
我真的无法理解此类问题的可能原因。我在不同的项目中使用了 SIngleInstance() 不同的时间,它总是可以正常工作。 为了进一步“调查”,我还创建了一个注册为单例的假类,并将其注入与装饰器相同的控制器中。它按预期工作,只创建了一个假类的实例。 为了完整起见,我将这个假的注册为:
builder.Register<Foo>(c => new Foo(c.ResolveNamed<IBackendOperatorServiceProxy>("BackendOperatorService"))).AsImplementedInterfaces().SingleInstance();
这是缓存(装饰)服务的构造函数:
public CachedBackendOperatorServiceProxy(IBackendOperatorServiceProxy decoratedServiceImplementation)
_decoratedServiceImplementation = decoratedServiceImplementation ?? throw new ArgumentNullException(nameof(decoratedServiceImplementation));
_cachedElements = new Dictionary<string, CachedOperatorDto>();
装饰器和 SIngleInstances 有什么问题或我缺少的东西吗?
【问题讨论】:
如果您手动注册装饰器,而不使用 RegisterDecorator - 会按预期工作吗? 是的。通过手动注册装饰器似乎可以按预期工作。所以autofac似乎存在某种问题。无论如何,这就是我注册服务的方式: builder.Register(c => new CachedBackendOperatorServiceProxy( c.ResolveNamed感谢 Evk,最简单的解决方案是坚持“手动”装饰器注册,因为当您需要装饰多个实现时,应该使用 RegisterDecorator(如 cmets 中提供的链接中所报告的那样),而不是像我之前的那样试图做。
【讨论】:
以上是关于多次构建 Autofac Singleton Decorator的主要内容,如果未能解决你的问题,请参考以下文章