閱讀330 返回首頁    go 搜狐


多線程處理寫法

1.rxjava,observeOn(Schedulers.io())封裝多線程,

Flowable.fromArray(ips)
.observeOn(Schedulers.io())
.flatMap(
ip -> Flowable.fromCallable(
() -> {
Boolean check = check(ip);
checkResult.put(ip,check);
return check;
}
)
).blockingSubscribe();
return checkResult;




2.線程池, 在線程池中執行saltStackUtil.restartJavaSync方法的同步,其返回值放入執行consummer

private static final ExecutorService executorService = Executors.newFixedThreadPool(10, new ThreadFactory() {
@Override
public Thread newThread(Runnable r) {
Thread thread = new Thread(r);
thread.setName("javaOperator");
return thread;
}

});




public void restartJava(String ip, String projectName, String commitId, String jarName, String jvmArgs, Consumer<AppServerOperateResult> appServerOperateResultConsumer) throws SaltException {
executorService.execute(() ->{
AppServerOperateResult appServerOperateResult = new AppServerOperateResult();
appServerOperateResult.setIp(ip);
appServerOperateResult.setProjectName(projectName);
appServerOperateResult.setCommitId(commitId);
appServerOperateResult.setJarName(jarName);
appServerOperateResult.setStartTime(new Date());
appServerOperateResult.setStatus(Constant.JAVA_APP_OPERATE_PROCESS);
appServerOperateResult.setType(Constant.JAVA_APP_OPERATE_RESTART);
appServerOperateResult.setRunParamater(jvmArgs);
Map<String, Result<Map<String, State.ApplyResult>>> stringResultMap = null;
try {
stringResultMap = saltStackUtil.restartJavaSync(ip, projectName, commitId, jarName, jvmArgs);
processResult(stringResultMap,appServerOperateResult);
appServerOperateResultConsumer.accept(appServerOperateResult);
} catch (Exception e) {
MyExceptionHandler.handlerException(e,logger);
}

});

}


3.stream,parallel()並行流執行foreach,consummer封裝返回數據到checkResult Map中


Stream.of(ips).filter(ip -> ip!=null).parallel().forEach(new Consumer<String>() {
@Override
public void accept(String ip) {
checkResult.put(ip, check(ip, appId, appTypeCode));
}
});

return checkResult;







最後更新:2017-09-27 15:04:37

  上一篇:go  2017 VQA Challenge 第一名技術報告
  下一篇:go  目標檢測101:一文帶你讀懂深度學習框架下的目標檢測