Skip to main content

A client library for accessing Lambda Cloud API

Project description

Lambda Cloud API - CLI

This project is a wrapper around the Lambda Cloud API with some additional Quality-of-Life additions. The documentation of the API can be found here: https://docs-api.lambda.ai/api/cloud

Installation

uv pip install lambda-ai-cloud-api-client

Usage

  1. Set up an API token and environment.

In your lambda.ai account go to https://cloud.lambda.ai/api-keys/cloud-api and generate a new Cloud AI Key. Set this token as an environment variable in the terminal you've installed this project.

export LAMBDA_CLOUD_API_TOKEN=<your-token>

The project also accepts LAMBDA_CLOUD_TOKEN and LAMBDA_API_TOKEN if you prefer that naming. Optionally you can set the api base url, LAMBDA_CLOUD_BASE_URL, the default is https://cloud.lambdalabs.com .

  1. Using the CLI

To save on keystrokes I've named the command lai for lambda.ai. To see all available commands use:

lai --help

Overview of features

Listing all instances

api doc: https://docs-api.lambda.ai/api/cloud#listInstances

lai ls

An overview of all your booting/running/terminating instances.

Details of a single instance

api doc: https://docs-api.lambda.ai/api/cloud#getInstance

lai get <name-or-id>

Starting an instance

api doc: https://docs-api.lambda.ai/api/cloud#launchInstance

Starting an instance with your configuration. You can choose to be exact and pass --instance-type <your-type> or use filters that narrow to a single instance type.

lai start --instance-type gpu_1x_a10 --name my-instance --ssh-key my-ssh-key

or start the cheapest available instance with some hardware requirement.

lai start --cheapest --available --min-gpus 1 --name my-instance --ssh-key my-ssh-key

See lai start --help for all filters. They can be used all together to find the best instance type. There's also a --dry-run option to see what would be selected.

Restart an instance / instances

api doc: https://docs-api.lambda.ai/api/cloud#restartInstance

Restart an instance, multiple arguments are allowed.

lai restart <id-or-name. 

Stop an instance / instances

api doc: https://docs-api.lambda.ai/api/cloud#terminateInstance

Stop an instance / instances, multiple arguments are allowed. This terminates the instance and removes it from your inventory. You cannot restart/start terminated instances.

lai stop <id-or-name> ...

SSH into an instance

Finds an instance by id or name and then starts an ssh session to it. Handy if you want to stop copy+pasting IP addresses of your started instances. Includes mechanism to wait for the instance to become available if it has just been started.

lai ssh my-instance # or id
Waiting for IP on instance 'my-instance' (8ac73ac801a749099ed3bc2a5508000f)... retrying in 5s
Waiting for SSH on instance 'my-instance' (132.145.199.110)... retrying in 5s
Executing: ssh -o StrictHostKeyChecking=accept-new -o UserKnownHostsFile=/dev/null ubuntu@132.145.199.110
(my-instance) $ 

Running a command on an instance

Most of the time the workflow of using instances is:

  1. Start an instance
  2. Rsync your code to it.
  3. Run a command, usually with env vars.
  4. Rsync results back.
  5. Stop the instance.

If this is your general workflow you'll find the following commands useful. In the most complex case it'll give you access to spot-like instances where you only pay for the amount of time taken on a machine before it is shut down.

  1. Run a command on an already started instance, including waiting for booting instances.
lai run my-instance -- <command>
  1. Start an instance, then run the command.
lai run --cheapest --available --ssh-key my-ssh-key -- <command>
  1. Start an instance, rsync a volume, run the cmd and rsync a volume back.
lai run --cheapest --available --ssh-key my-ssh-key -v <my-dir-or-file>:/home/ubuntu/ -- <command> /home/ubuntu/my-file
  1. All of the above but delete the instance after done.
lai run --rm --cheapest --available --ssh-key my-ssh-key -v <my-dir-or-file>:/home/ubuntu/ -- <command> /home/ubuntu/my-file

Listing instance types

api doc: https://docs-api.lambda.ai/api/cloud#listInstanceTypes

List all available instance types, with filters to select for --available or --region.

lai types

Listing available boot images

api doc: https://docs-api.lambda.ai/api/cloud#listImages

List all available boot images, with filters to select --arch and --family.

lai images

Listing your saved SSH keys

api doc: https://docs-api.lambda.ai/api/cloud#listSSHKeys

List all available ssh-keys you have saved in lambda.ai

lai keys

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

lambda_ai_cloud_api_client-2.4.0.tar.gz (54.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

lambda_ai_cloud_api_client-2.4.0-py3-none-any.whl (186.8 kB view details)

Uploaded Python 3

File details

Details for the file lambda_ai_cloud_api_client-2.4.0.tar.gz.

File metadata

File hashes

Hashes for lambda_ai_cloud_api_client-2.4.0.tar.gz
Algorithm Hash digest
SHA256 7dec936355e534893f95c16403f326820f47bfe1779ff5ff334bc51cd04b3143
MD5 aa3f564246990bde9544cfcf1cdcbd00
BLAKE2b-256 829c1aaf2d85cbc8c2fe557684bcd0fe9bf4fb629aeea728a1901492dc0e2d99

See more details on using hashes here.

Provenance

The following attestation bundles were made for lambda_ai_cloud_api_client-2.4.0.tar.gz:

Publisher: ci.yml on alexandervaneck/lambda-ai-cloud-api-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file lambda_ai_cloud_api_client-2.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for lambda_ai_cloud_api_client-2.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e5553134f10f26c731cc2bd4642027b39aeb5bd926cbb4c9d71cb0c862773b91
MD5 441deda83ece650ad9b8a2d0b0ee8beb
BLAKE2b-256 3d8e88c0e3b8db7b8760e1ea0042e7171fd4648bc27286e0935c7821c4b2416a

See more details on using hashes here.

Provenance

The following attestation bundles were made for lambda_ai_cloud_api_client-2.4.0-py3-none-any.whl:

Publisher: ci.yml on alexandervaneck/lambda-ai-cloud-api-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page