lsh is the Latitude.sh command-line interface (CLI) that will help you make it easier to retrieve any data from your team or perform any action you need.
Installing the latest version
brew install latitudesh/tools/lsh
curl -fsSL https://cli.latitude.sh/install.sh | shVisit the releases page and select any version you want to download.
Log in into Latitude.sh. An API Key is required.
lsh login <API_KEY>The CLI automatically detects when you use sudo and loads your credentials from your user directory.
List your servers
lsh servers listThe list of the available commands is available here.
See more examples here.
List a server with a specific hostname:
lsh servers list --hostname <HOSTNAME>
Create a server with Ubuntu 24:
lsh servers create --operating_system ubuntu_24_04_x64_lts --project <PROJECT_ID_OR_SLUG> --site <LOCATION> --hostname <HOSTNAME> --plan <PLAN>
List all GPU plans:
lsh plans list --gpu true
List volumes:
lsh volume list --project <PROJECT_ID>
Mount volume to a server (requires sudo, auto-installs nvme-cli and connects):
# First, login as normal user
lsh login <API_KEY>
# Then mount with sudo (automatically uses your credentials)
sudo lsh volume mount --id vol_abc123Why sudo is required:
- Installs
nvme-clipackage if not present - Loads NVMe kernel modules (
nvme_tcp) - Writes to
/etc/nvme/hostnqn - Runs privileged
nvme connectcommands
Important:
- Login as a normal user (without sudo):
lsh login <API_KEY> - The CLI automatically finds your credentials when you run commands with sudo
- Volume mount needs sudo for nvme-cli installation and NVMe operations
If you encounter any problems when installing the CLI with the installation script, you can use the command below to uninstall the CLI.
curl -sSL https://raw.githubusercontent.com/latitudesh/cli/main/uninstall.sh | bashIf sudo lsh volume mount says "API key not found":
# Make sure you've logged in as your normal user (not with sudo)
lsh login <API_KEY>
# Then try mount again
sudo lsh volume mount --id <VOLUME_ID>The CLI automatically detects your username via the SUDO_USER environment variable and loads your config.
For more information, see the documentation.
-
Open an issue for questions, feedback, bug reports or feature requests.
-
We welcome pull requests for bug fixes, new features, and improvements to the examples.