RunUtil

public class RunUtil
extends Object implements IRunUtil

java.lang.Object의 클래스
   ↳ com.android.tradefed.util.RunUtil.


작업 실행을 위한 도우미 메서드 컬렉션

요약

필드

public static final String INHERITIO_PREFIX

public static final String RUNNABLE_NOTIFIER_NAME

공개 생성자

RunUtil()

사용할 새 RunUtil 객체를 만듭니다.

RunUtil(boolean inheritEnvVars)

공개 메서드

void allowInterrupt(boolean allow)

현재 스레드에서 실행 인터럽트를 허용하거나 허용하지 않습니다.

static IRunUtil getDefault()

기본 RunUtil 객체에 대한 참조를 가져옵니다.

void interrupt(Thread thread, String message, ErrorIdentifier errorId)

지정된 스레드에서 진행 중이거나 진행 중인 실행 작업을 중단합니다.

void interrupt(Thread thread, String message)

지정된 스레드에서 진행 중이거나 진행 중인 실행 작업을 중단합니다.

boolean isInterruptAllowed()

RunUtil의 인터럽트 상태를 제공합니다.

static void linkFile(File destRoot, String relToRoot, File target)

targetdestRoot 아래의 장소에 연결합니다.

Process runCmdInBackground(Redirect redirect, command)

명령어 인수를 허용하는 대체 runCmdInBackground(String) 메서드 (ERROR(/List) 형식으로)

Process runCmdInBackground( command)

명령어 인수를 허용하는 대체 runCmdInBackground(String) 메서드 (ERROR(/List) 형식으로)

Process runCmdInBackground( command, OutputStream output)

ERROR(/OutputStream)를 사용하여 명령어를 실행하면 명령어의 출력이 로깅됩니다.

Process runCmdInBackground(String... command)

비동기식으로 시스템 명령어를 실행하는 도우미 메서드.

Process runCmdInBackground(Redirect redirect, String... command)

비동기식으로 시스템 명령어를 실행하는 도우미 메서드.

boolean runEscalatingTimedRetry(long opTimeout, long initialPollInterval, long maxPollInterval, long maxTime, IRunUtil.IRunnableResult runnable)

작업이 성공할 때까지 여러 번 차단하고 실행합니다.

boolean runFixedTimedRetry(long opTimeout, long pollInterval, long maxTime, IRunUtil.IRunnableResult runnable)

작업이 성공할 때까지 여러 번 차단하고 실행합니다.

boolean runFixedTimedRetryWithOutputMonitor(long opTimeout, long idleOutputTimeout, long pollInterval, long maxTime, IRunUtil.IRunnableResult runnable)

작업이 성공할 때까지 여러 번 차단하고 실행합니다.

CommandStatus runTimed(long timeout, IRunUtil.IRunnableResult runnable, boolean logErrors)

작업을 차단하고 실행합니다. 지정된 시간보다 오래 걸리면 취소됩니다.

CommandResult runTimedCmd(long timeout, OutputStream stdout, OutputStream stderr, String... command)

도우미 메서드가 시스템 명령을 실행하고, 지정된 시간보다 오래 걸리는 경우 중단하고, 지정된 경우 출력을 파일로 리디렉션합니다.

