pipelines/components/aws/emr/submit_spark_job/component.yaml

42 lines
1.9 KiB
YAML

# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
name: emr_submit_spark_job
description: >-
Submits an Elastic Map Reduce (EMR) Spark applications.
inputs:
- {name: region, description: 'The EMR region in which to handle the request.'}
- {name: jobflow_id, description: 'The cluster id to run the job.'}
- {name: job_name, description: The name of the spark job.}
- {name: jar_path, description: 'A path to a JAR file run during the step.'}
- {name: main_class, default: '', description: 'The name of the main class in the specified Java file. If not specified, the JAR file should specify a Main-Class in its manifest file.'}
- {name: input, description: 'File path of the dataset.'}
- {name: output, description: 'Output path of the result files.'}
outputs:
- {name: job_id, description: 'The id of the created EMR step.'}
- {name: output_location, description: 'S3 URI of the training job results.'}
implementation:
container:
image: seedjeffwan/kubeflow-pipeline-aws-emr:20190507
command: ['python', 'submit_spark_job.py']
args: [
--region, {inputValue: region},
--jobflow_id, {inputValue: jobflow_id},
--job_name, {inputValue: job_name},
--jar_path, {inputValue: jar_path},
--main_class, {inputValue: main_class},
--input, {inputValue: input},
--output, {inputValue: output},
--output_file, {outputPath: output_location},
]
fileOutputs:
job_id: /output.txt