【发布时间】:2014-12-12 15:11:10
【问题描述】:
我正在尝试使用 container:start 命令运行带有 sbt 的 scalatra,但我得到“断言失败:未找到生命周期类!”消息,这是我使用“last container:start”得到的完整堆栈跟踪:
块引用 最后一个容器:重新启动 java.lang.AssertionError:断言失败:找不到生命周期类! 在 scala.Predef$.assert(Predef.scala:179) 在 org.scalatra.servlet.ScalatraListener.probeForCycleClass(ScalatraListener.scala:50) 在 org.scalatra.servlet.ScalatraListener.configureCycleClass(ScalatraListener.scala:64) 在 org.scalatra.servlet.ScalatraListener.contextInitialized(ScalatraListener.scala:23) 在 org.eclipse.jetty.server.handler.ContextHandler.callContextInitialized(ContextHandler.java:800) 在 org.eclipse.jetty.servlet.ServletContextHandler.callContextInitialized(ServletContextHandler.java:446) 在 org.eclipse.jetty.server.handler.ContextHandler.startContext(ContextHandler.java:792) 在 org.eclipse.jetty.servlet.ServletContextHandler.startContext(ServletContextHandler.java:296) 在 org.eclipse.jetty.webapp.WebAppContext.startWebapp(WebAppContext.java:1359) 在 org.eclipse.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1352) 在 org.eclipse.jetty.server.handler.ContextHandler.doStart(ContextHandler.java:744) 在 org.eclipse.jetty.webapp.WebAppContext.doStart(WebAppContext.java:497) 在 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) 在 org.eclipse.jetty.util.component.ContainerLifeCycle.start(ContainerLifeCycle.java:125) 在 org.eclipse.jetty.util.component.ContainerLifeCycle.doStart(ContainerLifeCycle.java:107) 在 org.eclipse.jetty.server.handler.AbstractHandler.doStart(AbstractHandler.java:60) 在 org.eclipse.jetty.server.handler.ContextHandlerCollection.doStart(ContextHandlerCollection.java:154) 在 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) 在 org.eclipse.jetty.util.component.ContainerLifeCycle.start(ContainerLifeCycle.java:125) 在 org.eclipse.jetty.server.Server.start(Server.java:358) 在 org.eclipse.jetty.util.component.ContainerLifeCycle.doStart(ContainerLifeCycle.java:107) 在 org.eclipse.jetty.server.handler.AbstractHandler.doStart(AbstractHandler.java:60) 在 org.eclipse.jetty.server.Server.doStart(Server.java:325) 在 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) 在 com.earldouglas.xsbtwebplugin.Jetty9Runner.start(Jetty9Runner.scala:122) 在 com.earldouglas.xsbtwebplugin.Container$$anonfun$containerSettings$11.apply(Container.scala:77) 在 com.earldouglas.xsbtwebplugin.Container$$anonfun$containerSettings$11.apply(Container.scala:74) 在 scala.Function8$$anonfun$tupled$1.apply(Function8.scala:35) 在 scala.Function8$$anonfun$tupled$1.apply(Function8.scala:34) 在 scala.Function1$$anonfun$compose$1.apply(Function1.scala:47) 在 sbt.$tilde$greater$$anonfun$$u2219$1.apply(TypeFunctions.scala:42) 在 sbt.std.Transform$$anon$4.work(System.scala:64) 在 sbt.Execute$$anonfun$submit$1$$anonfun$apply$1.apply(Execute.scala:237) 在 sbt.Execute$$anonfun$submit$1$$anonfun$apply$1.apply(Execute.scala:237) 在 sbt.ErrorHandling$.wideConvert(ErrorHandling.scala:18) 在 sbt.Execute.work(Execute.scala:244) 在 sbt.Execute$$anonfun$submit$1.apply(Execute.scala:237) 在 sbt.Execute$$anonfun$submit$1.apply(Execute.scala:237) 在 sbt.ConcurrentRestrictions$$anon$4$$anonfun$1.apply(ConcurrentRestrictions.scala:160) 在 sbt.CompletionService$$anon$2.call(CompletionService.scala:30) 在 java.util.concurrent.FutureTask.run(FutureTask.java:262) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471) 在 java.util.concurrent.FutureTask.run(FutureTask.java:262) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) 在 java.lang.Thread.run(Thread.java:744) [错误](容器:重新启动)java.lang.AssertionError:断言失败:找不到生命周期类! 块引用
这是我的 LifeCycle 文件,名为:“ScalatraBootstrap.scala”,其内容为:
import org.Server.Controllers.Controller2
import org.scalatra.example.Server._
import org.scalatra.LifeCycle
import javax.servlet.ServletContext
class ScalatraBootstrap extends LifeCycle {
implicit val swagger = new FlowSwagger
override
def init(context: ServletContext) {
context.mount(new Controller1, "/*") context.mount(new Controller2, "/string1/*") context.mount(new Controller3, "/string2/*")
}
}
【问题讨论】: