通过Java方法去调用shell脚本并执行,该方法会先后调用两个脚本,出现问题的是调用第二个脚本的时候,出现了该问题
目录
- 问题
- 排查
- 解决
- 结论
- 参考
问题
- 使用方法Runtime.getRuntime().exec()调用并执行脚本
- Process.waitFor()方法返回值是否为0来确定是否成功执行(成功为0)
- 返回错误码126
- 查看Process.waitFor()方法的返回值:Required key not available 操作系统错误代码126:所需的Key不可用
排查
因为看到错误码对应的原因是:Required key not available,所需的Key不可用。查找了很多相关解决办法,发现都不太相关。
于是只能捕捉进程的输出来看是否能找到蛛丝马迹
增加代码如下:
Process proc = Runtime.getRuntime().exec(strMakePathPath);
StreamGobbler errorGobbler = new StreamGobbler(proc.getErrorStream(), "Error");
StreamGobbler outputGobbler = new StreamGobbler(proc.getInputStream(), "Output");
errorGobbler.start();
outputGobbler.start();
proc.waitFor();
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
public class StreamGobbler extends Thread {
InputStream is;
String type;
public StreamGobbler(InputStream is, String type) {
this.is = is;
this.type = type;
}
public void run() {
try {
InputStreamReader isr = new InputStreamReader(is);
BufferedReader br = new BufferedReader(isr);
String line = null;
while ((line = br.readLine()) != null) {
if (type.equals("Error")) {
System.out.println("Error :" + line);
} else {
System.out.println("Debug:" + line);
}
}
} catch (IOException ioe) {
ioe.printStackTrace();
}
}
}
校验输出如下error(当时忘记截图了,看红色字)
于是去看了一下两个脚本的权限,结果果然有区别,第二个脚本没有可执行权限
所以问题是否在这里呢?
解决
直接权限安排
chmod 777 文件
再次执行代码,发现问题解决了
结论
java通过Runtime.getRuntime().exec()执行shell,Process.waitFor()返回Required key not available(126)问题的解决办法:可以看一下文件权限是否有问题
参考
Process.waitFor()方法的返回值多线程Runtime.getRuntime().exec常见问题