處理將在Linux Web服務器上運行以從特定目錄中刪除日誌的應用程序,但是我一直收到FileNotFound異常。當文件存在時,ProcessBuilder給出「文件未找到」異常
下面是代碼:
public static void deleteLOG() {
try {
ProcessBuilder probuilder = new ProcessBuilder("find /home/root/multicraft/servers/ -name '*.log' -delete");
probuilder.start();
} catch (IOException e) {
e.printStackTrace();
}
}
和異常
java.io.IOException: Cannot run program "find . -name '*CoreData*' -delete" (in directory "/home/root/multicraft/servers"): error=2, No such file or directory
at java.lang.ProcessBuilder.start(Unknown Source)
at com.mcprohosting.com.nodecleanup.Preprocess.deleteCoreData(Preprocess.java:23)
at com.mcprohosting.com.nodecleanup.handlers.CleanupHandler.executeCleanup(CleanupHandler.java:36)
at com.mcprohosting.com.main.NodeCleaner.init(NodeCleaner.java:29)
at com.mcprohosting.com.main.NodeCleaner.main(NodeCleaner.java:25)
Caused by: java.io.IOException: error=2, No such file or directory
at java.lang.UNIXProcess.forkAndExec(Native Method)
at java.lang.UNIXProcess.<init>(Unknown Source)
at java.lang.ProcessImpl.start(Unknown Source)
... 5 more
但是命令cd /家庭/根/ multicraft /服務器工作完全正常。
我也試着:
ProcessBuilder probuilder = new ProcessBuilder("find . -name '*Backup*' -delete");
probuilder.directory(new File("/home/root/multicraft/servers/"));
probuilder.start();
感謝您的回答,沒有更多的錯誤,但它並沒有刪除任何文件。有關更多信息,該命令通常需要幾秒鐘才能完成,但在此行執行期間沒有暫停。這裏是更新後的代碼行 - 「find」,「/ home/root/multicraft/servers /」,「-name」,「'* CoreData *」,「-delete」 –
您是否有名爲'CoreData 「那裏?我可以看到你從模式的開頭和結尾刪除了'*'。 – Isaac