CommandResult runTimedCmd(long timeout, String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다.

CommandResult runTimedCmdRetry(long timeout, long retryInterval, int attempts, String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다.

CommandResult runTimedCmdRetryWithOutputMonitor(long timeout, long idleOutputTimeout, long retryInterval, int attempts, String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다.

CommandResult runTimedCmdSilently(long timeout, String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다.

CommandResult runTimedCmdSilentlyRetry(long timeout, long retryInterval, int attempts, String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다.

CommandResult runTimedCmdWithInput(long timeout, String input, File stdoutFile, File stderrFile, String... command)

도우미 메서드가 시스템 명령을 실행하고, 지정된 시간보다 오래 걸리는 경우 중단하고, 지정된 경우 출력을 파일로 리디렉션합니다.

CommandResult runTimedCmdWithInput(long timeout, String input, String... command)

stdin 입력이 필요한 시스템 명령어를 실행하고 stdin 입력이 필요한 경우 중단하는 도우미 메서드입니다. 지정된 시간보다 오래 걸리는 경우

CommandResult runTimedCmdWithInput(long timeout, String input, command)

stdin 입력이 필요한 시스템 명령어를 실행하고 stdin 입력이 필요한 경우 중단하는 도우미 메서드입니다. 지정된 시간보다 오래 걸리는 경우

CommandResult runTimedCmdWithInputRedirect(long timeout, File inputRedirect, String... command)

파일에서 Stdin을 리디렉션해야 하는 시스템 명령을 실행하는 도우미 메서드 지정된 시간보다 오래 걸리는 경우 취소됩니다.

CommandResult runTimedCmdWithOutputMonitor(long timeout, long idleOutputTimeout, OutputStream stdout, OutputStream stderr, String... command)

도우미 메서드가 시스템 명령을 실행하고, 지정된 시간보다 오래 걸리는 경우 중단하고, 지정된 경우 출력을 파일로 리디렉션합니다.

CommandResult runTimedCmdWithOutputMonitor(long timeout, long idleOutputTimeout, String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다.

CommandResult runTimedCmdWithOutputMonitor(long timeout, long idleOutputTimeout, OutputStream stdout, OutputStream stderr, ICacheClient cacheClient, String... command)

캐싱으로 시스템 명령어를 실행하는 도우미 메서드입니다.

boolean runTimedRetry(long opTimeout, long pollInterval, int attempts, IRunUtil.IRunnableResult runnable)

작업이 성공할 때까지 여러 번 차단하고 실행합니다.

boolean runTimedRetryWithOutputMonitor(long opTimeout, long idleOutputTimeout, long pollInterval, int attempts, IRunUtil.IRunnableResult runnable)

작업이 성공할 때까지 여러 번 차단하고 실행합니다.

CommandStatus runTimedWithOutputMonitor(long timeout, long idleOutputTimeout, IRunUtil.IRunnableResult runnable, boolean logErrors)

작업을 차단하고 실행합니다. 지정된 시간보다 오래 걸리면 취소됩니다.

void setEnvVariable(String name, String value)

시스템 명령어를 실행할 때 사용할 환경 변수를 설정합니다.

void setEnvVariablePriority(IRunUtil.EnvPriority priority)

프로세스 생성 시 환경 변수 설정 해제가 더 높음 우선순위를 설정하는 것보다 더 중요합니다.

void setInterruptibleInFuture(Thread thread, long timeMs)

대기 시간 후 중단 가능으로 설정합니다.

void setLinuxInterruptProcess(boolean interrupt)

Linux 'kill'을 사용하도록 허용 #runTimed 메서드를 통해 실행 중인 프로세스의 중단 제한 시간에 도달합니다.

void setRedirectStderrToStdout(boolean redirect)

시스템 실행 시 표준 출력 스트림으로 리디렉션되도록 표준 오류 스트림을 설정합니다. 명령어와 함께 사용하면 됩니다

void setWorkingDir(File dir)

시스템 명령어의 작업 디렉터리를 설정합니다.

void sleep(long time)

예외를 무시하고 주어진 시간 동안 절전 모드를 유지하는 도우미 메서드입니다.

static String toRelative(File start, String target)
void unsetEnvVariable(String key)

환경 변수를 설정 해제하여 시스템 명령어가 이 환경 변수 없이 실행되도록 합니다. 환경 변수는 상위 프로세스에서 상속될 수 있으므로 삭제해야 함 ProcessBuilder.environment()의 환경 변수

필드

INHERITIO_PREFIX

public static final String INHERITIO_PREFIX

RUNNABLE_NOTIFIER_NAME

public static final String RUNNABLE_NOTIFIER_NAME

공개 생성자

RunUtil

public RunUtil ()

사용할 새 RunUtil 객체를 만듭니다.

RunUtil

public RunUtil (boolean inheritEnvVars)

매개변수
inheritEnvVars boolean

공개 메서드

allowInterrupt

public void allowInterrupt (boolean allow)

현재 스레드에서 실행 인터럽트를 허용하거나 허용하지 않습니다. 허용하는 경우 현재 스레드는 interrupt(Thread, String) 메서드를 통해 다른 스레드에서 중단될 수 있습니다.

매개변수
allow boolean: 현재 스레드에서 실행 인터럽트를 허용할지 여부입니다.

getDefault

public static IRunUtil getDefault ()

기본 RunUtil 객체에 대한 참조를 가져옵니다.

이는 맞춤설정 없이 IRunUtil을 사용하려는 호출자에 유용합니다. 맞춤 IRunUtil 인스턴스가 필요한 호출자는 즉, setEnvVariable(String, String) 또는 setWorkingDir(File)님이 자체 사본을 만듭니다.

반환 값
IRunUtil

인터럽트

public void interrupt (Thread thread, 
                String message, 
                ErrorIdentifier errorId)

지정된 스레드에서 진행 중이거나 진행 중인 실행 작업을 중단합니다. 실행 작업은 주어진 스레드에서 RunInterruptedException이 발생합니다.

매개변수
message String: RunInterruptedException의 메시지입니다.

errorId ErrorIdentifier: 알려진 경우 중단의 원인을 나타냅니다.

인터럽트

public void interrupt (Thread thread, 
                String message)

지정된 스레드에서 진행 중이거나 진행 중인 실행 작업을 중단합니다. 실행 작업은 주어진 스레드에서 RunInterruptedException이 발생합니다.

매개변수
message String: RunInterruptedException의 메시지입니다.

isInterruptAllowed

public boolean isInterruptAllowed ()

RunUtil의 인터럽트 상태를 제공합니다.

반환 값
boolean 실행을 중단할 수 있으면 true, 그렇지 않으면 false입니다.

링크 파일

public static void linkFile (File destRoot, 
                String relToRoot, 
                File target)

targetdestRoot 아래의 장소에 연결합니다.

대상 파일 또는 심볼릭 링크가 이미 destRoot 아래에 있는 경우 파일은 연결되지 않습니다.

매개변수
destRoot File: 대상의 루트입니다.

relToRoot String: 대상 dir에서 루트까지의 상대 경로입니다.

target File: 연결할 대상 파일입니다.

생성 값
대상 파일이 연결되지 않은 경우입니다.

runCmdInBackground

public Process runCmdInBackground (Redirect redirect, 
                 command)

명령어 인수를 허용하는 대체 runCmdInBackground(String) 메서드 (ERROR(/List) 형식으로)

매개변수
redirect Redirect: ProcessBuilder에 적용할 ERROR(/Redirect)입니다.

command : 지정된 시스템 명령어와 선택적 인수가 포함된 ERROR(/List)입니다. 실행

반환 값
Process 실행된 명령어의 Process

runCmdInBackground

public Process runCmdInBackground ( command)

명령어 인수를 허용하는 대체 runCmdInBackground(String) 메서드 (ERROR(/List) 형식으로)

매개변수
command : 지정된 시스템 명령어와 선택적 인수가 포함된 ERROR(/List)입니다. 실행

반환 값
Process 실행된 명령어의 Process

runCmdInBackground

public Process runCmdInBackground ( command, 
                OutputStream output)

ERROR(/OutputStream)를 사용하여 명령어를 실행하면 명령어의 출력이 로깅됩니다. Stdout과 stderr이 함께 병합됩니다.

매개변수
command : 실행할 명령어입니다.

output OutputStream: 출력을 저장할 OutputStream입니다.

반환 값
Process 명령어를 실행하는 Process

runCmdInBackground

public Process runCmdInBackground (String... command)

비동기식으로 시스템 명령어를 실행하는 도우미 메서드.

명령어를 실행한 직후에 반환됩니다.

매개변수
command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
Process 실행된 명령어의 Process

runCmdInBackground

public Process runCmdInBackground (Redirect redirect, 
                String... command)

비동기식으로 시스템 명령어를 실행하는 도우미 메서드.

명령어를 실행한 직후에 반환됩니다.

매개변수
redirect Redirect: ProcessBuilder에 적용할 ERROR(/Redirect)입니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
Process 실행된 명령어의 Process

runEscalatingTimedRetry

public boolean runEscalatingTimedRetry (long opTimeout, 
                long initialPollInterval, 
                long maxPollInterval, 
                long maxTime, 
                IRunUtil.IRunnableResult runnable)

작업이 성공할 때까지 여러 번 차단하고 실행합니다.

작업 시도 간 대기 시간을 기하급수적으로 늘립니다. 이는 Cloud IAM과 서버 폴링과 같은 작업을 수행할 때, 만일의 경우 복구 시간을 주기 위해 이(가) 일시적으로 다운되었습니다.

매개변수
opTimeout long: 단일 작업 시도를 기다리는 최대 시간(밀리초)입니다.

initialPollInterval long: 작업 시도 사이에 대기할 초기 시간입니다.

maxPollInterval long: 작업 시도 사이에 대기하는 최대 시간입니다.

maxTime long: 작업을 계속 시도할 수 있는 대략적인 총 최대 시간

runnable IRunUtil.IRunnableResult: 실행할 IRunUtil.IRunnableResult

반환 값
boolean maxTime이 만료되기 전에 작업이 완료된 경우 true

runFixedTimedRetry

public boolean runFixedTimedRetry (long opTimeout, 
                long pollInterval, 
                long maxTime, 
                IRunUtil.IRunnableResult runnable)

작업이 성공할 때까지 여러 번 차단하고 실행합니다.

매개변수
opTimeout long: 단일 작업 시도를 기다리는 최대 시간(밀리초)입니다.

pollInterval long: 작업 시도 사이에 대기할 초기 시간입니다.

maxTime long: 작업을 계속 시도할 수 있는 대략적인 총 최대 시간

runnable IRunUtil.IRunnableResult: 실행할 IRunUtil.IRunnableResult

반환 값
boolean maxTime이 만료되기 전에 작업이 완료된 경우 true

runFixedTimedRetryWithOutputMonitor

public boolean runFixedTimedRetryWithOutputMonitor (long opTimeout, 
                long idleOutputTimeout, 
                long pollInterval, 
                long maxTime, 
                IRunUtil.IRunnableResult runnable)

작업이 성공할 때까지 여러 번 차단하고 실행합니다. 또한 활동의 출력 스트림으로, 지정된 시간 동안 스트림 활동이 관찰되지 않으면 취소됩니다. idOutputTimeout을 0으로 설정하면 스트림 모니터링이 발생하지 않습니다.

매개변수
opTimeout long: 단일 작업 시도를 기다리는 최대 시간(밀리초)입니다.

idleOutputTimeout long: 출력 스트림의 출력을 기다리는 최대 시간(밀리초)입니다.

pollInterval long: 작업 시도 사이에 대기할 초기 시간입니다.

maxTime long: 작업을 계속 시도할 수 있는 대략적인 총 최대 시간

runnable IRunUtil.IRunnableResult: 실행할 IRunUtil.IRunnableResult

반환 값
boolean maxTime이 만료되기 전에 작업이 완료된 경우 true

runTimed

public CommandStatus runTimed (long timeout, 
                IRunUtil.IRunnableResult runnable, 
                boolean logErrors)

작업을 차단하고 실행합니다. 지정된 시간보다 오래 걸리면 취소됩니다.

매개변수
timeout long: 최대 대기 시간(밀리초)

runnable IRunUtil.IRunnableResult: 실행할 IRunUtil.IRunnableResult

logErrors boolean: 예외 시 오류를 로깅합니다.

반환 값
CommandStatus 작업의 CommandStatus 결과입니다.

runTimedCmd

public CommandResult runTimedCmd (long timeout, 
                OutputStream stdout, 
                OutputStream stderr, 
                String... command)

도우미 메서드가 시스템 명령을 실행하고, 지정된 시간보다 오래 걸리는 경우 중단하고, 지정된 경우 출력을 파일로 리디렉션합니다. 이러한 방식으로 ERROR(/OutputStream)가 제공되면 함수의 끝에서 열린 상태로 유지됩니다.

매개변수
timeout long: 대기하는 최대 시간 제한 시간(밀리초)입니다. 0은 제한시간이 없음을 의미합니다.

stdout OutputStream: ERROR(/OutputStream)이며 여기서 표준 출력이 리디렉션됩니다. null일 수 있습니다.

stderr OutputStream: ERROR(/OutputStream). 여기서 오류 출력이 리디렉션됩니다. null일 수 있습니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmd

public CommandResult runTimedCmd (long timeout, 
                String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다.

매개변수
timeout long: 최대 대기 시간(밀리초)입니다. 0은 제한시간이 없음을 의미합니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdRetry

public CommandResult runTimedCmdRetry (long timeout, 
                long retryInterval, 
                int attempts, 
                String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다.

매개변수
timeout long: 각 시도의 최대 대기 시간(밀리초)입니다.

retryInterval long: 명령어 재시도 사이의 대기 시간입니다.

attempts int: 시도할 최대 시도 횟수입니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdRetryWithOutputMonitor

public CommandResult runTimedCmdRetryWithOutputMonitor (long timeout, 
                long idleOutputTimeout, 
                long retryInterval, 
                int attempts, 
                String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다. 출력 스트림에서 활동을 모니터링합니다. 스트림 활동이 없으면 취소됩니다. 자동으로 생성됩니다 idOutputTimeout을 0으로 설정하면 스트림 모니터링이 이루어지지 않습니다. 발생할 수 있습니다

매개변수
timeout long: 각 시도의 최대 대기 시간(밀리초)입니다.

idleOutputTimeout long: 출력 스트림의 출력을 기다리는 최대 시간(밀리초)입니다.

retryInterval long: 명령어 재시도 사이의 대기 시간입니다.

attempts int: 시도할 최대 시도 횟수입니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdSilently

public CommandResult runTimedCmdSilently (long timeout, 
                String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다. runTimedCmd(long, String)와 비슷하지만 오류를 기록하지 않습니다. 예외가 인정됩니다.

매개변수
timeout long: 최대 대기 시간(밀리초)

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdSilentlyRetry

public CommandResult runTimedCmdSilentlyRetry (long timeout, 
                long retryInterval, 
                int attempts, 
                String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다. runTimedCmdRetry(long, long, int, String[])와 마찬가지로 예외에 대한 오류는 기록하지 않습니다.

매개변수
timeout long: 최대 대기 시간(밀리초)

retryInterval long: 명령어 재시도 사이의 대기 시간입니다.

attempts int: 시도할 최대 시도 횟수입니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdWithInput

public CommandResult runTimedCmdWithInput (long timeout, 
                String input, 
                File stdoutFile, 
                File stderrFile, 
                String... command)

도우미 메서드가 시스템 명령을 실행하고, 지정된 시간보다 오래 걸리는 경우 중단하고, 지정된 경우 출력을 파일로 리디렉션합니다.

매개변수
timeout long: 대기하는 최대 시간 제한 시간(밀리초)입니다. 0은 제한시간이 없음을 의미합니다.

input String: 프로세스에 전달할 stdin 입력입니다.

stdoutFile File: ERROR(/File)이며 여기서 표준 출력이 리디렉션됩니다. null일 수 있습니다.

stderrFile File: ERROR(/File). 여기서 오류 출력이 리디렉션됩니다. null일 수 있습니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdWithInput

public CommandResult runTimedCmdWithInput (long timeout, 
                String input, 
                String... command)

stdin 입력이 필요한 시스템 명령어를 실행하고 stdin 입력이 필요한 경우 중단하는 도우미 메서드입니다. 지정된 시간보다 오래 걸리는 경우

매개변수
timeout long: 최대 대기 시간(밀리초)

input String: 프로세스에 전달할 stdin 입력입니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdWithInput

public CommandResult runTimedCmdWithInput (long timeout, 
                String input, 
                 command)

stdin 입력이 필요한 시스템 명령어를 실행하고 stdin 입력이 필요한 경우 중단하는 도우미 메서드입니다. 지정된 시간보다 오래 걸리는 경우

매개변수
timeout long: 최대 대기 시간(밀리초)

input String: 프로세스에 전달할 stdin 입력입니다.

command : 시스템 명령어 및 exec의 선택적 인수가 포함된 ERROR(/List)입니다.

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdWithInputRedirect

public CommandResult runTimedCmdWithInputRedirect (long timeout, 
                File inputRedirect, 
                String... command)

파일에서 Stdin을 리디렉션해야 하는 시스템 명령을 실행하는 도우미 메서드 지정된 시간보다 오래 걸리는 경우 취소됩니다.

매개변수
timeout long: 최대 대기 시간(밀리초)

inputRedirect File: ProcessBuilder.redirectInput()를 사용하여 표준 입력으로 리디렉션할 ERROR(/File)입니다. null이면 stdin이 리디렉션되지 않습니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdWithOutputMonitor

public CommandResult runTimedCmdWithOutputMonitor (long timeout, 
                long idleOutputTimeout, 
                OutputStream stdout, 
                OutputStream stderr, 
                String... command)

도우미 메서드가 시스템 명령을 실행하고, 지정된 시간보다 오래 걸리는 경우 중단하고, 지정된 경우 출력을 파일로 리디렉션합니다. 이러한 방식으로 ERROR(/OutputStream)가 제공되면 함수의 끝에서 열린 상태로 유지됩니다.

매개변수
timeout long: 대기하는 최대 시간 제한 시간(밀리초)입니다. 0은 제한시간이 없음을 의미합니다.

idleOutputTimeout long: 출력 스트림의 출력을 기다리는 최대 시간(밀리초)입니다.

stdout OutputStream: ERROR(/OutputStream)이며 여기서 표준 출력이 리디렉션됩니다. null일 수 있습니다.

stderr OutputStream: ERROR(/OutputStream). 여기서 오류 출력이 리디렉션됩니다. null일 수 있습니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdWithOutputMonitor

public CommandResult runTimedCmdWithOutputMonitor (long timeout, 
                long idleOutputTimeout, 
                String... command)

시스템 명령을 실행하고 지정된 시간보다 오래 걸리는 경우 중단하는 도우미 메서드 있습니다. 출력 스트림에서 활동을 모니터링합니다. 스트림 활동이 없으면 취소됩니다. 자동으로 생성됩니다 idOutputTimeout을 0으로 설정하면 스트림 모니터링이 이루어지지 않습니다. 발생할 수 있습니다

매개변수
timeout long: 최대 대기 시간(밀리초)입니다. 0은 제한시간이 없음을 의미합니다.

idleOutputTimeout long: 출력 스트림의 출력을 기다리는 최대 시간(밀리초)입니다.

command String: 지정된 시스템 명령어 및 exec(선택사항)의 인수

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult

runTimedCmdWithOutputMonitor

public CommandResult runTimedCmdWithOutputMonitor (long timeout, 
                long idleOutputTimeout, 
                OutputStream stdout, 
                OutputStream stderr, 
                ICacheClient cacheClient, 
                String... command)

캐싱으로 시스템 명령어를 실행하는 도우미 메서드입니다.

cacheClient가 지정되면 캐싱이 사용 설정됩니다. 캐시가 캐시된 결과가 반환됩니다. 그렇지 않으면 runTimedCmdWithOutputMonitor(long, long, OutputStream, OutputStream, String) 명령어를 실행하는 데 사용되며 결과는 캐싱을 위해 업로드됩니다.

매개변수
timeout long: 대기하는 최대 시간 제한 시간(밀리초)입니다. 0은 제한시간이 없음을 의미합니다.

idleOutputTimeout long: 출력 스트림의 출력을 기다리는 최대 시간(밀리초)입니다.

stdout OutputStream: ERROR(/OutputStream)이며 여기서 표준 출력이 리디렉션됩니다. null일 수 있습니다.

stderr OutputStream: ERROR(/OutputStream). 여기서 오류 출력이 리디렉션됩니다. null일 수 있습니다.

cacheClient ICacheClient: 캐싱을 처리하는 데 사용되는 ICacheClient의 인스턴스입니다.

command String: 지정된 시스템 명령어이며 exec의 선택적 인수입니다.

반환 값
CommandResult 명령어 실행의 결과가 포함된 CommandResult입니다.

runTimedRetry

public boolean runTimedRetry (long opTimeout, 
                long pollInterval, 
                int attempts, 
                IRunUtil.IRunnableResult runnable)

작업이 성공할 때까지 여러 번 차단하고 실행합니다.

매개변수
opTimeout long: 작업 시도 1회를 기다리는 최대 시간(밀리초)입니다.

pollInterval long: 명령어 재시도 사이의 대기 시간입니다.

attempts int: 시도할 최대 시도 횟수입니다.

runnable IRunUtil.IRunnableResult: 실행할 IRunUtil.IRunnableResult

반환 값
boolean 시도에 도달하기 전에 작업이 성공적으로 완료된 경우 true입니다.

runTimedRetryWithOutputMonitor

public boolean runTimedRetryWithOutputMonitor (long opTimeout, 
                long idleOutputTimeout, 
                long pollInterval, 
                int attempts, 
                IRunUtil.IRunnableResult runnable)

작업이 성공할 때까지 여러 번 차단하고 실행합니다. 또한 활동의 출력 스트림으로, 지정된 시간 동안 스트림 활동이 관찰되지 않으면 취소됩니다. idOutputTimeout을 0으로 설정하면 스트림 모니터링이 발생하지 않습니다.

매개변수
opTimeout long: 작업 시도 1회를 기다리는 최대 시간(밀리초)입니다.

idleOutputTimeout long: 출력 스트림의 출력을 기다리는 최대 시간(밀리초)입니다.

pollInterval long: 명령어 재시도 사이의 대기 시간입니다.

attempts int: 시도할 최대 시도 횟수입니다.

runnable IRunUtil.IRunnableResult: 실행할 IRunUtil.IRunnableResult

반환 값
boolean 시도에 도달하기 전에 작업이 성공적으로 완료된 경우 true입니다.

runTimedWithOutputMonitor

public CommandStatus runTimedWithOutputMonitor (long timeout, 
                long idleOutputTimeout, 
                IRunUtil.IRunnableResult runnable, 
                boolean logErrors)

작업을 차단하고 실행합니다. 지정된 시간보다 오래 걸리면 취소됩니다. 또한 출력 스트림에서 활동을 모니터링하고, 특정 이벤트에 대해 스트림 활동이 관찰되지 않으면 중단하고, 지정할 수 있습니다. idOutputTimeout을 0으로 설정하면 스트림 모니터링이 발생하지 않습니다.

매개변수
timeout long: 최대 대기 시간(밀리초)

idleOutputTimeout long: 출력 스트림의 출력을 기다리는 최대 시간(밀리초)입니다.

runnable IRunUtil.IRunnableResult: 실행할 IRunUtil.IRunnableResult

logErrors boolean: 예외 시 오류를 로깅합니다.

반환 값
CommandStatus 작업의 CommandStatus 결과입니다.

setEnvVariable

public void setEnvVariable (String name, 
                String value)

시스템 명령어를 실행할 때 사용할 환경 변수를 설정합니다.

매개변수
name String: 변수 이름

value String: 변수 값입니다.

setEnvVariablePriority

public void setEnvVariablePriority (IRunUtil.EnvPriority priority)

프로세스 생성 시 환경 변수 설정 해제가 더 높음 우선순위를 설정하는 것보다 더 중요합니다. 기본적으로 설정 해제는 우선순위가 더 높습니다. 즉, 똑같은 이름이 만들어지면 변수가 설정되지 않으므로 이는 발생하지 않습니다. 기본 IRunUtil 인스턴스에서는 사용할 수 없습니다.

매개변수
priority IRunUtil.EnvPriority

미래에 인터럽트 가능

public void setInterruptibleInFuture (Thread thread, 
                long timeMs)

대기 시간 후 중단 가능으로 설정합니다. ERROR(/CommandScheduler#shutdownHard())로 설정하여 종료해야 합니다.

매개변수
thread Thread: 중단할 스레드입니다.

timeMs long: 인터럽트 가능을 설정하기 전에 기다리는 시간입니다.

setLinuxInterruptProcess

public void setLinuxInterruptProcess (boolean interrupt)

Linux 'kill'을 사용하도록 허용 #runTimed 메서드를 통해 실행 중인 프로세스의 중단 제한 시간에 도달합니다. 기본 IRunUtil 인스턴스에서는 사용할 수 없습니다.

매개변수
interrupt boolean

setRedirectStderrToStdout

public void setRedirectStderrToStdout (boolean redirect)

시스템 실행 시 표준 출력 스트림으로 리디렉션되도록 표준 오류 스트림을 설정합니다. 명령어와 함께 사용하면 됩니다 초기 값은 false입니다.

매개변수
redirect boolean: 리디렉션 여부를 나타내는 새 값

setWorkingDir

public void setWorkingDir (File dir)

시스템 명령어의 작업 디렉터리를 설정합니다.

매개변수
dir File: 작업 디렉터리

sleep

public void sleep (long time)

예외를 무시하고 주어진 시간 동안 절전 모드를 유지하는 도우미 메서드입니다.

매개변수
time long: 절전 모드까지 소요 시간(밀리초)입니다. 0 이하의 값은 무시됩니다.

상대적

public static String toRelative (File start, 
                String target)

매개변수
start File

target String

반환 값
String

UnvVariable을 설정하지 않음

public void unsetEnvVariable (String key)

환경 변수를 설정 해제하여 시스템 명령어가 이 환경 변수 없이 실행되도록 합니다. 환경 변수는 상위 프로세스에서 상속될 수 있으므로 삭제해야 함 ProcessBuilder.environment()의 환경 변수

매개변수
key String: 변수 이름