【问题标题】:Tridion 2009 Template Publishing FailureTridion 2009 模板发布失败
【发布时间】:2012-05-22 13:24:36
【问题描述】:

在 Tridion 2009 中尝试发布页面 (.NET) 时,我们刚刚开始遇到一些错误。它开始时出现间歇性的经典“RenderComponentPresentation 超出最大渲染失败次数 0”错误,然后进展为完全失败.

我们可以正确预览页面,所以我不愿意相信这与实际的模板代码有关。

不幸的是,我无法控制正在运行的机器,所以我将无法运行任何调试代码等......所以这是在黑暗中的一个镜头!

堆栈跟踪如下:

Event Type:        Error 
Event Source:        Publishing 
Event Category:        None 
Event ID:        100 
Date:                22/05/2012 
Time:                14:28:22 
User:                N/A 
Computer:        XXXXXXXXXX
Description: 
Exception has been thrown by the target of an invocation. 
Old format or invalid type library. (Exception from HRESULT: 0x80028019 (TYPE_E_UNSUPFORMAT)) 


Component: Tridion.ContentManager.Publishing 
Errorcode: 0 
User: NT AUTHORITY\SYSTEM 

StackTrace Information Details: 
   at System.RuntimeMethodHandle._InvokeConstructor(Object[] args, SignatureStruct& signature, IntPtr declaringType) 
   at System.RuntimeMethodHandle.InvokeConstructor(Object[] args, SignatureStruct signature, RuntimeTypeHandle declaringType) 
   at System.Reflection.RuntimeConstructorInfo.Invoke(BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture) 
   at System.RuntimeType.CreateInstanceImpl(BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes) 
   at System.Activator.CreateInstance(Type type, BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes) 
   at Tridion.ContentManager.Session.GetObject(String uri) 
   at Tridion.ContentManager.Publishing.Publisher.QueueMessageHandler.HandleMessage() 

【问题讨论】:

  • 我记得在 5.3 中也有类似的错误,因为我的程序集被编译到“任何 CPU”,服务器是 x64,并且 Tridion 试图加载它们会破坏它。在强制它编译到 x86 后,我停止了错误,所以没有比这更进一步的调查。

标签: tridion


【解决方案1】:

看起来您在该系统的某个地方有一个旧的 DLL。检查您在盒子上的所有依赖项(因此您放入 GAC 或 Tridion*\bin 目录的 DLL)是否是最新的,并让它们重新启动与 Tridion 相关的服务、COM+ 应用程序和 IIS 应用程序池。

编辑:实际上,如果模板生成器工作,看起来 DLL 可能已经是最新的,您只需要重新启动服务+COM+应用程序池。如果您的团队不知道如何做到这一点,只需让他们重新启动机器或查看this script,它会强力重启所有与 Tridion 相关的内容。

【讨论】:

  • 谢谢弗兰克 - 它已经完成并且它再次工作。您对这个问题的根本原因有什么建议吗?
  • 似乎其中一个进程挂在旧版本的 DLL 上。由于 Tridion 会自动重新加载您上传的程序集,因此它很可能是最近更新的依赖项。你最近有没有安装任何附加组件。
  • 嗨弗兰克,我们没有在服务器上安装任何东西 - 最近的部署是 2009 年的一个非常普通的安装。我们通过 Tridion 部署我们的 TBB,因为不幸的是我们不能使用 TcmUploadAssembly 作为内容经理在反向代理后面。这是否可能与此问题的根本原因有关(即部署的程序集在发布请求期间同时使用,并且需要重新启动才能重新加载?)
  • 无论你是从 CME 执行 TcmUploadAssembly 还是从磁盘加载,到程序集加载的结果是完全相同的。所以这不应该导致问题。我正在和 Nuno 谈论它,他提到了一些关于 64 位/32 位或通用 DLL 的内容。当您在 Visual Studio 中构建 DLL 时,您在 DLL 中使用什么目标?
  • Nuno 回忆说,这就是在 Tridion 2011 之前有时会导致问题的原因。因此,如果再次发生这种情况,请考虑将目标设置为正确的位数 - 或者当然升级到 Tridion 2011 :-)。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2012-04-29
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-04-04
  • 2023-03-04
  • 1970-01-01
相关资源
最近更新 更多