0
0

More than 1 year has passed since last update.

Delta Live Tablesの強化オートスケーリングによる高信頼かつコスト効率の高いストリーミングデータパイプラインの構築

Posted at

Build Reliable and Cost Effective Streaming Data Pipelines With Delta Live Tables’ Enhanced Autoscaling - The Databricks Blogの翻訳です。

本書は抄訳であり内容の正確性を保証するものではありません。正確な内容に関しては原文を参照ください。

我々は、信頼性のあるデータパイプラインの構築にシンプルかつ宣言型のアプローチを用いる市場初のETLフレームワークである、Delta Live Tables (DLT)の正式提供を今年発表しました。ローンチ以来、Databricksは新機能でDLTを拡張し続けてきています。本日、Delta Live Tables (DLT)の強化オートスケーリングの正式提供を発表できることを嬉しく思っています。アナリストやデータエンジニアは、プロダクションで利用できるストリーミングデータパイプラインやバッチデータパイプラインをクイックに作成するためにDLTを活用することができます。SQLあるいはPythonを用いてデータに対して実行する変換処理を定義するだけでよく、DLTはパイプラインの依存関係を理解し、計算資源管理、モニタリング、データ品質、エラーハンドリングを自動化します。

DLTの強化オートスケーリングは、スパイクがあり予測不可能なストリーミングワークロードを取り扱うために設計されています。あなたのデータパイプラインが一貫性のあるSLAを維持するために必要なリソースを保証しつつも、コストを削減するためにストリーミングワークロードにおけるクラスターの利用率を最適化します。これによって、ビジネスサイドが最新データにアクセスでき、コストが最適化されていることに自信を持って、データを操作することにフォーカスできるようになります。スタートアップからNasdaqShellのようなエンタープライズに至る多くのお客様がすでにプロダクション環境で強化オートスケーリングを活用しています。DLTの強化オートスケーリングは、賞を受賞するようなグローバル移民法律事務所であるBerry Appleman & Leiden LLP(BAL)のようなお客様におけるプロダクションユースケースを支援しています。

「DLTの強化オートスケーリングによって、BALのような法律事務所はレーテンシー要件を満たしつつもストリーミングデータパイプラインを最適化することができるようになりました。これまでより4倍高速にクライアントにレポートをデリバリーしており、彼らの移民プログラムに関してより多くの情報に基づく意思決定をできるようになりました。」— Chanille Juneau, Chief Technology Officer, BAL

データのストリーミングはミッションクリティカルです

膨大な新規データに対してよりクイックに意思決定を行うため、ストリーミングワークロードの人気はこれまで以上に高まっています。リアルタイムの処理によって、企業の分析や機械学習モデルに可能な限り最新のデータを提供することで、より迅速かつ優れた意思決定、より正確な予測を実現し、改善された顧客体験などを提供できるようになります。多くのDatabricksユーザーは、低レーテンシー、耐障害性、インクリメンタル処理のサポートを活用するために、レイクハウスでストリーミングを導入しています。オープンソースのApache SparkユーザーとDatabricksユーザーの両方でストリーミングが多数導入されている様子を確認しています。以下のグラフでは、過去3年間におけるDatabricks上のストリーミングジョブの週あたりの数を示しており、数千から数百万に成長し、いまだに加速しています。

図: Databricksで実行されるストリーミングジョブの数

時間とともにデータボリュームが変動するワークロードは数多く存在します: クリックストリームのイベント、eコマースのトランザクション、サービスログなどです。同時に、我々のお客様は、より予測可能なレーテンシー、データの可用性と新鮮さに関する保証をリクエストしています。

一貫性のあるSLAを保持しつつストリーミングデータを取り扱えるように、インフラストラクチャをスケーリングさせることは通常は困難であり、従来型のバッチ処理よりとは異なり、より複雑な要件が存在しています。この問題を解決するために、データチームは多くの場合ピークロードに合わせてインフラストラクチャのサイジングを行い、結果として低い利用率と高価なコストとなります。主導によるインフラストラクチャの管理は、オペレーション上複雑で時間を浪費するものです。

計算需要の変化に対応するために計算資源をスケールする問題を解決するために、Databricksでは2018年にクラスターのオートスケーリングを導入しました。クラスターのオートスケーリングは、コストが高くつくダウンタイムを回避するために、ワークロードに必要なキャパシティを保証しつつもお客様の費用を節約しました。しかし、クラスターのオートスケーリングは、比較的計算リソースの需要がわかっており、ワークフローの途中での変動がないバッチ指向の処理向けに設計されたものです。DLTの強化オートスケーリングは、ストリーミングパイプラインで生じる予測できないデータフローに特に対応するために開発され、ストリーミングワークロードにおいて一貫性のあるSLAを保証することで、お客様の費用を節約し、オペレーションをシンプルにします。

