Local Mode
SageMaker Pipelines local mode is an easy way to test your training, processing and inference
scripts, as well as the runtime compatibility of pipeline parameters
Pipelines local mode leverages SageMaker jobs local
mode
Pipeline local mode currently supports the following step types:
-
Model Step (with Create Model arguments only)
As opposed to the managed Pipelines service which allows multiple steps to execute in parallel using Parallelism Configuration
Note
Pipelines local mode is not compatible with SageMaker algorithms such as XGBoost. If you to want use these algorithms, you must use them in script mode
In order to execute a pipeline locally, the sagemaker_session
fields associated with the pipeline steps and the pipeline itself need to be of type LocalPipelineSession
.
The following example shows how you can define a SageMaker pipeline to execute locally.
from sagemaker.workflow.pipeline_context import LocalPipelineSession from sagemaker.pytorch import PyTorch from sagemaker.workflow.steps import TrainingStep from sagemaker.workflow.pipeline import Pipeline local_pipeline_session = LocalPipelineSession() pytorch_estimator = PyTorch( sagemaker_session=local_pipeline_session, role=sagemaker.get_execution_role(), instance_type="ml.c5.xlarge", instance_count=1, framework_version="1.8.0", py_version="py36", entry_point="./entry_point.py", ) step = TrainingStep( name="MyTrainingStep", step_args=pytorch_estimator.fit( inputs=TrainingInput(s3_data="s3://
amzn-s3-demo-bucket/my-data/train
"), ) ) pipeline = Pipeline( name="MyPipeline", steps=[step], sagemaker_session=local_pipeline_session ) pipeline.create( role_arn=sagemaker.get_execution_role(), description="local pipeline example" ) // pipeline will execute locally execution = pipeline.start() steps = execution.list_steps() training_job_name = steps['PipelineExecutionSteps'][0]['Metadata']['TrainingJob']['Arn'] step_outputs = pipeline_session.sagemaker_client.describe_training_job(TrainingJobName = training_job_name)
Once you are ready to execute the pipeline on the managed SageMaker Pipelines service, you can do
so by replacing LocalPipelineSession
in the previous code snippet with
PipelineSession
(as shown in the following code sample) and rerunning the
code.
from sagemaker.workflow.pipeline_context import PipelineSession pipeline_session = PipelineSession()