在我的工作区中有几个动态Web项目,每个项目都包含类,并引用其他实用程序项目(简单的Java项目)和第三方jar。
这些应用程序(动态Web项目)使用eclipse WTP(Helios 3.6)部署在tomcat v6.0.6上
当我更新我的工作区,并从SVN存储库中提取新的类/资源/jar时,我在tomcat应用程序中重新发布我的应用程序,并重新启动它。
偶尔,当tomcat启动我的一个应用程序时,它会抛出ClassNotFoundException,或者抱怨缺少其他资源。有时候我会看到一个部署的资源(例如spring beans xml)不是最新的,里面有“旧”的内容。
我常用的抗巫-黑-魔疗法:用途:* 停止/启动tomcat * 清理(当右键单击服务器配置时)* 清理tomcat工作目录 * 从tomcat中删除所有应用,清理,重新启动tomcat,添加所有应用
我需要运行这个“程序”几次,直到问题得到解决。
你们也有这种病吗?这是一个已知的bug吗?有什么建议吗?使用jar而不是实用程序项目是否可以解决/减少这个问题?
我会考虑使用嵌入式Jetty代替,我只是想避免专有的脚本运行Jetty的'生产'环境。
-- Yonatan
8条答案
按热度按时间gjmwrych1#
我也遇到过类似的问题。当我发布一个Web应用程序时,Eclipse没有包含一个jar,因此通过Eclipse发布到服务器失败。我通过修改项目的.classpath文件来纠正依赖关系,如下所示。确保它与其他jar配置同步。
xmq68pz92#
似乎在解决这个问题上正在取得进展。
https://bugs.eclipse.org/bugs/show_bug.cgi?id=365748
希望它能在Eclipse的下一个版本中得到修复。
r8xiu3jd3#
一个可能的解决方案可能是您的bin文件夹没有被创建。检查你没有删除build/bin文件夹,它确实存在于你的工作空间。
deikduxw4#
TL;DR在eclipse中刷新
Package Explorer
视图并发布(或重新发布)服务。这个问题通常发生在文件是在eclipse/wtp环境之外创建的时候。例如,maven构建过程可能会在
target
文件夹下生成..$1.class
文件。eclipse/wtp在发布时会忽略它们,因为它不知道它们的存在。通过刷新Package Explorer
视图重新构建eclipse的文件索引有助于eclipse拾取这些更改。这似乎是eclipse/wtp在IDE外部创建文件时的一个限制。
mtb9vblg5#
我经常遇到这种事。我可不认为那是巫毒教。我认为当你在后台改变一些东西时,Eclipse WTP不能很好地工作(例如,一个专业的建筑)。
为了解决这个问题,我所做的就是完全避免使用它。相反,我使用Maven WAR插件来部署应用程序:
这工作非常快,因为它不需要组装,并 Package 战争。
然后要取消部署应用程序:
我有剧本
它看起来像这样:
启动tomcat并部署app:
取消部署并停止tomcat:
可能与任何其他构建脚本相同-这只是你必须编写多少代码的问题。
我选择了Maven的战争:原地目标是因为它做得很少,因此运行得很快。点击这里:maven.apache.org/plugins/maven-war-plugin/usage.html
顺便说一句,ANT和Gradle有一个战争任务/插件,可能可以配置为做类似的事情(我真的不记得了.)
希望这对你有帮助。
oxf4rvwz6#
另一件需要注意的事情是,应该启用
Project -> Build Automatically
,并且项目不应该有任何构建路径问题。打开navigator视图并确认构建文件夹已生成
class
文件。如果文件没有被构建,它们将不会被发布。虽然这看起来很明显,但很容易看过,浪费了我很多时间。
w3nuxt5m7#
有趣的行为....由于权限问题,我的Linux机器上也发生了类似的事情。
我建议不要使用WTP。尝试使用ant build script。它很简单,对我来说,它工作得很好。
0dxa2lsx8#
自从Eclipse问世以来,这些问题一直存在。到达这里是因为atm my web.xml不再被部署。特别是与m2eclipse结合使用时,您永远不会知道当您尝试启动Tomcat时会发生什么。我认识的每个使用Eclipse的人都有这些问题,我不明白为什么他们没有得到解决.不幸的是,作为承包商工作意味着我不能选择我的IDE或容器或发布方式,所以大多数时候我都被WTP卡住了。