{"id":40193,"date":"2023-11-21T16:36:07","date_gmt":"2023-11-29T06:03:32","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/"},"modified":"2024-05-04T10:07:51","modified_gmt":"2024-05-04T02:07:51","slug":"%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/","title":{"rendered":"\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528SpringBatch\u8fdb\u884c\u6279\u5904\u7406"},"content":{"rendered":"<h3>\u9996\u5148<\/h3>\n<p>\u8fd9\u7bc7\u6587\u7ae0\u5c06\u4ece\u96f6\u5f00\u59cb\u4ecb\u7ecdSpring Batch\uff0c\u5e76\u901a\u8fc7\u5229\u7528\u5b83\u8fdb\u884c\u73af\u5883\u914d\u7f6e\u6765\u5b9e\u73b0\u6279\u5904\u7406\u3002\u603b\u4f53\u800c\u8a00\uff0c\u6279\u5904\u7406\u8fc7\u7a0b\u662f\u8fd9\u6837\u7684\uff1a\u5f53\u6279\u5904\u7406\u7a0b\u5e8f\u8fd0\u884c\u65f6\uff0c\u5b83\u4f1a\u4ece\u67d0\u4e2aJSON\u6587\u4ef6\u4e2d\u8bfb\u53d6\u6570\u636e\uff0c\u5e76\u5c06\u5176\u5199\u5165MySQL\u6570\u636e\u5e93\u4e2d\u3002<\/p>\n<h3>SpringBatch\u662f\u4ec0\u4e48<\/h3>\n<p>Spring Batch\u662fSpring\u7684\u5b50\u9879\u76ee\u4e4b\u4e00\u3002\u5b83\u4ee5Spring\u4e3a\u57fa\u7840\uff0c\u662f\u4e00\u4e2a\u6279\u5904\u7406\u5e94\u7528\u7a0b\u5e8f\u6846\u67b6\u3002<\/p>\n<h3>SpringBatch\u7684\u914d\u7f6e<\/h3>\n<p>\u5728\u4e0b\u56fe\u4e2d\u5c55\u793a\u4e86Spring Batch\u7684\u4e3b\u8981\u7ec4\u6210\u90e8\u5206\u548c\u6574\u4e2a\u5904\u7406\u6d41\u7a0b\uff08\u5757\u6a21\u578b\uff09\u3002<\/p>\n<p>\u8bf7\u6ce8\u610f\uff1a\u672c\u673a\u4e2d\u6587\u6587\u672c\u662f\u7531\u4eba\u5de5\u667a\u80fd\u751f\u6210\u7684\uff0c\u4ec5\u4f9b\u53c2\u8003\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3f4937434c4406c8e5ca\/6-0.png\" alt=\"springbatch.png\" \/><\/div>\n<div>\n<div class=\"post-table\">\u69cb\u6210\u8981\u7d20\u5f79\u5272JobSpring Batch\u306b\u304a\u3051\u308b\u30d0\u30c3\u30c1\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u4e00\u9023\u306e\u51e6\u7406\u3092\u307e\u3068\u3081\u305f1\u5b9f\u884c\u5358\u4f4d\u3002StepJob\u3092\u69cb\u6210\u3059\u308b\u51e6\u7406\u306e\u5358\u4f4d\u30021\u3064\u306eJob\u306b1\uff5eN\u500b\u306eStep\u3092\u3082\u305f\u305b\u308b\u3053\u3068\u304c\u53ef\u80fd\u3002JobLauncherJob\u3092\u8d77\u52d5\u3059\u308b\u305f\u3081\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3002ItemReader\u30c1\u30e3\u30f3\u30af\u30e2\u30c7\u30eb\u3092\u5b9f\u88c5\u3059\u308b\u969b\u306b\u3001\u30c7\u30fc\u30bf\u306e\u5165\u529b\uff0f\u52a0\u5de5\uff0f\u51fa\u529b\u306e3\u3064\u306b\u5206\u5272\u3059\u308b\u305f\u3081\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3002ItemProcessor\u30c1\u30e3\u30f3\u30af\u30e2\u30c7\u30eb\u3092\u5b9f\u88c5\u3059\u308b\u969b\u306b\u3001\u30c7\u30fc\u30bf\u306e\u5165\u529b\uff0f\u52a0\u5de5\uff0f\u51fa\u529b\u306e3\u3064\u306b\u5206\u5272\u3059\u308b\u305f\u3081\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3002ItemWriter\u30c1\u30e3\u30f3\u30af\u30e2\u30c7\u30eb\u3092\u5b9f\u88c5\u3059\u308b\u969b\u306b\u3001\u30c7\u30fc\u30bf\u306e\u5165\u529b\uff0f\u52a0\u5de5\uff0f\u51fa\u529b\u306e3\u3064\u306b\u5206\u5272\u3059\u308b\u305f\u3081\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3002JobRepositoryJob\u3084Step\u306e\u72b6\u6cc1\u3092\u7ba1\u7406\u3059\u308b\u6a5f\u69cb\u3002\u3053\u308c\u3089\u306e\u7ba1\u7406\u60c5\u5831\u306f\u3001Spring Batch\u304c\u898f\u5b9a\u3059\u308b\u30c6\u30fc\u30d6\u30eb\u30b9\u30ad\u30fc\u30de\u3092\u5143\u306b\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u4e0a\u306b\u6c38\u7d9a\u5316\u3055\u308c\u308b\u3002<\/div>\n<\/div>\n<h3>\u73af\u5883\u6784\u5efa<\/h3>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">SpringBatch<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">SpringBoot<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Java<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">Grade<\/ul>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3f4937434c4406c8e5ca\/10-0.png\" alt=\"grade.png\" \/><\/div>\n<h3>\u6e90\u4ee3\u7801\u7684\u5b9e\u73b0<\/h3>\n<p>\u63a5\u4e0b\u6765\uff0c\u6211\u4eec\u5c06\u521b\u5efa\u4e00\u4e2a\u9879\u76ee\u5e76\u8fdb\u884c\u8bf4\u660e\u3002<\/p>\n<h4>\u5f15\u5165\u56fe\u4e66\u9986<\/h4>\n<p>\u8fd9\u4e2a\u6587\u4ef6\u662f\u4e00\u4e2a\u56fe\u4e66\u9986\u8bf7\u6c42\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"n\">buildscript<\/span> <span class=\"o\">{<\/span>\r\n   <span class=\"n\">ext<\/span> <span class=\"o\">{<\/span>\r\n      <span class=\"n\">springBootVersion<\/span> <span class=\"o\">=<\/span> <span class=\"err\">'<\/span><span class=\"mf\">2.0<\/span><span class=\"o\">.<\/span><span class=\"mi\">4<\/span><span class=\"o\">.<\/span><span class=\"na\">RELEASE<\/span><span class=\"err\">'<\/span>\r\n   <span class=\"o\">}<\/span>\r\n   <span class=\"n\">repositories<\/span> <span class=\"o\">{<\/span>\r\n      <span class=\"n\">mavenCentral<\/span><span class=\"o\">()<\/span>\r\n   <span class=\"o\">}<\/span>\r\n   <span class=\"n\">dependencies<\/span> <span class=\"o\">{<\/span>\r\n      <span class=\"n\">classpath<\/span><span class=\"o\">(<\/span><span class=\"s\">\"org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}\"<\/span><span class=\"o\">)<\/span>\r\n   <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n\r\n<span class=\"n\">apply<\/span> <span class=\"nl\">plugin:<\/span> <span class=\"err\">'<\/span><span class=\"n\">java<\/span><span class=\"err\">'<\/span>\r\n<span class=\"n\">apply<\/span> <span class=\"nl\">plugin:<\/span> <span class=\"err\">'<\/span><span class=\"n\">idea<\/span><span class=\"err\">'<\/span>\r\n<span class=\"n\">apply<\/span> <span class=\"nl\">plugin:<\/span> <span class=\"err\">'<\/span><span class=\"n\">org<\/span><span class=\"o\">.<\/span><span class=\"na\">springframework<\/span><span class=\"o\">.<\/span><span class=\"na\">boot<\/span><span class=\"err\">'<\/span>\r\n<span class=\"n\">apply<\/span> <span class=\"nl\">plugin:<\/span> <span class=\"err\">'<\/span><span class=\"n\">io<\/span><span class=\"o\">.<\/span><span class=\"na\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">dependency<\/span><span class=\"o\">-<\/span><span class=\"n\">management<\/span><span class=\"err\">'<\/span>\r\n\r\n<span class=\"n\">group<\/span> <span class=\"o\">=<\/span> <span class=\"err\">'<\/span><span class=\"n\">com<\/span><span class=\"o\">.<\/span><span class=\"na\">demo<\/span><span class=\"err\">'<\/span>\r\n<span class=\"n\">version<\/span> <span class=\"o\">=<\/span> <span class=\"err\">'<\/span><span class=\"mf\">0.0<\/span><span class=\"o\">.<\/span><span class=\"mi\">1<\/span><span class=\"o\">-<\/span><span class=\"no\">SNAPSHOT<\/span><span class=\"err\">'<\/span>\r\n<span class=\"n\">sourceCompatibility<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">1.8<\/span>\r\n\r\n<span class=\"n\">repositories<\/span> <span class=\"o\">{<\/span>\r\n   <span class=\"n\">mavenCentral<\/span><span class=\"o\">()<\/span>\r\n<span class=\"o\">}<\/span>\r\n\r\n<span class=\"n\">dependencies<\/span> <span class=\"o\">{<\/span>\r\n   <span class=\"n\">compile<\/span><span class=\"o\">(<\/span><span class=\"err\">'<\/span><span class=\"n\">org<\/span><span class=\"o\">.<\/span><span class=\"na\">springframework<\/span><span class=\"o\">.<\/span><span class=\"na\">boot<\/span><span class=\"o\">:<\/span><span class=\"n\">spring<\/span><span class=\"o\">-<\/span><span class=\"n\">boot<\/span><span class=\"o\">-<\/span><span class=\"n\">starter<\/span><span class=\"o\">-<\/span><span class=\"n\">batch<\/span><span class=\"err\">'<\/span><span class=\"o\">)<\/span>\r\n   <span class=\"n\">compile<\/span><span class=\"o\">(<\/span><span class=\"err\">'<\/span><span class=\"n\">org<\/span><span class=\"o\">.<\/span><span class=\"na\">springframework<\/span><span class=\"o\">.<\/span><span class=\"na\">boot<\/span><span class=\"o\">:<\/span><span class=\"n\">spring<\/span><span class=\"o\">-<\/span><span class=\"n\">boot<\/span><span class=\"o\">-<\/span><span class=\"n\">starter<\/span><span class=\"o\">-<\/span><span class=\"n\">jdbc<\/span><span class=\"err\">'<\/span><span class=\"o\">)<\/span>\r\n   <span class=\"n\">compile<\/span><span class=\"o\">(<\/span><span class=\"s\">\"org.springframework.boot:spring-boot-starter-data-jpa\"<\/span><span class=\"o\">)<\/span>\r\n   <span class=\"n\">compile<\/span> <span class=\"nl\">group:<\/span> <span class=\"err\">'<\/span><span class=\"n\">com<\/span><span class=\"o\">.<\/span><span class=\"na\">fasterxml<\/span><span class=\"o\">.<\/span><span class=\"na\">jackson<\/span><span class=\"o\">.<\/span><span class=\"na\">datatype<\/span><span class=\"err\">'<\/span><span class=\"o\">,<\/span> <span class=\"nl\">name:<\/span> <span class=\"err\">'<\/span><span class=\"n\">jackson<\/span><span class=\"o\">-<\/span><span class=\"n\">datatype<\/span><span class=\"o\">-<\/span><span class=\"n\">joda<\/span><span class=\"err\">'<\/span><span class=\"o\">,<\/span> <span class=\"nl\">version:<\/span> <span class=\"err\">'<\/span><span class=\"mf\">2.9<\/span><span class=\"o\">.<\/span><span class=\"mi\">4<\/span><span class=\"err\">'<\/span>\r\n   <span class=\"n\">compile<\/span> <span class=\"nl\">group:<\/span> <span class=\"err\">'<\/span><span class=\"n\">org<\/span><span class=\"o\">.<\/span><span class=\"na\">jadira<\/span><span class=\"o\">.<\/span><span class=\"na\">usertype<\/span><span class=\"err\">'<\/span><span class=\"o\">,<\/span> <span class=\"nl\">name:<\/span> <span class=\"err\">'<\/span><span class=\"n\">usertype<\/span><span class=\"o\">.<\/span><span class=\"na\">core<\/span><span class=\"err\">'<\/span><span class=\"o\">,<\/span> <span class=\"nl\">version:<\/span> <span class=\"err\">'<\/span><span class=\"mf\">6.0<\/span><span class=\"o\">.<\/span><span class=\"mi\">1<\/span><span class=\"o\">.<\/span><span class=\"na\">GA<\/span><span class=\"err\">'<\/span>\r\n   <span class=\"n\">compile<\/span> <span class=\"nl\">group:<\/span> <span class=\"err\">'<\/span><span class=\"n\">mysql<\/span><span class=\"err\">'<\/span><span class=\"o\">,<\/span> <span class=\"nl\">name:<\/span> <span class=\"err\">'<\/span><span class=\"n\">mysql<\/span><span class=\"o\">-<\/span><span class=\"n\">connector<\/span><span class=\"o\">-<\/span><span class=\"n\">java<\/span><span class=\"err\">'<\/span><span class=\"o\">,<\/span> <span class=\"nl\">version:<\/span> <span class=\"err\">'<\/span><span class=\"mf\">6.0<\/span><span class=\"o\">.<\/span><span class=\"mi\">6<\/span><span class=\"err\">'<\/span><span class=\"o\">,<\/span>\r\n   <span class=\"n\">testCompile<\/span><span class=\"o\">(<\/span><span class=\"err\">'<\/span><span class=\"n\">org<\/span><span class=\"o\">.<\/span><span class=\"na\">springframework<\/span><span class=\"o\">.<\/span><span class=\"na\">boot<\/span><span class=\"o\">:<\/span><span class=\"n\">spring<\/span><span class=\"o\">-<\/span><span class=\"n\">boot<\/span><span class=\"o\">-<\/span><span class=\"n\">starter<\/span><span class=\"o\">-<\/span><span class=\"n\">test<\/span><span class=\"err\">'<\/span><span class=\"o\">)<\/span>\r\n   <span class=\"n\">testCompile<\/span><span class=\"o\">(<\/span><span class=\"err\">'<\/span><span class=\"n\">org<\/span><span class=\"o\">.<\/span><span class=\"na\">springframework<\/span><span class=\"o\">.<\/span><span class=\"na\">batch<\/span><span class=\"o\">:<\/span><span class=\"n\">spring<\/span><span class=\"o\">-<\/span><span class=\"n\">batch<\/span><span class=\"o\">-<\/span><span class=\"n\">test<\/span><span class=\"err\">'<\/span><span class=\"o\">)<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<h4>SpringBatch\u7684\u90e8\u7f72<\/h4>\n<p>\u9996\u5148\uff0c\u8fdb\u884c\u5168\u5c40\u8bbe\u7f6e\u3002\u7136\u540e\uff0c\u8fdb\u884cJOB\u7684\u914d\u7f6e\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nd\">@Configuration<\/span>\r\n<span class=\"nd\">@EnableAutoConfiguration<\/span>\r\n<span class=\"nd\">@EnableBatchProcessing<\/span><span class=\"o\">(<\/span><span class=\"n\">modular<\/span> <span class=\"o\">=<\/span> <span class=\"kc\">true<\/span><span class=\"o\">)<\/span>\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">SpringBatchConfiguration<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"nd\">@Bean<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">ApplicationContextFactory<\/span> <span class=\"nf\">firstJobContext<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"k\">new<\/span> <span class=\"nf\">GenericApplicationContextFactory<\/span><span class=\"o\">(<\/span><span class=\"nc\">FirstJobConfiguration<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"nd\">@Bean<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">ApplicationContextFactory<\/span> <span class=\"nf\">secondJobContext<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"k\">new<\/span> <span class=\"nf\">GenericApplicationContextFactory<\/span><span class=\"o\">(<\/span><span class=\"nc\">SecondJobConfiguration<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<h4>\u521b\u5efa\u5b9e\u4f53\u7c7b<\/h4>\n<p>\u8fd9\u662f\u6309\u7167Json\u6570\u636e\u7684\u683c\u5f0f\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nd\">@Entity<\/span>\r\n<span class=\"nd\">@Table<\/span><span class=\"o\">(<\/span><span class=\"n\">name<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"message\"<\/span><span class=\"o\">)<\/span>\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">Message<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"nd\">@Id<\/span>\r\n    <span class=\"nd\">@Column<\/span><span class=\"o\">(<\/span><span class=\"n\">name<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"object_id\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">nullable<\/span> <span class=\"o\">=<\/span> <span class=\"kc\">false<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">objectId<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"nd\">@Column<\/span><span class=\"o\">(<\/span><span class=\"n\">name<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"content\"<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">content<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"nd\">@Column<\/span><span class=\"o\">(<\/span><span class=\"n\">name<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"last_modified_time\"<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">LocalDateTime<\/span> <span class=\"n\">lastModifiedTime<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"nd\">@Column<\/span><span class=\"o\">(<\/span><span class=\"n\">name<\/span> <span class=\"o\">=<\/span> <span class=\"s\">\"created_time\"<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">LocalDateTime<\/span> <span class=\"n\">createdTime<\/span><span class=\"o\">;<\/span>\r\n<span class=\"o\">}<\/span>\r\n\r\n<\/code><\/pre>\n<h4>\u521b\u5efa\u5de5\u4f5c<\/h4>\n<pre class=\"post-pre\"><code><span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">MessageMigrationJobConfiguration<\/span> <span class=\"o\">{<\/span>\r\n  <span class=\"nd\">@Autowired<\/span>\r\n  <span class=\"kd\">private<\/span> <span class=\"nc\">JobBuilderFactory<\/span> <span class=\"n\">jobBuilderFactory<\/span><span class=\"o\">;<\/span>\r\n\r\n  <span class=\"nd\">@Autowired<\/span>\r\n  <span class=\"kd\">private<\/span> <span class=\"nc\">StepBuilderFactory<\/span> <span class=\"n\">stepBuilderFactory<\/span>\r\n\r\n  <span class=\"nd\">@Autowired<\/span>\r\n  <span class=\"kd\">private<\/span> <span class=\"nc\">EntityManagerFactory<\/span> <span class=\"n\">entityManager<\/span><span class=\"o\">;<\/span>\r\n\r\n  <span class=\"c1\">\/\/ Job\u3092\u4f5c\u6210<\/span>\r\n  <span class=\"nd\">@Bean<\/span>\r\n  <span class=\"kd\">public<\/span> <span class=\"nc\">Job<\/span> <span class=\"nf\">messageMigrationJob<\/span><span class=\"o\">(<\/span><span class=\"nd\">@Qualifier<\/span><span class=\"o\">(<\/span><span class=\"s\">\"messageMigrationStep\"<\/span><span class=\"o\">)<\/span> <span class=\"nc\">Step<\/span>    <span class=\"n\">messageMigrationStep<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">jobBuilderFactory<\/span><span class=\"o\">.<\/span><span class=\"na\">get<\/span><span class=\"o\">(<\/span><span class=\"s\">\"messageMigrationJob\"<\/span><span class=\"o\">)<\/span>\r\n            <span class=\"o\">.<\/span><span class=\"na\">start<\/span><span class=\"o\">(<\/span><span class=\"n\">messageMigrationStep<\/span><span class=\"o\">)<\/span>\r\n            <span class=\"o\">.<\/span><span class=\"na\">build<\/span><span class=\"o\">();<\/span>\r\n  <span class=\"o\">}<\/span>\r\n\r\n  <span class=\"c1\">\/\/ Step\u3092\u4f5c\u6210<\/span>\r\n  <span class=\"nd\">@Bean<\/span>\r\n  <span class=\"kd\">public<\/span> <span class=\"nc\">Step<\/span> <span class=\"nf\">messageMigrationStep<\/span><span class=\"o\">(<\/span><span class=\"nd\">@Qualifier<\/span><span class=\"o\">(<\/span><span class=\"s\">\"jsonMessageReader\"<\/span><span class=\"o\">)<\/span> <span class=\"nc\">FlatFileItemReader<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">jsonMessageReader<\/span><span class=\"o\">,<\/span>\r\n                                 <span class=\"nd\">@Qualifier<\/span><span class=\"o\">(<\/span><span class=\"s\">\"messageItemWriter\"<\/span><span class=\"o\">)<\/span> <span class=\"nc\">JpaItemWriter<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">messageItemWriter<\/span><span class=\"o\">,<\/span>\r\n                                 <span class=\"nd\">@Qualifier<\/span><span class=\"o\">(<\/span><span class=\"s\">\"errorWriter\"<\/span><span class=\"o\">)<\/span> <span class=\"nc\">Writer<\/span> <span class=\"n\">errorWriter<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">stepBuilderFactory<\/span><span class=\"o\">.<\/span><span class=\"na\">get<\/span><span class=\"o\">(<\/span><span class=\"s\">\"messageMigrationStep\"<\/span><span class=\"o\">)<\/span>\r\n            <span class=\"o\">.&lt;<\/span><span class=\"nc\">Message<\/span><span class=\"o\">,<\/span> <span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span><span class=\"n\">chunk<\/span><span class=\"o\">(<\/span><span class=\"no\">CHUNK_SIZE<\/span><span class=\"o\">)<\/span>\r\n            <span class=\"o\">.<\/span><span class=\"na\">reader<\/span><span class=\"o\">(<\/span><span class=\"n\">jsonMessageReader<\/span><span class=\"o\">).<\/span><span class=\"na\">faultTolerant<\/span><span class=\"o\">().<\/span><span class=\"na\">skip<\/span><span class=\"o\">(<\/span><span class=\"nc\">JsonParseException<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">).<\/span><span class=\"na\">skipLimit<\/span><span class=\"o\">(<\/span><span class=\"no\">SKIP_LIMIT<\/span><span class=\"o\">)<\/span>\r\n            <span class=\"o\">.<\/span><span class=\"na\">listener<\/span><span class=\"o\">(<\/span><span class=\"k\">new<\/span> <span class=\"nc\">MessageItemReadListener<\/span><span class=\"o\">(<\/span><span class=\"n\">errorWriter<\/span><span class=\"o\">))<\/span>\r\n            <span class=\"o\">.<\/span><span class=\"na\">writer<\/span><span class=\"o\">(<\/span><span class=\"n\">messageItemWriter<\/span><span class=\"o\">).<\/span><span class=\"na\">faultTolerant<\/span><span class=\"o\">().<\/span><span class=\"na\">skip<\/span><span class=\"o\">(<\/span><span class=\"nc\">Exception<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">).<\/span><span class=\"na\">skipLimit<\/span><span class=\"o\">(<\/span><span class=\"no\">SKIP_LIMIT<\/span><span class=\"o\">)<\/span>\r\n            <span class=\"o\">.<\/span><span class=\"na\">listener<\/span><span class=\"o\">(<\/span><span class=\"k\">new<\/span> <span class=\"nc\">MessageWriteListener<\/span><span class=\"o\">())<\/span>\r\n            <span class=\"o\">.<\/span><span class=\"na\">build<\/span><span class=\"o\">();<\/span>\r\n  <span class=\"o\">}<\/span>\r\n\r\n  <span class=\"c1\">\/\/ Reader\u3092\u4f5c\u6210<\/span>\r\n  <span class=\"nd\">@Bean<\/span>\r\n  <span class=\"kd\">public<\/span> <span class=\"nc\">FlatFileItemReader<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"nf\">jsonMessageReader<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"nc\">FlatFileItemReader<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">reader<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">FlatFileItemReader<\/span><span class=\"o\">&lt;&gt;();<\/span>\r\n    <span class=\"c1\">\/\/ \u5b9f\u969b\u306eJson Data\u30d5\u30a1\u30a4\u30eb\u30d1\u30b9\u3092\u5165\u308c\u308b<\/span>\r\n    <span class=\"n\">reader<\/span><span class=\"o\">.<\/span><span class=\"na\">setResource<\/span><span class=\"o\">(<\/span><span class=\"k\">new<\/span> <span class=\"nc\">FileSystemResource<\/span><span class=\"o\">(<\/span><span class=\"k\">new<\/span> <span class=\"nc\">File<\/span><span class=\"o\">(<\/span><span class=\"no\">MESSAGE_FILE<\/span><span class=\"o\">)));<\/span>\r\n    <span class=\"n\">reader<\/span><span class=\"o\">.<\/span><span class=\"na\">setLineMapper<\/span><span class=\"o\">(<\/span><span class=\"k\">new<\/span> <span class=\"nc\">MessageLineMapper<\/span><span class=\"o\">());<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">reader<\/span><span class=\"o\">;<\/span>\r\n <span class=\"o\">}<\/span>\r\n\r\n  <span class=\"c1\">\/\/ Writer\u3092\u4f5c\u6210<\/span>\r\n  <span class=\"nd\">@Bean<\/span>\r\n  <span class=\"kd\">public<\/span> <span class=\"nc\">JpaItemWriter<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"nf\">messageItemWriter<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"nc\">JpaItemWriter<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">writer<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">JpaItemWriter<\/span><span class=\"o\">&lt;&gt;();<\/span>\r\n    <span class=\"n\">writer<\/span><span class=\"o\">.<\/span><span class=\"na\">setEntityManagerFactory<\/span><span class=\"o\">(<\/span><span class=\"n\">entityManager<\/span><span class=\"o\">);<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">writer<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<h4>\u5b9e\u73b0\u6570\u636e\u5904\u7406\u65b9\u6cd5\u3002<\/h4>\n<p>\u5728\u8fd9\u91cc\uff0c\u4f7f\u7528LineMapper\u4ecetxt\u6e90\u6587\u4ef6\u9010\u884c\u8bfb\u53d6\u6570\u636e\u5e76\u5c06\u5176\u8f6c\u6362\u4e3aMessage\u5bf9\u8c61\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">MessageLineMapper<\/span> <span class=\"kd\">implements<\/span> <span class=\"nc\">LineMapper<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">MappingJsonFactory<\/span> <span class=\"n\">factory<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">MappingJsonFactory<\/span><span class=\"o\">();<\/span>\r\n\r\n    <span class=\"nd\">@Override<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"nc\">Message<\/span> <span class=\"nf\">mapLine<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span> <span class=\"n\">line<\/span><span class=\"o\">,<\/span> <span class=\"kt\">int<\/span> <span class=\"n\">lineNumber<\/span><span class=\"o\">)<\/span> <span class=\"kd\">throws<\/span> <span class=\"nc\">Exception<\/span> <span class=\"o\">{<\/span>   \r\n        <span class=\"nc\">JsonParser<\/span> <span class=\"n\">parser<\/span> <span class=\"o\">=<\/span> <span class=\"n\">factory<\/span><span class=\"o\">.<\/span><span class=\"na\">createParser<\/span><span class=\"o\">(<\/span><span class=\"n\">line<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">Map<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">String<\/span><span class=\"o\">,<\/span> <span class=\"nc\">Object<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">map<\/span> <span class=\"o\">=<\/span> <span class=\"o\">(<\/span><span class=\"nc\">Map<\/span><span class=\"o\">)<\/span> <span class=\"n\">parser<\/span><span class=\"o\">.<\/span><span class=\"na\">readValueAs<\/span><span class=\"o\">(<\/span><span class=\"nc\">Map<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">Message<\/span> <span class=\"n\">message<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Message<\/span><span class=\"o\">();<\/span>\r\n        <span class=\"o\">...<\/span> <span class=\"c1\">\/\/ TODO \u30c7\u30fc\u30bf\u8ee2\u63db\u30ed\u30b8\u30c3\u30af<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"n\">message<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<h4>\u521b\u5efaproperties\u6587\u4ef6<\/h4>\n<pre class=\"post-pre\"><code><span class=\"n\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">datasource<\/span><span class=\"o\">.<\/span><span class=\"na\">url<\/span><span class=\"o\">=<\/span><span class=\"nl\">jdbc:mysql:<\/span><span class=\"c1\">\/\/database<\/span>\r\n<span class=\"n\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">datasource<\/span><span class=\"o\">.<\/span><span class=\"na\">username<\/span><span class=\"o\">=<\/span><span class=\"n\">username<\/span>\r\n<span class=\"n\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">datasource<\/span><span class=\"o\">.<\/span><span class=\"na\">password<\/span><span class=\"o\">=<\/span><span class=\"n\">password<\/span>\r\n<span class=\"n\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">datasource<\/span><span class=\"o\">.<\/span><span class=\"na\">driverClassName<\/span><span class=\"o\">=<\/span><span class=\"n\">com<\/span><span class=\"o\">.<\/span><span class=\"na\">mysql<\/span><span class=\"o\">.<\/span><span class=\"na\">cj<\/span><span class=\"o\">.<\/span><span class=\"na\">jdbc<\/span><span class=\"o\">.<\/span><span class=\"na\">Driver<\/span>\r\n<span class=\"n\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">jpa<\/span><span class=\"o\">.<\/span><span class=\"na\">database<\/span><span class=\"o\">-<\/span><span class=\"n\">platform<\/span><span class=\"o\">=<\/span><span class=\"n\">org<\/span><span class=\"o\">.<\/span><span class=\"na\">hibernate<\/span><span class=\"o\">.<\/span><span class=\"na\">dialect<\/span><span class=\"o\">.<\/span><span class=\"na\">MySQLDialect<\/span>\r\n<span class=\"n\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">jpa<\/span><span class=\"o\">.<\/span><span class=\"na\">show<\/span><span class=\"o\">-<\/span><span class=\"n\">sql<\/span><span class=\"o\">=<\/span><span class=\"kc\">true<\/span>\r\n<span class=\"n\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">jpa<\/span><span class=\"o\">.<\/span><span class=\"na\">properties<\/span><span class=\"o\">.<\/span><span class=\"na\">jadira<\/span><span class=\"o\">.<\/span><span class=\"na\">usertype<\/span><span class=\"o\">.<\/span><span class=\"na\">autoRegisterUserTypes<\/span><span class=\"o\">=<\/span><span class=\"kc\">true<\/span>\r\n<span class=\"n\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">jackson<\/span><span class=\"o\">.<\/span><span class=\"na\">serialization<\/span><span class=\"o\">.<\/span><span class=\"na\">write<\/span><span class=\"o\">-<\/span><span class=\"n\">dates<\/span><span class=\"o\">-<\/span><span class=\"n\">as<\/span><span class=\"o\">-<\/span><span class=\"n\">timestamps<\/span><span class=\"o\">=<\/span><span class=\"kc\">false<\/span>\r\n<span class=\"n\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">batch<\/span><span class=\"o\">.<\/span><span class=\"na\">initialize<\/span><span class=\"o\">-<\/span><span class=\"n\">schema<\/span><span class=\"o\">=<\/span><span class=\"no\">ALWAYS<\/span>\r\n<span class=\"n\">spring<\/span><span class=\"o\">.<\/span><span class=\"na\">jpa<\/span><span class=\"o\">.<\/span><span class=\"na\">hibernate<\/span><span class=\"o\">.<\/span><span class=\"na\">ddl<\/span><span class=\"o\">-<\/span><span class=\"n\">auto<\/span><span class=\"o\">=<\/span><span class=\"n\">update<\/span>\r\n<\/code><\/pre>\n<h4>\u5b9e\u73b0Listener<\/h4>\n<p>\u5f53\u53d1\u751f\u9519\u8bef\u65f6\uff0c\u76d1\u542c\u5668\u5c06\u9519\u8bef\u6d88\u606f\u8f93\u51fa\u5230\u6587\u4ef6\u4e2d\u3002<\/p>\n<p>\u9605\u8bfb\u76d1\u542c\u5668<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">MessageItemReadListener<\/span> <span class=\"kd\">implements<\/span> <span class=\"nc\">ItemReadListener<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">Writer<\/span> <span class=\"n\">errorWriter<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"kd\">public<\/span> <span class=\"nf\">MessageItemReadListener<\/span><span class=\"o\">(<\/span><span class=\"nc\">Writer<\/span> <span class=\"n\">errorWriter<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">this<\/span><span class=\"o\">.<\/span><span class=\"na\">errorWriter<\/span> <span class=\"o\">=<\/span> <span class=\"n\">errorWriter<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"nd\">@Override<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">beforeRead<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"nd\">@Override<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">afterRead<\/span><span class=\"o\">(<\/span><span class=\"nc\">Message<\/span> <span class=\"n\">item<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"nd\">@Override<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">onReadError<\/span><span class=\"o\">(<\/span><span class=\"nc\">Exception<\/span> <span class=\"n\">ex<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n         <span class=\"n\">errorWriter<\/span><span class=\"o\">.<\/span><span class=\"na\">write<\/span><span class=\"o\">(<\/span><span class=\"n\">format<\/span><span class=\"o\">(<\/span><span class=\"s\">\"%s%n\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">ex<\/span><span class=\"o\">.<\/span><span class=\"na\">getMessage<\/span><span class=\"o\">()));<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<p>2. \u5199\u76d1\u542c\u5668 (Xi\u011b q\u00ec)<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">MessageWriteListener<\/span> <span class=\"kd\">implements<\/span> <span class=\"nc\">ItemWriteListener<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"o\">{<\/span>\r\n\r\n    <span class=\"nd\">@Autowired<\/span>\r\n    <span class=\"kd\">private<\/span> <span class=\"nc\">Writer<\/span> <span class=\"n\">errorWriter<\/span><span class=\"o\">;<\/span>\r\n\r\n    <span class=\"nd\">@Override<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">beforeWrite<\/span><span class=\"o\">(<\/span><span class=\"nc\">List<\/span><span class=\"o\">&lt;?<\/span> <span class=\"kd\">extends<\/span> <span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">items<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"nd\">@Override<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">afterWrite<\/span><span class=\"o\">(<\/span><span class=\"nc\">List<\/span><span class=\"o\">&lt;?<\/span> <span class=\"kd\">extends<\/span> <span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">items<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"o\">}<\/span>\r\n\r\n    <span class=\"nd\">@Override<\/span>\r\n    <span class=\"kd\">public<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">onWriteError<\/span><span class=\"o\">(<\/span><span class=\"nc\">Exception<\/span> <span class=\"n\">exception<\/span><span class=\"o\">,<\/span> <span class=\"nc\">List<\/span><span class=\"o\">&lt;?<\/span> <span class=\"kd\">extends<\/span> <span class=\"nc\">Message<\/span><span class=\"o\">&gt;<\/span> <span class=\"n\">items<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"n\">errorWriter<\/span><span class=\"o\">.<\/span><span class=\"na\">write<\/span><span class=\"o\">(<\/span><span class=\"n\">format<\/span><span class=\"o\">(<\/span><span class=\"s\">\"%s%n\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">exception<\/span><span class=\"o\">.<\/span><span class=\"na\">getMessage<\/span><span class=\"o\">()));<\/span>\r\n        <span class=\"k\">for<\/span> <span class=\"o\">(<\/span><span class=\"nc\">Message<\/span> <span class=\"n\">message<\/span> <span class=\"o\">:<\/span> <span class=\"n\">items<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"n\">errorWriter<\/span><span class=\"o\">.<\/span><span class=\"na\">write<\/span><span class=\"o\">(<\/span><span class=\"n\">format<\/span><span class=\"o\">(<\/span><span class=\"s\">\"Failed writing message id: %s\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">message<\/span><span class=\"o\">.<\/span><span class=\"na\">getObjectId<\/span><span class=\"o\">()));<\/span>\r\n        <span class=\"o\">}<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<h4>\u6267\u884c\u5de5\u4f5c<\/h4>\n<p>\u9996\u5148\uff0c\u6211\u6b63\u5728\u521b\u5efa\u4e00\u4e2a\u6d4b\u8bd5\u65b9\u6cd5\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">public<\/span> <span class=\"kd\">static<\/span> <span class=\"kt\">void<\/span> <span class=\"nf\">main<\/span><span class=\"o\">(<\/span><span class=\"nc\">String<\/span><span class=\"o\">[]<\/span> <span class=\"n\">args<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"nc\">String<\/span> <span class=\"n\">jobName<\/span> <span class=\"o\">=<\/span> <span class=\"n\">args<\/span><span class=\"o\">[<\/span><span class=\"mi\">0<\/span><span class=\"o\">];<\/span>\r\n\r\n    <span class=\"k\">try<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"nc\">ConfigurableApplicationContext<\/span> <span class=\"n\">context<\/span> <span class=\"o\">=<\/span> <span class=\"nc\">SpringApplication<\/span><span class=\"o\">.<\/span><span class=\"na\">run<\/span><span class=\"o\">(<\/span><span class=\"nc\">ZuociBatchApplication<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">,<\/span> <span class=\"n\">args<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">JobRegistry<\/span> <span class=\"n\">jobRegistry<\/span> <span class=\"o\">=<\/span> <span class=\"n\">context<\/span><span class=\"o\">.<\/span><span class=\"na\">getBean<\/span><span class=\"o\">(<\/span><span class=\"nc\">JobRegistry<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">Job<\/span> <span class=\"n\">job<\/span> <span class=\"o\">=<\/span> <span class=\"n\">jobRegistry<\/span><span class=\"o\">.<\/span><span class=\"na\">getJob<\/span><span class=\"o\">(<\/span><span class=\"n\">jobName<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">JobLauncher<\/span> <span class=\"n\">jobLauncher<\/span> <span class=\"o\">=<\/span> <span class=\"n\">context<\/span><span class=\"o\">.<\/span><span class=\"na\">getBean<\/span><span class=\"o\">(<\/span><span class=\"nc\">JobLauncher<\/span><span class=\"o\">.<\/span><span class=\"na\">class<\/span><span class=\"o\">);<\/span>\r\n        <span class=\"nc\">JobExecution<\/span> <span class=\"n\">jobExecution<\/span> <span class=\"o\">=<\/span> <span class=\"n\">jobLauncher<\/span><span class=\"o\">.<\/span><span class=\"na\">run<\/span><span class=\"o\">(<\/span><span class=\"n\">job<\/span><span class=\"o\">,<\/span> <span class=\"n\">createJobParams<\/span><span class=\"o\">());<\/span>\r\n        <span class=\"k\">if<\/span> <span class=\"o\">(!<\/span><span class=\"n\">jobExecution<\/span><span class=\"o\">.<\/span><span class=\"na\">getExitStatus<\/span><span class=\"o\">().<\/span><span class=\"na\">equals<\/span><span class=\"o\">(<\/span><span class=\"nc\">ExitStatus<\/span><span class=\"o\">.<\/span><span class=\"na\">COMPLETED<\/span><span class=\"o\">))<\/span> <span class=\"o\">{<\/span>\r\n            <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nf\">RuntimeException<\/span><span class=\"o\">(<\/span><span class=\"n\">format<\/span><span class=\"o\">(<\/span><span class=\"s\">\"%s Job execution failed.\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">jobName<\/span><span class=\"o\">));<\/span>\r\n        <span class=\"o\">}<\/span>\r\n    <span class=\"o\">}<\/span> <span class=\"k\">catch<\/span> <span class=\"o\">(<\/span><span class=\"nc\">Exception<\/span> <span class=\"n\">e<\/span><span class=\"o\">)<\/span> <span class=\"o\">{<\/span>\r\n        <span class=\"k\">throw<\/span> <span class=\"k\">new<\/span> <span class=\"nf\">RuntimeException<\/span><span class=\"o\">(<\/span><span class=\"n\">format<\/span><span class=\"o\">(<\/span><span class=\"s\">\"%s Job execution failed.\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">jobName<\/span><span class=\"o\">));<\/span>\r\n    <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n\r\n<span class=\"kd\">private<\/span> <span class=\"kd\">static<\/span> <span class=\"nc\">JobParameters<\/span> <span class=\"nf\">createJobParams<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"k\">new<\/span> <span class=\"nf\">JobParametersBuilder<\/span><span class=\"o\">().<\/span><span class=\"na\">addDate<\/span><span class=\"o\">(<\/span><span class=\"s\">\"date\"<\/span><span class=\"o\">,<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Date<\/span><span class=\"o\">()).<\/span><span class=\"na\">toJobParameters<\/span><span class=\"o\">();<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<p>\u5c06\u9879\u76ee\u6253\u5305\u6210jar\u6587\u4ef6\uff0c\u5e76\u5c1d\u8bd5\u901a\u8fc7\u4ee5\u4e0b\u547d\u4ee4\u6765\u6267\u884c\u3002<\/p>\n<blockquote><p>\u4f7f\u7528Java\u547d\u4ee4\u8fd0\u884c&#8221;YOUR_BATCH_NAME.jar&#8221;\u6587\u4ef6\uff0c\u5e76\u6267\u884c&#8221;YOUR_JOB_NAME&#8221;\u4f5c\u4e1a\u3002<\/p><\/blockquote>\n<h4>\u8fd0\u884c\u7ed3\u679c<\/h4>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3f4937434c4406c8e5ca\/41-0.png\" alt=\"data.png\" \/><\/div>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3f4937434c4406c8e5ca\/42-1.png\" alt=\"erro.png\" \/><\/div>\n<h3>\u6700\u540e<\/h3>\n<p>\u975e\u5e38\u611f\u8c22\u60a8\u8bfb\u5230\u6700\u540e\u3002<br \/>\n\u5982\u679c\u6709\u4efb\u4f55\u89c9\u5f97\u4e0d\u5bf9\u7684\u5730\u65b9\uff0c\u8bf7\u6beb\u4e0d\u72b9\u8c6b\u5730\u6307\u51fa\u3002<br \/>\n\u8c22\u8c22\u5408\u4f5c\u3002<\/p>\n<p>\u53c2\u8003\u8d44\u6599\uff1a<br \/>\n1. https:\/\/terasoluna-batch.github.io\/guideline\/5.0.0.RELEASE\/zh-cn\/Ch02_SpringBatchArchitecture.html<\/p>\n<p>2. \u8fd9\u662f\u5173\u4e8eSpring\u6279\u5904\u7406\u7684\u5b98\u65b9\u7f51\u7ad9\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u9996\u5148 \u8fd9\u7bc7\u6587\u7ae0\u5c06\u4ece\u96f6\u5f00\u59cb\u4ecb\u7ecdSpring Batch\uff0c\u5e76\u901a\u8fc7\u5229\u7528\u5b83\u8fdb\u884c\u73af\u5883\u914d\u7f6e\u6765\u5b9e\u73b0\u6279\u5904\u7406\u3002\u603b\u4f53\u800c\u8a00\uff0c\u6279\u5904\u7406\u8fc7 [&hellip;]<\/p>\n","protected":false},"author":7,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-40193","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528SpringBatch\u8fdb\u884c\u6279\u5904\u7406 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528springbatch\u8fdb\u884c\u6279\u5904\u7406\u3002\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528SpringBatch\u8fdb\u884c\u6279\u5904\u7406\" \/>\n<meta property=\"og:description\" content=\"\u9996\u5148 \u8fd9\u7bc7\u6587\u7ae0\u5c06\u4ece\u96f6\u5f00\u59cb\u4ecb\u7ecdSpring Batch\uff0c\u5e76\u901a\u8fc7\u5229\u7528\u5b83\u8fdb\u884c\u73af\u5883\u914d\u7f6e\u6765\u5b9e\u73b0\u6279\u5904\u7406\u3002\u603b\u4f53\u800c\u8a00\uff0c\u6279\u5904\u7406\u8fc7 [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528springbatch\u8fdb\u884c\u6279\u5904\u7406\u3002\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-11-29T06:03:32+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-05-04T02:07:51+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3f4937434c4406c8e5ca\/6-0.png\" \/>\n<meta name=\"author\" content=\"\u79d1, \u9896\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u79d1, \u9896\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/\",\"name\":\"\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528SpringBatch\u8fdb\u884c\u6279\u5904\u7406 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-11-29T06:03:32+00:00\",\"dateModified\":\"2024-05-04T02:07:51+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/8ca01ba7f7362ad4edb7da206a12f29e\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528SpringBatch\u8fdb\u884c\u6279\u5904\u7406\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/8ca01ba7f7362ad4edb7da206a12f29e\",\"name\":\"\u79d1, \u9896\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/8a6fb3cc7ba2f69d2189ba532aec4633ea7ed75ac0af162ec367cb3abc0fb2af?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/8a6fb3cc7ba2f69d2189ba532aec4633ea7ed75ac0af162ec367cb3abc0fb2af?s=96&d=mm&r=g\",\"caption\":\"\u79d1, \u9896\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/keying\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528SpringBatch\u8fdb\u884c\u6279\u5904\u7406 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528springbatch\u8fdb\u884c\u6279\u5904\u7406\u3002\/","og_locale":"zh_CN","og_type":"article","og_title":"\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528SpringBatch\u8fdb\u884c\u6279\u5904\u7406","og_description":"\u9996\u5148 \u8fd9\u7bc7\u6587\u7ae0\u5c06\u4ece\u96f6\u5f00\u59cb\u4ecb\u7ecdSpring Batch\uff0c\u5e76\u901a\u8fc7\u5229\u7528\u5b83\u8fdb\u884c\u73af\u5883\u914d\u7f6e\u6765\u5b9e\u73b0\u6279\u5904\u7406\u3002\u603b\u4f53\u800c\u8a00\uff0c\u6279\u5904\u7406\u8fc7 [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528springbatch\u8fdb\u884c\u6279\u5904\u7406\u3002\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-11-29T06:03:32+00:00","article_modified_time":"2024-05-04T02:07:51+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3f4937434c4406c8e5ca\/6-0.png"}],"author":"\u79d1, \u9896","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u79d1, \u9896","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"3 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/","name":"\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528SpringBatch\u8fdb\u884c\u6279\u5904\u7406 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-11-29T06:03:32+00:00","dateModified":"2024-05-04T02:07:51+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/8ca01ba7f7362ad4edb7da206a12f29e"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u5168\u9762\u89e3\u91ca\uff01\u4f7f\u7528SpringBatch\u8fdb\u884c\u6279\u5904\u7406"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/8ca01ba7f7362ad4edb7da206a12f29e","name":"\u79d1, \u9896","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/8a6fb3cc7ba2f69d2189ba532aec4633ea7ed75ac0af162ec367cb3abc0fb2af?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/8a6fb3cc7ba2f69d2189ba532aec4633ea7ed75ac0af162ec367cb3abc0fb2af?s=96&d=mm&r=g","caption":"\u79d1, \u9896"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/keying\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%85%a8%e9%9d%a2%e8%a7%a3%e9%87%8a%ef%bc%81%e4%bd%bf%e7%94%a8springbatch%e8%bf%9b%e8%a1%8c%e6%89%b9%e5%a4%84%e7%90%86%e3%80%82\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/40193","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/7"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=40193"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/40193\/revisions"}],"predecessor-version":[{"id":97685,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/40193\/revisions\/97685"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=40193"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=40193"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=40193"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}