通过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常见问题
                




