Почему в этом коде выполнение ProcessBuilder влияет на основной поток?
В этой программе через 10 минут в главном потоке разница между временем запуска и текущим временем увеличивается от более 1 секунды до 8 секунд. почему это происходит, процесс строителя влияет на выполнение основного потока.
Java-версия "1.6.0_26"
Java (TM) SE Runtime Environment (сборка 1.6.0_26-b03)
Серверная виртуальная машина Java HotSpot(TM) (сборка 20.1-b02, смешанный режим)
OS: Solaris
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ExecTest {
public ExecThread getExecThread(String cmd, int callNumberStart) {
return new ExecThread(cmd, callNumberStart);
}
public class ExecThread implements Runnable {
private String cmd;
private int callNumberStart;
public ExecThread(String cmd, int callNumberStart) {
this.cmd = cmd;
this.callNumberStart = callNumberStart;
}
public String executeCommand(String origLegCallId, String cmd) {
Process process = null;
String cmdOutput = null;
try {
List<String> command = new ArrayList<String>();
String[] splittedCmd = cmd.split("\\s+");
for(String tmp : splittedCmd){
command.add(tmp);
}
ProcessBuilder builder = new ProcessBuilder(command);
process = builder.start();
process.waitFor();
InputStreamReader isr = new InputStreamReader(process.getInputStream());
BufferedReader br = new BufferedReader(isr);
String line = null;
cmdOutput = new String();
while ((line = br.readLine()) != null) {
cmdOutput = cmdOutput + line;
}
} catch (Exception ex) {
ex.printStackTrace();
cmdOutput = null;
}
return cmdOutput;
}
@Override
public void run() {
while (true) {
System.out.println(callNumberStart + ":: " + Thread.currentThread().getName() + ":: Start " +
new Date());
String output=executeCommand("" + callNumberStart, cmd);
System.out.println(Thread.currentThread().getName()+"Output is:"+output);
System.out.println(callNumberStart + ":: " + Thread.currentThread().getName() + ":: End " + n
ew Date());
callNumberStart++;
}
}
}
public static void main (String args []) {
int numberOfThread =100;
String cmd = /home/run.sh; //{sleep 5;echo 'hello'}
ExecutorService es = Executors.newFixedThreadPool(numberOfThread);
ExecTest test=new ExecTest();
for (int i = 1; i <= numberOfThread; i++) {
es.submit(test.getExecThread(cmd, i*10000));
}
while (true) {
long startTime = System.currentTimeMillis();
for (int j=0; j<5; j++) {
try {
Thread.sleep(200);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
System.out.println("Processing Time:: " + (System.currentTimeMillis()-startTime));
}
}
}
1 ответ
Из-за этого process.waitFor();
,
Просмотрите Javadoc здесь.
РЕДАКТИРОВАТЬ 1:
После второго взгляда на код кажется, что вы не закрываете свои потоки, поэтому довольно быстро расходуете много ресурсов (множество потоков выполняет IO).