解决方案:Ambari-metrics-collector启动报错:CIRCULAR REFERENCE: java.lang.NoSuchMethodError: javax.servlet.ServletContext.createFilter(Ljava/lang/Class;)Ljavax/servlet/Filter;]
1.检查Ambari-metrics-collector调用jar包目录:/usr/lib/ambari-metrics-collector
根据报错信息检查javax.servlet-api-3.1.0.jar 包,用开发工具打开,发现其有上述报错信息的类,那么不是这里的问题;很有可能是没有调用上边的包。
2.检查jetty包,打开可以发现其引用也没有问题,因为没有完成的工程,所以是没法看到实际调用情况的。
3.那么,根据多年的排错经验,很有可能是jetty调用servlet的时候没有调用3.1.0版本的包,继续排查路径下是否有相同类的jar包;最终,发现了罪魁祸首servlet-api-2.5.jar,因为createFilter是在3.0以后才有的,所以,删除这个jar包,再启动就ok了。
4.删除其他节点下的2.5版本的jar包。