异常处理——restart重启

2024-05-16 07:08
文章标签 异常 处理 重启 restart

本文主要是介绍异常处理——restart重启,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

当spring batch批处理时遇到异常,可以采用如下方式

一、restart

1、在job中阻止重启

    //job//在job中设置了preventRestart会阻止job重启,第一次不管执行成功还是失败,都不会重启第二次@Beanpublic Job fileReaderJob(){return jobBuilderFactory.get("fileReaderJob").start(chunkStep()).preventRestart() //阻止重启.build();}//step@Beanpublic Step chunkStep(){return stepBuilderFactory.get("chunkStep").chunk(3)                                           .reader(fileItemReader())                           .writer(list -> list.forEach(System.out::println)).build();}

如果第二次重启job,会报job实例存在的错误

JobInstance already exists and is not restartable

2、在step中阻止重启

如果Job允许重启,但step不允许重启,当重启job后,会跳过不允许重启的step,不会报错

    //job@Beanpublic Job fileReaderJob(){return jobBuilderFactory.get("fileReaderJob").start(chunkStep()).build();}//step*/@Beanpublic Step chunkStep(){return stepBuilderFactory.get("chunkStep").chunk(3)                                           .reader(fileItemReader())                           .writer(list -> list.forEach(System.out::println)).allowStartIfComplete(false).build();}

当重启Job后,在日志表中可以看到job的status是COMPLETED,exit_code是NOOP,exit_message是 All steps already completed or no steps configured for this job.

3、在step中限制重启的次数

    //job@Beanpublic Job fileReaderJob(){return jobBuilderFactory.get("fileReaderJob").start(chunkStep()).build();}//step*/@Beanpublic Step chunkStep(){return stepBuilderFactory.get("chunkStep").chunk(3)                                           .reader(fileItemReader())                           .writer(list -> list.forEach(System.out::println)).startLimit(3) //设置有异常时,重启次数是3次,如果没异常,不重启.build();}

当该job作业没有异常时,job不管运行多少次,step都只在第一次运行;如果该job作业有异常,当job执行第一次在step中抛出异常后,当后面重启job后,step从上次异常中断的地方重启,如果还是异常,一直到3次后,就不再重启,提示已经超过最大执行次数:Maximum start limit exceeded for step: chunkStep1StartMax: 3 。

4、即使job成功后,也允许重启
前三种都是当job出现异常,重启后,从抛出异常的地方继续执行。而下面情况,每次重启job后,都是从开始的地方执行。

    //job@Beanpublic Job fileReaderJob(){return jobBuilderFactory.get("fileReaderJob").start(chunkStep()).build();}//step*/@Beanpublic Step chunkStep(){return stepBuilderFactory.get("chunkStep").chunk(3)                                           .reader(fileItemReader())                           .writer(list -> list.forEach(System.out::println)).allowStartIfComplete(true).build();}

这篇关于异常处理——restart重启的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994215

相关文章

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

电脑提示xlstat4.dll丢失怎么修复? xlstat4.dll文件丢失处理办法

《电脑提示xlstat4.dll丢失怎么修复?xlstat4.dll文件丢失处理办法》长时间使用电脑,大家多少都会遇到类似dll文件丢失的情况,不过,解决这一问题其实并不复杂,下面我们就来看看xls... 在Windows操作系统中,xlstat4.dll是一个重要的动态链接库文件,通常用于支持各种应用程序

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛

Golang 日志处理和正则处理的操作方法

《Golang日志处理和正则处理的操作方法》:本文主要介绍Golang日志处理和正则处理的操作方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录1、logx日志处理1.1、logx简介1.2、日志初始化与配置1.3、常用方法1.4、配合defer

springboot加载不到nacos配置中心的配置问题处理

《springboot加载不到nacos配置中心的配置问题处理》:本文主要介绍springboot加载不到nacos配置中心的配置问题处理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录springboot加载不到nacos配置中心的配置两种可能Spring Boot 版本Nacos