nimbus (1.2.4) | 2018-01-25 20:02 |
nimbus-sample (1.2.4) | 2018-01-26 17:06 |
jp.ossc.nimbus.service.scheduler2.ConcentrateScheduleExecutorServiceは、業務フローを使ってスケジュールされた集配信処理を実行するScheduleExecutor実装サービスです。
ここで言う集配信処理とは、FTPを代表とするデータ転送プロトコルを使って、データを配信(FTPではPUT)または収集(FTPではGET)するバッチ処理の事です。
このScheduleExecutorは、一定のフォーマット("GET|PUT,source,destination")で記述されたスケジュールの入力文字列を解析し、ConcentrateRequestに変換します。また、スケジュールの出力にはConcentrateResponseを設定し、業務フローに渡します。
業務フローでは、スケジュールの入力に設定されたConcentrateRequestから、集配信の種別(配信または収集)と、集配信元のパス情報、集配信先のパス情報を受け取り、集配信を行います。
同時に、集配信したデータをファイルとして一時保存して、ConcentrateResponseに登録します。
ConcentrateResponseに登録されたファイルをConcentrateBackupManagerに渡して、バックアップします。
このサービスは、複合的なサービスで、以下のサービスを下位サービスとして使用します。
下位サービスインタフェース | 用途 |
jp.ossc.nimbus.service.scheduler2.ScheduleManager | スケジュールの状態を変更する。 |
jp.ossc.nimbus.service.beancontrol.BeanFlowInvokerFactory | 業務フローを取得する。 |
jp.ossc.nimbus.service.scheduler2.ConcentrateBackupManager | 集配信データファイルをバックアップする |
以下に簡単なサービス定義を示します。
- <?xml version="1.0" encoding="Shift_JIS"?>
- <!DOCTYPE server PUBLIC
- "-//Nimbus//DTD Nimbus 1.0//JA"
- "http://nimbus.sourceforge.jp/dtd/nimbus-service_1_0.dtd">
- <server>
- <manager>
- <!-- ScheduleExecutorサービス -->
- <service name="ScheduleExecutor"
- code="jp.ossc.nimbus.service.scheduler2.ConcentrateScheduleExecutorService">
- <!-- ScheduleManagerサービスのサービス名を設定する -->
- <attribute name="ScheduleManagerServiceName">#ScheduleManager</attribute>
- <!-- BeanFlowInvokerFactoryサービスのサービス名を設定する -->
- <attribute name="BeanFlowInvokerFactoryServiceName">#BeanFlowInvokerFactory</attribute>
- <!-- ConcentrateBackupManagerサービスのサービス名を設定する -->
- <attribute name="ConcentrateBackupManagerServiceName">#ConcentrateBackupManager</attribute>
- <depends>ScheduleManager</depends>
- <depends>BeanFlowInvokerFactory</depends>
- <depends>ConcentrateBackupManager</depends>
- </service>
- <!-- ScheduleManagerサービス -->
- <service name="ScheduleManager"
- code="jp.ossc.nimbus.service.scheduler2.DefaultScheduleManagerService">
- <attribute name="ScheduleMasterServiceNames">
- #ScheduleMaster1
- #ScheduleMaster2
- #ScheduleMaster3
- #ScheduleMaster4
- </attribute>
- <attribute name="PersistDir">./schedule</attribute>
- <depends>
- <!-- スケジュールマスタ1
- 08:00:00にFlow1を実行するスケジュール
- -->
- <service name="ScheduleMaster1"
- code="jp.ossc.nimbus.service.scheduler2.DefaultScheduleMaster">
- <attribute name="Id">Schedule1</attribute>
- <attribute name="TaskName">Flow1</attribute>
- <attribute name="StartTime">// 08:00:00 000</attribute>
- </service>
- </depends>
- <depends>
- <!-- スケジュールマスタ2
- スケジュールマスタ1の終了を待って、08:00:00にFlow2を実行するスケジュール
- -->
- <service name="ScheduleMaster2"
- code="jp.ossc.nimbus.service.scheduler2.DefaultScheduleMaster">
- <attribute name="Id">Schedule2</attribute>
- <attribute name="TaskName">Flow2</attribute>
- <attribute name="StartTime">// 08:00:00 000</attribute>
- <attribute name="Input">100</attribute>
- <attribute name="Depends">Schedule1</attribute>
- </service>
- </depends>
- <depends>
- <!-- スケジュールマスタ3
- スケジュールマスタ2の終了を待って、08:01:00から08:02:00まで5秒間隔にFlow3を実行するスケジュール
- -->
- <service name="ScheduleMaster3"
- code="jp.ossc.nimbus.service.scheduler2.DefaultScheduleMaster">
- <attribute name="Id">Schedule3</attribute>
- <attribute name="TaskName">Flow3</attribute>
- <attribute name="StartTime">// 08:01:00 000</attribute>
- <attribute name="EndTime">// 08:02:00 000</attribute>
- <attribute name="RepeatInterval">5000</attribute>
- <attribute name="Depends">Schedule2</attribute>
- </service>
- </depends>
- <depends>
- <!-- スケジュールマスタ4
- スケジュールマスタ1とスケジュールマスタ3の終了を待って、08:00:00から08:03:00までFlow4の結果でリトライを指示される限り、10秒間隔でFlow4を実行するスケジュール
- 08:03:00に達しても、リトライを指示された場合は、エラー終了する
- -->
- <service name="ScheduleMaster4"
- code="jp.ossc.nimbus.service.scheduler2.DefaultScheduleMaster">
- <attribute name="Id">Schedule4</attribute>
- <attribute name="TaskName">Flow4</attribute>
- <attribute name="StartTime">// 08:00:00 000</attribute>
- <attribute name="Depends">Schedule1,Schedule3</attribute>
- <attribute name="RetryInterval">10000</attribute>
- <attribute name="RetryEndTime">// 08:03:00 000</attribute>
- </service>
- </depends>
- </service>
- <!-- BeanFlowInvokerを生成するBeanFlowInvokerFactoryサービス -->
- <service name="BeanFlowInvokerFactory"
- code="jp.ossc.nimbus.service.beancontrol.DefaultBeanFlowInvokerFactoryService">
- <attribute name="DirPaths">flows</attribute>
- <attribute name="BeanFlowInvokerAccessClass">jp.ossc.nimbus.service.beancontrol.BeanFlowInvokerAccessImpl2</attribute>
- <attribute name="Validate">true</attribute>
- </service>
- <!-- 集配信データファイルをバックアップするConcentrateBackupManagerサービス -->
- <service name="ConcentrateBackupManager"
- code="jp.ossc.nimbus.service.scheduler2.FileConcentrateBackupManagerService">
- <attribute name="BackupDirectory(">backup</attribute>
- </service>
- </manager>
- </server>
jp.ossc.nimbus.service.scheduler2.ConcentrateBackupManagerは、集配信スケジュールで集配信したデータファイルをバックアップする機能を抽象化したインタフェースです。
このインタフェースの実装サービスは、下位サービスで、以下の上位サービスから使用します。
上位サービス | 用途 |
jp.ossc.nimbus.service.scheduler2.ConcentrateScheduleExecutorService | 集配信したデータファイルをバックアップするために使用する |
実装サービスの一覧は以下のとおりです。
実装サービス | 実装概要 |
jp.ossc.nimbus.service.scheduler2.FileConcentrateBackupManagerService | 集配信したデータファイルをファイルとしてバックアップディレクトリに退避する |