DLTの強化オートスケーリングはストリーミングとバッチのワークロードをインテリジェントにスケールします

オートスケーリングを持つDLTは、小売、金融サービス、鉄鋼を含むすべての業界における数多くのユースケースに対応します。この例では、サイバーセキュリティイベントを分析するユースケースをピックアップします。それでは、Delta Live Tablesの強化オートスケーリングがどのように低コストで最新のデータをデリバリーしつつも、手動によるインフラストラクチャの管理の必要性を排除したのかを見ていきましょう。一般的な実世界におけるサンプルで説明します: Delta Live Tablesを用いたサイバーセキュリティイベントの検知です。

サイバーセキュリティのワークロードは、本質的にスパイクを伴います。ユーザーは朝にコンピュータにログインし、ランチのために離席し、より多くのユーザーが別のタイムゾーンで起床し、このサイクルが繰り返されます。セキュリティチームは、コストを制御下に置きつつも、ビジネスを防御するために可能な限り迅速にイベントを処理する必要があります。

このデモでは、人気のオープンソースネットワーク監視ツールであるZeekによって生成される接続ログを取り込み、処理します。

図: ランディングゾーンに書き込まれる行数

Delta Live Tablesのパイプラインは標準的なメダリオンアーキテクチャに従います。Databricks Auto Loaderを用いてブロンズレイヤーにJSONデータを取り込み、データ型を調整し、カラム名を変更し、不正データを取り扱うためにデータエクスペクテーションを適用することでクレンジングしたデータをシルバーレイヤーに移動します。完全なストリーミングパイプラインは以下のようになりますが、これは数行のコードで作成されます。

図: サイバーセキュリティDLTパイプラインのサンプル

分析のために、Deltaテーブルで利用できるDLTイベントログからの情報を活用します。

以下のグラフは、データボリュームによって強化オートスケーリングが設定されたクラスターがどのように増強され、データボリュームが減少した際にクラスターサイズが減少し、バックログが処理されるのかを示しています。

図: 強化オートスケーリングを用いたDLTパイプラインによって使用されるエグゼキューターの数

グラフからわかるように、クラスターのサイズを自動で増減される能力によってリソースが劇的に節約されます。

Delta Live Tablesは、オートスケーリングとクラスターイベントを含むデータパイプラインに関する有用なメトリクスを収集します。クラスターリソースのイベントは、現在のエグゼキューターやタスクスロットの数、タスクスロットの利用率、キューされたタスクの数に関する情報を提供します。強化オートスケーリングは、与えられたワークロードに対する最適なエグゼキューター(クラスター)の数を計算するために、リアルタイムでこのデータを活用します。例えば、以下のグラフではタスク数の増加は起動されるクラスターの数の増加につながり、タスクの数が減少するとコストを最適下するためにクラスターも削除されています。

図: 現在のエグゼキューター数 vs 予測最適数、キューされたタスクの平均数

まとめ

変化し続け、予測不可能なデータボリュームによって、ベストなパフォーマンスを得るために手動でクラスターをサイジングすることは困難であり、過度にプロビジョンするリスクを伴います。DLTの強化オートスケーリングは、コストを削減するために全体的なエンドツーエンドのレーテンシーを削減しつつも、クラスターの利用率を最大化します。

本書では、DLTの強化オートスケーリングがどのようにして、現在と予測されるデータロードに基づき、計算リソースの最適量を選択することで、ストリーミングワークロードの要件を満たすためにスケールアップするのかをデモンストレーションしました。また、費用を削減するために、どのように強化オートスケーリングがクラスターのリソースを停止することでスケールダウンするのかもデモンストレーションしました。

Databricksレイクハウスプラットフォームで強化オートスケーリングとDelta Live Tablesを使い始める

強化オートスケーリングは、DLTユーザーインタフェースで作成される新規パイプラインでは自動で有効化されています。DLT UIのSettings buttonをクリックすることで既存のDLTパイプラインで強化オートスケーリングを有効化することをお勧めします。REST APIを通じて作成されたDLTパイプラインでは、強化オートスケーリングを有効化する設定を含める必要があります(ドキュメントをご覧ください)。設定でオートスケーリングモードが設定されていないDLTパイプラインにおいては、強化オートスケーリングをデフォルトにする変更を徐々にロールアウトしていきます。

データエンジニアやアナリストがどれだけ容易にDLTを活用できるのかを知るために以下のデモをご覧ください。

すでにDatabricksを使われているのであれば、シンプルにスタートガイドに従ってください。そうでない場合には、Databricks無料トライアルにサインアップいただき、DLTの詳細な価格をこちらから確認してください。

Databricks 無料トライアル

Databricks 無料トライアル

0
0
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
0
0