事实证明,这里的 LocalReport 使用 .NET Remoting 动态创建子应用程序域并运行报告,以避免内部某处泄漏。然后我们注意到,最终,报告将在 10 到 20 分钟后释放所有内存。对于生成大量 PDF 的人来说,这是行不通的。然而,这里的关键是他们正在使用 .NET Remoting。Remoting 的关键部分之一是所谓的“租赁”。租赁意味着它将保留那个元帅对象一段时间,因为远程处理通常设置起来很昂贵,而且它可能会被多次使用。LocalReport RDLC 正在滥用此功能。
默认情况下,租赁时间是... 10 分钟!此外,如果有什么东西发出各种呼叫,它会增加另外 2 分钟的等待时间!因此,它可以随机在 10 到 20 分钟之间,具体取决于呼叫的排列方式。幸运的是,您可以更改此超时发生的时间。不幸的是,您只能为每个应用程序域设置一次...因此,如果您需要除 PDF 生成之外的远程处理,您可能需要让另一个服务运行它,以便您可以更改默认值。为此,您需要做的就是在启动时运行以下 4 行代码:
LifetimeServices.LeaseTime = TimeSpan.FromSeconds(5);
LifetimeServices.LeaseManagerPollTime = TimeSpan.FromSeconds(5);
LifetimeServices.RenewOnCallTime = TimeSpan.FromSeconds(1);
LifetimeServices.SponsorshipTimeout = TimeSpan.FromSeconds(5);