330
搜狐
多線程處理寫法
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
上一篇:
2017 VQA Challenge 第一名技術報告
下一篇:
目標檢測101:一文帶你讀懂深度學習框架下的目標檢測
Activiti-master java線web流程設計器整合視頻教程
對話希拉裏創新事務顧問亞力克·羅斯:中美科技公司正激烈競爭
NYOJ325-zb的生日
碼棧開發手冊(四)---編碼方式開發(其他功能函數)
Core ML && Caffe 入門實踐
API Demos 2.3 學習筆記 (8)-- Views->ImageButton
工廠模式的Assembly.Load(path).CreateInstance(className)出錯解決方法
arm-linux-gcc下載與安裝
6.4 Android?????????????????????-??????-????????????-?????????
cocos2d-x 創建工程詳解