我使用
ProcessBuilder
从java代码执行mysqldump,这是我的代码
public static void executeCommant(String... command) throws Exception {
ProcessBuilder processBuilder = null;
processBuilder = new ProcessBuilder(command);
processBuilder.redirectErrorStream(true);
Process process = processBuilder.start();
int resultCode = process.waitFor();
if (resultCode != 0) {
throw new Exception("" + readCommandOutput(process.getInputStream()));
private static String readCommandOutput(InputStream inputStream) throws IOException {
StringBuilder sb = new StringBuilder();
BufferedReader br = null;
try {
br = new BufferedReader(new InputStreamReader(inputStream));
String line = null;
while ((line = br.readLine()) != null) {
sb.append(line + System.getProperty("line.separator"));
} finally {
br.close();
return sb.toString();
public static void main(String[] args) throws Exception {
executeCommant("mysqldump -u root -P 3316 -h localhost > G:\\test.sql");
}
问题是,我得到了以下异常,即使当我从cmd运行相同的命令,我没有任何问题,我只是不知道为什么它找不到指定的文件!PS:我尝试给出mysqldump.exe的完整路径,并得到了相同的结果。
Exception in thread "main" java.io.IOException: Cannot run program "mysqldump -u root -P 3316 -h localhost > G:\test.sql": CreateProcess error=2, The system cannot find the file specified
at java.lang.ProcessBuilder.start(ProcessBuilder.java:470)
at com.etq.e2mc.platform.windows.WindowsProcess.executeCommant(WindowsProcess.java:46)
at com.etq.e2mc.platform.windows.WindowsProcess.main(WindowsProcess.java:67)
Caused by: java.io.IOException: CreateProcess error=2, The system cannot find the file specified
at java.lang.ProcessImpl.create(Native Method)
at java.lang.ProcessImpl.<init>(ProcessImpl.java:177)
at java.lang.ProcessImpl.start(ProcessImpl.java:28)
at java.lang.ProcessBuilder.start(ProcessBuilder.java:452)
... 2 more
发布于 2016-05-02 11:38:31
首先,使用数组调用
ProcessBuilder(String... command)
,这意味着数组的第一个值是程序。但是,您正在发送整个字符串
"mysqldump -u root -P 3316 -h localhost > G:\\test.sql"
,而这不是一个程序。只有
mysqldump
才是程序。
第二,在使用
getInputStream()
捕获输出时,您需要在调用
waitFor()
之前这样做,否则,您的输出缓冲区可能会完全运行,从而停止正在运行的程序的执行,从而在等待命令退出的程序和等待您读取输出的命令之间造成死锁。如果需要该流,通常需要在一个单独的线程中读取它。
第三,不能在命令字符串中使用
>
重定向输出。这是
cmd.exe
所做的事情,而不是调用
cmd.exe
。由于您希望重定向到文件,所以直接使用
ProcessBuilder
进行重定向。
ProcessBuilder processBuilder = new ProcessBuilder(
"mysqldump", "-u", "root", "-P", "3316", "-h", "localhost");
processBuilder.redirectErrorStream(true);