我写了一个小的演示网络应用程序,我可以在tomcat服务器上运行,并显示一个vaadin图表。
当我第一次重启服务器并加载应用程序时,它可以运行。一旦我对代码进行了更改并且应该自动重新部署应用程序,我就会在下面得到 ClassNotFoundException:com.vaadin.ui.AbstractComponent 异常。我重新编译了widgetset,因为图表需要这个。
在添加图表之前,这没有问题,所以我假设图表组件缺少某些东西,但是当我重启服务器时它会起作用,这让我很困惑。
在不更改图表特定代码时,我是否需要不断重新编译图表?我需要如何调整常春藤文件才能实现此目的?
注释:
@VaadinServletConfiguration(productionMode = false, ui = DerstandarduseranalyzerUI.class, widgetset = "com.example.derstandarduseranalyzer.widgetset.DerstandarduseranalyzerWidgetset")
Widgetset gwt
<inherits name="com.vaadin.DefaultWidgetSet" />
<inherits name="com.vaadin.addon.charts.Widgetset" />
<inherits name="com.vaadin.addon.timeline.gwt.TimelineWidgetSet" />
的ivy.xml
<?xml version="1.0"?>
<!DOCTYPE ivy-module [
<!ENTITY vaadin.version "7.4.4">
]>
<ivy-module version="2.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="http://ant.apache.org/ivy/schemas/ivy.xsd">
<info organisation="com.example" module="v7proj" />
<configurations>
<conf name="default" />
<conf name="widgetset-compile" />
<conf name="nodeploy" />
</configurations>
<dependencies defaultconf="default" defaultconfmapping="default->default">
<dependency org="com.vaadin" name="vaadin-server" rev="&vaadin.version;" />
<dependency org="com.vaadin" name="vaadin-themes" rev="&vaadin.version;" />
<dependency org="com.vaadin" name="vaadin-push" rev="&vaadin.version;" conf="default->default"/>
<dependency org="javax.servlet" name="javax.servlet-api" rev="3.0.1" conf="nodeploy->default" />
<dependency org="com.vaadin" name="vaadin-testbench-api" rev="latest.release" conf="nodeploy -> default" />
<dependency org="com.vaadin" name="vaadin-client-compiled"
rev="&vaadin.version;" />
<dependency org="com.vaadin" name="vaadin-client" rev="&vaadin.version;" conf="widgetset-compile->default" />
<dependency org="com.vaadin" name="vaadin-client-compiler" rev="&vaadin.version;" conf="widgetset-compile->default" />
</dependencies>
</ivy-module>
ivysettings.xml
<?xml version="1.0" encoding="UTF-8"?>
<ivysettings>
<settings defaultResolver="default" />
<resolvers>
<chain name="default">
<ibiblio name="public" m2compatible="true" />
<ibiblio
name="vaadin-addons"
usepoms="true"
m2compatible="true"
root="http://maven.vaadin.com/vaadin-addons" />
<ibiblio name="vaadin-addons" usepoms="true" m2compatible="true"
root="http://maven.vaadin.com/vaadin-addons" />
<ibiblio name="vaadin-snapshots" usepoms="true" m2compatible="true"
root="https://oss.sonatype.org/content/repositories/vaadin-snapshots" />
<dual name="custom-smartsprites">
<filesystem name="smartsprites-ivy">
<ivy pattern="${basedir}/ivymodule/[module]-ivy-[revision].xml" />
</filesystem>
<url name="smartsprites-artifact">
<artifact
pattern="http://dev.vaadin.com/svn/versions/6.8/build/smartsprites/lib/[artifact](-[revision]).[ext]" />
</url>
</dual>
</chain>
</resolvers>
<modules>
<module organisation="com.carrotsearch" name="smartsprites"
revision="0.2.3-itmill" resolver="custom-smartsprites" />
</modules>
</ivysettings>
错误
2015年4月22日下午11:31:54 org.apache.catalina.core.StandardContext 重新加载INFO:使用名称[/ derStandardUserAnalyzer]重新加载上下文 已于2015年4月22日下午11:31:54开始 org.apache.catalina.loader.WebappClassLoaderBase checkThreadLocalMapForLeaks严重:Web应用程序 [/ derStandardUserAnalyzer]使用类型的键创建了一个ThreadLocal [com.google.gson.Gson $ 1](价值[com.google.gson.Gson$1@e7f068c])和 值类型为[java.util.HashMap](值[{}])但无法删除 当Web应用程序停止时。线程将是 随着时间的推移重新尝试避免可能的内存泄漏。 4月22日, 2015 11:31:54 PM org.apache.jasper.servlet.TldScanner scanJars INFO: 至少有一个JAR被扫描用于TLD但尚未包含TLD。启用 调试此记录器的日志记录,以获取完整的JAR列表 扫描但未找到TLD。在期间跳过不需要的JAR 扫描可以缩短启动时间和JSP编译时间。 4月22日, 2015 11:31:54 org.apache.catalina.session.StandardManager startInternal SEVERE:来自持久性的异常加载会话 存储java.lang.NoClassDefFoundError: com / vaadin / ui / AbstractComponent at java.lang.ClassLoader.defineClass1(Native Method)at java.lang.ClassLoader.defineClass(未知来源)at java.security.SecureClassLoader.defineClass(未知来源)at org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2450) 在 org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:852) 在 org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1262) 在 org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1145) at java.lang.Class.forName0(Native Method)at java.lang.Class.forName(未知来源)at org.apache.catalina.util.CustomObjectInputStream.resolveClass(CustomObjectInputStream.java:74) 在java.io.ObjectInputStream.readNonProxyDesc(未知来源)at java.io.ObjectInputStream.readClassDesc(未知来源)at java.io.ObjectInputStream.readClass(未知来源)at java.io.ObjectInputStream.readObject0(未知来源)at java.io.ObjectInputStream.skipCustomData(未知来源)at java.io.ObjectInputStream.readSerialData(未知来源)at java.io.ObjectInputStream.readOrdinaryObject(Unknown Source)at java.io.ObjectInputStream.readObject0(未知来源)at java.io.ObjectInputStream.defaultReadFields(未知来源)at java.io.ObjectInputStream.readSerialData(未知来源)at java.io.ObjectInputStream.readOrdinaryObject(Unknown Source)at java.io.ObjectInputStream.readObject0(未知来源)at java.io.ObjectInputStream.defaultReadFields(未知来源)at java.io.ObjectInputStream.readSerialData(未知来源)at java.io.ObjectInputStream.readOrdinaryObject(Unknown Source)at java.io.ObjectInputStream.readObject0(未知来源)at java.io.ObjectInputStream.readObject(未知来源)at org.apache.catalina.session.StandardSession.doReadObject(StandardSession.java:1634) 在 org.apache.catalina.session.StandardSession.readObjectData(StandardSession.java:1099) 在 org.apache.catalina.session.StandardManager.doLoad(StandardManager.java:261) 在 org.apache.catalina.session.StandardManager.load(StandardManager.java:180) 在 org.apache.catalina.session.StandardManager.startInternal(StandardManager.java:460) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5238) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 在 org.apache.catalina.core.StandardContext.reload(StandardContext.java:3821) 在 org.apache.catalina.loader.WebappLoader.backgroundProcess(WebappLoader.java:292) 在 org.apache.catalina.core.StandardContext.backgroundProcess(StandardContext.java:5576) 在 org.apache.catalina.core.ContainerBase $ ContainerBackgroundProcessor.processChildren(ContainerBase.java:1377) 在 org.apache.catalina.core.ContainerBase $ ContainerBackgroundProcessor.processChildren(ContainerBase.java:1381) 在 org.apache.catalina.core.ContainerBase $ ContainerBackgroundProcessor.processChildren(ContainerBase.java:1381) 在 org.apache.catalina.core.ContainerBase $ ContainerBackgroundProcessor.run(ContainerBase.java:1349) 在java.lang.Thread.run(未知来源)引起: java.lang.ClassNotFoundException:com.vaadin.ui.AbstractComponent at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1293) 在 org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1145)
答案 0 :(得分:2)
我也时不时地发生这种情况。不是与Vaadin相关的问题,而是容器的问题。基本上它没有更新。通常重启机器(它可能挂在某处)有帮助;一个快速的选择是&#34;项目&gt;清除&#34;并且在用于运行/调试的服务器上(“服务器”选项卡)&#34;右键单击&gt;清除&#34 ;. 每次都这样做有点烦人,但为我工作。