Cloud Pub/Sub to Cloud Storage テンプレート
Serverless for Apache Spark Cloud Pub/Sub to Cloud Storage テンプレートを使用して、Pub/Sub から Cloud Storage にデータを抽出します。
テンプレートの使用
gcloud CLI または Dataproc API を使用してテンプレートを実行します。
gcloud
後述のコマンドデータを使用する前に、次のように置き換えます。
- PROJECT_ID: 必須。IAM 設定に記載された Google Cloud プロジェクト ID。
- REGION: 必須。Compute Engine のリージョン。
- SUBNET: 省略可。サブネットが指定されていない場合、
defaultネットワークの指定された REGION のサブネットが選択されます。例:
projects/PROJECT_ID/regions/REGION/subnetworks/SUBNET_NAME - TEMPLATE_VERSION: 必須。最新のテンプレート バージョンまたは特定バージョンの日付(
2023-03-17_v0.1.0-betaなど)にはlatestを指定します(gs://dataproc-templates-binaries にアクセスするか、gcloud storage ls gs://dataproc-templates-binariesを実行して、使用可能なテンプレート バージョンを一覧表示します)。 - PUBSUB_SUBSCRIPTION_PROJECT_ID: 必須。読み取る入力 Pub/Sub サブスクリプションが含まれる IAM 設定に一覧表示された Google Cloud プロジェクト ID。
- SUBSCRIPTION: 必須。Pub/Sub サブスクリプション名。
- CLOUD_STORAGE_OUTPUT_BUCKET_NAME: 必須。出力が保存される Cloud Storage バケット名。
注: 出力ファイルは、バケット内の
output/フォルダに保存されます。 - FORMAT: 必須。出力データ形式。オプション:
avro、json。注:
avroの場合、jarsgcloud CLI フラグまたは API フィールドに「file:///usr/lib/spark/connector/spark-avro.jar」を追加する必要があります。例(
file://接頭辞は Apache Spark 用 Serverless jar ファイルを参照します):--jars=file:///usr/lib/spark/connector/spark-avro.jar,[ ... other jars] - TIMEOUT: 省略可。ストリームの終了までの時間(ミリ秒)。デフォルトは 60,000 です。
- DURATION: 省略可。Cloud Storage への書き込みの頻度(秒)。デフォルトでは 15 秒になっています。
- NUM_RECEIVERS: 省略可。Pub/Sub サブスクリプションから並行して読み取られたストリームの数。デフォルトは 5 です。
- BATCHSIZE: 省略可。1 回のラウンド トリップで Cloud Storage に挿入するレコードの数。デフォルトは 1,000 です。
- SERVICE_ACCOUNT: 省略可。指定されていない場合は、デフォルトの Compute Engine サービス アカウントが使用されます。
- PROPERTY、PROPERTY_VALUE: 省略可。Spark プロパティ=
valueペアのカンマ区切りのリスト。 - LABEL、LABEL_VALUE: 省略可。
label=valueペアのカンマ区切りのリスト。 - LOG_LEVEL: 省略可。ロギングのレベル。
ALL、DEBUG、ERROR、FATAL、INFO、OFF、TRACE、WARNのいずれかです。デフォルト:INFO -
KMS_KEY: 省略可。暗号化に使用する Cloud Key Management Service 鍵。鍵が指定されていない場合、データは Google-owned and Google-managed encryption keyを使用して保存時に暗号化されます。
例:
projects/PROJECT_ID/regions/REGION/keyRings/KEY_RING_NAME/cryptoKeys/KEY_NAME
次のコマンドを実行します。
Linux、macOS、Cloud Shell
gcloud dataproc batches submit spark \ --class=com.google.cloud.dataproc.templates.main.DataProcTemplate \ --version="1.2" \ --project="PROJECT_ID" \ --region="REGION" \ --jars="gs://dataproc-templates-binaries/TEMPLATE_VERSION/java/dataproc-templates.jar" \ --subnet="SUBNET" \ --kms-key="KMS_KEY" \ --service-account="SERVICE_ACCOUNT" \ --properties="PROPERTY=PROPERTY_VALUE" \ --labels="LABEL=LABEL_VALUE" \ -- --template=PUBSUBTOGCS \ --templateProperty log.level="LOG_LEVEL" \ --templateProperty pubsubtogcs.input.project.id="PUBSUB_SUBSCRIPTION_PROJECT_ID" \ --templateProperty pubsubtogcs.input.subscription="SUBSCRIPTION" \ --templateProperty pubsubtogcs.gcs.bucket.name="CLOUD_STORAGE_OUTPUT_BUCKET_NAME" \ --templateProperty pubsubtogcs.gcs.output.data.format="FORMAT" \ --templateProperty pubsubtogcs.timeout.ms="TIMEOUT" \ --templateProperty pubsubtogcs.streaming.duration.seconds="DURATION" \ --templateProperty pubsubtogcs.total.receivers="NUM_RECEIVERS" \ --templateProperty pubsubtogcs.batch.size="BATCHSIZE"
Windows(PowerShell)
gcloud dataproc batches submit spark ` --class=com.google.cloud.dataproc.templates.main.DataProcTemplate ` --version="1.2" ` --project="PROJECT_ID" ` --region="REGION" ` --jars="gs://dataproc-templates-binaries/TEMPLATE_VERSION/java/dataproc-templates.jar" ` --subnet="SUBNET" ` --kms-key="KMS_KEY" ` --service-account="SERVICE_ACCOUNT" ` --properties="PROPERTY=PROPERTY_VALUE" ` --labels="LABEL=LABEL_VALUE" ` -- --template=PUBSUBTOGCS ` --templateProperty log.level="LOG_LEVEL" ` --templateProperty pubsubtogcs.input.project.id="PUBSUB_SUBSCRIPTION_PROJECT_ID" ` --templateProperty pubsubtogcs.input.subscription="SUBSCRIPTION" ` --templateProperty pubsubtogcs.gcs.bucket.name="CLOUD_STORAGE_OUTPUT_BUCKET_NAME" ` --templateProperty pubsubtogcs.gcs.output.data.format="FORMAT" ` --templateProperty pubsubtogcs.timeout.ms="TIMEOUT" ` --templateProperty pubsubtogcs.streaming.duration.seconds="DURATION" ` --templateProperty pubsubtogcs.total.receivers="NUM_RECEIVERS" ` --templateProperty pubsubtogcs.batch.size="BATCHSIZE"
Windows(cmd.exe)
gcloud dataproc batches submit spark ^ --class=com.google.cloud.dataproc.templates.main.DataProcTemplate ^ --version="1.2" ^ --project="PROJECT_ID" ^ --region="REGION" ^ --jars="gs://dataproc-templates-binaries/TEMPLATE_VERSION/java/dataproc-templates.jar" ^ --subnet="SUBNET" ^ --kms-key="KMS_KEY" ^ --service-account="SERVICE_ACCOUNT" ^ --properties="PROPERTY=PROPERTY_VALUE" ^ --labels="LABEL=LABEL_VALUE" ^ -- --template=PUBSUBTOGCS ^ --templateProperty log.level="LOG_LEVEL" ^ --templateProperty pubsubtogcs.input.project.id="PUBSUB_SUBSCRIPTION_PROJECT_ID" ^ --templateProperty pubsubtogcs.input.subscription="SUBSCRIPTION" ^ --templateProperty pubsubtogcs.gcs.bucket.name="CLOUD_STORAGE_OUTPUT_BUCKET_NAME" ^ --templateProperty pubsubtogcs.gcs.output.data.format="FORMAT" ^ --templateProperty pubsubtogcs.timeout.ms="TIMEOUT" ^ --templateProperty pubsubtogcs.streaming.duration.seconds="DURATION" ^ --templateProperty pubsubtogcs.total.receivers="NUM_RECEIVERS" ^ --templateProperty pubsubtogcs.batch.size="BATCHSIZE"
REST
リクエストのデータを使用する前に、次のように置き換えます。
- PROJECT_ID: 必須。IAM 設定に記載された Google Cloud プロジェクト ID。
- REGION: 必須。Compute Engine のリージョン。
- SUBNET: 省略可。サブネットが指定されていない場合、
defaultネットワークの指定された REGION のサブネットが選択されます。例:
projects/PROJECT_ID/regions/REGION/subnetworks/SUBNET_NAME - TEMPLATE_VERSION: 必須。最新のテンプレート バージョンまたは特定バージョンの日付(
2023-03-17_v0.1.0-betaなど)にはlatestを指定します(gs://dataproc-templates-binaries にアクセスするか、gcloud storage ls gs://dataproc-templates-binariesを実行して、使用可能なテンプレート バージョンを一覧表示します)。 - PUBSUB_SUBSCRIPTION_PROJECT_ID: 必須。読み取る入力 Pub/Sub サブスクリプションが含まれる IAM 設定に一覧表示された Google Cloud プロジェクト ID。
- SUBSCRIPTION: 必須。Pub/Sub サブスクリプション名。
- CLOUD_STORAGE_OUTPUT_BUCKET_NAME: 必須。出力が保存される Cloud Storage バケット名。
注: 出力ファイルは、バケット内の
output/フォルダに保存されます。 - FORMAT: 必須。出力データ形式。オプション:
avro、json。注:
avroの場合、jarsgcloud CLI フラグまたは API フィールドに「file:///usr/lib/spark/connector/spark-avro.jar」を追加する必要があります。例(
file://接頭辞は Apache Spark 用 Serverless jar ファイルを参照します):--jars=file:///usr/lib/spark/connector/spark-avro.jar,[ ... other jars] - TIMEOUT: 省略可。ストリームの終了までの時間(ミリ秒)。デフォルトは 60,000 です。
- DURATION: 省略可。Cloud Storage への書き込みの頻度(秒)。デフォルトでは 15 秒になっています。
- NUM_RECEIVERS: 省略可。Pub/Sub サブスクリプションから並行して読み取られたストリームの数。デフォルトは 5 です。
- BATCHSIZE: 省略可。1 回のラウンド トリップで Cloud Storage に挿入するレコードの数。デフォルトは 1,000 です。
- SERVICE_ACCOUNT: 省略可。指定されていない場合は、デフォルトの Compute Engine サービス アカウントが使用されます。
- PROPERTY、PROPERTY_VALUE: 省略可。Spark プロパティ=
valueペアのカンマ区切りのリスト。 - LABEL、LABEL_VALUE: 省略可。
label=valueペアのカンマ区切りのリスト。 - LOG_LEVEL: 省略可。ロギングのレベル。
ALL、DEBUG、ERROR、FATAL、INFO、OFF、TRACE、WARNのいずれかです。デフォルト:INFO -
KMS_KEY: 省略可。暗号化に使用する Cloud Key Management Service 鍵。鍵が指定されていない場合、データは Google-owned and Google-managed encryption keyを使用して保存時に暗号化されます。
例:
projects/PROJECT_ID/regions/REGION/keyRings/KEY_RING_NAME/cryptoKeys/KEY_NAME
HTTP メソッドと URL:
POST https://dataproc.googleapis.com/v1/projects/PROJECT_ID/locations/REGION/batches
リクエストの本文(JSON):
{
"environmentConfig":{
"executionConfig":{
"subnetworkUri":"SUBNET",
"kmsKey": "KMS_KEY",
"serviceAccount": "SERVICE_ACCOUNT"
}
},
"labels": {
"LABEL": "LABEL_VALUE"
},
"runtimeConfig": {
"version": "1.2",
"properties": {
"PROPERTY": "PROPERTY_VALUE"
}
},
"sparkBatch":{
"mainClass":"com.google.cloud.dataproc.templates.main.DataProcTemplate",
"args":[
"--template","PUBSUBTOGCS",
"--templateProperty","log.level=LOG_LEVEL",
"--templateProperty","pubsubtogcs.input.project.id=PUBSUB_SUBSCRIPTION_PROJECT_ID",
"--templateProperty","pubsubtogcs.input.subscription=SUBSCRIPTION",
"--templateProperty","pubsubtogcs.gcs.bucket.name=CLOUD_STORAGE_OUTPUT_BUCKET_NAME",
"--templateProperty","pubsubtogcs.gcs.output.data.format=FORMAT",
"--templateProperty","pubsubtogcs.timeout.ms=TIMEOUT",
"--templateProperty","pubsubtogcs.streaming.duration.seconds=DURATION",
"--templateProperty","pubsubtogcs.total.receivers=NUM_RECEIVERS",
"--templateProperty","pubsubtogcs.batch.size=BATCHSIZE"
],
"jarFileUris":[
"file:///usr/lib/spark/connector/spark-avro.jar", "gs://dataproc-templates-binaries/TEMPLATE_VERSION/java/dataproc-templates.jar"
]
}
}
リクエストを送信するには、次のいずれかのオプションを展開します。
次のような JSON レスポンスが返されます。
{
"name": "projects/PROJECT_ID/regions/REGION/operations/OPERATION_ID",
"metadata": {
"@type": "type.googleapis.com/google.cloud.dataproc.v1.BatchOperationMetadata",
"batch": "projects/PROJECT_ID/locations/REGION/batches/BATCH_ID",
"batchUuid": "de8af8d4-3599-4a7c-915c-798201ed1583",
"createTime": "2023-02-24T03:31:03.440329Z",
"operationType": "BATCH",
"description": "Batch"
}
}