Weblogic Ant JWSC任务生成webservice war文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Weblogic Ant JWSC任务生成webservice war文件相关的知识,希望对你有一定的参考价值。

我正在运行jwsc ant任务来生成war文件。如果我在运行ant脚本之前将weblogic.jar添加到classpath(CLASSPATH = / opt / bea / weblogic91 / server / lib / weblogic.jar export CLASSPATH),它对我来说运行正常。

但是如果我在build.xml中添加它,则无效,如下所示:

<target name="GenerateWarFiles">   
<path id="lib.jwsc.id">  
<pathelement path="/opt/bea/weblogic91/server/lib/weblogic.jar"/>  
</path>  
<taskdef name="jwsc" classname="weblogic.wsee.tools.anttasks.JwscTask" classpathref="lib.jwsc.id"/>  
<jwsc srcdir="${src.java.dir}" destdir="${build.war.file.dir}" verbose="on" debug="on" classpathref="lib.jwsc.id">  
<jws file="sep/com/bt/prf/jws/TypeImpl.java" compiledWsdl="${ivy.lib.dir}/WSDLC/Jwslib-8.0.jar" />  
</jwsc>   
</target>

我收到以下错误。

[AntUtil.deleteDir] Deleting directory /var/tmp/_927vxb

BUILD FAILED
/wls_domains/CIT/cruisecontrol-bin-2.8.3/util/Ivy/build.xml:231: Deployment descriptor: /var/tmp/_927vxb/web.xml does not exist.
at weblogic.wsee.tools.anttasks.JwscTask.execute(JwscTask.java:184)
at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:288)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:585)
at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:105)
at org.apache.tools.ant.Task.perform(Task.java:348)
at org.apache.tools.ant.Target.execute(Target.java:357)
at org.apache.tools.ant.Target.performTasks(Target.java:385)
at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1329)
at org.apache.tools.ant.Project.executeTarget(Project.java:1298)
at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
at org.apache.tools.ant.Project.executeTargets(Project.java:1181)
at org.apache.tools.ant.Main.runBuild(Main.java:698)
at org.apache.tools.ant.Main.startAnt(Main.java:199)
at org.apache.tools.ant.launch.Launcher.run(Launcher.java:257)
at org.apache.tools.ant.launch.Launcher.main(Launcher.java:104)
Caused by: Deployment descriptor: /var/tmp/_927vxb/web.xml does not exist.
at org.apache.tools.ant.taskdefs.War.setWebxml(War.java:95)
at weblogic.wsee.tools.anttasks.JwscTask.jar(JwscTask.java:397)
at weblogic.wsee.tools.anttasks.JwscTask.pkg(JwscTask.java:331)
at weblogic.wsee.tools.anttasks.JwscTask.execute(JwscTask.java:166)
... 17 more
--- Nested Exception ---
Deployment descriptor: /var/tmp/_927vxb/web.xml does not exist.
at org.apache.tools.ant.taskdefs.War.setWebxml(War.java:95)
at weblogic.wsee.tools.anttasks.JwscTask.jar(JwscTask.java:397)
at weblogic.wsee.tools.anttasks.JwscTask.pkg(JwscTask.java:331)
at weblogic.wsee.tools.anttasks.JwscTask.execute(JwscTask.java:166)
at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:288)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:585)
at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:105)
at org.apache.tools.ant.Task.perform(Task.java:348)
at org.apache.tools.ant.Target.execute(Target.java:357)
at org.apache.tools.ant.Target.performTasks(Target.java:385)
at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1329)
at org.apache.tools.ant.Project.executeTarget(Project.java:1298)
at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
at org.apache.tools.ant.Project.executeTargets(Project.java:1181)
at org.apache.tools.ant.Main.runBuild(Main.java:698)
at org.apache.tools.ant.Main.startAnt(Main.java:199)
at org.apache.tools.ant.launch.Launcher.run(Launcher.java:257)
at org.apache.tools.ant.launch.Launcher.main(Launcher.java:104)

Total time: 1 minute 3 seconds

我在Solaris中运行weblogic91。

答案

我打赌你的部署目标(这里没有发布)试图“清理”部署目录,并且当它找不到名为/var/tmp/_927vxb/web.xml的文件时失败

3意见建议:

  1. 从命令行运行touch /var/tmp/_927vxb/web.xml并尝试再次运行构建/部署。这将创建一个空文件,至少可以让您通过删除错误时找不到的文件。这不是一个长期的解决方案,而是试图揭露真正的问题。
  2. 查看/wls_domains/CIT/cruisecontrol-bin-2.8.3/util/Ivy/build.xml文件中的第231行。也许有一个delete蚂蚁任务是failing on error。如果是这种情况,请将“failonerror =”false“添加到导致问题的ant任务中。
  3. 在此处发布更多构建文件。能够将文件中的行号与错误对齐将有助于解码问题。

以上是关于Weblogic Ant JWSC任务生成webservice war文件的主要内容,如果未能解决你的问题,请参考以下文章

在 Weblogic 10.3 上使用 ant 部署 WAR 时出现“Java 堆空间”错误

Ant+Weblogic - CreateProcess 错误=206

基于ant自动部署ear/war 文件到weblogic12c

使用Ant自动化发布web工程

weblogic对JSP预编译weblogic读取JSP编译后的class文件ant中jspc预编译JSP

如何将 JUnit Ant 任务配置为仅在失败时生成输出?