【问题标题】:Tomcat 7 fails to deploy on EC2 instance due to Exceptions由于异常,Tomcat 7 无法在 EC2 实例上部署
【发布时间】:2016-05-31 02:16:58
【问题描述】:

我已经根据以下内容构建了我的基座应用程序

https://github.com/pedestal/pedestal/blob/master/guides/documentation/service-war-deployment.md

然后我上传 .war 文件并部署它。

但是,当我 ssh 进入 ec2 实例时,我发现它没有成功部署,即使它这么说

INFO: At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JARs durin$ May 31, 2016 2:09:52 AM org.apache.catalina.core.ContainerBase addChildInternal SEVERE: ContainerBase.addChild: start: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[]]
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:153)
        at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:899)
        at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:875)
        at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:652)
        at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1091)
        at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1980)
        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
        at java.util.concurrent.FutureTask.run(FutureTask.java:262)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
        at java.lang.Thread.run(Thread.java:745) Caused by: java.lang.NoClassDefFoundError: org/apache/tomcat/util/descriptor/tld/TldParser
        at org.apache.jasper.servlet.TldScanner.<init>(TldScanner.java:86)
        at org.apache.jasper.servlet.JasperInitializer.newTldScanner(JasperInitializer.java:120)
        at org.apache.jasper.servlet.JasperInitializer.onStartup(JasperInitializer.java:101)
        at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5573)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:147)
        ... 10 more Caused by: java.lang.ClassNotFoundException: org.apache.tomcat.util.descriptor.tld.TldParser
        at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1858)
        at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1701)
        ... 15 more

May 31, 2016 2:09:52 AM org.apache.catalina.startup.HostConfig deployWAR SEVERE: Error deploying web application archive /var/lib/tomcat7/webapps/ROOT.war java.lang.IllegalStateException: ContainerBase.addChild: start: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[]]
        at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:903)
        at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:875)
        at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:652)
        at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1091)
        at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1980)
        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
        at java.util.concurrent.FutureTask.run(FutureTask.java:262)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
        at java.lang.Thread.run(Thread.java:745)


May 31, 2016 2:09:52 AM org.apache.catalina.startup.HostConfig deployWAR INFO: Deployment of web application archive /var/lib/tomcat7/webapps/ROOT.war has finished in 6,440 ms 
May 31, 2016 2:09:52 AM org.apache.coyote.AbstractProtocol start INFO: Starting ProtocolHandler ["http-bio-8080"] 
May 31, 2016 2:09:52 AM org.apache.coyote.AbstractProtocol start INFO: Starting ProtocolHandler ["ajp-bio-8009"] 
May 31, 2016 2:09:52 AM org.apache.catalina.startup.Catalina start INFO: Server startup in 6530 ms

我认为这是特定于基座的,因为我成功部署了一个打包成 war 的 clojure ring web 应用程序,没有任何问题。

【问题讨论】:

    标签: amazon-ec2 clojure tomcat7 leiningen pedestal


    【解决方案1】:

    从堆栈跟踪来看,似乎缺少这个类:org/apache/tomcat/util/descriptor/tld/TldParser

    您提供的 uber-war 可能仍然包含 Tomcat 类。您链接到的说明以删除 Tomcat 依赖项:

    [io.pedestal/pedestal.tomcat "0.1.0"] 
    

    我猜 EC2 提供了它自己的 Tomcat,如果你没有提供任何冲突的类,你就不会得到那个错误。

    您可以使用任何 zip/归档工具查看战争内部并确认您已完全删除 Tomcat:毕竟它只是一个 zip 文件。

    【讨论】:

    • 后者听起来更有可能,需要删除哪些文件?
    • 我猜是所有嵌入 tomcat 的*.jar 文件
    • 你从哪里得到 0.1.0?我正在使用 `[io.pedestal/pedestal.tomcat "0.4.1"]`,就像那个文档中的一样
    • 哦该死的现在我想我现在为什么`;;删除此行并取消注释下一行到 ;;使用 Immutant 或 Tomcat 而不是 Jetty:` 在 project.clj 中,我认为这意味着取消注释掉 tomcat 但这会创建 tomcat-embed*.jar 我认为这会造成冲突!!!
    • 我刚刚从您提供的链接中的第一步复制了[io.pedestal/pedestal.tomcat "0.1.0"]。我们必须以某种方式被带到不同的页面,我的年龄要大得多。
    猜你喜欢
    • 2015-11-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-02-26
    • 2021-11-08
    • 2021-10-19
    • 1970-01-01
    • 2020-12-18
    相关资源
    最近更新 更多