2016-07-22 129 views
2

我收到以下错误蚂蚁在控制台在运行码头:使用MVN任务停止命令,权限(java.lang.RuntimePermission exitVM)在执行停止码头与Maven Ant任务未被授予

[artifact:mvn] org.apache.tools.ant.ExitException: Permission (java.lang.RuntimePermission exitVM) was not granted. 
[artifact:mvn] at org.apache.tools.ant.types.Permissions$MySM.checkExit(Permissions.java:196) 
[artifact:mvn] at java.lang.Runtime.exit(Runtime.java:88) 
[artifact:mvn] at java.lang.System.exit(System.java:904) 
[artifact:mvn] at org.codehaus.classworlds.Launcher.main(Launcher.java:376) 
[artifact:mvn] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
[artifact:mvn] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
[artifact:mvn] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
[artifact:mvn] at java.lang.reflect.Method.invoke(Method.java:597) 
[artifact:mvn] at org.apache.tools.ant.taskdefs.ExecuteJava.run(ExecuteJava.java:217) 
[artifact:mvn] at org.apache.tools.ant.taskdefs.ExecuteJava.execute(ExecuteJava.java:152) 
[artifact:mvn] at org.apache.tools.ant.taskdefs.Java.run(Java.java:764) 
[artifact:mvn] at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:218) 
[artifact:mvn] at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:132) 
[artifact:mvn] at org.apache.tools.ant.taskdefs.Java.execute(Java.java:105) 
[artifact:mvn] at org.apache.maven.artifact.ant.Mvn.execute(Mvn.java:81) 
[artifact:mvn] at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:288) 
[artifact:mvn] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
[artifact:mvn] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
[artifact:mvn] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
[artifact:mvn] at java.lang.reflect.Method.invoke(Method.java:597) 
[artifact:mvn] at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106) 
[artifact:mvn] at org.apache.tools.ant.Task.perform(Task.java:348) 
[artifact:mvn] at org.apache.tools.ant.Target.execute(Target.java:357) 
[artifact:mvn] at org.apache.tools.ant.Target.performTasks(Target.java:385) 
[artifact:mvn] at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1337) 
[artifact:mvn] at org.apache.tools.ant.Project.executeTarget(Project.java:1306) 
[artifact:mvn] at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41) 
[artifact:mvn] at org.apache.tools.ant.Project.executeTargets(Project.java:1189) 
[artifact:mvn] at org.apache.tools.ant.Main.runBuild(Main.java:758) 
[artifact:mvn] at org.apache.tools.ant.Main.startAnt(Main.java:217) 
[artifact:mvn] at org.apache.tools.ant.launch.Launcher.run(Launcher.java:257) 
[artifact:mvn] at org.apache.tools.ant.launch.Launcher.main(Launcher.java:104) 

在搜索对于这个错误,我得到了类似的帖子,

https://stackoverflow.com/a/8588201/1793718

https://issues.apache.org/jira/browse/MANTTASKS-201

https://readthefuckingmanual.net/error/1010/

提示设置fork="true"将解决这个问题,但如果已经是我叉设置为true(或者甚至是错误的),我得到这个错误

下面是我的Ant目标调用停止Jetty服务器,

<target name="jetty-stop" fork="true"> 
    <artifact:mvn mavenHome="${maven.home}"> 
     <jvmarg value="-Xmx1024m" /> 
     <arg value="jetty:stop"/> 
    </artifact:mvn> 
</target> 

更新:

我也注意到错误消息,同时初始化C3P0相同这一问题提到,

java.security.AccessControlException when using Ant, but runs ok when invoking java from console

同时使用下面的蚂蚁任务启动服务器,

<target name="jetty-start-jdk8"> 
    <delete dir="war/WEB-INF/lib"/> 
    <artifact:mvn mavenHome="${maven.home}" fork="true"> 
     <jvmarg value="-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=8000" /> 
     <jvmarg value="-javaagent:${jrebel.path}" /> 
     <jvmarg value="-Xbootclasspath/p:C:/Users/admin/AppData/Local/Temp//rebelboot.jar" /> 
     <arg value="compile"/> 
     <arg value="war:exploded"/> 
     <arg value="jetty:run"/> 
    </artifact:mvn> 
</target> 

上述职位还建议设置fork="true"来解决它。但它已被设置为真。这里可能是什么问题?

回答

2

解决方案:

使用JDK,而不是JRE的构建路径。

问题是我的项目在eclipse中配置了JRE而不是JDK,build.xml正在拾取我的项目配置,这是一个JRE。出于某些原因,使用JRE运行ant任务作为您的系统库。更改为JDK 1.8解决了这个问题。更改构建路径后,从Ant视图中删除Build.XML并再次添加以运行任务。