admin管理员组文章数量:1031616
Linux:java通过Runtime.getRuntime().exec()执行shell,Process.waitFor()返回Required key not available(126)问题
通过Java方法去调用shell脚本并执行,该方法会先后调用两个脚本,出现问题的是调用第二个脚本的时候,出现了该问题
问题
- 使用方法Runtime.getRuntime().exec()调用并执行脚本
- Process.waitFor()方法返回值是否为0来确定是否成功执行(成功为0)
- 返回错误码126
- 查看Process.waitFor()方法的返回值:Required key not available 操作系统错误代码126:所需的Key不可用
排查
因为看到错误码对应的原因是:Required key not available,所需的Key不可用。查找了很多相关解决办法,发现都不太相关。
于是只能捕捉进程的输出来看是否能找到蛛丝马迹 增加代码如下:
代码语言:javascript代码运行次数:0运行复制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();
代码语言:javascript代码运行次数:0运行复制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(当时忘记截图了,看红色字)
于是去看了一下两个脚本的权限,结果果然有区别,第二个脚本没有可执行权限 所以问题是否在这里呢?
解决
直接权限安排
代码语言:javascript代码运行次数:0运行复制chmod 777 文件
再次执行代码,发现问题解决了
结论
java通过Runtime.getRuntime().exec()执行shell,Process.waitFor()返回Required key not available(126)问题的解决办法:可以看一下文件权限是否有问题
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2025-04-07,如有侵权请联系 cloudcommunity@tencent 删除runtimejavalinuxkeyprocessLinux:java通过Runtime.getRuntime().exec()执行shell,Process.waitFor()返回Required key not available(126)问题
通过Java方法去调用shell脚本并执行,该方法会先后调用两个脚本,出现问题的是调用第二个脚本的时候,出现了该问题
问题
- 使用方法Runtime.getRuntime().exec()调用并执行脚本
- Process.waitFor()方法返回值是否为0来确定是否成功执行(成功为0)
- 返回错误码126
- 查看Process.waitFor()方法的返回值:Required key not available 操作系统错误代码126:所需的Key不可用
排查
因为看到错误码对应的原因是:Required key not available,所需的Key不可用。查找了很多相关解决办法,发现都不太相关。
于是只能捕捉进程的输出来看是否能找到蛛丝马迹 增加代码如下:
代码语言:javascript代码运行次数:0运行复制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();
代码语言:javascript代码运行次数:0运行复制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(当时忘记截图了,看红色字)
于是去看了一下两个脚本的权限,结果果然有区别,第二个脚本没有可执行权限 所以问题是否在这里呢?
解决
直接权限安排
代码语言:javascript代码运行次数:0运行复制chmod 777 文件
再次执行代码,发现问题解决了
结论
java通过Runtime.getRuntime().exec()执行shell,Process.waitFor()返回Required key not available(126)问题的解决办法:可以看一下文件权限是否有问题
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2025-04-07,如有侵权请联系 cloudcommunity@tencent 删除runtimejavalinuxkeyprocess本文标签: Linuxjava通过RuntimegetRuntime()exec()执行shell,ProcesswaitFor()返回Required key not available(126)问题
版权声明:本文标题:Linux:java通过Runtime.getRuntime().exec()执行shell,Process.waitFor()返回Required key not available(126)问题 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://it.en369.cn/jiaocheng/1747853706a2217916.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论