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

通过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(当时忘记截图了,看红色字)
在这里插入图片描述
于是去看了一下两个脚本的权限,结果果然有区别,第二个脚本没有可执行权限
所以问题是否在这里呢?

解决

直接权限安排

chmod 777  文件

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

结论

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

参考

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

猜你喜欢

转载自blog.csdn.net/m0_37482190/article/details/129006246