チュートリアル: 最初のカスタム Databricks アセット バンドル テンプレートを作成する
このチュートリアルでは、特定の Docker コンテナー イメージを使用して、クラスター上の特定の Python タスクでジョブを実行するバンドルを作成するためのカスタム Databricks アセット バンドル テンプレートを作成します。
開始する前に
Databricks CLI バージョン 0.218.0 以降をインストールします。 既にインストールしている場合は、コマンド ラインから databricks -version
を実行して、バージョンが 0.218.0 以降であることを確認します。
ユーザー プロンプト変数を定義する
バンドル テンプレートを作成する最初の手順は、databricks bundle init
ユーザー プロンプト変数を定義することです。 コマンドラインから:
dab-container-template
という名前の空のディレクトリを作成します。mkdir dab-container-template
ディレクトリのルートで、
databricks_template_schema.json
という名前のファイルを作成します。cd dab-container-template touch databricks_template_schema.json
databricks_template_schema.json
に次の内容を追加し、ファイルを保存します。 各変数は、バンドルを作成するときにユーザー プロンプトに変換されます。{ "properties": { "project_name": { "type": "string", "default": "project_name", "description": "Project name", "order": 1 } } }
バンドル フォルダー構造を作成する
次に、テンプレート ディレクトリで、resources
および src
という名前のサブディレクトリを作成します。 template
フォルダーには、生成されるバンドルのディレクトリ構造が含まれます。 サブディレクトリとファイルの名前は、ユーザー valuesから派生した場合、Go パッケージ テンプレートの構文に従います。
mkdir -p "template/resources"
mkdir -p "template/src"
YAML 構成テンプレートを追加する
template
ディレクトリで、databricks.yml.tmpl
という名前のファイルを作成し、次の YAML を追加します。
touch template/databricks.yml.tmpl
# This is a Databricks asset bundle definition for {{.project_name}}.
# See https://docs.databricks.com/dev-tools/bundles/index.html for documentation.
bundle:
name: {{.project_name}}
include:
- resources/*.yml
targets:
# The 'dev' target, used for development purposes.
# Whenever a developer deploys using 'dev', they get their own copy.
dev:
# We use 'mode: development' to make sure everything deployed to this target gets a prefix
# like '[dev my_user_name]'. Setting this mode also disables any schedules and
# automatic triggers for jobs and enables the 'development' mode for Delta Live Tables pipelines.
mode: development
default: true
workspace:
host: {{workspace_host}}
# The 'prod' target, used for production deployment.
prod:
# For production deployments, we only have a single copy, so we override the
# workspace.root_path default of
# /Workspace/Users/${workspace.current_user.userName}/.bundle/${bundle.target}/${bundle.name}
# to a path that is not specific to the current user.
#
# By making use of 'mode: production' we enable strict checks
# to make sure we have correctly configured this target.
mode: production
workspace:
host: {{workspace_host}}
root_path: /Shared/.bundle/prod/${bundle.name}
{{- if not is_service_principal}}
run_as:
# This runs as {{user_name}} in production. Alternatively,
# a service principal could be used here using service_principal_name
# (see Databricks documentation).
user_name: {{user_name}}
{{end -}}
{{.project_name}}_job.yml.tmpl
という名前の別の YAML ファイルを作成し、template/resources
ディレクトリに配置します。 この新しい YAML ファイルは、プロジェクトのジョブ定義を、バンドルの定義の残りの部分から分離します。 このファイルに次の YAML を追加してテンプレート ジョブを記述します。これには、特定の Docker コンテナー イメージを使用してジョブ クラスターで実行する特定の Python タスクが含まれています。
touch template/resources/{{.project_name}}_job.yml.tmpl
# The main job for {{.project_name}}
resources:
jobs:
{{.project_name}}_job:
name: {{.project_name}}_job
tasks:
- task_key: python_task
job_cluster_key: job_cluster
spark_python_task:
python_file: ../src/{{.project_name}}/task.py
job_clusters:
- job_cluster_key: job_cluster
new_cluster:
docker_image:
url: databricksruntime/python:10.4-LTS
node_type_id: i3.xlarge
spark_version: 13.3.x-scala2.12
この例では、既定の Databricks のベース Docker コンテナー イメージを使用しますが、代わりに独自のカスタム イメージを指定することもできます。
構成で参照されるファイルを追加する
次に、template/src/{{.project_name}}
ディレクトリを作成し、テンプレートでジョブによって参照される Python タスク ファイルを作成します。
mkdir -p template/src/{{.project_name}}
touch template/src/{{.project_name}}/task.py
次を task.py
に追加します。
import pyspark
from pyspark.sql import SparkSession
spark = SparkSession.builder.master('local[*]').appName('example').getOrCreate()
print(f'Spark version{spark.version}')
バンドル テンプレート構造を確認する
バンドル テンプレート プロジェクトのフォルダー構造を確認します。 内容は次のようになります。
.
├── databricks_template_schema.json
└── template
├── databricks.yml.tmpl
├── resources
│ └── {{.project_name}}_job.yml.tmpl
└── src
└── {{.project_name}}
└── task.py
テンプレートのテスト
最後に、バンドル テンプレートをテストします。 新しいカスタム テンプレートに基づいてバンドルを generate するには、databricks bundle init
コマンドを使用して、新しいテンプレートの場所を指定します。 バンドル プロジェクトのルート フォルダーから、以下を実行します。
mkdir my-new-container-bundle
cd my-new-container-bundle
databricks bundle init dab-container-template
次のステップ
- ノートブックを Azure Databricks ワークスペースにデプロイし、そのデプロイされたノートブックを Azure Databricks ジョブとして実行するバンドルを作成します。 「Databricks アセット バンドルを使用して Azure Databricks でジョブを開発する」を参照してください。
- ノートブックを Azure Databricks ワークスペースにデプロイし、そのノートブックを Delta Live Tables パイプラインとして実行するバンドルを作成します。 Databricks Asset Bundlesを使用して Delta Live
パイプラインを開発する を参照してください。 - MLOps Stack をデプロイして実行するバンドルを作成します。 「MLOps Stacks の Databricks アセット バンドル」を参照してください。
- GitHub の CI/CD (継続的インテグレーション/継続的デプロイ) ワークフローにバンドルを追加します。 「Databricks アセット バンドルとGitHub Actions を使用して CI/CD ワークフローを実行する」を参照してください。