Skip to content

Releases: aws-samples/sagemaker-ssh-helper

Release v2.3.0

28 Feb 14:36

Choose a tag to compare

New in v2.3.0:

  • (HOT!) #51 #72 #67 #57 #68 - Support of the new Amazon SageMaker Studio experience. SageMaker Studio Classic is deprecated and not supported anymore.

  • #69 - Better support for China region

  • Stabilize tests and improve reliability

  • #71 - Fix noise in resolution of instances

Release v2.2.1

28 Nov 19:12
126b62f

Choose a tag to compare

New in v2.2.1:

sm-ssh got support for extra args, see CLI syntax.

sm-local-* scripts API refactoring, use sm-ssh tool with extra args instead to avoid breaking changes

#64 - Deprecating Python 3.7 . Supported versions: 3.8, 3.9, 3.10, 3.11.

Improved logging and output formatting

Documentation updates: Windows instructions, troubleshooting steps, moving to CloudShell from Cloud9, IDE integration steps

IAM: Adding missing document/SSM-SessionManagerRunShell resource to ssm:StartSession action

Increased SSH timeout to prevent connection time out to slower containers like Spark Analytics

Release v2.2.0

12 May 21:39

Choose a tag to compare

New in v2.2.0:

  • (HOT!) Introducing FQDN scheme for SSH by host name ssh xxx.yyy.sagemaker. See ssh_config section in README. Closes #33 for smoothly switching instances.
  • (HOT!) UI: Introducing sm-ssh CLI tool with connect command as the alternative to sm-local-ssh-* and the list command to show all instances that you can connect to. Moving closer to pure Python implementation as mentioned in #38. See sm-ssh section in README.
  • UI: New script sm-ssh-deregister-instances to be used in place of deregister_old_instances_from_ssm.py now as mentioned in the FAQ.md.
  • API: New method print_ssh_info() for the wrappers to print the useful links and commands for connection
  • Added fail-on-error options to all setup scripts, resulting stronger error handling that helps with troubleshooting of SSH Helper issues. Discussed in #37.
  • Improved testing for IDE notebook through Selenium and Firefox. Introduced the class for SageMaker Studio automation (can be used to test your own notebooks, too) – sagemaker_ssh_helper/browser_automation.py.
  • FAQ: How to improve performance of SageMaker Studio when using remote interpreter?
  • Fixed Windows installation and updated instructions in FAQ.md, as discussed in #38.
  • Improved logic for Low GPU utilization Lambda described in FAQ.md.
  • Improved logging
  • Resource monitoring in tests with pytest-monitor
  • Introducing timedelta() syntax instead of counting seconds in API.
  • MXNet SageMaker Studio kernel image support
  • Refined the docs

Release v2.1.0

23 Aug 16:48

Choose a tag to compare

New in v2.1.0:

Set your SageMaker Studio domain ID and user profile name, to allow multiple users connecting to multiple domains with the same kernel gateway name:

sm-local-ssh-ide set-domain-id <<domain_id>>
sm-local-ssh-ide set-user-profile-name <<user_profile_name>>

IAM action ssm:DeregisterManagedInstance removed from SSHSageMakerClientPolicy, because instance cleanup is to be run by an admin.

#32 - switch to regional STS endpoints in wrappers, to fetch the local user ID.

#35 - Support HF accelerate and DeepSpeed for inference.

#27 - Support Hugging Face Accelerate for training.

Support SSH into training with SageMaker Training Compiler.

Support for SSH into Jupyter Server instance.
FAQ: Can I connect from my local machine to Jupyter Server in addition to Kernel Gateways?

Improved support for SSH Agent keys forwarding into SageMaker.
FAQ: How do I securely forward my local private SSH keys from local machine to the remote host with SSH Agent?

API: get_instance_ids() method receives an optional timeout_in_sec parameter that is by default 900 seconds (15 minutes), to highlight the difference from connection_wait_time_seconds passed to the wrapper, which is by default 600 seconds (10 minutes).

Added development journey to README.

Improved logging.

Improved troubleshooting instructions.

Release v2.0.0

25 Jul 06:55

Choose a tag to compare

New in v2.0.0:

Internet-free mode support: I'm running SageMaker in a VPC. Do I need to make extra configuration?

Amazon Linux support for SageMaker Studio

MATE desktop is now the default environment for VNC both for Amazon Linux and Debian-based SageMaker Studio images

Windows procedure now uses virtual env and doesn't need admin rights

Documentation improvements, more detailed architecture diagrams

Improve CI/CD testing of the code

Release v1.12.0

20 Jul 05:18

Choose a tag to compare

New in v1.12.0:

#31 - fixed sm-local-configure on macOS

FAQ:

sm-wait stop now have to be used instead of pkill to gracefully shut down the waiting loop

IAM policy SSHSageMakerServerPolicy changes – ssm:ListInstanceAssociations requires * as a resource name to avoid errors in logs (see IAM_SSM_Setup.md for more details).

CDK apps has been split (see IAM_SSM_Setup.md for more details):

  • sagemaker_ssh_helper.cdk.iam_ssm_app
  • sagemaker_ssh_helper.cdk.advanced_tier_app

API Changes:

  • ssh_wrapper.training_job_name() instead of ssh_wrapper.latest_training_job_name()
  • sm-ssh-ide get-metadata to print SageMaker Studio details to connect
  • sm-ssh-ide set-local-user-id "$LOCAL_USER_ID" and sm-ssh-ide init-ssm instead of a single init-ssm command.

Added the tip to set the Web VNC screen resolution with xrandr

sm-save-env now handles special symbols and quotes in variables

Improve CI/CD testing of the code

Release v1.11.0

07 Jun 08:40

Choose a tag to compare

New in v1.11.0:

IAM/SSM policy update - needs ssm:GetCommandInvocation permission for better performance – 2628c4f
IAM/SSM policy update - needs * for ssm:ListInstanceAssociations to avoid errors in logs – 049f97b

#28 – fixed issue with new SageMaker Python SDK: Invalid bucket name "sagemaker.config INFO - Fetched defaults config from location: ": Bucket name must match the regex. The change related to SageMaker defaults :
https://github.com/aws/sagemaker-python-sdk/pull/3872/files

Added support for SageMaker defaults
Improved MME support for TF
Added support for pre-trained HuggingFace models
Better support for popular SageMaker Studio images
Support attaching to already submitted training jobs with SSHEstimatorWrapper.attach()

Documented alternative way to add SSH Helper dependency through requirements.txt

Release v1.10.4

16 May 18:24

Choose a tag to compare

New in v1.10.4:

#25 - fix for IDE notebook / kernel lifecycle configuration script: installing sudo that is missing in some kernels

Release v1.10.3

12 May 15:34

Choose a tag to compare

New in v1.10.3:

WebVNC through noVNC and AWS Jupyter Proxy

#25 - fix for sm-local-configure on Linux: sudo for installing AWS CLI and Session Manager Plugin

Release v1.10.2

11 May 17:03

Choose a tag to compare

New in v1.10.2:

#21 - don't update the pre-installed pip in SageMaker Studio that can cause issues with PyYAML

The sm-local-ssh-ide script now supports extra SSH args for forwarding additional ports:

sm-local-ssh-ide connect <kernel_gateway_name> [--ssh-only] [<extra_ssh_args>]

The new method is_last_session_timeout() to prevent unused resources for the placeholder job if there's were no SSM or SSH sessions for the specified period of time.

Documentation updates

New train_placeholder.py script that ends when sessions timeout.

Added section on Forwarding TCP ports over SSH tunnel - useful to access remote apps like Dask or Streamlit