- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们的 Spring 批处理需要有两个步骤
Step1:Deque 是来自 JMS 的消息,处理该消息并将输出数据写入文件。步骤 2:包含 2 个从属步骤的分区步骤。每个从属步骤对步骤 1 的输出数据应用不同的算法。
问题:第 2 步从未被调用。尝试将步骤监听器附加到步骤 1(以及编写器),但它从未执行。看起来步骤 1 始终处于连续状态,因此步骤 2(分区步骤)永远不会被执行。
观察:当用普通(文件/数据库)读取器替换步骤 1 中的 JMSReader 时,控制转到步骤 2
注意:需要firstQueueTemplate.setReceiveTimeout(Long.MAX_VALUE);因为我们需要连续地将消息逐一出列。
public TransactionAwareConnectionFactoryProxy activeMQConnectionFactory() {
ActiveMQConnectionFactory amqConnectionFactory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_BROKER_URL);
TransactionAwareConnectionFactoryProxy activeMQConnectionFactory = new TransactionAwareConnectionFactoryProxy(amqConnectionFactory);
return activeMQConnectionFactory;
}
@Bean
public ActiveMQQueue defaultQueue() {
return new ActiveMQQueue("batch-test");
}
@Bean
@DependsOn(value = { "activeMQConnectionFactory", "defaultQueue" })
public JmsTemplate firstQueueTemplate(ActiveMQQueue defaultQueue, TransactionAwareConnectionFactoryProxy activeMQConnectionFactory) {
JmsTemplate firstQueueTemplate = new JmsTemplate(activeMQConnectionFactory);
firstQueueTemplate.setDefaultDestination(defaultQueue);
firstQueueTemplate.setSessionTransacted(true);
firstQueueTemplate.setReceiveTimeout(Long.MAX_VALUE);
return firstQueueTemplate;
}
@Bean(name = "partitionerJob")
public Job partitionerJob() throws UnexpectedInputException, MalformedURLException, ParseException {
return jobs.get("partitionerJob")
.start(ingestionstep())
.next(partitionStep())
.build();
}
@Bean
public Step ingestionstep() throws UnexpectedInputException, MalformedURLException, ParseException {
System.out.println("ingestionstep forming");
return steps.get("ingsetionstep")
.<SPDRIngestScanBO, SPDRIngestScanBO>chunk(1)
.reader(jmsItemReader())
.processor(ingestionProcessor())
.writer(ingestionwriter() )
.listener(new StepExecutionListener() {
@Override
public void beforeStep(StepExecution stepExecution) {
// TODO Auto-generated method stub
}
@Override
public ExitStatus afterStep(StepExecution stepExecution) {
System.out.println("step exit status :"+stepExecution.getExitStatus());
return null;
}
})
// .listener(promotionListener())
.build();
}
@Bean
@StepScope
public Step partitionStep() throws UnexpectedInputException, MalformedURLException, ParseException {
System.out.println(" Inside partitionStep method ");
return steps.get("partitionStep")
.partitioner("partitionscans", partitioner(null))
.gridSize(2)
.step(scanStep())
.taskExecutor(taskExecutor())
.build();
}
@Bean
public JmsItemReader<SPDRIngestScanBO> jmsItemReader() {
JmsItemReader<SPDRIngestScanBO> jmsItemReader = new JmsItemReader<>();
jmsItemReader.setJmsTemplate(jmsTemplate);
jmsItemReader.setItemType(SPDRIngestScanBO.class);
return jmsItemReader;
}
@Bean
public SPDRIngestionStepProcessor ingestionProcessor() {
return new SPDRIngestionStepProcessor();
}
@Bean
public SPDRIngestionStepWriter ingestionwriter() {
return new SPDRIngestionStepWriter();
}
@Bean
@StepScope
public ModelsPartitioner partitioner(@Value("#{jobExecutionContext[models]}") List<SPDRScanModelBO> models) {
ModelsPartitioner partitioner = new ModelsPartitioner();
partitioner.setModels(models);
System.out.println("----partitioner----");
return partitioner;
}
@Bean
@StepScope
public Step scanStep() throws UnexpectedInputException, MalformedURLException, ParseException {
return steps.get("scanstep")
.<SPDRScanModelBO, SPDRScanResultBO>chunk(1)
.reader(scanStepReader(null))
.processor(scanStepProcessor())
.writer(scanStepWriter())
.build();
}
@Bean
@StepScope
public SPDRScanStepReader scanStepReader(@Value("#{stepExecutionContext[model]}") SPDRScanModelBO scanModelBO){
System.out.println("----scanStepReader----");
SPDRScanStepReader scanStepReader = new SPDRScanStepReader();
scanStepReader.setScanModelBO(scanModelBO);
return scanStepReader;
}
@Bean
@StepScope
public SPDRScanStepProcessor scanStepProcessor(){
SPDRScanStepProcessor scanStepProcessor = new SPDRScanStepProcessor();
return scanStepProcessor;
}
@Bean
@StepScope
public SPDRScanStepWriter scanStepWriter(){
SPDRScanStepWriter scanStepWriter = new SPDRScanStepWriter();
return scanStepWriter;
}
@Bean
@StepScope
public TaskExecutor taskExecutor() {
ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();
taskExecutor.setMaxPoolSize(2);
taskExecutor.setCorePoolSize(2);
taskExecutor.setQueueCapacity(2);
taskExecutor.afterPropertiesSet();
return taskExecutor;
}
```
最佳答案
在 Spring Batch 中,当您按顺序运行两个步骤时,先说步骤 1,然后说步骤 2,那么只有当步骤 1 完成时才会执行步骤 2。
在您的情况下,step1 使用 receiveTimeout = Long.MAX_VALUE
从 jms 队列中读取数据,因此除非发生此超时,否则您的 step1 将不会完成,因此 step2 将不会启动。
关于java - JMS Reader/Processor/Writer 步骤之后的 Spring Batch 步骤未触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61968218/
我的代码有问题。它总是忽略if(userDigit=1).. 谁能告诉我这里出了什么问题? for(i=0; i=1) { //
我正在尝试从字符串 html_doc 中提取 id=obj1 并尝试将 onclick 函数 附加到它 document.addEventListener("DOMContentLoaded", fu
我正在尝试使用 css 动画来动画化从一个类到另一个类的变化。基本思想是在用户单击按钮时为从一个边缘滑动到另一个边缘的 slider 设置动画。 到目前为止我的代码。 https://jsfiddle
我目前面临使用前后伪元素淡入导航项的问题。 当我悬停导航项时,它必须将其背景颜色从白色更改为蓝色。没什么疯狂的。但它也必须显示两个背景图像,分别通过将::before 伪元素从 0 更改为 1 和::
有没有简单的方法可以在最近的sqlite版本中修改表,使其与预定义的架构匹配? 架构: war_id INTEGER NOT NULL, clanname VARCHAR(64), clanhomep
我该如何将我的搜索结果变成这样的: http://i.stack.imgur.com/NfPGs.png 结果显示特定术语在单元格中的位置。 我目前有这个基本的搜索脚本: $terms =
我正在尝试使用按钮创建输入字段。但我想要的是,当创建输入字段时,我想用相同的按钮隐藏创建的输入字段。我尝试了 slideToggle 函数,但效果不是很好。 $('#addEmail').one('
我想做这样的事情: Reference of image. 我所做的:两个 UIImagesView,一个带有 UIViewContentModeLeft,另一个带有 UIViewContentMod
我在使用应该修复表中列的插入触发器时遇到了问题: id - auto increment int thread_id - int [NULL] 我想要实现的是将 thread_id 设置
我使用 tinter.after() 每 200 毫秒 刷新一次树莓派上模拟时钟的显示。一开始还可以,但逐渐地,每次刷新之间的时间达到大约 2-3 秒。是否有任何解决方案可以将刷新间隔保持在 200m
我有一个按钮,它使用::after 伪来填充背景。目前它从左到右填充,这在宽度从 0 到 100% 时有意义。但是,我希望它翻转它填充的方式。 a.project--link { margin:
我正在尝试添加带有伪元素:after的下划线来注释一些文本。 我的问题是,我想强调下划线。在此示例中,这是短语“实际上确实可以...”和“ ...不起作用”。 .test { margin-top
鉴于此: This is a test It is 有没有我可以应用到 的 CSS?那它会出现在“This is...”之前,并且在 PREVIOUS LINE 之前吗? float:left; d
我正在使用链接左侧的图像。 现在,我使用图像的::before 属性来显示,但它显示在链接的上方。 我需要对齐它。这是一张照片: Link 我使用的代码是: .vocabulary-duration
我有一个页脚有 与 6 body {background:#bbb;} .main-footer a::after { content: " | "; color: white; mar
我有一个父元素和一些子元素,但我不能直接更改它们的 CSS。所以,我试图在父元素的 CSS 中更改我 child 的 CSS。示例: .parent { & .child {
我可以 div:after { content: "hello" } 但我能否为 hello 文本添加标题,以便当我用鼠标悬停它时显示标题? 谢谢 最佳答案 你不需要伪元素: p { ba
CSS 2.1 :after 和 CSS 3 ::after 伪选择器(除了 ::after 旧浏览器不支持)?是否有任何实际理由使用更新的规范? 最佳答案 这是伪类与伪元素的区别。 除了 ::fir
「掏出钥匙开门,然后在黑暗中摸索着墙壁开关的位置,最后将室内的灯点亮。」 这是一个星期之前,我每天晚上下班回家时的固定戏码,也可能是大部分人每天回家时的经历。这种「一对一」的日常琐碎还有许多许
我正在尝试包装 , ,和具有 的元素修复我无法直接编辑的表单上的某些定位。由于某种原因,当我尝试使用以下代码时: $("label").before(""); $("input[type=tex
我是一名优秀的程序员,十分优秀!