SpringBatch-クイックガイド
Batch processingは、ユーザーの操作なしで一連の自動化された複雑なジョブの実行を伴う処理モードです。バッチプロセスはバルクデータを処理し、長時間実行されます。
いくつかのエンタープライズアプリケーションは、以下を含む操作を実行するために巨大なデータを処理する必要があります。
周期計算などの時間ベースのイベント。
大規模なデータセットで繰り返し処理される定期的なアプリケーション。
トランザクション方式で利用可能なデータの処理と検証を処理するアプリケーション。
したがって、バッチ処理は、そのようなトランザクションを実行するためにエンタープライズアプリケーションで使用されます。
SpringBatchとは
春のバッチは lightweight framework 開発に使用されます Batch Applications エンタープライズアプリケーションで使用されます。
一括処理に加えて、このフレームワークは次の機能を提供します。
- ロギングとトレースを含む
- トランザクション管理
- ジョブ処理統計
- ジョブの再開
- スキップとリソース管理
分割手法を使用して、SpringBatchアプリケーションをスケーリングすることもできます。
SpringBatchの特徴
以下は、SpringBatchの注目すべき機能です-
Flexibility− SpringBatchアプリケーションは柔軟性があります。XMLファイルを変更するだけで、アプリケーションの処理順序を変更できます。
Maintainability− SpringBatchアプリケーションは保守が簡単です。Spring Batchジョブにはステップが含まれており、他のステップに影響を与えることなく、各ステップを分離、テスト、および更新できます。
Scalability−分割手法を使用して、SpringBatchアプリケーションをスケーリングできます。これらのテクニックにより、次のことが可能になります。
ジョブのステップを並行して実行します。
シングルスレッドを並行して実行します。
Reliability −障害が発生した場合は、ステップを切り離すことにより、停止した場所からジョブを再開できます。
Support for multiple file formats − Spring Batchは、XML、フラットファイル、CSV、MYSQL、Hibernate、JDBC、Mongo、Neo4jなどの多数のリーダーとライターのサポートを提供します。
Multiple ways to launch a job − Webアプリケーション、Javaプログラム、コマンドラインなどを使用してSpringBatchジョブを起動できます。
これらに加えて、SpringBatchアプリケーションは以下をサポートします-
失敗後の自動再試行。
バッチ実行中およびバッチ処理の完了後のステータスと統計の追跡。
同時ジョブを実行します。
ロギング、リソース管理、スキップ、処理の再開などのサービス。
この章では、EclipseIDEでSpringBatch環境を設定する方法について説明します。インストールを続行する前に、システムにEclipseがインストールされていることを確認してください。そうでない場合は、Eclipseをダウンロードしてシステムにインストールします。
Eclipseの詳細については、Eclipseチュートリアルを参照してください。
EclipseでのSpringBatchの設定
以下の手順に従って、EclipseでSpringBatch環境を設定します。
Step 1 −次のスクリーンショットに示すように、Eclipseをインストールし、新しいプロジェクトを開きます。
Step 2 −以下に示すように、サンプルのSpringBatchプロジェクトを作成します。
Step 3−以下に示すように、プロジェクトを右クリックしてMavenプロジェクトに変換します。Mavenプロジェクトに変換すると、Pom.xml必要な依存関係について言及する必要がある場合。その後、jar それらのファイルは自動的にプロジェクトにダウンロードされます。
Step 4 −さて、 pom.xml プロジェクトの内容をコピーして貼り付け(Spring Batchアプリケーションの依存関係)、プロジェクトを更新します。
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.tutorialspoint</groupId>
<artifactId>SpringBatchSample</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>SpringBatchExample</name>
<url>http://maven.apache.org</url>
<properties>
<jdk.version>1.8</jdk.version>
<spring.version>4.3.8.RELEASE</spring.version>
<spring.batch.version>3.0.7.RELEASE</spring.batch.version>
<mysql.driver.version>5.1.25</mysql.driver.version>
<junit.version>4.11</junit.version>
</properties>
<dependencies>
<!-- Spring Core -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- Spring jdbc, for database -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- Spring XML to/back object -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-oxm</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- MySQL database driver -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.driver.version}</version>
</dependency>
<!-- Spring Batch dependencies -->
<dependency>
<groupId>org.springframework.batch</groupId>
<artifactId>spring-batch-core</artifactId>
<version>${spring.batch.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.batch</groupId>
<artifactId>spring-batch-infrastructure</artifactId>
<version>${spring.batch.version}</version>
</dependency>
<!-- Spring Batch unit test -->
<dependency>
<groupId>org.springframework.batch</groupId>
<artifactId>spring-batch-test</artifactId>
<version>${spring.batch.version}</version>
</dependency>
<!-- Junit -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit.version}</version>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<finalName>spring-batch</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-eclipse-plugin</artifactId>
<version>2.9</version>
<configuration>
<downloadSources>true</downloadSources>
<downloadJavadocs>false</downloadJavadocs>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>${jdk.version}</source>
<target>${jdk.version}</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
最後に、Mavenの依存関係を観察すると、必要なすべての依存関係を観察できます。 jar ファイルがダウンロードされました。
以下は、SpringBatchのアーキテクチャーの図式表現です。図に示されているように、アーキテクチャには3つの主要なコンポーネントが含まれています。Application, Batch Core、および Batch Infrastructure。
Application −このコンポーネントには、SpringBatchフレームワークを使用して記述したすべてのジョブとコードが含まれています。
Batch Core −このコンポーネントには、バッチジョブを制御および起動するために必要なすべてのAPIクラスが含まれています。
Batch Infrastructure −このコンポーネントには、アプリケーションとバッチコアコンポーネントの両方で使用されるリーダー、ライター、およびサービスが含まれています。
SpringBatchのコンポーネント
次の図は、Spring Batchのさまざまなコンポーネントと、それらがどのように相互に接続されているかを示しています。
ジョブ
Spring Batchアプリケーションでは、ジョブは実行されるバッチプロセスです。中断することなく最初から最後まで実行されます。このジョブはさらにステップに分割されます(またはジョブにステップが含まれます)。
XMLファイルまたはJavaクラスを使用してSpringBatchでジョブを構成します。以下は、SpringBatchでのジョブのXML構成です。
<job id = "jobid">
<step id = "step1" next = "step2"/>
<step id = "step2" next = "step3"/>
<step id = "step3"/>
</job>
バッチジョブは、タグ<job> </ job>内で構成されます。名前の付いた属性がありますid。これらのタグ内で、ステップの定義と順序を定義します。
Restartable −一般に、ジョブが実行されているときに、ジョブを再開しようとすると、次のように見なされます。 restartそしてそれは再び開始されます。これを回避するには、を設定する必要がありますrestartable の値 false 以下に示すように。
<job id = "jobid" restartable = "false" >
</job>
ステップ
A step ジョブの独立した部分であり、ジョブを定義および実行するために必要な情報が含まれています(その部分)。
図で指定されているように、各ステップはItemReader、ItemProcessor(オプション)、およびItemWriterで構成されています。 A job may contain one or more steps。
リーダー、ライター、およびプロセッサー
アン item reader 特定のソースからSpringBatchアプリケーションにデータを読み取りますが、 item writer SpringBatchアプリケーションから特定の宛先にデータを書き込みます。
アン Item processorSpringBatchに読み込まれたデータを処理する処理コードを含むクラスです。アプリケーションが"n" レコードの場合、プロセッサのコードは各レコードで実行されます。
リーダーとライターが指定されていない場合、 taskletSpringBatchのプロセッサとして機能します。単一のタスクのみを処理します。たとえば、MySQLデータベースからデータを読み取り、それを処理してファイルに書き込む(フラット)という単純なステップを含むジョブを作成している場合、このステップでは-を使用します。
A reader これはMySQLデータベースから読み取ります。
A writer フラットファイルに書き込みます。
A custom processor これは私たちの望み通りにデータを処理します。
<job id = "helloWorldJob">
<step id = "step1">
<tasklet>
<chunk reader = "mysqlReader" writer = "fileWriter"
processor = "CustomitemProcessor" ></chunk>
</tasklet>
</step>
</ job>
SpringBatchはの長いリストを提供します readers そして writers。これらの事前定義されたクラスを使用して、それらのBeanを定義できます。私たちは議論する予定ですreaders そして writers これについては、次の章で詳しく説明します。
JobRepository
Spring Batchのジョブリポジトリは、JobLauncher、Job、およびStep実装の作成、取得、更新、および削除(CRUD)操作を提供します。以下に示すように、XMLファイルでジョブリポジトリを定義します。
<job-repository id = "jobRepository"/>
に加えて id、利用可能ないくつかのオプション(オプション)があります。以下は、すべてのオプションとそのデフォルト値を使用したジョブリポジトリの構成です。
<job-repository id = "jobRepository"
data-source = "dataSource"
transaction-manager = "transactionManager"
isolation-level-for-create = "SERIALIZABLE"
table-prefix = "BATCH_"
max-varchar-length = "1000"/>
In-Memory Repository − Spring Batchのドメインオブジェクトをデータベースに永続化したくない場合は、以下に示すように、メモリ内バージョンのjobRepositoryを構成できます。
<bean id = "jobRepository"
class = "org.springframework.batch.core.repository.support.MapJobRepositoryFactoryBean ">
<property name = "transactionManager" ref = "transactionManager"/>
</bean>
JobLauncher
JobLauncherは、SpringBatchジョブを起動するインターフェイスです。 given set of parameters。 SampleJoblauncher を実装するクラスです JobLauncherインターフェース。以下は、JobLauncherの構成です。
<bean id = "jobLauncher"
class = "org.springframework.batch.core.launch.support.SimpleJobLauncher">
<property name = "jobRepository" ref = "jobRepository" />
</bean>
JobInstance
A JobInstanceジョブの論理実行を表します。ジョブを実行すると作成されます。各ジョブインスタンスは、ジョブの名前と実行中に渡されるパラメータによって区別されます。
JobInstanceの実行が失敗した場合、同じJobInstanceを再度実行できます。したがって、各JobInstanceは複数のジョブを実行できます。
JobExecutionとStepExecution
JobExecutionとStepExecutionは、ジョブ/ステップの実行を表しています。これらには、(ジョブ/ステップの)開始時間、(ジョブ/ステップの)終了時間などのジョブ/ステップの実行情報が含まれています。
このチュートリアルのほとんどすべての例には、次のファイルが含まれています-
- 構成ファイル(XMLファイル)
- タスクレット/プロセッサ(Javaクラス)
- セッターとゲッターを備えたJavaクラス(Javaクラス(bean))
- マッパークラス(Javaクラス)
- ランチャークラス(Javaクラス)
構成ファイル
構成ファイル(XML)には、次のものが含まれています。
ザ・ job そして step 定義。
定義するBean readers そして writers。
JobLauncher、JobRepository、Transaction Manager、データソースなどのコンポーネントの定義。
この例では、理解を深めるために、これを2つのファイルに分割しています。 job.xml ファイル(ジョブ、ステップ、リーダー、ライターを定義)および context.xml ファイル(ジョブランチャー、ジョブリポジトリ、トランザクションマネージャー、データソース)。
マッパークラス
Mapperクラスは、リーダーに応じて、次のようなインターフェイスを実装します。 row mapper、 field set mapper、など。リーダーからデータを取得し、それをJavaクラスに設定するためのコードが含まれています。 setter そして getter メソッド(Java Bean)。
JavaBeanクラス
とのJavaクラス setters そして getters(Java Bean)は、複数の値を持つデータを表します。ヘルパークラスとして機能します。このクラスのオブジェクトの形式で、1つのコンポーネント(リーダー、ライター、プロセッサー)から他のコンポーネントにデータを渡します。
タスクレット/プロセッサ
タスクレット/プロセッサクラスには、SpringBatchアプリケーションの処理コードが含まれています。プロセッサは、読み取られたデータを含むオブジェクトを受け取り、それを処理し、処理されたデータを(フォームオブジェクトで)返すクラスです。
ランチャークラス
このクラス(App.java)には、SpringBatchアプリケーションを起動するためのコードが含まれています。
Spring Batchアプリケーションの作成中に、Spring Batch名前空間で提供されるXMLタグを使用して、ジョブ、ステップ、JobLauncher、JobRepository、Transaction Manager、リーダー、およびライターを構成します。したがって、以下に示すように、この名前空間をXMLファイルに含める必要があります。
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:batch = "http://www.springframework.org/schema/batch"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/batch
http://www.springframework.org/schema/batch/spring-batch-2.2.xsd
http://www.springframework.org/schema/bean
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">
次のセクションでは、Spring Batch名前空間で使用できるさまざまなタグ、それらの属性、および例について説明します。
ジョブ
このタグは、SpringBatchのジョブを定義/構成するために使用されます。これには一連のステップが含まれており、JobLauncherを使用して起動できます。
このタグには、以下の2つの属性があります-
S.No | 属性と説明 |
---|---|
1 | Id これはジョブのIDであり、この属性に値を指定する必要があります。 |
2 | restartable これは、ジョブを再開可能かどうかを指定するために使用される属性です。この属性はオプションです。 |
以下は、SpringBatchのジョブのXML構成です。
<job id = "jobid" restartable = "false" >
. . . . . . . .
. . . . . . . .
. . . . . . . . // Step definitions
</job>
ステップ
このタグは、SpringBatchジョブのステップを定義/構成するために使用されます。次の3つの属性があります-
S.No | 属性と説明 |
---|---|
1 | Id これはジョブのIDであり、この属性に値を指定する必要があります。 |
2 | next 次のステップを指定するためのショートカットです。 |
3 | parent これは、構成が継承する親Beanの名前を指定するために使用されます。 |
以下は、SpringBatchのステップのXML構成です。
<job id = "jobid">
<step id = "step1" next = "step2"/>
<step id = "step2" next = "step3"/>
<step id = "step3"/>
</job>
チャンク
このタグは、チャンクを定義/構成するために使用されます tasklet。次の4つの属性があります-
S.No | 属性と説明 |
---|---|
1 | reader アイテムリーダーBeanの名前を表します。タイプの値を受け入れますorg.springframework.batch.item.ItemReader。 |
2 | writer アイテムリーダーBeanの名前を表します。タイプの値を受け入れますorg.springframework.batch.item.ItemWriter。 |
3 | processor アイテムリーダーBeanの名前を表します。タイプの値を受け入れますorg.springframework.batch.item.ItemProcessor。 |
4 | commit-interval トランザクションをコミットする前に処理するアイテムの数を指定するために使用されます。 |
以下は、SpringBatchのチャンクのXML構成です。
<batch:step id = "step1">
<batch:tasklet>
<batch:chunk reader = "xmlItemReader"
writer = "mysqlItemWriter" processor = "itemProcessor" commit-interval = "10">
</batch:chunk>
</batch:tasklet>
</batch:step>
JobRepository
JobRepository Beanは、リレーショナルデータベースを使用してJobRepositoryを構成するために使用されます。このBeanは、タイプのクラスに関連付けられていますorg.springframework.batch.core.repository.JobRepository。
S.No | 属性と説明 |
---|---|
1 | dataSource これは、データソースを定義するBean名を指定するために使用されます。 |
2 | transactionManager これは、transactionmanagerを定義するBeanの名前を指定するために使用されます。 |
3 | databaseType ジョブリポジトリで使用されるリレーショナルデータベースのタイプを指定します。 |
以下は、JobRepositoryの構成例です。
<bean id = "jobRepository"
class = "org.springframework.batch.core.repository.support.JobRepositoryFactoryBean">
<property name = "dataSource" ref = "dataSource" />
<property name = "transactionManager" ref="transactionManager" />
<property name = "databaseType" value = "mysql" />
</bean>
JobLauncher
JobLauncher Beanは、JobLauncherを構成するために使用されます。クラスに関連付けられていますorg.springframework.batch.core.launch.support.SimpleJobLauncher(私たちのプログラムで)。このBeanには、という名前のプロパティが1つあります。jobrepository、およびを定義するBeanの名前を指定するために使用されます jobrepository。
以下は、jobLauncherの構成例です。
<bean id = "jobLauncher"
class = "org.springframework.batch.core.launch.support.SimpleJobLauncher">
<property name = "jobRepository" ref = "jobRepository" />
</bean>
TransactionManager
TransactionManager Beanは、リレーショナルデータベースを使用してTransactionManagerを構成するために使用されます。このBeanは、タイプのクラスに関連付けられていますorg.springframework.transaction.platform.TransactionManager。
<bean id = "transactionManager"
class = "org.springframework.batch.support.transaction.ResourcelessTransactionManager" />
情報元
データソースBeanは、 Datasource。このBeanは、タイプのクラスに関連付けられていますorg.springframework.jdbc.datasource.DriverManagerDataSource。
S.No | 属性と説明 |
---|---|
1 | driverClassName これは、データベースへの接続に使用されるドライバーのクラス名を指定します。 |
2 | url これは、データベースのURLを指定します。 |
3 | username これは、データベースに接続するためのユーザー名を指定します。 |
4 | password これは、データベースに接続するためのパスワードを指定します。 |
以下は、の構成例です。 datasource。
<bean id = "dataSource"
class = "org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name = "driverClassName" value = "com.mysql.jdbc.Driver" />
<property name = "url" value = "jdbc:mysql://localhost:3306/details" />
<property name = "username" value = "myuser" />
<property name = "password" value = "password" />
</bean>
アン Item Reader 特定のソースからSpringBatchアプリケーションにデータを読み込みますが、 Item Writer SpringBatchアプリケーションから特定の宛先にデータを書き込みます。
アン Item processorSpringBatchに読み込まれたデータを処理する処理コードを含むクラスです。アプリケーションがnレコードを読み取ると、プロセッサのコードが各レコードで実行されます。
A chunk の子要素です tasklet。これは、読み取り、書き込み、および処理操作を実行するために使用されます。以下に示す手順で、この要素を使用してリーダー、ライター、およびプロセッサーを構成できます。
<batch:job id = "helloWorldJob">
<batch:step id = "step1">
<batch:tasklet>
<batch:chunk reader = "cvsFileItemReader" writer = "xmlItemWriter"
processor = "itemProcessor" commit-interval = "10">
</batch:chunk>
</batch:tasklet>
</batch:step>
</batch:job>
Spring Batchは、MongoDB、Neo4j、MySQL、XML、フラットファイル、CSVなどのさまざまなファイルシステム/データベースからデータを読み書きするためのリーダーとライターを提供します。
アプリケーションにリーダーを含めるには、そのリーダーのBeanを定義し、Bean内の必要なすべてのプロパティに値を指定して、 id チャンク要素の属性への値としてのそのようなBeanの reader (同じ writer)。
ItemReader
これは、データを読み取る(バッチプロセスの)ステップのエンティティです。ItemReaderは、一度に1つのアイテムを読み取ります。SpringBatchはインターフェースを提供しますItemReader。全てのreaders このインターフェースを実装します。
以下は、さまざまなソースから読み取るためにSpringBatchによって提供される事前定義されたItemReaderクラスの一部です。
読者 | 目的 |
---|---|
FlatFIleItemReader | フラットファイルからデータを読み取るため。 |
StaxEventItemReader | XMLファイルからデータを読み取るため。 |
StoredProcedureItemReader | データベースのストアドプロシージャからデータを読み取ること。 |
JDBCPagingItemReader | リレーショナルデータベースデータベースからデータを読み取るため。 |
MongoItemReader | MongoDBからデータを読み取るため。 |
Neo4jItemReader | Neo4jItemReaderからデータを読み取るため。 |
を構成する必要があります ItemReaders豆を作成することによって。以下はの例ですStaxEventItemReader XMLファイルからデータを読み取ります。
<bean id = "mysqlItemWriter"
class = "org.springframework.batch.item.xml.StaxEventItemWriter">
<property name = "resource" value = "file:xml/outputs/userss.xml" />
<property name = "marshaller" ref = "reportMarshaller" />
<property name = "rootTagName" value = "Tutorial" />
</bean>
<bean id = "reportMarshaller"
class = "org.springframework.oxm.jaxb.Jaxb2Marshaller">
<property name = "classesToBeBound">
<list>
<value>Tutorial</value>
</list>
</property>
</bean>
観察されたように、構成中に、必要なリーダーのそれぞれのクラス名を指定する必要があり、必要なすべてのプロパティに値を提供する必要があります。
ItemWriter
それはの要素です stepデータを書き込むバッチプロセスの。ItemWriterは、一度に1つのアイテムを書き込みます。SpringBatchはインターフェースを提供しますItemWriter。すべてのライターがこのインターフェースを実装しています。
以下は、さまざまなソースから読み取るためにSpringBatchによって提供される事前定義されたItemWriterクラスの一部です。
作家 | 目的 |
---|---|
FlatFIleItemWriter | フラットファイルにデータを書き込むこと。 |
StaxEventItemWriter | XMLファイルにデータを書き込むこと。 |
StoredProcedureItemWriter | データベースのストアドプロシージャにデータを書き込むこと。 |
JDBCPagingItemWriter | リレーショナルデータベースデータベースにデータを書き込むこと。 |
MongoItemWriter | MongoDBにデータを書き込むため。 |
Neo4jItemWriter | Neo4jにデータを書き込むため。 |
同様に、Beanを作成してItemWriterを構成する必要があります。以下はの例ですJdbcCursorItemReader MySQLデータベースにデータを書き込みます。
<bean id = "dbItemReader"
class = "org.springframework.batch.item.database.JdbcCursorItemReader" scope = "step">
<property name = "dataSource" ref = "dataSource" />
<property name = "sql" value = "select * from tutorialsdata" />
<property name = "rowMapper">
<bean class = "TutorialRowMapper" />
</property>
</bean>
アイテムプロセッサ
ItemProcessor:ItemProcessorは、データを処理するために使用されます。指定されたアイテムが無効な場合は、null、それ以外の場合は、指定されたアイテムを処理し、処理された結果を返します。インターフェースItemProcessor<I,O> プロセッサを表します。
Tasklet class −いいえの場合 reader そして writer与えられると、タスクレットはSpringBatchのプロセッサとして機能します。単一のタスクのみを処理します。
インターフェイスを実装することで、カスタムアイテムプロセッサを定義できます ItemProcessor パッケージの org.springframework.batch.item.ItemProcessor。このItemProcessorクラスは、オブジェクトを受け入れてデータを処理し、処理されたデータを別のオブジェクトとして返します。
バッチプロセスでは、 "n"レコードまたはデータ要素が読み取られ、レコードごとに、データが読み取られて処理され、ライターにデータが書き込まれます。データを処理するために、渡されたプロセッサを中継します。
たとえば、特定のPDFドキュメントをロードし、新しいページを作成し、データ項目を表形式でPDFに書き込むコードを記述したとします。このアプリケーションを実行すると、XMLドキュメントからすべてのデータ項目が読み取られ、MySQLデータベースに保存され、指定されたPDFドキュメントの個々のページに出力されます。
例
以下は、ItemProcessorクラスのサンプルです。
import org.springframework.batch.item.ItemProcessor;
public class CustomItemProcessor implements ItemProcessor<Tutorial, Tutorial> {
@Override
public Tutorial process(Tutorial item) throws Exception {
System.out.println("Processing..." + item);
return item;
}
}
この章では、基本的なSpringBatchアプリケーションについて説明します。単に実行しますtasklet メッセージを表示します。
SpringBatchアプリケーションには次のファイルが含まれています-
Configuration file−これは、ジョブとジョブのステップを定義するXMLファイルです。(アプリケーションにリーダーとライターも含まれる場合は、readers そして writers このファイルにも含まれています。)
Context.xml −このファイルでは、ジョブリポジトリ、ジョブランチャー、トランザクションマネージャーなどのBeanを定義します。
Tasklet class −このクラスでは、処理コードジョブを記述します(この場合、単純なメッセージが表示されます)
Launcher class −このクラスでは、ジョブランチャーを実行してバッチアプリケーションを起動します。
jobConfig.xml
以下は、サンプルのSpringBatchアプリケーションの構成ファイルです。
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:batch = "http://www.springframework.org/schema/batch"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/batch
http://www.springframework.org/schema/batch/spring-batch-2.2.xsd
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd ">
<import resource="context.xml" />
<!-- Defining a bean -->
<bean id = "tasklet" class = "a_sample.MyTasklet" />
<!-- Defining a job-->
<batch:job id = "helloWorldJob">
<!-- Defining a Step -->
<batch:step id = "step1">
<tasklet ref = "tasklet"/>
</batch:step>
</batch:job>
</beans>
Context.xml
以下は context.xml SpringBatchアプリケーションの
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">
<bean id = "jobRepository"
class="org.springframework.batch.core.repository.support.MapJobRepositoryFactoryBean">
<property name = "transactionManager" ref = "transactionManager" />
</bean>
<bean id = "transactionManager"
class = "org.springframework.batch.support.transaction.ResourcelessTransactionManager" />
<bean id = "jobLauncher"
class = "org.springframework.batch.core.launch.support.SimpleJobLauncher">
<property name = "jobRepository" ref = "jobRepository" />
</bean>
</beans>
Tasklet.java
以下は、簡単なメッセージを表示するTaskletクラスです。
import org.springframework.batch.core.StepContribution;
import org.springframework.batch.core.scope.context.ChunkContext;
import org.springframework.batch.core.step.tasklet.Tasklet;
import org.springframework.batch.repeat.RepeatStatus;
public class MyTasklet implements Tasklet {
@Override
public RepeatStatus execute(StepContribution arg0, ChunkContext arg1) throws Exception {
System.out.println("Hello This is a sample example of spring batch");
return RepeatStatus.FINISHED;
}
}
App.java
以下は、バッチプロセスを起動するコードです。
import org.springframework.batch.core.Job;
import org.springframework.batch.core.JobExecution;
import org.springframework.batch.core.JobParameters;
import org.springframework.batch.core.launch.JobLauncher;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class App {
public static void main(String[] args)throws Exception {
// System.out.println("hello");
String[] springConfig = {"a_sample/job_hello_world.xml"};
// Creating the application context object
ApplicationContext context = new ClassPathXmlApplicationContext(springConfig);
// Creating the job launcher
JobLauncher jobLauncher = (JobLauncher) context.getBean("jobLauncher");
// Creating the job
Job job = (Job) context.getBean("helloWorldJob");
// Executing the JOB
JobExecution execution = jobLauncher.run(job, new JobParameters());
System.out.println("Exit Status : " + execution.getStatus());
}
}
実行すると、上記のSpringBatchプログラムは次の出力を生成します-
Apr 24, 2017 4:40:54 PM org.springframework.context.support.AbstractApplicationContext prepareRefresh
INFO:Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@2ef1e4fa: startup date [Mon Apr 24 16:40:54 IST 2017]; root of context hierarchy
Apr 24, 2017 4:40:54 PM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions INFO: Loading XML bean definitions
Apr 24, 2017 4:40:54 PM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
INFO: Loading XML bean definitions
Apr 24, 2017 4:40:54 PM org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons
Apr 24, 2017 4:40:55 PM org.springframework.batch.core.launch.support.SimpleJobLauncher afterPropertiesSet
INFO: No TaskExecutor has been set, defaulting to synchronous executor.
Apr 24, 2017 4:40:55 PM org.springframework.batch.core.launch.support.SimpleJobLauncher$1 run
INFO: Job: [FlowJob: [name=helloWorldJob]] launched with the following parameters: [{}]
Apr 24, 2017 4:40:55 PM org.springframework.batch.core.job.SimpleStepHandler handleStep INFO: Executing step: [step1]
Hello This is a sample example of spring batch
Apr 24, 2017 4:40:55 PM org.springframework.batch.core.launch.support.SimpleJobLauncher$1 run
INFO: Job: [FlowJob: [name=helloWorldJob]] completed with the following parameters: [{}] and the following status: [COMPLETED]
Exit Status : COMPLETED
この章では、XMLリーダーとMySQLライターを使用するSpringBatchアプリケーションを作成します。
Reader −アプリケーションで使用しているリーダーは StaxEventItemReader XMLドキュメントからデータを読み取るため。
以下は、このアプリケーションで使用している入力XMLドキュメントです。このドキュメントには、チュートリアルID、チュートリアルの作成者、チュートリアルのタイトル、送信日、チュートリアルアイコン、チュートリアルの説明などの詳細を指定するデータレコードが含まれています。
<?xml version="1.0" encoding="UTF-8"?>
<tutorials>
<tutorial>
<tutorial_id>1001</tutorial_id>
<tutorial_author>Sanjay</tutorial_author>
<tutorial_title>Learn Java</tutorial_title>
<submission_date>06-05-2007</submission_date>
<tutorial_icon>https://www.tutorialspoint.com/java/images/java-minilogo.jpg</tutorial_icon>
<tutorial_description>Java is a high-level programming language originally
developed by Sun Microsystems and released in 1995.
Java runs on a variety of platforms.
This tutorial gives a complete understanding of Java.');</tutorial_description>
</tutorial>
<tutorial>
<tutorial_id>1002</tutorial_id>
<tutorial_author>Abdul S</tutorial_author>
<tutorial_title>Learn MySQL</tutorial_title>
<submission_date>19-04-2007</submission_date>
<tutorial_icon>https://www.tutorialspoint.com/mysql/images/mysql-minilogo.jpg</tutorial_icon>
<tutorial_description>MySQL is the most popular
Open Source Relational SQL database management system.
MySQL is one of the best RDBMS being used for developing web-based software applications.
This tutorial will give you quick start with MySQL
and make you comfortable with MySQL programming.</tutorial_description>
</tutorial>
<tutorial>
<tutorial_id>1003</tutorial_id>
<tutorial_author>Krishna Kasyap</tutorial_author>
<tutorial_title>Learn JavaFX</tutorial_title>
<submission_date>06-07-2017</submission_date>
<tutorial_icon>https://www.tutorialspoint.com/javafx/images/javafx-minilogo.jpg</tutorial_icon>
<tutorial_description>JavaFX is a Java library used to build Rich Internet Applications.
The applications developed using JavaFX can run on various devices
such as Desktop Computers, Mobile Phones, TVs, Tablets, etc.
This tutorial, discusses all the necessary elements of JavaFX that are required
to develop effective Rich Internet Applications</tutorial_description>
</tutorial>
</tutorials>
Writer − writer アプリケーションで使用しているのは JdbcBatchItemWriterMySQLデータベースにデータを書き込みます。MySQLでというデータベース内にテーブルを作成したと仮定します。"details"。
CREATE TABLE details.TUTORIALS(
tutorial_id int(10) NOT NULL,
tutorial_author VARCHAR(20),
tutorial_title VARCHAR(50),
submission_date VARCHAR(20),
tutorial_icon VARCHAR(200),
tutorial_description VARCHAR(1000)
);
Processor −アプリケーションで使用しているプロセッサは、PDFドキュメントに各レコードのデータを書き込むカスタムプロセッサです。
バッチプロセスでは、 "n"レコードまたはデータ要素が読み取られた後、レコードごとに、データが読み取られて処理され、ライターにデータが書き込まれます。データを処理するために、渡されたプロセッサを中継します。この場合、カスタムプロセッサクラスでは、特定のPDFドキュメントをロードし、新しいページを作成し、データ項目を表形式でPDFに書き込むコードを記述しました。
最後に、このアプリケーションを実行すると、XMLドキュメントからすべてのデータ項目が読み取られ、MySQLデータベースに保存され、指定されたPDFドキュメントの個々のページに出力されます。
jobConfig.xml
以下は、サンプルのSpringBatchアプリケーションの構成ファイルです。このファイルでは、ジョブとステップを定義します。これらに加えて、ItemReader、ItemProcessor、およびItemWriterのBeanも定義します。(ここでは、それらをそれぞれのクラスに関連付け、それらを構成するために必要なプロパティの値を渡します。)
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:batch = "http://www.springframework.org/schema/batch"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns:util = "http://www.springframework.org/schema/util"
xsi:schemaLocation = "http://www.springframework.org/schema/batch
http://www.springframework.org/schema/batch/spring-batch-2.2.xsd
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/util
http://www.springframework.org/schema/util/spring-util-3.0.xsd ">
<import resource = "../jobs/context.xml" />
<bean id = "itemProcessor" class = "CustomItemProcessor" />
<batch:job id = "helloWorldJob">
<batch:step id = "step1">
<batch:tasklet>
<batch:chunk reader = "xmlItemReader" writer = "mysqlItemWriter" processor = "itemProcessor">
</batch:chunk>
</batch:tasklet>
</batch:step>
</batch:job>
<bean id = "xmlItemReader"
class = "org.springframework.batch.item.xml.StaxEventItemReader">
<property name = "fragmentRootElementName" value = "tutorial" />
<property name = "resource" value = "classpath:resources/tutorial.xml" />
<property name = "unmarshaller" ref = "customUnMarshaller" />
</bean>
<bean id = "customUnMarshaller" class = "org.springframework.oxm.xstream.XStreamMarshaller">
<property name = "aliases">
<util:map id = "aliases">
<entry key = "tutorial" value = "Tutorial" />
</util:map>
</property>
</bean>
<bean id = "mysqlItemWriter" class = "org.springframework.batch.item.database.JdbcBatchItemWriter">
<property name = "dataSource" ref = "dataSource" />
<property name = "sql">
<value>
<![CDATA[insert into details.tutorials (tutorial_id, tutorial_author, tutorial_title,
submission_date, tutorial_icon, tutorial_description)
values (:tutorial_id, :tutorial_author, :tutorial_title, :submission_date,
:tutorial_icon, :tutorial_description);]]>
</value>
</property>
<property name = "itemSqlParameterSourceProvider">
<bean class = "org.springframework.batch.item.database.BeanPropertyItemSqlParameterSourceProvider" />
</property>
</bean>
</beans>
Context.xml
以下は context.xmlSpringBatchアプリケーションの このファイルでは、ジョブリポジトリ、ジョブランチャー、トランザクションマネージャーなどのBeanを定義します。
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:jdbc = "http://www.springframework.org/schema/jdbc"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd">
<!-- stored job-meta in database -->
<bean id = "jobRepository"
class = "org.springframework.batch.core.repository.support.JobRepositoryFactoryBean">
<property name = "dataSource" ref = "dataSource" />
<property name = "transactionManager" ref = "transactionManager" />
<property name = "databaseType" value = "mysql" />
</bean>
<bean id = "transactionManager"
class = "org.springframework.batch.support.transaction.ResourcelessTransactionMana ger" />
<bean id = "jobLauncher"
class = "org.springframework.batch.core.launch.support.SimpleJobLauncher">
<property name = "jobRepository" ref = "jobRepository" />
</bean>
<!-- connect to MySQL database -->
<bean id = "dataSource"
class = "org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name = "driverClassName" value = "com.mysql.jdbc.Driver" />
<property name = "url" value = "jdbc:mysql://localhost:3306/details" />
<property name = "username" value = "myuser" />
<property name = "password" value = "password" />
</bean>
<!-- create job-meta tables automatically -->
<jdbc:initialize-database data-source = "dataSource">
<jdbc:script location = "org/springframework/batch/core/schema-drop-mysql.sql"/>
<jdbc:script location = "org/springframework/batch/core/schema-mysql.sql"/>
</jdbc:initialize-database>
</beans>
CustomItemProcessor.java
以下は processorクラス。このクラスでは、アプリケーションで処理のコードを記述します。ここでは、PDFドキュメントをロードし、新しいページを作成し、テーブルを作成し、各レコードに次の値を挿入しています:チュートリアルID、チュートリアル名、作成者、テーブルへの送信日。
import java.io.File;
import java.io.IOException;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDPage;
import org.apache.pdfbox.pdmodel.PDPageContentStream;
import org.apache.pdfbox.pdmodel.font.PDType1Font;
import org.springframework.batch.item.ItemProcessor;
public class CustomItemProcessor implements ItemProcessor<Tutorial, Tutorial> {
public static void drawTable(PDPage page, PDPageContentStream contentStream,
float y, float margin, String[][] content) throws IOException {
final int rows = content.length;
final int cols = content[0].length;
final float rowHeight = 50;
final float tableWidth = page.getMediaBox().getWidth()-(2*margin);
final float tableHeight = rowHeight * rows;
final float colWidth = tableWidth/(float)cols;
final float cellMargin=5f;
// draw the rows
float nexty = y ;
for (int i = 0; i <= rows; i++) {
contentStream.drawLine(margin,nexty,margin+tableWidth,nexty);
nexty-= rowHeight;
}
//draw the columns
float nextx = margin;
for (int i = 0; i <= cols; i++) {
contentStream.drawLine(nextx,y,nextx,y-tableHeight);
nextx += colWidth;
}
// now add the text
contentStream.setFont(PDType1Font.HELVETICA_BOLD,12);
float textx = margin+cellMargin;
float texty = y-15;
for(int i = 0; i < content.length; i++){
for(int j = 0 ; j < content[i].length; j++){
String text = content[i][j];
contentStream.beginText();
contentStream.moveTextPositionByAmount(textx,texty);
contentStream.drawString(text);
contentStream.endText();
textx += colWidth;
}
texty-=rowHeight;
textx = margin+cellMargin;
}
}
@Override
public Tutorial process(Tutorial item) throws Exception {
System.out.println("Processing..." + item);
// Creating PDF document object
PDDocument doc = PDDocument.load(new File("C:/Examples/test.pdf"));
// Creating a blank page
PDPage page = new PDPage();
doc.addPage( page );
PDPageContentStream contentStream = new PDPageContentStream(doc, page);
String[][] content = {{"Id",""+item.getTutorial_id()},
{"Title", item.getTutorial_title()},
{"Authour", item.getTutorial_author()},
{"Submission Date", item.getSubmission_date()}} ;
drawTable(page, contentStream, 700, 100, content);
contentStream.close();
doc.save("C:/Examples/test.pdf" );
System.out.println("Hello");
return item;
}
}
TutorialFieldSetMapper.java
以下は、データをチュートリアルクラスに設定するReportFieldSetMapperクラスです。
import org.springframework.batch.item.file.mapping.FieldSetMapper;
import org.springframework.batch.item.file.transform.FieldSet;
import org.springframework.validation.BindException;
public class TutorialFieldSetMapper implements FieldSetMapper<Tutorial> {
@Override
public Tutorial mapFieldSet(FieldSet fieldSet) throws BindException {
// instantiating the Tutorial class
Tutorial tutorial = new Tutorial();
// Setting the fields from XML
tutorial.setTutorial_id(fieldSet.readInt(0));
tutorial.setTutorial_title(fieldSet.readString(1));
tutorial.setTutorial_author(fieldSet.readString(2));
tutorial.setTutorial_icon(fieldSet.readString(3));
tutorial.setTutorial_description(fieldSet.readString(4));
return tutorial;
}
}
Tutorial.java
以下は Tutorialクラス。シンプルなクラスですsetter そして getter メソッド。
public class Tutorial {
private int tutorial_id;
private String tutorial_author;
private String tutorial_title;
private String submission_date;
private String tutorial_icon;
private String tutorial_description;
@Override
public String toString() {
return " [id=" + tutorial_id + ", author=" + tutorial_author
+ ", title=" + tutorial_title + ", date=" + submission_date + ", icon ="
+tutorial_icon +", description = "+tutorial_description+"]";
}
public int getTutorial_id() {
return tutorial_id;
}
public void setTutorial_id(int tutorial_id) {
this.tutorial_id = tutorial_id;
}
public String getTutorial_author() {
return tutorial_author;
}
public void setTutorial_author(String tutorial_author) {
this.tutorial_author = tutorial_author;
}
public String getTutorial_title() {
return tutorial_title;
}
public void setTutorial_title(String tutorial_title) {
this.tutorial_title = tutorial_title;
}
public String getSubmission_date() {
return submission_date;
}
public void setSubmission_date(String submission_date) {
this.submission_date = submission_date;
}
public String getTutorial_icon() {
return tutorial_icon;
}
public void setTutorial_icon(String tutorial_icon) {
this.tutorial_icon = tutorial_icon;
}
public String getTutorial_description() {
return tutorial_description;
}
public void setTutorial_description(String tutorial_description) {
this.tutorial_description = tutorial_description;
}
}
App.java
以下は、バッチプロセスを起動するコードです。このクラスでは、JobLauncherを実行してバッチアプリケーションを起動します。
public class App {
public static void main(String[] args) throws Exception {
String[] springConfig = { "jobs/job_hello_world.xml" };
// Creating the application context object
ApplicationContext context = new ClassPathXmlApplicationContext(springConfig);
// Creating the job launcher
JobLauncher jobLauncher = (JobLauncher) context.getBean("jobLauncher");
// Creating the job
Job job = (Job) context.getBean("helloWorldJob");
// Executing the JOB
JobExecution execution = jobLauncher.run(job, new JobParameters());
System.out.println("Exit Status : " + execution.getStatus());
}
}
このアプリケーションを実行すると、次の出力が生成されます。
May 05, 2017 4:39:22 PM org.springframework.context.support.ClassPathXmlApplicationContext
prepareRefresh
INFO: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@306a30c7:
startup date [Fri May 05 16:39:22 IST 2017]; root of context hierarchy
May 05, 2017 4:39:23 PM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
May 05, 2017 4:39:32 PM org.springframework.batch.core.job.SimpleStepHandler handleStep
INFO: Executing step: [step1]
Processing... [id=1001, author=Sanjay, title=Learn Java, date=06-05-2007,
icon =https://www.tutorialspoint.com/java/images/java-mini-logo.jpg,
description = Java is a high-level programming language originally developed by Sun Microsystems
and released in 1995. Java runs on a variety of platforms.
This tutorial gives a complete understanding of Java.');]
Hello
Processing.. [id=1002, author=Abdul S, title=Learn MySQL, date=19-04-2007,
icon =https://www.tutorialspoint.com/mysql/images/mysql-mini-logo.jpg,
description = MySQL is the most popular Open Source Relational SQL database management system.
MySQL is one of the best RDBMS being used for developing web-based software applications.
This tutorial will give you quick start with MySQL and make you comfortable with MySQL programming.]
Hello
Processing... [id=1003, author=Krishna Kasyap, title=Learn JavaFX, date=06-072017,
icon =https://www.tutorialspoint.com/javafx/images/javafx-mini-logo.jpg,
description = JavaFX is a Java library used to build Rich Internet Applications.
The applications developed using JavaFX can run on various devices
such as Desktop Computers, Mobile Phones, TVs, Tablets, etc.
This tutorial, discusses all the necessary elements of JavaFX
that are required to develop effective Rich Internet Applications]
Hello
May 05, 2017 4:39:36 PM org.springframework.batch.core.launch.support.SimpleJobLauncher run
INFO: Job: [FlowJob: [name=helloWorldJob]] completed with the following parameters: [{}]
and the following status: [COMPLETED]
Exit Status : COMPLETED
確認した場合 details.tutorial データベース内のテーブルには、次の出力が表示されます-
チュートリアル_id | チュートリアル_author | チュートリアル_title | 提出日 | チュートリアル_icon | チュートリアル_description |
---|---|---|---|---|---|
1001 | サンジェイ | Javaを学ぶ | 2007年6月5日 | https://www.tutorials point.com / java / images / java-mini-logo.jpg | Javaは、もともとSun Microsystemsによって開発され、1995年にリリースされた高水準プログラミング言語です。Javaはさまざまなプラットフォームで実行されます。このチュートリアルでは、Javaを完全に理解できます。 |
1002 | アブドゥルS | MySQLを学ぶ | 2007年4月19日 | https:// www。tutorialspoint.com / mysql / images /mysql-minilogo.jpg | MySQLは、最も人気のあるオープンソースのリレーショナルSQLデータベース管理システムです。MySQLは、Webベースのソフトウェアアプリケーションの開発に使用されている最高のRDBMSの1つです。このチュートリアルでは、MySQLをすばやく開始し、MySQLプログラミングに慣れることができます。 |
1003 | JavaFXを学ぶ | クリシュナカシャップ | 2017年6月7日 | https:// www。tutorialspoint.com / javafx / images / javafx-minilogo.jpg | MySQLは、最も人気のあるオープンソースのリレーショナルSQLデータベース管理システムです。MySQLは、Webベースのソフトウェアアプリケーションの開発に使用されている最高のRDBMSの1つです。このチュートリアルでは、MySQLをすばやく開始し、MySQLプログラミングに慣れることができます。 |
これにより、以下に示すように、各ページのレコードを含むPDFが生成されます。
この章では、CSVリーダーとXMLライターを使用する簡単なSpringBatchアプリケーションを作成します。
Reader − reader アプリケーションで使用しているのは FlatFileItemReader CSVファイルからデータを読み取ります。
以下は、このアプリケーションで使用している入力CSVファイルです。このドキュメントには、チュートリアルID、チュートリアルの作成者、チュートリアルのタイトル、送信日、チュートリアルアイコン、チュートリアルの説明などの詳細を指定するデータレコードが含まれています。
1001, "Sanjay", "Learn Java", 06/05/2007
1002, "Abdul S", "Learn MySQL", 19/04/2007
1003, "Krishna Kasyap", "Learn JavaFX", 06/07/2017
Writer −アプリケーションで使用しているライターは StaxEventItemWriter データをXMLファイルに書き込みます。
Processor −アプリケーションで使用しているプロセッサは、CSVファイルから読み取ったレコードを出力するだけのカスタムプロセッサです。
jobConfig.xml
以下は、サンプルのSpringBatchアプリケーションの構成ファイルです。このファイルでは、ジョブとステップを定義します。これらに加えて、ItemReader、ItemProcessor、およびItemWriterのBeanも定義します。(ここでは、それらをそれぞれのクラスに関連付け、それらを構成するために必要なプロパティの値を渡します。)
<beans xmlns = " http://www.springframework.org/schema/beans"
xmlns:batch = "http://www.springframework.org/schema/batch"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/batch
http://www.springframework.org/schema/batch/spring-batch-2.2.xsd
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">
<import resource = "../jobs/context.xml" />
<bean id = "report" class = "Report" scope = "prototype" />
<bean id = "itemProcessor" class = "CustomItemProcessor" />
<batch:job id = "helloWorldJob">
<batch:step id = "step1">
<batch:tasklet>
<batch:chunk reader = "cvsFileItemReader" writer = "xmlItemWriter"
processor = "itemProcessor" commit-interval = "10">
</batch:chunk>
</batch:tasklet>
</batch:step>
</batch:job>
<bean id = "cvsFileItemReader"
class = "org.springframework.batch.item.file.FlatFileItemReader">
<property name = "resource" value = "classpath:resources/report.csv" />
<property name = "lineMapper">
<bean
class = "org.springframework.batch.item.file.mapping.DefaultLineMapper">
<property name = "lineTokenizer">
<bean
class = "org.springframework.batch.item.file.transform.DelimitedLineTokenizer">
<property name = "names" value = "tutorial_id,
tutorial_author, Tutorial_title, submission_date" />
</bean>
</property>
<property name = "fieldSetMapper">
<bean class = "ReportFieldSetMapper" />
</property>
</bean>
</property>
</bean>
<bean id = "xmlItemWriter"
class = "org.springframework.batch.item.xml.StaxEventItemWriter">
<property name = "resource" value = "file:xml/outputs/tutorials.xml" />
<property name = "marshaller" ref = "reportMarshaller" />
<property name = "rootTagName" value = "tutorials" />
</bean>
<bean id = "reportMarshaller"
class = "org.springframework.oxm.jaxb.Jaxb2Marshaller">
<property name = "classesToBeBound">
<list>
<value>Tutorial</value>
</list>
</property>
</bean>
</beans>
Context.xml
以下は context.xmlSpringBatchアプリケーションの このファイルでは、ジョブリポジトリ、ジョブランチャー、トランザクションマネージャーなどのBeanを定義します。
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:jdbc = "http://www.springframework.org/schema/jdbc"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd">
<!-- stored job-meta in database -->
<bean id = "jobRepository"
class = "org.springframework.batch.core.repository.support.JobRepositoryFactoryBean">
<property name = "dataSource" ref = "dataSource" />
<property name = "transactionManager" ref = "transactionManager" />
<property name = "databaseType" value = "mysql" />
</bean>
<bean id = "transactionManager"
class = "org.springframework.batch.support.transaction.ResourcelessTransactionManager" />
<bean id = "jobLauncher"
class = "org.springframework.batch.core.launch.support.SimpleJobLauncher">
<property name = "jobRepository" ref = "jobRepository" />
</bean>
<bean id = "dataSource" class = "org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name = "driverClassName" value = "com.mysql.jdbc.Driver" />
<property name = "url" value = "jdbc:mysql://localhost:3306/details" />
<property name = "username" value = "myuser" />
<property name = "password" value = "password" />
</bean>
<!-- create job-meta tables automatically -->
<jdbc:initialize-database data-source = "dataSource">
<jdbc:script location = "org/springframework/batch/core/schema-drop-mysql.sql" />
<jdbc:script location = "org/springframework/batch/core/schema-mysql.sql" />
</jdbc:initialize-database>
</beans>
CustomItemProcessor.java
以下はProcessorクラスです。このクラスでは、アプリケーションで処理のコードを記述します。ここでは、各レコードの内容を印刷しています。
import org.springframework.batch.item.ItemProcessor;
public class CustomItemProcessor implements ItemProcessor<Tutorial, Tutorial> {
@Override
public Tutorial process(Tutorial item) throws Exception {
System.out.println("Processing..." + item);
return item;
}
}
TutorialFieldSetMapper.java
以下は、データをチュートリアルクラスに設定するTutorialFieldSetMapperクラスです。
import org.springframework.batch.item.file.mapping.FieldSetMapper;
import org.springframework.batch.item.file.transform.FieldSet;
import org.springframework.validation.BindException;
public class TutorialFieldSetMapper implements FieldSetMapper<Tutorial> {
@Override
public Tutorial mapFieldSet(FieldSet fieldSet) throws BindException {
//Instantiating the report object
Tutorial tutorial = new Tutorial();
//Setting the fields
tutorial.setTutorial_id(fieldSet.readInt(0));
tutorial.setTutorial_author(fieldSet.readString(1));
tutorial.setTutorial_title(fieldSet.readString(2));
tutorial.setSubmission_date(fieldSet.readString(3));
return tutorial;
}
}
Tutorial.javaクラス
以下は Tutorialクラス。これは単純なJavaクラスです。setter そして getterメソッド。このクラスでは、アノテーションを使用して、このクラスのメソッドをXMLファイルのタグに関連付けています。
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
@XmlRootElement(name = "tutorial")
public class Tutorial {
private int tutorial_id;
private String tutorial_author;
private String tutorial_title;
private String submission_date;
@XmlAttribute(name = "tutorial_id")
public int getTutorial_id() {
return tutorial_id;
}
public void setTutorial_id(int tutorial_id) {
this.tutorial_id = tutorial_id;
}
@XmlElement(name = "tutorial_author")
public String getTutorial_author() {
return tutorial_author;
}
public void setTutorial_author(String tutorial_author) {
this.tutorial_author = tutorial_author;
}
@XmlElement(name = "tutorial_title")
public String getTutorial_title() {
return tutorial_title;
}
public void setTutorial_title(String tutorial_title) {
this.tutorial_title = tutorial_title;
}
@XmlElement(name = "submission_date")
public String getSubmission_date() {
return submission_date;
}
public void setSubmission_date(String submission_date) {
this.submission_date = submission_date;
}
@Override
public String toString() {
return " [Tutorial id=" + tutorial_id + ",
Tutorial Author=" + tutorial_author + ",
Tutorial Title=" + tutorial_title + ",
Submission Date=" + submission_date + "]";
}
}
App.java
以下は、バッチプロセスを起動するコードです。このクラスでは、JobLauncherを実行してバッチアプリケーションを起動します。
import org.springframework.batch.core.Job;
import org.springframework.batch.core.JobExecution;
import org.springframework.batch.core.JobParameters;
import org.springframework.batch.core.launch.JobLauncher;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class App {
public static void main(String[] args) throws Exception {
String[] springConfig = { "jobs/job_hello_world.xml" };
// Creating the application context object
ApplicationContext context = new ClassPathXmlApplicationContext(springConfig);
// Creating the job launcher
JobLauncher jobLauncher = (JobLauncher) context.getBean("jobLauncher");
// Creating the job
Job job = (Job) context.getBean("helloWorldJob");
// Executing the JOB
JobExecution execution = jobLauncher.run(job, new JobParameters());
System.out.println("Exit Status : " + execution.getStatus());
}
}
このアプリケーションを実行すると、次の出力が生成されます。
May 08, 2017 10:10:12 AM org.springframework.context.support.ClassPathXmlApplicationContext prepareRefresh
INFO: Refreshing
org.springframework.context.support.ClassPathXmlApplicationContext@3d646c37: startup date
[Mon May 08 10:10:12 IST 2017]; root of context hierarchy
May 08, 2017 10:10:12 AM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
May 08, 2017 10:10:15 AM org.springframework.jdbc.datasource.init.ScriptUtils executeSqlScript
INFO: Executing step: [step1]
Processing... [Tutorial id=1001, Tutorial Author=Sanjay,
Tutorial Title=Learn Java, Submission Date=06/05/2007]
Processing... [Tutorial id=1002, Tutorial Author=Abdul S,
Tutorial Title=Learn MySQL, Submission Date=19/04/2007]
Processing... [Tutorial id=1003, Tutorial Author=Krishna Kasyap,
Tutorial Title=Learn JavaFX, Submission Date=06/07/2017]
May 08, 2017 10:10:21 AM org.springframework.batch.core.launch.support.SimpleJobLauncher run
INFO: Job: [FlowJob: [name=helloWorldJob]] completed with the following parameters:
[{}] and the following status: [COMPLETED]
Exit Status : COMPLETED
これにより、次の内容のXMLファイルが生成されます。
<?xml version = "1.0" encoding = "UTF-8"?>
<tutorials>
<tutorial tutorial_id = "1001">
<submission_date>06/05/2007</submission_date>
<tutorial_author>Sanjay</tutorial_author>
<tutorial_title>Learn Java</tutorial_title>
</tutorial>
<tutorial tutorial_id = "1002">
<submission_date>19/04/2007</submission_date>
<tutorial_author>Abdul S</tutorial_author>
<tutorial_title>Learn MySQL</tutorial_title>
</tutorial>
<tutorial tutorial_id = "1003">
<submission_date>06/07/2017</submission_date>
<tutorial_author>Krishna Kasyap</tutorial_author>
<tutorial_title>Learn JavaFX</tutorial_title>
</tutorial>
</tutorials>
この章では、MySQLリーダーとXMLライターを使用するSpringBatchアプリケーションを作成します。
Reader −アプリケーションで使用しているリーダーは JdbcCursorItemReader MySQLデータベースからデータを読み取ります。
以下に示すように、MySQLデータベースにテーブルを作成したと仮定します-
CREATE TABLE details.xml_mysql(
person_id int(10) NOT NULL,
sales VARCHAR(20),
qty int(3),
staffName VARCHAR(20),
date VARCHAR(20)
);
以下のレコードを挿入したと仮定します。
mysql> select * from tutorialsdata;
+-------------+-----------------+----------------+-----------------+
| tutorial_id | tutorial_author | tutorial_title | submission_date |
+-------------+-----------------+----------------+-----------------+
| 101 | Sanjay | Learn Java | 06-05-2007 |
| 102 | Abdul S | Learn MySQL | 19-04-2007 |
| 103 | Krishna Kasyap | Learn JavaFX | 06-07-2017 |
+-------------+-----------------+----------------+-----------------+
3 rows in set (0.00 sec)
Writer −アプリケーションで使用しているライターは StaxEventItemWriter XMLファイルにデータを書き込みます。
Processor −アプリケーションで使用しているプロセッサは、CSVファイルから読み取ったレコードを出力するだけのカスタムプロセッサです。
jobConfig.xml
以下は、サンプルのSpringBatchアプリケーションの構成ファイルです。このファイルでは、ジョブとステップを定義します。これらに加えて、ItemReader、ItemProcessor、およびItemWriterのBeanも定義します。(ここでは、それらをそれぞれのクラスに関連付け、それらを構成するために必要なプロパティの値を渡します。)
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:batch = "http://www.springframework.org/schema/batch"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns:util = "http://www.springframework.org/schema/util"
xsi:schemaLocation = " http://www.springframework.org/schema/batch
http://www.springframework.org/schema/batch/spring-batch-2.2.xsd
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">
<import resource = "../jobs/context.xml" />
<bean id = "report" class = "Report" scope = "prototype" />
<bean id = "itemProcessor" class = "CustomItemProcessor" />
<batch:job id = "helloWorldJob">
<batch:step id = "step1">
<batch:tasklet>
<batch:chunk reader = "dbItemReader"
writer = "mysqlItemWriter" processor = "itemProcessor" commit-interval = "10">
</batch:chunk>
</batch:tasklet>
</batch:step>
</batch:job>
<bean id = "dbItemReader"
class = "org.springframework.batch.item.database.JdbcCursorItemReader" scope = "step">
<property name = "dataSource" ref = "dataSource" />
<property name = "sql" value = "select * from tutorials_data" />
<property name = "rowMapper">
<bean class = "TutorialRowMapper" />
</property>
</bean>
<bean id = "mysqlItemWriter"
class = "org.springframework.batch.item.xml.StaxEventItemWriter">
<property name = "resource" value = "file:xml/outputs/tutorials.xml" />
<property name = "marshaller" ref = "reportMarshaller" />
<property name = "rootTagName" value = "Tutorial" />
</bean>
<bean id = "reportMarshaller" class = "org.springframework.oxm.jaxb.Jaxb2Marshaller">
<property name = "classesToBeBound">
<list>
<value>Tutorial</value>
</list>
</property>
</bean>
</beans>
Context.xml
以下は context.xmlSpringBatchアプリケーションの このファイルでは、ジョブリポジトリ、ジョブランチャー、トランザクションマネージャーなどのBeanを定義します。
<beans xmlns = " http://www.springframework.org/schema/beans"
xmlns:jdbc = "http://www.springframework.org/schema/jdbc"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd ">
<!-- stored job-meta in database -->
<bean id = "jobRepository"
class = "org.springframework.batch.core.repository.support.JobRepositoryFactoryBean">
<property name = "dataSource" ref = "dataSource" />
<property name = "transactionManager" ref = "transactionManager" />
<property name = "databaseType" value = "mysql" />
</bean>
<bean id = "transactionManager"
class = "org.springframework.batch.support.transaction.ResourcelessTransactionMana ger" />
<bean id = "jobLauncher"
class = "org.springframework.batch.core.launch.support.SimpleJobLauncher">
<property name = "jobRepository" ref = "jobRepository" />
</bean>
<!-- connect to MySQL database -->
<bean id = "dataSource"
class = "org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name = "driverClassName" value = "com.mysql.jdbc.Driver" />
<property name = "url" value = "jdbc:mysql://localhost:3306/details" />
<property name = "username" value = "myuser" />
<property name = "password" value = "password" />
</bean>
<!-- create job-meta tables automatically -->
<jdbc:initialize-database data-source = "dataSource">
<jdbc:script location = "org/springframework/batch/core/schema-drop-mysql.sql" />
<jdbc:script location = "org/springframework/batch/core/schema-mysql.sql" />
</jdbc:initialize-database>
</beans>
CustomItemProcessor.java
以下はProcessorクラスです。このクラスでは、アプリケーションで処理のコードを記述します。ここでは、各レコードの内容を印刷しています。
import org.springframework.batch.item.ItemProcessor;
public class CustomItemProcessor implements ItemProcessor<Tutorial, Tutorial> {
@Override
public Tutorial process(Tutorial item) throws Exception {
System.out.println("Processing..." + item);
return item;
}
}
TutorialRowMapper.java
以下は TutorialRowMapper データをに設定するクラス Tutorial クラス。
import java.sql.ResultSet;
import java.sql.SQLException;
import org.springframework.jdbc.core.RowMapper;
public class TutorialRowMapper implements RowMapper<Tutorial> {
@Override
public Tutorial mapRow(ResultSet rs, int rowNum) throws SQLException {
Tutorial tutorial = new Tutorial();
tutorial.setTutorial_id(rs.getInt("tutorial_id"));
tutorial.setTutorial_author(rs.getString("tutorial_author"));
tutorial.setTutorial_title(rs.getString("tutorial_title"));
tutorial.setSubmission_date(rs.getString("submission_date"));
return tutorial;
}
}
Tutorial.java
以下は Tutorialクラス。これは単純なJavaクラスです。setter そして getterメソッド。このクラスでは、アノテーションを使用して、このクラスのメソッドをXMLファイルのタグに関連付けています。
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
@XmlRootElement(name = "details")
public class Tutorial {
int tutorial_id;
String tutorial_author;
String submission_date;
@XmlAttribute(name = "tutorial_id")
public int getTutorial_id() {
return tutorial_id;
}
public void setTutorial_id(int tutorial_id) {
this.tutorial_id = tutorial_id;
}
@XmlElement(name = "tutorial_author")
public String getTutorial_author() {
return tutorial_author;
}
public void setTutorial_author(String tutorial_author) {
this.tutorial_author = tutorial_author;
}
@XmlElement(name = "tutorial_title")
public String getTutorial_title() {
return tutorial_title;
}
public void setTutorial_title(String tutorial_title) {
this.tutorial_title = tutorial_title;
}
@XmlElement(name = "submission_date")
public String getSubmission_date() {
return submission_date;
}
public void setSubmission_date(String submission_date) {
this.submission_date = submission_date;
}
public String toString() {
return " [Tutorial Id=" + tutorial_id + ",
Tutorial Author =" + tutorial_author + ",
Tutorial Title =" + tutorial_title + ",
Submission Date =" + submission_date + "]";
}
}
App.java
以下は、バッチプロセスを起動するコードです。このクラスでは、JobLauncherを実行してバッチアプリケーションを起動します。
import org.springframework.batch.core.Job;
import org.springframework.batch.core.JobExecution;
import org.springframework.batch.core.JobParameters;
import org.springframework.batch.core.launch.JobLauncher;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class App {
public static void main(String[] args) throws Exception {
String[] springConfig = { "jobs/job_hello_world.xml" };
// Creating the application context object
ApplicationContext context = new ClassPathXmlApplicationContext(springConfig);
// Creating the job launcher
JobLauncher jobLauncher = (JobLauncher) context.getBean("jobLauncher");
// Creating the job
Job job = (Job) context.getBean("helloWorldJob");
// Executing the JOB
JobExecution execution = jobLauncher.run(job, new JobParameters());
System.out.println("Exit Status : " + execution.getStatus());
}
}
このアプリケーションを実行すると、次の出力が生成されます。
May 08, 2017 11:32:06 AM org.springframework.context.support.ClassPathXmlApplicationContext prepareRefresh
INFO: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@3d646c37:
startup date [Mon May 08 11:32:06 IST 2017]; root of context hierarchy
May 08, 2017 11:32:06 AM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
INFO: Loading XML bean definitions from class path resource [jobs/job_hello_world.xml]
May 08, 2017 11:32:07 AM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
May 08, 2017 11:32:14 AM org.springframework.batch.core.job.SimpleStepHandler handleStep
INFO: Executing step: [step1]
Processing... [Tutorial Id=101, Tutorial Author=Sanjay,
Tutorial Title=Learn Java, Submission Date=06-05-2007]
Processing... [Tutorial Id=102, Tutorial Author=Abdul S,
Tutorial Title=Learn MySQL, Submission Date=19-04-2007]
Processing... [Tutorial Id=103, Tutorial Author=Krishna Kasyap,
Tutorial Title=Learn JavaFX, Submission Date=06-07-2017]
May 08, 2017 11:32:14 AM org.springframework.batch.core.launch.support.SimpleJobLauncher run
INFO: Job: [FlowJob: [name=helloWorldJob]] completed with the following parameters:
[{}] and the following status: [COMPLETED]
Exit Status : COMPLETED
これにより、次の内容のXMLファイルが生成されます。
<?xml version = "1.0" encoding = "UTF-8"?>
<Tutorial>
<details tutorial_id = "101">
<submission_date>06-05-2007</submission_date>
<tutorial_author>Sanjay</tutorial_author>
<tutorial_title>Learn Java</tutorial_title>
</details>
<details tutorial_id = "102">
<submission_date>19-04-2007</submission_date>
<tutorial_author>Abdul S</tutorial_author>
<tutorial_title>Learn MySQL</tutorial_title>
</details>
<details tutorial_id = "103">
<submission_date>06-07-2017</submission_date>
<tutorial_author>Krishna Kasyap</tutorial_author>
<tutorial_title>Learn JavaFX</tutorial_title>
</details>
</Tutorial>
この章では、MySQLリーダーとを使用するSpringBatchアプリケーションを作成します。 Flatfile ライター(.txt)。
Reader −アプリケーションで使用しているリーダーは JdbcCursorItemReader MySQLデータベースからデータを読み取ります。
以下に示すように、MySQLデータベースにテーブルを作成したと仮定します。
CREATE TABLE details.xml_mysql(
person_id int(10) NOT NULL,
sales VARCHAR(20),
qty int(3),
staffName VARCHAR(20),
date VARCHAR(20)
);
次のレコードを挿入したと仮定します。
mysql> select * from tutorialsdata;
+-------------+-----------------+----------------+-----------------+
| tutorial_id | tutorial_author | tutorial_title | submission_date |
+-------------+-----------------+----------------+-----------------+
| 101 | Sanjay | Learn Java | 06-05-2007 |
| 102 | Abdul S | Learn MySQL | 19-04-2007 |
| 103 | Krishna Kasyap | Learn JavaFX | 06-07-2017 |
+-------------+-----------------+----------------+-----------------+
3 rows in set (0.00 sec)
Writer −アプリケーションで使用しているライターは FlatFileItemWriter データを書き込む flatfile (。txt)。
Processor −アプリケーションで使用しているプロセッサは、CSVファイルから読み取ったレコードを出力するだけのカスタムプロセッサです。
jobConfig.xml
以下は、サンプルのSpringBatchアプリケーションの構成ファイルです。このファイルでは、ジョブとステップを定義します。これらに加えて、ItemReader、ItemProcessor、およびItemWriterのBeanも定義します。(ここでは、それらをそれぞれのクラスに関連付け、それらを構成するために必要なプロパティの値を渡します。)
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:batch = "http://www.springframework.org/schema/batch"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns:util = "http://www.springframework.org/schema/util"
xsi:schemaLocation = "http://www.springframework.org/schema/batch
http://www.springframework.org/schema/batch/spring-batch-2.2.xsd
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">
<import resource = "../jobs/context.xml" />
<bean id = "tutorial" class = "Tutorial" scope = "prototype" />
<bean id = "itemProcessor" class = "CustomItemProcessor" />
<batch:job id = "helloWorldJob">
<batch:step id = "step1">
<batch:tasklet>
<batch:chunk reader = "mysqlItemReader"
writer = "flatFileItemWriter" processor = "itemProcessor"
commit-interval = "10">
</batch:chunk>
</batch:tasklet>
</batch:step>
</batch:job>
<bean id = "mysqlItemReader"
class = "org.springframework.batch.item.database.JdbcCursorItemReader" >
<property name = "dataSource" ref = "dataSource" />
<property name = "sql" value = "select * from details.tutorialsdata" />
<property name = "rowMapper">
<bean class = "TutorialRowMapper" />
</property>
</bean>
<bean id = "flatFileItemWriter"
class = " org.springframework.batch.item.file.FlatFileItemWriter">
<property name = "resource" value = "file:target/outputfiles/employee_output.txt"/>
<property name = "lineAggregator">
<bean class = " org.springframework.batch.item.file.transform.PassThroughLineAggregator"/>
</property>
</bean>
</beans>
Context.xml
以下は context.xmlSpringBatchアプリケーションの このファイルでは、ジョブリポジトリ、ジョブランチャー、トランザクションマネージャーなどのBeanを定義します。
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns:jdbc = "http://www.springframework.org/schema/jdbc"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd ">
<!-- stored job-meta in database -->
<bean id = "jobRepository"
class = "org.springframework.batch.core.repository.support.JobRepositoryFactoryBean">
<property name = "dataSource" ref = "dataSource" />
<property name = "transactionManager" ref = "transactionManager" />
<property name = "databaseType" value = "mysql" />
</bean>
<bean id = "transactionManager"
class = "org.springframework.batch.support.transaction.ResourcelessTransactionManager" />
<bean id = "dataSource"
class = "org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name = "driverClassName" value = "com.mysql.jdbc.Driver" />
<property name = "url" value = "jdbc:mysql://localhost:3306/details" />
<property name = "username" value = "myuser" />
<property name = "password" value = "password" />
</bean>
<bean id = "jobLauncher"
class = "org.springframework.batch.core.launch.support.SimpleJobLauncher">
<property name = "jobRepository" ref = "jobRepository" />
</bean>
<!-- create job-meta tables automatically -->
<jdbc:initialize-database data-source = "dataSource">
<jdbc:script location = "org/springframework/batch/core/schema-drop-mysql.sql" />
<jdbc:script location = "org/springframework/batch/core/schema-mysql.sql" />
</jdbc:initialize-database>
</beans>
CustomItemProcessor.java
以下はProcessorクラスです。このクラスでは、アプリケーションで処理のコードを記述します。ここでは、各レコードの内容を印刷しています。
import org.springframework.batch.item.ItemProcessor;
// Implementing the ItemProcessor interface
public class CustomItemProcessor implements ItemProcessor<Tutorial, Tutorial> {
@Override
public Tutorial process(Tutorial item) throws Exception {
System.out.println("Processing..." + item);
return item;
}
}
TutorialRowMapper.java
以下は TutorialRowMapper データをに設定するクラス Tutorial クラス。
public class TutorialRowMapper implements RowMapper<Tutorial> {
@Override
public Tutorial mapRow(ResultSet rs, int rowNum) throws SQLException {
Tutorial tutorial = new Tutorial();
tutorial.setTutorial_id(rs.getInt("tutorial_id"));
tutorial.setTutorial_title(rs.getString("tutorial_title"));
tutorial.setTutorial_author(rs.getString("tutorial_author"));
tutorial.setSubmission_date(rs.getString("submission_date"));
return tutorial;
}
}
Tutorial.java
以下は Tutorialクラス。これは単純なJavaクラスです。setter そして getterメソッド。このクラスでは、アノテーションを使用して、このクラスのメソッドをXMLファイルのタグに関連付けています。
public class Tutorial {
private int tutorial_id;
private String tutorial_title;
private String tutorial_author;
private String submission_date;
public int getTutorial_id() {
return tutorial_id;
}
public void setTutorial_id(int tutorial_id) {
this.tutorial_id = tutorial_id;
}
public String getTutorial_title() {
return tutorial_title;
}
public void setTutorial_title(String tutorial_title) {
this.tutorial_title = tutorial_title;
}
public String getTutorial_author() {
return tutorial_author;
}
public void setTutorial_author(String tutorial_author) {
this.tutorial_author = tutorial_author;
}
public String getSubmission_date() {
return submission_date;
}
public void setSubmission_date(String submission_date) {
this.submission_date = submission_date;
}
@Override
public String toString() {
return " [id=" + tutorial_id + ", title=" +
tutorial_title + ",
author=" + tutorial_author + ", date=" +
submission_date + "]";
}
}
App.java
以下は、バッチプロセスを起動するコードです。このクラスでは、JobLauncherを実行してバッチアプリケーションを起動します。
import org.springframework.batch.core.Job;
import org.springframework.batch.core.JobExecution;
import org.springframework.batch.core.JobParameters;
import org.springframework.batch.core.launch.JobLauncher;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class App {
public static void main(String[] args) throws Exception {
String[] springConfig = { "jobs/job_hello_world.xml" };
// Creating the application context object
ApplicationContext context = new ClassPathXmlApplicationContext(springConfig);
// Creating the job launcher
JobLauncher jobLauncher = (JobLauncher) context.getBean("jobLauncher");
// Creating the job
Job job = (Job) context.getBean("helloWorldJob");
// Executing the JOB
JobExecution execution = jobLauncher.run(job, new JobParameters());
System.out.println("Exit Status : " + execution.getStatus());
}
}
このアプリケーションを実行すると、次の出力が生成されます。
May 09, 2017 5:44:48 PM org.springframework.context.support.ClassPathXmlApplicationContext prepareRefresh
INFO: Refreshing org.springframework.context.support.ClassPathXml
ApplicationContext@3d646c37: startup date [Tue May
09 17:44:48 IST 2017]; root of context hierarchy
May 09, 2017 5:44:48 PM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
May 09, 2017 5:44:56 PM org.springframework.batch.core.launch.support.SimpleJobLauncher run
INFO: Job: [FlowJob: [name=helloWorldJob]] launched
with the following parameters: [{}]
May 09, 2017 5:44:56 PM org.springframework.batch.core.job.SimpleStepHandler handleStep
INFO: Executing step: [step1]
Processing...Report [id=101, title=Learn Java, author=Sanjay, date=06-05-2007]
Processing...Report [id=102, title=Learn MySQL, author=Abdul S, date=19-04-2007]
Processing...Report [id=103, title=Learn JavaFX, author=Krishna Kasyap, date=0607-2017]
May 09, 2017 5:44:57 PM org.springframework.batch.core.launch.support.SimpleJobLauncher run
INFO: Job: [FlowJob: [name=helloWorldJob]] completed with the following parameters:
[{}] and the following status: [COMPLETED]
Hello
Exit Status : COMPLETED
これにより、 .txt 以下の内容のファイル。
Report [id=101, title=Learn Java, author=Sanjay, date=06-05-2007]
Report [id=102, title=Learn MySQL, author=Abdul S, date=19-04-2007]
Report [id=103, title=Learn JavaFX, author=Krishna Kasyap, date=06-07-2017]