2016-07-22 130 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並再次添加以運行任務。