java job 配置_如何使用java配置创建spring bean时传递JobParameters

@Bean

@Qualifier("stepScope")

public org.springframework.batch.core.scope.StepScope stepScope() {

final org.springframework.batch.core.scope.StepScope stepScope = new org.springframework.batch.core.scope.StepScope();

stepScope.setAutoProxy(true);

return stepScope;

}

有了这个改变,我无法在创建bean时传递作业参数,因为它正在抛出

在'org.springframework.beans.factory.config.BeanExpressionContext'类型的对象上找不到'jobParameters'

我的配置就像

@Configuration

@EnableBatchProcessing

public class MyConfig{

@Bean

@Qualifier("partitionJob")

public Job partitionJob() throws Exception {

return jobBuilderFactory

.get("partitionJob")

.incrementer(new RunIdIncrementer())

.start(partitionStep(null))

.build();

}

@Bean

@StepScope

public Step partitionStep(

@Value("#{jobParameters[gridSize]}") String gridSize)

throws Exception {

return stepBuilderFactory

.get("partitionStep")

.partitioner("slaveStep", partitioner())

.gridSize(gridZize)

.step(slaveStep(chunkSize))

.taskExecutor(threadPoolTaskExecutor()).build();

}

@Bean

@StepScope

public Step slaveStep(int chunkSize) throws Exception {

return stepBuilderFactory

.get("slaveStep")

......

........

}

我读过如果需要像我的例子一样访问作业参数,那么应该用@ StepScope注释bean . 但是我正如上面解释的那样得到例外 .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值