Skip to main content

Start and manage cloud instances.

Project description

Spare Cores Runner

Spare Cores Runner is a command-line tool and Python API designed to simplify the process of provisioning and managing cloud instances across various cloud providers. It leverages Pulumi to handle infrastructure-as-code and automate the creation and destruction of compute instances in your preferred cloud environment.

Spare Cores Runner (sc-runner from now on) is used by Spare Cores Inspector to start up basic cloud instances with the required minimum configuration and environment to start the machine with a custom cloud-init script, but it can also be used to simply start an instance with a given SSH key, making it available for basic use cases.

Supported Cloud Providers and their Credentials

sc-runner uses the Spare Cores database to pre-fill the available configuration options, like what regions and instance types are available for a given cloud provider. To use a given cloud provider, you have to provide credentials for them, either by running it in an environment where the underlying library can pick them up, or by specifying them through environment variables or command line options.

For more details, see the supported vendor's Pulumi integration:

Pulumi

As sc-runner uses Pulumi under the hood to manage the cloud providers, it'll need to have a Pulumi project. You can configure Pulumi project-related settings either by specifying them using command line arguments, shown below:

sc-runner create --help
Usage: sc-runner create [OPTIONS] COMMAND [ARGS]...

Options:
  --project-name TEXT        Pulumi project name  [default: runner]
  --work-dir TEXT            Pulumi work dir  [default: /data/workdir]
  --pulumi-home TEXT         Pulumi home  [default: /root/.pulumi]
  --pulumi-backend-url TEXT  Pulumi backend URL  [default: file:///data/backend]
  --stack-name TEXT          Pulumi stack name, defaults to
                             {vendor}.{region}.{zone}.{instance_id} or similar
  --help                     Show this message and exit.

Commands:
  aws
  azure
  gcp
  hcloud
  ovh
  upcloud

Or by setting the following environment variables:

  • PULUMI_PROJECT_NAME
  • PULUMI_WORK_DIR
  • PULUMI_HOME
  • PULUMI_BACKEND_URL

sc-runner should create the project on the first invocation, during which it'll create multiple stacks for each vendor.region.zone.instance_id tuple. This allows concurrent creation of instances, supporting our Spare Cores Inspector use case, where we start a given instance type once to collect data from them.

Usage

CLI examples

Create instances

Create and destroy a default t3.micro instance in the default VPC/subnet in AWS:

sc-runner create aws
sc-runner destroy aws

Create an Azure instance with a public key:

sc-runner create azure --instance Standard_DS1_v2 --public-key $(cat .ssh/id_ed25519.pub)

Create an AWS instance with public IP and an already stored SSH key named spare_cores:

sc-runner create aws --region us-west-2 --instance t4g.large --instance-opts '{"associate_public_ip_address": true,"key_name":"spare-cores"}' --public-key ""

Destroy instances

sc-runner destroy azure --instance Standard_DS1_v2
sc-runner destroy aws --region us-west-2 --instance t4g.large

You can also use destroy-stack instead of destroy, which performs a pulumi refresh first, synchronizing the underlying cloud state with Pulumi's internal backend and destroying only what's really there (so it won't fail on already deleted resources).

Cancelling Pulumi Locks

Sometimes Pulumi might leave a lock file in its state store, preventing further operations. With this command you can cancel those:

sc-runner cancel aws --region us-west-2 --instance t4g.large

Docker

sc-runner is available through a Docker image as well, which you can use with the following command:

docker run --rm -ti ghcr.io/sparecores/sc-runner:main --help

You'll have to set up the same environment variables or configure the cloud credentials for Pulumi.

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

sparecores_runner-0.0.42.tar.gz (23.1 kB view details)

Uploaded Source

Built Distribution

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

sparecores_runner-0.0.42-py3-none-any.whl (27.6 kB view details)

Uploaded Python 3

File details

Details for the file sparecores_runner-0.0.42.tar.gz.

File metadata

  • Download URL: sparecores_runner-0.0.42.tar.gz
  • Upload date:
  • Size: 23.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sparecores_runner-0.0.42.tar.gz
Algorithm Hash digest
SHA256 7a55d71674afb2286aabb70507fb2c2050447af4d7470f7c2e1e6b72e0dea570
MD5 dabe61a8aeea7168d3b06cf9e190f070
BLAKE2b-256 375d1319e7ec8fe5347355dda1e6b9431c2d0774fe4c765d90e14dce56b47c63

See more details on using hashes here.

Provenance

The following attestation bundles were made for sparecores_runner-0.0.42.tar.gz:

Publisher: release.yml on SpareCores/sc-runner

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

File details

Details for the file sparecores_runner-0.0.42-py3-none-any.whl.

File metadata

File hashes

Hashes for sparecores_runner-0.0.42-py3-none-any.whl
Algorithm Hash digest
SHA256 bd79b32d2d2597401b6b27f7c7347599049f95ea9b3825a8099c63a0ca2e86f8
MD5 4b1f76c41106bb257fd337e7c1b9f26f
BLAKE2b-256 2dbb3f9fe61e6537c8bde1592fd8afea591fcff923dfdf5dbbd56ccc7976e08b

See more details on using hashes here.

Provenance

The following attestation bundles were made for sparecores_runner-0.0.42-py3-none-any.whl:

Publisher: release.yml on SpareCores/sc-runner

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