【发布时间】:2012-07-30 14:33:07
【问题描述】:
我的团队在五台不同的服务器上运行 ColdFusion (v9)。其中三台在负载均衡路由器上,另外两台是开发和测试机。
几个月前,我们开始遇到某些页面/模板请求会失败的问题。当我说失败时,我的意思是服务器会返回 500 错误。但是,该错误没有通过 cftry/cfcatch 和 cferror 触发我们的 ColdFusion 异常处理。
检查 HTTP 标头后,它看起来像是某种 jrun 错误,所以我进入了异常日志。下面是一个错误示例(这是今天早上发生的):
"Error","jrpp-1","07/30/12","06:30:02",,"(class: cfezReporting2ecfc400556386, method: runPage signature: ()Ljava/lang/Object;) Incompatible object argument for function call The specific sequence of files included or processed is: X:\docs\ezBuilder\index.cfm'' "
java.lang.VerifyError: (class: cfezReporting2ecfc400556386, method: runPage signature: ()Ljava/lang/Object;) Incompatible object argument for function call
at java.lang.Class.getDeclaredConstructors0(Native Method)
at java.lang.Class.privateGetDeclaredConstructors(Class.java:2389)
at java.lang.Class.getConstructor0(Class.java:2699)
at java.lang.Class.newInstance0(Class.java:326)
at java.lang.Class.newInstance(Class.java:308)
at coldfusion.runtime.TemplateClassLoader.newInstance(TemplateClassLoader.java:552)
at coldfusion.runtime.TemplateClassLoader.newInstance(TemplateClassLoader.java:523)
at coldfusion.runtime.TemplateProxyFactory.getCFCInstance(TemplateProxyFactory.java:270)
at coldfusion.runtime.TemplateProxyFactory.resolveName(TemplateProxyFactory.java:173)
at coldfusion.runtime.TemplateProxyFactory.resolveName(TemplateProxyFactory.java:158)
at coldfusion.runtime.TemplateProxyFactory.resolveName(TemplateProxyFactory.java:148)
at coldfusion.cfc.ComponentProxyFactory.getProxy(ComponentProxyFactory.java:62)
at coldfusion.tagext.lang.InvokeTag.doEndTag(InvokeTag.java:373)
at cfezBuilder2ecfc293785079$funcCREATE_UVN._factor7(X:\docs\ezBuilder\components\ezBuilder.cfc:376)
at cfezBuilder2ecfc293785079$funcCREATE_UVN.runFunction(X:\docs\ezBuilder\components\ezBuilder.cfc:327)
at coldfusion.runtime.UDFMethod.invoke(UDFMethod.java:472)
at coldfusion.runtime.UDFMethod$ReturnTypeFilter.invoke(UDFMethod.java:405)
at coldfusion.runtime.UDFMethod$ArgumentCollectionFilter.invoke(UDFMethod.java:368)
at coldfusion.filter.FunctionAccessFilter.invoke(FunctionAccessFilter.java:55)
at coldfusion.runtime.UDFMethod.runFilterChain(UDFMethod.java:321)
at coldfusion.runtime.UDFMethod.invoke(UDFMethod.java:517)
at coldfusion.runtime.CfJspPage._invokeUDF(CfJspPage.java:2547)
at coldfusion.tagext.lang.InvokeTag.doEndTag(InvokeTag.java:460)
一旦模板上发生此错误,它将继续发生,即它不是零星的,也没有“自行修复”。
另一个有趣的消息是,这个错误似乎在所有服务器上同时发生在同一个文件上。同时,我的意思是当我们收到一个出错的通知时,我们测试其他服务器并发现它们也出错了。
无法在任何地方找到有关此特定错误详细信息的帮助,我猜测 ColdFusion 不知何故无法找到模板或类文件。我检查了每台服务器,发现 .cfc 文件在那里(另外,“找不到模板”异常总是不同的)。
因此,我对文件(上例中的 ezReporting.cfc)进行了更改,并将其复制到所有服务器,你瞧,它起作用了。更改只是添加然后删除一个空格-我猜基本上是强制模板重新编译。每次发生错误时,我都会在接下来的几周内每次都这样做。它总是在那个 .cfc 文件上。
大约一周后,下一次发生错误时,它在完全相同的文件中。这一次,我清除了服务器上的模板缓存,而不是物理更改模板。它又起作用了。
从那时起,同样的错误出现在几个不同的文件上——CFC 和 CFM 文件。我没有注意到(a)文件的“年龄”/最后更新日期的模式 - 从一天到一年多的所有内容,(b)文件的内容 - 从简单块到 SQL 查询到一些基本设置/循环,或 (c) 文件的名称。
今天早上,它发生在另一个文件上,我知道两天前它在所有服务器上都有效。自去年以来,CFC 文件内容没有在任何服务器上被触及。而且,当我访问所有五台服务器时,完全相同的文件在所有服务器上都失败了。当我清除模板缓存后,每台服务器都重新开始工作。
我提供所有这些无聊的细节是因为我正在寻求任何可以提供帮助的东西。也许文件本身发生了某种过期,这可以解释为什么文件几乎同时在所有服务器上过期——我们在开发服务器上更改它,然后将它移到测试和生产服务器一个简单的复制/粘贴。但是,似乎没有任何到期的韵律或原因,因为所讨论的文件具有不同的年龄,如上所述。
我尝试了 Adobe 论坛以获取有关此特定异常/转储的帮助,但没有找到遇到相同问题的任何人。
还有其他人有什么想法吗?这个错误让我很困扰,因为它不会触发我们正常的异常处理,所以如果没有人工干预,我们无法做太多事情。感谢您提供任何具体指导。
【问题讨论】:
-
因此,当接下来发生这种情况时,请查看您的 cfclasses 文件夹。 cfezReporting2ecfc400556386.class ) 或下次调用的任何文件系统中是否有最近修改的日期?另外,你的集群设置是什么?您是否打开了粘性会话?您是否打开了会话复制?被调用的对象是否保存在服务器、应用程序或会话等长期存在的范围内?
-
感谢您的澄清问题。下次发生时我会检查类文件是否存在。没有真正的聚类;实例彼此分开,我们不使用粘性会话会话复制。此外,到目前为止,正在调用的“缺失”对象要么是简单的 cfincluded cfm 文件,要么是通过调用模板中的 cfinvoke 调用的静态 CFC。这些案例中不涉及服务器/应用程序/会话范围的 CFC。
-
我记得我今天早上在这种状态下留下了一个测试服务器,以防万一。有问题的类文件的日期为 2012 年 3 月 1 日(cfc 自 2011 年以来未更新)。当我清除模板缓存时,类文件收到今天的日期。
标签: templates coldfusion coldfusion-9