use of org.apache.commons.exec.DefaultExecutor in project Saturn by vipshop.
the class ScriptPidUtils method exeCmdWithoutPipe.
public static String exeCmdWithoutPipe(CommandLine cmdLine, ByteArrayInputStream input, Map<String, String> env) {
DefaultExecutor executor = new DefaultExecutor();
ExecuteWatchdog dog = new ExecuteWatchdog(3 * 1000);
executor.setWatchdog(dog);
executor.setExitValue(0);
try {
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
SaturnLogOutputStream errorOS = new SaturnLogOutputStream(log, SaturnLogOutputStream.LEVEL_ERROR);
PumpStreamHandler streamHandler = new PumpStreamHandler(outputStream, errorOS, input);
executor.setStreamHandler(streamHandler);
log.info("msg=exec command: {}", cmdLine);
int value = executor.execute(cmdLine, env);
if (value == 0) {
String out = outputStream.toString();
return out;
} else {
return null;
}
} catch (Exception e) {
log.error("msg=" + e.getMessage(), e);
return null;
}
}
use of org.apache.commons.exec.DefaultExecutor in project Robot by fo0.
the class Commander method execute.
public String execute(boolean shell, String homedir, String cmds) {
if (cmds == null || cmds.isEmpty()) {
Logger.info("stopped cmd command is empty");
return null;
}
CommandLine cli = null;
DefaultExecutor executor = null;
switch(OSCheck.getOperatingSystemType()) {
case Windows:
cli = new CommandLine("cmd");
if (shell) {
cli.addArgument("/c ");
}
break;
case Linux:
cli = new CommandLine("/bin/bash");
if (shell) {
cli.addArgument("-c");
}
break;
}
cli.addArgument(cmds, false);
Logger.debug("HomeDir: " + homedir + " => " + StringUtils.join(cli.getArguments(), ","));
try {
executor = new DefaultExecutor();
executor.setStreamHandler(new PumpStreamHandler(new OutputStream() {
@Override
public void write(int b) throws IOException {
try {
String str = String.valueOf((char) b);
if (listener != null)
listener.event(str);
buffer.append(str);
} catch (Exception e) {
e.printStackTrace();
}
}
}, new OutputStream() {
@Override
public void write(int b) throws IOException {
error = true;
try {
String str = String.valueOf((char) b);
if (listener != null)
listener.event(str);
buffer.append(str);
} catch (Exception e) {
e.printStackTrace();
}
}
}));
executor.execute(cli);
executor.setWorkingDirectory(new File(homedir));
try {
executor.wait(30 * 1000);
} catch (Exception e) {
// TODO: handle exception
}
} catch (Exception e) {
error = true;
Logger.error("failed commander in Cmd: " + cli + " | " + e);
e.printStackTrace();
}
return buffer.toString();
}
use of org.apache.commons.exec.DefaultExecutor in project camel by apache.
the class ProvokeExceptionExecCommandExecutor method prepareDefaultExecutor.
@Override
protected DefaultExecutor prepareDefaultExecutor(ExecCommand execCommand) {
DefaultExecutor executor = new DefaultExecutorMock();
executor.setExitValues(null);
executor.setProcessDestroyer(new ShutdownHookProcessDestroyer());
return executor;
}
use of org.apache.commons.exec.DefaultExecutor in project camel by apache.
the class DefaultExecCommandExecutor method execute.
@Override
public ExecResult execute(ExecCommand command) {
notNull(command, "command");
ByteArrayOutputStream out = new ByteArrayOutputStream();
ByteArrayOutputStream err = new ByteArrayOutputStream();
DefaultExecutor executor = prepareDefaultExecutor(command);
// handle error and output of the process and write them to the given
// out stream
PumpStreamHandler handler = new PumpStreamHandler(out, err, command.getInput());
executor.setStreamHandler(handler);
CommandLine cl = toCommandLine(command);
try {
int exitValue = executor.execute(cl);
// if the size is zero, we have no output, so construct the result
// with null (required by ExecResult)
InputStream stdout = out.size() == 0 ? null : new ByteArrayInputStream(out.toByteArray());
InputStream stderr = err.size() == 0 ? null : new ByteArrayInputStream(err.toByteArray());
ExecResult result = new ExecResult(command, stdout, stderr, exitValue);
return result;
} catch (ExecuteException ee) {
LOG.error("ExecException while executing command: " + command.toString() + " - " + ee.getMessage());
InputStream stdout = out.size() == 0 ? null : new ByteArrayInputStream(out.toByteArray());
InputStream stderr = err.size() == 0 ? null : new ByteArrayInputStream(err.toByteArray());
throw new ExecException("Failed to execute command " + command, stdout, stderr, ee.getExitValue(), ee);
} catch (IOException ioe) {
InputStream stdout = out.size() == 0 ? null : new ByteArrayInputStream(out.toByteArray());
InputStream stderr = err.size() == 0 ? null : new ByteArrayInputStream(err.toByteArray());
// use 0 as exit value as the executor didn't return the value
int exitValue = 0;
if (executor instanceof ExecDefaultExecutor) {
// get the exit value from the executor as it captures this to work around the common-exec bug
exitValue = ((ExecDefaultExecutor) executor).getExitValue();
}
// workaround to ignore if the stream was already closes due some race condition in commons-exec
String msg = ioe.getMessage();
if (msg != null && "stream closed".equals(msg.toLowerCase(Locale.ENGLISH))) {
LOG.debug("Ignoring Stream closed IOException", ioe);
ExecResult result = new ExecResult(command, stdout, stderr, exitValue);
return result;
}
// invalid working dir
LOG.error("IOException while executing command: " + command.toString() + " - " + ioe.getMessage());
throw new ExecException("Unable to execute command " + command, stdout, stderr, exitValue, ioe);
} finally {
// the inputStream must be closed after the execution
IOUtils.closeQuietly(command.getInput());
}
}
use of org.apache.commons.exec.DefaultExecutor in project opennms by OpenNMS.
the class RScriptExecutor method exec.
/**
* Executes by given script by:
* - Searching both the classpath and the filesystem for the path
* - Copying the script at the given path to a temporary file and
* performing variable substitution with the arguments using Freemarker.
* - Invoking the script with commons-exec
* - Converting the input table to CSV and passing this to the process via stdin
* - Parsing stdout, expecting CSV output, and converting this to an immutable table
*/
public RScriptOutput exec(String script, RScriptInput input) throws RScriptException {
Preconditions.checkNotNull(script, "script argument");
Preconditions.checkNotNull(input, "input argument");
// Grab the script/template
Template template;
try {
template = m_freemarkerConfiguration.getTemplate(script);
} catch (IOException e) {
throw new RScriptException("Failed to read the script.", e);
}
// Create a temporary file
File scriptOnDisk;
try {
scriptOnDisk = File.createTempFile("Rcsript", "R");
scriptOnDisk.deleteOnExit();
} catch (IOException e) {
throw new RScriptException("Failed to create a temporary file.", e);
}
// Perform variable substitution and write the results to the temporary file
try (FileOutputStream fos = new FileOutputStream(scriptOnDisk);
Writer out = new OutputStreamWriter(fos)) {
template.process(input.getArguments(), out);
} catch (IOException | TemplateException e) {
scriptOnDisk.delete();
throw new RScriptException("Failed to process the template.", e);
}
// Convert the input matrix to a CSV string which will be passed to the script via stdin.
// The table may be large, so we try and avoid writing it to disk
final StringBuilder inputTableAsCsv;
try {
inputTableAsCsv = toCsv(input.getTable());
} catch (IOException e) {
scriptOnDisk.delete();
throw new RScriptException("Failed to convert the input table to CSV.", e);
}
// Invoke Rscript against the script (located in a temporary file)
CommandLine cmdLine = new CommandLine(RSCRIPT_BINARY);
cmdLine.addArgument(scriptOnDisk.getAbsolutePath());
// Use commons-exec to execute the process
DefaultExecutor executor = new DefaultExecutor();
// Use the CharSequenceInputStream in order to avoid explicitly converting
// the StringBuilder a string and then an array of bytes.
InputStream stdin = new CharSequenceInputStream(inputTableAsCsv, StandardCharsets.UTF_8);
ByteArrayOutputStream stderr = new ByteArrayOutputStream();
ByteArrayOutputStream stdout = new ByteArrayOutputStream();
executor.setStreamHandler(new PumpStreamHandler(stdout, stderr, stdin));
// Fail if we get a non-zero exit code
executor.setExitValue(0);
// Fail if the process takes too long
ExecuteWatchdog watchdog = new ExecuteWatchdog(SCRIPT_TIMEOUT_MS);
executor.setWatchdog(watchdog);
// Execute
try {
executor.execute(cmdLine);
} catch (IOException e) {
scriptOnDisk.delete();
throw new RScriptException("An error occured while executing Rscript, or the requested script.", inputTableAsCsv.toString(), stderr.toString(), stdout.toString(), e);
}
// Parse and return the results
try {
ImmutableTable<Long, String, Double> table = fromCsv(stdout.toString());
return new RScriptOutput(table);
} catch (Throwable t) {
throw new RScriptException("Failed to parse the script's output.", inputTableAsCsv.toString(), stderr.toString(), stdout.toString(), t);
} finally {
scriptOnDisk.delete();
}
}
Aggregations