本文整理汇总了Java中javax.batch.runtime.BatchRuntime类的典型用法代码示例。如果您正苦于以下问题:Java BatchRuntime类的具体用法?Java BatchRuntime怎么用?Java BatchRuntime使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
BatchRuntime类属于javax.batch.runtime包,在下文中一共展示了BatchRuntime类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: afterJob
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@Override
public void afterJob() throws Exception {
List<Long> activeJobs = BatchRuntime.getJobOperator().getRunningExecutions(BatchConstants.MATRIX_JOB);
log.info("Finished matrix job. Remaining: {}", activeJobs);
if (activeJobs.size() == 0) {
// final job execution: save current time stamp of creation to db
try {
logRepository.insert(new Date());
coreBootstrapper.computationFinished();
log.info("Finished all matrix computations. All done!");
} catch (DatabaseException e) {
log.error("FATAL: Error inserting new computation log! {}", e.getMessage());
}
}
}
示例2: startCartesianMatrixJob
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@Override
public void startCartesianMatrixJob(List<EsriPointFeature> sourcePoints, LegType legType) {
if (checkNullOrEmpty(sourcePoints)) {
log.error("Will not start Cartesian Matrix job with invalid sourcePoints for leg type {}", legType);
return;
}
JobOperator jo = BatchRuntime.getJobOperator();
Properties properties = new Properties();
properties.setProperty(BatchConstants.PATH_TYPE, legType.toString());
// assume here that the size of both sets is roughly equivalent!
properties.setProperty(BatchConstants.BATCH_SIZE, String.valueOf(sourcePoints.size()));
properties.setProperty(BatchConstants.PARTITIONING, String.valueOf(false));
properties.setProperty(BatchConstants.CARTESIAN, String.valueOf(true));
Long jobId = jo.start(BatchConstants.MATRIX_JOB, properties);
log.info("Dispatched Cartesian Matrix job with id {}", jobId);
sourcePointStash.put(jobId, sourcePoints);
}
示例3: startIVMatrixJob
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@Override
public void startIVMatrixJob(IVRequestTuple request, LegType legType) {
if (checkNullOrEmpty(request.getTargets())) {
log.error("Will not start IV Matrix job with invalid targets for leg type {}", legType);
return;
}
JobOperator jo = BatchRuntime.getJobOperator();
Properties properties = new Properties();
properties.setProperty(BatchConstants.PATH_TYPE, legType.toString());
// assume here that the size of both sets is roughly equivalent!
properties.setProperty(BatchConstants.BATCH_SIZE, String.valueOf(request.getTargets().size()));
properties.setProperty(BatchConstants.PARTITIONING, String.valueOf(true));
properties.setProperty(BatchConstants.IVROUTE, String.valueOf(true));
Long jobId = jo.start(BatchConstants.MATRIX_JOB, properties);
List<EsriPointFeature> source = new ArrayList<>();
source.add(request.getSource());
log.info("Dispatched IV Matrix job with id {}", jobId);
sourcePointStash.put(jobId, source);
carTargetStash.put(jobId, new ArrayList<>(request.getTargets()));
}
示例4: startMatrixJob
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@Override
public void startMatrixJob(List<IVRequestTuple> points, LegType legType) {
if (checkNullOrEmpty(points)) {
log.error("Will not start Matrix job with invalid points for leg type {}", legType);
return;
}
JobOperator jo = BatchRuntime.getJobOperator();
Properties properties = new Properties();
properties.setProperty(BatchConstants.PATH_TYPE, legType.toString());
properties.setProperty(BatchConstants.BATCH_SIZE, String.valueOf(points.size()));
properties.setProperty(BatchConstants.PARTITIONING, String.valueOf(true));
Long jobId = jo.start(BatchConstants.MATRIX_JOB, properties);
log.info("Dispatched Matrix job with id {}", jobId);
matrixStash.put(jobId, points);
}
示例5: startNeighborsJob
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@Override
public void startNeighborsJob(List<RasterPoint> rasterPoints) {
if (checkNullOrEmpty(rasterPoints)) {
log.error("Will not start Neighbors job with invalid rasterPoints.");
return;
}
JobOperator jo = BatchRuntime.getJobOperator();
Properties properties = new Properties();
properties.setProperty(BatchConstants.BATCH_SIZE, String.valueOf(rasterPoints.size()));
properties.setProperty(BatchConstants.MAX_WALK, String.valueOf(maxWalk));
Long jobId = jo.start(BatchConstants.NEIGHBORS_JOB, properties);
log.info("Dispatched Neighbors job with id {}", jobId);
rasterStash.put(jobId, rasterPoints);
}
示例6: waitForCompletion
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
private void waitForCompletion(final long executionId, final int timeout, final TimeUnit unit) {
final JobExecution jobExecution = BatchRuntime.getJobOperator().getJobExecution(executionId);
long time = unit.toMillis(timeout);
long sleep = 100;
boolean complete = false;
while (!complete && time > 0) {
switch (jobExecution.getBatchStatus()) {
case STARTED:
case STARTING:
case STOPPING:
try {
TimeUnit.MILLISECONDS.sleep(sleep);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
time -= sleep;
sleep = Math.max(sleep / 2, 100L);
break;
default:
complete = true;
break;
}
}
Assert.assertTrue("Batch job did not complete withing allotted time.", complete);
}
示例7: doWorkWithJobOperator
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
public <T> T doWorkWithJobOperator(JobOperatorWork<T> w, String applicationName) throws NamingException {
if (operationMode == OperationMode.DIRECT) {
return w.doWorkWithJobOperator(BatchRuntime.getJobOperator());
}
final String lookupName = getLookupName(applicationName);
log.log(Level.FINE, "lookupName={0}, applicationName={1}", new Object[]{lookupName, applicationName});
InitialContext ic = null;
try {
ic = new InitialContext();
JobOperator jobOperator = (JobOperator) ic.lookup(lookupName);
return w.doWorkWithJobOperator(jobOperator);
} finally {
if (ic != null) {
ic.close();
}
}
}
示例8: open
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@Override
public void open(Serializable checkpoint) throws Exception {
String resourceName = BatchRuntime
.getJobOperator()
.getParameters(this.jobCtx.getExecutionId())
.getProperty("resourceName");
if (null == resourceName) {
resourceName = this.resourceNameDefault;
}
if (null == resourceName) {
throw new NullPointerException("'resourceName' is not set!");
}
LOGGER.info("Opening " + resourceName);
this.reader = new BufferedReader(
new InputStreamReader(
currentThread()
.getContextClassLoader()
.getResourceAsStream("META-INF/" + resourceName)));
}
示例9: testEndNormallyExecuteBoth
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@Test
public void testEndNormallyExecuteBoth() throws Exception {
JobOperator jo = BatchRuntime.getJobOperator();
Properties props = new Properties();
props.put("forceFailure", "true");
long exec1Id = jo.start("nextOnStep1Failure", props);
Thread.sleep(normalSleepTime);
JobExecution je = jo.getJobExecution(exec1Id);
Map<String, StepExecution> steps = new HashMap<String,StepExecution>();
for (StepExecution se : jo.getStepExecutions(exec1Id)) { steps.put(se.getStepName(), se); }
assertEquals("Job batch status", BatchStatus.COMPLETED, je.getBatchStatus());
assertEquals("exit status", "COMPLETED", je.getExitStatus());
assertEquals("Steps executed", 2, steps.size());
assertEquals("Step failed", BatchStatus.FAILED, steps.get("step1").getBatchStatus());
assertEquals("Step failed", BatchStatus.COMPLETED, steps.get("step2").getBatchStatus());
}
示例10: testBatchDecision
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@Test
public void testBatchDecision() throws Exception {
JobOperator jobOperator = BatchRuntime.getJobOperator();
Long executionId = jobOperator.start("myJob", new Properties());
JobExecution jobExecution = jobOperator.getJobExecution(executionId);
BatchTestHelper.keepTestAlive(jobExecution);
List<StepExecution> stepExecutions = jobOperator.getStepExecutions(executionId);
List<String> executedSteps = new ArrayList<>();
for (StepExecution stepExecution : stepExecutions) {
executedSteps.add(stepExecution.getStepName());
}
assertEquals(2, stepExecutions.size());
assertArrayEquals(new String[] {"step1", "step3"}, executedSteps.toArray());
assertFalse(executedSteps.contains("step2"));
assertEquals(BatchStatus.COMPLETED, jobExecution.getBatchStatus());
}
示例11: testBatchSplit
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@Test
public void testBatchSplit() throws Exception {
JobOperator jobOperator = BatchRuntime.getJobOperator();
Long executionId = jobOperator.start("myJob", new Properties());
JobExecution jobExecution = jobOperator.getJobExecution(executionId);
BatchTestHelper.keepTestAlive(jobExecution);
List<StepExecution> stepExecutions = jobOperator.getStepExecutions(executionId);
List<String> executedSteps = new ArrayList<>();
for (StepExecution stepExecution : stepExecutions) {
executedSteps.add(stepExecution.getStepName());
}
assertEquals(3, stepExecutions.size());
assertTrue(executedSteps.contains("step1"));
assertTrue(executedSteps.contains("step2"));
assertTrue(executedSteps.contains("step3"));
assertTrue(executedSteps.get(0).equals("step1") || executedSteps.get(0).equals("step2"));
assertTrue(executedSteps.get(1).equals("step1") || executedSteps.get(1).equals("step2"));
assertTrue(executedSteps.get(2).equals("step3"));
assertEquals(BatchStatus.COMPLETED, jobExecution.getBatchStatus());
}
示例12: startBatches
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
public void startBatches() throws JobSecurityException, JobStartException, NoSuchJobExecutionException {
JobOperator jobOperator = BatchRuntime.getJobOperator();
logger.log(Level.INFO, "starting simple");
Long executionId = jobOperator.start("simple", new Properties());
JobExecution jobExecution = jobOperator.getJobExecution(executionId);
logger.log(Level.INFO, "Started simple job with id {0}", jobExecution.getExecutionId());
logger.log(Level.INFO, "Status simple {0}", jobExecution.getBatchStatus());
// logger.log(Level.INFO, "starting chunk");
// Long chunkExecutionId = jobOperator.start("chunk", new Properties());
// JobExecution chunkJobExecution = jobOperator.getJobExecution(chunkExecutionId);
//
// logger.log(Level.INFO, "Status chunk {0}", chunkJobExecution.getBatchStatus());
// logger.log(Level.INFO, "Started chunk job with id {0}", chunkJobExecution.getExecutionId());
}
示例13: setup
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@PostCreated
@PostRecovery
@PostConfig
public void setup()
{
_batchDataConsumer = new BatchDataConsumer(this);
_batchDataProvider = new BatchDataProvider(this);
BatchDataConsumerMap.getBatchDataConsumerMap().add(_batchDataConsumer);
BatchDataProviderMap.getBatchDataProviderMap().add(_batchDataProvider);
JobOperator jobOperator = BatchRuntime.getJobOperator();
Properties jobParameters = new Properties();
jobParameters.setProperty(BatchDataConsumerMap.ID_PROPERTYNAME, _batchDataConsumer.getId());
jobParameters.setProperty(BatchDataProviderMap.ID_PROPERTYNAME, _batchDataProvider.getId());
long execId = jobOperator.start(_properties.get(JOBID_PROPERTYNAME), jobParameters);
logger.log(Level.FINE, "BatchDataService: " + execId);
}
示例14: setup
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@PostCreated
@PostRecovery
@PostConfig
public void setup()
{
_batchDataConsumer = new BatchDataConsumer(this);
BatchDataConsumerMap.getBatchDataConsumerMap().add(_batchDataConsumer);
JobOperator jobOperator = BatchRuntime.getJobOperator();
Properties jobParameters = new Properties();
jobParameters.setProperty(BatchDataConsumerMap.ID_PROPERTYNAME, _batchDataConsumer.getId());
long execId = jobOperator.start(_properties.get(JOBID_PROPERTYNAME), jobParameters);
logger.log(Level.FINE, "BatchDataService: " + execId);
}
示例15: setup
import javax.batch.runtime.BatchRuntime; //导入依赖的package包/类
@PostCreated
@PostRecovery
@PostConfig
public void setup()
{
_batchDataConsumer = new BatchDataConsumer(this);
_batchDataProvider = new BatchDataProvider(this);
BatchDataConsumerMap.getBatchDataConsumerMap().add(_batchDataConsumer);
BatchDataProviderMap.getBatchDataProviderMap().add(_batchDataProvider);
JobOperator jobOperator = BatchRuntime.getJobOperator();
Properties jobParameters = new Properties();
jobParameters.setProperty(BatchDataConsumerMap.ID_PROPERTYNAME, _batchDataConsumer.getId());
jobParameters.setProperty(BatchDataProviderMap.ID_PROPERTYNAME, _batchDataProvider.getId());
long execId = jobOperator.start(_properties.get(JOBID_PROPERTYNAME), jobParameters);
logger.log(Level.FINE, "BatchDataProcessor: " + execId);
}