通过Java方法去调用shell脚本并执行,该方法会先后调用两个脚本,出现问题的是调用第二个脚本的时候,出现了该问题


目录

  • 问题
  • 排查
  • 解决
  • 结论
  • 参考


问题

  1. 使用方法Runtime.getRuntime().exec()调用并执行脚本
  2. Process.waitFor()方法返回值是否为0来确定是否成功执行(成功为0)
  3. 返回错误码126
  4. 查看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(当时忘记截图了,看红色字)

Linux:java通过Runtime.getRuntime().exec()执行shell,Process.waitFor()返回Required key not available(126)问题_开发语言


于是去看了一下两个脚本的权限,结果果然有区别,第二个脚本没有可执行权限

所以问题是否在这里呢?

解决

直接权限安排

chmod 777  文件

再次执行代码,发现问题解决了

结论

java通过Runtime.getRuntime().exec()执行shell,Process.waitFor()返回Required key not available(126)问题的解决办法:可以看一下文件权限是否有问题

参考

Process.waitFor()方法的返回值多线程Runtime.getRuntime().exec常见问题