LoginSignup
2
3

More than 3 years have passed since last update.

【SFDC】バッチ処理をチェーン化してみる

Posted at

概要

SalesforceではAPEXバッチ処理をスケジュール出来る上限が100件までと決まっている。
似たような処理や依存性のある処理を登録していると意外に上限まで行ってしまう。
そこで、バッチ処理を連結させてスケジューリング枠を減らす方法を考えてみた。

まあ、普通は100件行く前にリファクタや処理を見直すのが正しい施策とは思うが・・・

早速やってみた

public class hogeBatch implements Database.Batchable<sObject>, Schedulable {
  public void start() {
    ~略~
  }

  public void finish(Database.BatchableContext BC) {
    ChainSettings__mdt cs = [select batchNames__c from ChainSettings__mdt where DeveloperName = 'hogehoge'][0];
    List<String> names = cs. batchNames__c;
    String nextBatchName = '';
    for (Integer i = 0; i < names.size(); i++) {
      String batchName = names.get(i);
      if (batchName == this.class.getName()) {
        if (names.size() > (i + 1)) {
          nextBatchName = names.get(i + 1);
        }
      }
    }
    if (String.isNotEmpty(nextBatchName)) {
      if (Test.isRunningTest()) return; // Testクラス実行時は稼働させない
      Batchable nextBatch = Type.forName(nextBatchName).newInstance();
      Database.executeBatch(nextBatch, 200);
  }
}

こんな感じ。
この処理で肝となるのは、「カスタムメタデータ型のリストを使う」点です。
カスタムメタデータ型の使い方などはこちらをどうぞ

カスタムメタデータ型の設定

まずは 設定 > カスタムメタデータ型 > 新規作成で適当に作成

screencapture-sochi-dev-ed-lightning-force-lightning-setup-CustomMetadata-page-2019-07-14-22_38_24.png

カスタム項目を作成する

  • 複数のバッチクラスを自由記述したいので、ロングテキストエリアを選択。
    screencapture-sochi-dev-ed-lightning-force-lightning-setup-CustomMetadata-page-2019-07-14-22_39_21.png

  • 名前などを設定
    screencapture-sochi-dev-ed-lightning-force-lightning-setup-CustomMetadata-page-2019-07-14-22_40_37.png

  • 保存
    screencapture-sochi-dev-ed-lightning-force-lightning-setup-CustomMetadata-page-2019-07-14-22_41_07.png

レコードを作成

  • リストビューから、「レコードの管理」をクリック
    screencapture-sochi-dev-ed-lightning-force-lightning-setup-CustomMetadata-home-2019-07-14-22_41_48.png

  • 「新規」ボタンをクリック
    screencapture-sochi-dev-ed-lightning-force-lightning-setup-CustomMetadata-page-2019-07-14-22_42_07.png

  • レコード情報設定で、「batchNames」にチェーン化したいバッチクラスをカンマ区切りで入力し、保存
    screencapture-sochi-dev-ed-lightning-force-lightning-setup-CustomMetadata-page-2019-07-14-22_43_11.png

以上

まとめ

この方法を使うことで、以下のメリットが得られます
- SF上のスケジュール数を抑えることが出来るので、より多くのバッチ処理を稼働させられる
- チェーン化したいバッチが増減した時、カスタムメタデータの値を変更するだけで済む(Apex修正不要)
- updateやdeleteなど、処理タイプごとにチェーン対象をレコードで切り分けられる
など。
まぁ、バッチの並行稼働数や一日の稼働上限なども設けられているため、無制限に増やすことは出来ないが、
スケジュール時に「この時間帯が埋まって新規登録出来ない!」が無くなるのは大きな利点かな。
1つ1つのバッチ時間が意外と短かったりすると、無駄なスケジューリングバッファ取られることになるからね。。。

2
3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
3