症状
当在 Microsoft SQL Server 2008 R2 或 Microsoft SQL Server 2012 中拥有 Service Broker 邮件转发的服务器时,如果存在以下一个或多个条件,则可能会在服务器上收到 "未生成" 错误:
-
服务器是繁忙转发 Service Broker 消息。
-
要转发的邮件数量很大。
-
在 SQL Server Profiler 跟踪中,你会注意到,由于网络问题或到达消息的生命周期,无法将某些消息发送到目标服务器。
-
Sys. 路由表中有多个条目。
此外,邮件处理的性能会减少。
原因
错误日志中的 "无法生成" 消息是一条警告。 收到此消息时,SQL server 正忙于检查消息目标列表。 此外,SQL server 确定消息是否比超时值旧,是否需要删除。 如果路由表的大小很大,而邮件列表很长,则此过程可能需要花费很长时间才能完成导致 "无法生成" 错误的工作。
解决方案
累积更新信息
SQL Server 2012 累积更新6
此问题的修补程序首次在累积更新6中发布。有关如何为 SQL Server 2012 获取此累积更新包的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2728897 SQL Server 2012 累积更新包6注意 由于这些版本是累积的,因此每个新的修复版本都包含以前的 SQL Server 2012 修复版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2692828 在 SQL Server 2012 发布后发布的 SQL Server 2012 版本
SQL Server 2012 SP1 的累积更新2
此问题的修补程序首次在累积更新2中发布。有关如何获取此累积更新包的 SQL Server 2012 SP1 的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2790947 SQL Server 2012 的累积更新包 2 Service Pack 1注意 由于这些版本是累积的,因此每个新的修复版本都包含了以前的 SQL Server 2012 SP1 修补程序版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2772858 在发布 SQL Server 2012 Service Pack 1 之后发布的 SQL Server 2012 版本
累积更新4 SQL Server 2008 R2 Service Pack 2 (SP2)
此问题的修补程序首次在累积更新4中发布。有关如何为 SQL Server 2008 R2 Service Pack 2 获取此累积更新包的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2777358 SQL Server 2008 R2 Service Pack 2 的累积更新程序包4注意 由于这些版本是累积的,因此每个新的修复版本都包含了以前的 SQL Server 2008 R2 Service Pack 2 修复版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2730301 发布 SQL Server 2008 R2 Service Pack 2 后发布的 SQL Server 2008 R2 版本
状态
Microsoft 已确认这是在“适用范围”部分中列出的 Microsoft 产品存在的问题。