Commonsense Git, Docker, and Jupyter integrations.
Project description
gsmo
Commonsense Git, Docker, and Jupyter integrations.
- mount local Git clones into purpose-built Docker containers
- easily configure dependencies, set useful default Git configs, and mirror host user/group so that Git commits in container transparently exist on the host
- run scripts non-interactively, automatically Git-commit updated files
- run "remotely" against Git repositories, pushing changes upstream for static, serverless workflows
- easily boot a Jupyter server or Bash shell from a clone and its corresponding Docker image, for interactive work.
See gsmo.yml for configuration options
Usage
Run notebooks non-interactively
gsmo helps run notebooks and scripts in a reproducible fashion (inside Docker containers), and pass-through changes (Git commits) to the host machine:
Running:
gsmo run
in a project directory will:
- load configs (
gsmo.yml) - build a Docker image
- run a container from that image
- run the project's
run.ipynbnotebook inside that container - Git-commit results
Run interactively
Jupyter Server
Build a Docker image from the current directory, configured by gsmo.yml, and launch a Jupyter server with the current directory mounted (and various Git- and OS-level configs set, so that changes/commits transparently pass through to the host machine):
gsmo jupyter # or: gsmo j
- runs at a "random" but stable port (derived from a hash of the module name)
- easily configure Python/Linux environment using
gsmo.yml
Bash shell
Build a Docker image from the current directory, configured by gsmo.yml, and launch a Bash shell with it mounted (and various Git- and OS-level configs set, so that changes/commits transparently pass through to the host machine):
gsmo sh
Module configuration:
gsmo.yml
When you run gsmo in a directory, it will look for a gsmo.yml file in the current directory with any of the following fields and build a corresponding Docker image:
General configs
(see gsmo -h for full/authoritative list):
name(str; default: project directory's basename): module name; also used as repository for built Docker imagepip(strorList[str]):piplibraries to installapt(strorList[str]):aptlibraries to installenv(strorList[str]): environment variables to setenv_file(str): file with environment variablesgroup(strorList[str]): OS groups to add to the user inside the container- paths are accepted, in which case the group that owns that path will be used
tag(strorList[str]): additional Docker tags withinnamerepositorymount(strorList[str]): Docker mounts, in several convenient formats:<path>: equivalent to<path>:/<path>; easily pass local project subdirectories into Docker container, e.g.home/.bashrc,etc/pip.conf, etc.- standard Docker
<src>:<dst>syntax is also supported - in all cases,
~and env vars are expanded
image(str; default:runsascoded/gsmo:<gsmo version>): base Docker image to build from;<gsmo version>will be the pip version ofgsmothat was installedroot(bool; defaultFalse)- when set, run as
rootinside container - by default, host-machine uid+gid are used
- when set, run as
dst(str: default/src): path inside container to mount current directory to
gsmo run configs
These configs are passed into the Docker container / pertain to the running of a script or notebook inside the container (see non-interactive mode):
run(str; default:run.ipynb): notebook to rundir(str; default: current directory): resolve paths (incl. mounts) relative to this directoryyaml(strorList[str]): YAML string(s) with configuration settings for the module being runyaml_path(strorList[str]): YAML file(s) with configuration settings for the module being runcommit(strorList[str]; default:outconfig dir): paths to Git commit after a run (in non-interactive mode)out(str; defaultnbs): directory to write executed notebooks to
gsmo run -h
usage: gsmo [input] run [-h] [-b BRANCH] [--clone] [--commit COMMIT] [-C DIR] [-o OUT] [--push PUSH] [-x RUN] [-y YAML] [-Y YAML_PATH]
optional arguments:
-h, --help show this help message and exit
-b BRANCH, --branch BRANCH
Branch to clone, work in, and push results back to. Can also be passed as a trailing '@<branch>' slug on directory path or remote Git
repo URL. For local repositories, implies --clone
--clone Clone local directory into a temporary dir for duration of the run
--commit COMMIT Paths to `git add` and commit after running
-C DIR, --dir DIR Resolve paths (incl. mounts) relative to this directory (default: current directory)
-o OUT, --out OUT Path or directory to write output notebook to (relative to `--dir` directory; default: "nbs")
--push PUSH Push to this remote spec when done running
-x RUN, --run RUN, --execute RUN
Notebook to run (default: run.ipynb)
-y YAML, --yaml YAML YAML string(s) with configuration settings for the module being run
-Y YAML_PATH, --yaml-path YAML_PATH
YAML file(s) with configuration settings for the module being run
gsmo jupyter configs
gsmo jupyter -h
usage: gsmo [input] jupyter [-h] [-d] [-D] [-O] [-s] [--dir DIR]
optional arguments:
-h, --help show this help message and exit
-d, --detach When booting into Jupyter server mode, detach the container
-D, --no-docker Run in the current shell instead of in Docker
-O, --no-open Skip opening Jupyter notebook server in browser
-s, --shell Open a /bin/bash shell in the container (instead of running a jupyter server)
--dir DIR Root dir for jupyter notebook server (default: --dst / `/src`
Dockerfile
When building the Docker image (in any of the above modes), if a Dockerfile is present in the repository, it will be built and used as the base image (and any gsmo.yml configs applied on top of it).
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gsmo-0.1.1.tar.gz.
File metadata
- Download URL: gsmo-0.1.1.tar.gz
- Upload date:
- Size: 22.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.8.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
086007d9c24bdd46db98f478335948191e5c1b51e66e14a2b72cd15bbd2acf26
|
|
| MD5 |
f7d38614514e87c3280ed840feeb838e
|
|
| BLAKE2b-256 |
494620917f69144108ef83f1597381758aa68ecc1ce30e22cdc66d746f7c5461
|
File details
Details for the file gsmo-0.1.1-py3-none-any.whl.
File metadata
- Download URL: gsmo-0.1.1-py3-none-any.whl
- Upload date:
- Size: 23.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.8.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
240cf332d785399c368f32c2f70a13c3a756064c0f0aa08964e76f19fdf3443f
|
|
| MD5 |
5046a07deff49a05bf11b834ea494b54
|
|
| BLAKE2b-256 |
a33d0e02d355253a556726514770b5101a3f3dc88494acb754f7242ebb4412e8
|