processbuilder无法找到给定命令的文件

vcudknz3  于 2021-06-30  发布在  Java
关注(0)|答案(0)|浏览(369)

我正在构建一个运行以下maven命令的cli工具

mvn archetype:generate -B -DarchetypeGroupId=me.pablo -DarchetypeArtifactId=fleeti-archetype -DarchetypeVersion=1.0 -Dversion=1.0 -DgroupId=me.pablo -Dpackage=me.pablo -Dname=Test -DartifactId=test

它应该在下面的目录中运行这个命令

C:\Users\35356\Desktop\Test

现在,我创建了自己的实用程序类,以便使用processbuilder运行所需的命令:

package me.pablo.processes;

import me.pablo.FleetiMessage;
import me.pablo.FleetiMessageType;
import me.pablo.commands.Command;

import java.io.*;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
import java.util.function.Consumer;
import java.util.Arrays;

public class FleetiProcess
{
    private List<Command> commands;
    private List<Process> allProcesses;

    public FleetiProcess(final List<Command> commands) {
        this.commands = commands;
        this.allProcesses = new ArrayList<>();
    }

    public void execute() {
       runProcess();
    }

    public void executeAsync(final int delayInSeconds) {
        Executors.newSingleThreadScheduledExecutor().schedule(this::runProcess, delayInSeconds, TimeUnit.SECONDS);
    }

    public void execute(final int delayInSeconds) {
        Executors.newSingleThreadScheduledExecutor().schedule(this::stopFleetiProcess, delayInSeconds, TimeUnit.SECONDS);
        runProcess();
    }

    public void stopFleetiProcess() {
        allProcesses.forEach(Process::destroyForcibly);
    }

    private void runProcess() {
        commands.forEach(command -> {
            // Debug messages
            System.out.println("Raw command is \n" + command.getRawCommand());
            System.out.println("Split command is \n" + Arrays.toString(command.getRawCommand().split(" ")));
            System.out.println("Target file exist: \n" + new File(command.getPath()).exists());

            final ProcessBuilder commandBuilder = new ProcessBuilder();
            commandBuilder.command(command.getRawCommand().split(" "));
            commandBuilder.directory(new File(command.getPath()));
            try {
                final Process commandProcess = commandBuilder.start();
                final StreamGobbler streamGobbler = new StreamGobbler(commandProcess.getInputStream(), System.out::println);
                Executors.newSingleThreadExecutor().submit(streamGobbler);
                allProcesses.add(commandProcess);

                int exitVal = commandProcess.waitFor();
                if (exitVal == 0) {
                    FleetiMessage.printMessage(
                            new FleetiMessage(FleetiMessageType.SUCCESS, "Successfully ran process for " + command.getRawCommand()));
                } else {
                    FleetiMessage.printMessage(
                            new FleetiMessage(FleetiMessageType.ERROR, "Could not run process for command " + command.getRawCommand()));
                }
            } catch (final IOException | InterruptedException e) {
                e.printStackTrace();
            }
        });
    }

    private static class StreamGobbler implements Runnable {
        private InputStream inputStream;
        private Consumer<String> consumer;

        StreamGobbler(InputStream inputStream, Consumer<String> consumer) {
            this.inputStream = inputStream;
            this.consumer = consumer;
        }

        @Override
        public void run() {
            new BufferedReader(new InputStreamReader(inputStream)).lines()
                    .forEach(consumer);
        }
    }
}

每次运行此代码时,都会遇到相同的错误:
java.io.ioexception:无法运行程序“mvn”(在目录“c:\users\356\desktop\test”中):createprocess error=2,系统找不到指定的文件
我研究了这个问题,并尝试了建议的解决方案:尝试在processbuilder构造函数中传递命令,将命令作为单个字符串运行,并确保文件确实存在。
但是,我知道这个文件确实存在。这是完整的控制台输出:

Raw command is
mvn archetype:generate -B -DarchetypeGroupId=me.pablo -DarchetypeArtifactId=fleeti-archetype -DarchetypeVersion=1.0 -Dversion=1.0 -DgroupId=me.pablo -Dpackage=me.pablo -Dname=Test -DartifactId=test
Split command is
[mvn, archetype:generate, -B, -DarchetypeGroupId=me.pablo, -DarchetypeArtifactId=fleeti-archetype, -DarchetypeVersion=1.0, -Dversion=1.0, -DgroupId=me.pablo, -Dpackage=me.pablo, -Dname=Test, -DartifactId=test]
Target file exist:
true
java.io.IOException: Cannot run program "mvn" (in directory "C:\Users\35356\Desktop\Test"): CreateProcess error=2, The system cannot find the file specified
        at java.base/java.lang.ProcessBuilder.start(Unknown Source)
        at java.base/java.lang.ProcessBuilder.start(Unknown Source)
        at me.pablo.processes.FleetiProcess.lambda$runProcess$0(FleetiProcess.java:53)
        at java.base/java.lang.Iterable.forEach(Unknown Source)
        at me.pablo.processes.FleetiProcess.runProcess(FleetiProcess.java:43)
        at me.pablo.processes.FleetiProcess.execute(FleetiProcess.java:26)
        at me.pablo.commands.FleetiCreateAppCommand.run(FleetiCreateAppCommand.java:89)
        at picocli.CommandLine.executeUserObject(CommandLine.java:1729)
        at picocli.CommandLine.access$900(CommandLine.java:145)
        at picocli.CommandLine$RunLast.handle(CommandLine.java:2101)
        at picocli.CommandLine$RunLast.handle(CommandLine.java:2068)
        at picocli.CommandLine$AbstractParseResultHandler.execute(CommandLine.java:1935)
        at picocli.CommandLine.execute(CommandLine.java:1864)
        at me.pablo.FleetiCLI.main(FleetiCLI.java:19)
Caused by: java.io.IOException: CreateProcess error=2, The system cannot find the file specified
        at java.base/java.lang.ProcessImpl.create(Native Method)
        at java.base/java.lang.ProcessImpl.<init>(Unknown Source)
        at java.base/java.lang.ProcessImpl.start(Unknown Source)
        ... 14 more

我在macos上运行了这个代码,运行得非常好。我只有在windows上运行时才遇到此问题。有人知道问题出在哪里吗?

暂无答案!

目前还没有任何答案,快来回答吧!

相关问题