Skip to main content

A simple development environment manager.

Project description

space-control

space-control, or sctl, is a simple CLI tool for working within a distributed environment. The goal is to allow batch operations to be easily executed on any number of hosts, whether that means executing commands, downloading or uploading files, or whatever else is needed.

Sample configuration file:

directory: /
nodes:
  - host: 'some_host'
    user: 'root'
    connect_kwargs: {
      password: password
    }
  - host: 'mypi'
    user: 'pi'

sctl by default will look for a configuration file relative to your current location: .sctl/config.yml. If a file cannot be found, it will look in ~/.sctl/config.yml. Alternatively you can specify a path to a configuration using the -c / --configuration option. This will be expanded on in the future to allow for multiple "profiles" in a single config.

The keys for each entry of nodes are the parameters specified by fabric.connection.Connection (of the wonderful fabric) library. Any configuration you want to do locally with SSH keys, authorized_keys, etc. is up to you. If you are not familiar (as I was merely 10 hours ago) fabric is an awesome wrapper around paramiko and some other tools, and it is so easy and clean to use. Check out both of those libraries.

This tool is not complete and is far from it.

Install

Install via pip:

pip install sctl

Or for latest and greatest, clone this repository and then run:

python setup.py install

or install directly from GitHub with pip:

python -m pip install git+https://github.com/Lnk2past/space-control.git

Sample Usage

Run ls on each node and print the output (the default action is exec and may be omitted):

sctl ls
sctl exec ls

Download the .bashrc from each node:

sctl download .bashrc

Upload a new .bashrc to each node:

sctl upload .bashrc

Notes

You may omit specifying a directory in your configuration; in these cases the default directory is usually the home directory of the user you are logging in as.

Configurable Actions

space-control refers to executing commands and transferring files as actions. While you can certainly specify actions directly on the CLI (as shown above), you can also provide custom sets of actions in your configuration file. The added benefit here is that configurable actions are designed to allow you to chain multiple actions together (something you cannot do directly with the CLI). So for example, you can upload a file, run a command to produce a new file, and download that new file all by configuring a single set of actions.

nodes:
  - host: 'somehost'
    user: 'root'
actions:
  pgdump:
    - action: 'exec'
      command: 'docker exec postgres pg_dump -f pg_data.txt -t my_table my_db'
    - action: 'exec'
      command: 'docker cp postgres:pg_data.txt pg_data.txt'
    - action: 'download'
      remote: 'pg_data.txt'

The custom action pgdump here will execute pg_dump within the postgres container, copy the file from the postgres container, and then download it locally.

Filtering Nodes

Sometimes you may want to run an action on specific nodes in your configuration. This can be done using the -n / --nodes input options. This option takes a regex pattern and will filter nodes on that pattern. For example, given the following config:

nodes:
  - host: 'foo'
    user: 'root'
  - host: 'bar'
    user: 'root'
  - host: 'foobar'
    user: 'root'

We can run an action against the foo and foobar nodes only using:

sctl -n foo ls

Here the pattern foo will be partial matches for both foo and foobar and will both be included in the set of nodes to run against.

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

sctl-2020.0.4.tar.gz (5.8 kB view details)

Uploaded Source

Built Distribution

sctl-2020.0.4-py3-none-any.whl (7.8 kB view details)

Uploaded Python 3

File details

Details for the file sctl-2020.0.4.tar.gz.

File metadata

  • Download URL: sctl-2020.0.4.tar.gz
  • Upload date:
  • Size: 5.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.0 CPython/3.8.4

File hashes

Hashes for sctl-2020.0.4.tar.gz
Algorithm Hash digest
SHA256 49376a696e696e8d9a373af846a63bcaa02983d42db4150aeeff262d2c0967ae
MD5 a5e2a070b337acca87a7b5d34f402b40
BLAKE2b-256 edeab7a6e6d8662d6fe924588d84f9a6dec14eff2e5519ad3475bb80c8ab3058

See more details on using hashes here.

File details

Details for the file sctl-2020.0.4-py3-none-any.whl.

File metadata

  • Download URL: sctl-2020.0.4-py3-none-any.whl
  • Upload date:
  • Size: 7.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.0 CPython/3.8.4

File hashes

Hashes for sctl-2020.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b80ec44795eeb15a741ef5b85f0aa9fdb738e5a2a5fc2dfb07da125a6a9425e8
MD5 0f1ac17314bb9e3030a6b303d9c0492e
BLAKE2b-256 144a7592d4bb80905ce7f162e7a0d2c4ae60fa98a00fcf11f752b4d3a57a21f1

See more details on using hashes here.

Supported by

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