Skip to main content

Balic - Command-line Linux Containers Toolset

Project description

Balič (read balitch) is a command-line toolset for working with LXC containers.

PyPI - License PyPI - Downloads
PyPI - Status PyPI - Format PyPI - Wheel
PyPI - Version PyPI - Python Versions PyPI - Implementation
coverage.io report

Installation

Install balic via pip:

pip install balic

Balic requires the following packages installed:

appdirs
cliff

Usage

Create a new container:

# create a new lxc container called test
balic create -n test

Build setup:

# create test build directory
mkdir test

# create build.sh that echos hello world inside the container
echo 'echo "hello world"' > test/build.sh

# copy test directory into the container and run build.sh
balic build -n test -d test

In case you need to prepare anything in the build directory:

# create prepare.sh which will be executed locally to prepare build dir
echo 'echo "prepare something inside build dir: `dirname "$0"`"' > test/prepare.sh

# run prepare.sh in given build dir
balic prepare -n test -d test

Multi-step builds can be done as well:

# create test_step2 build directory
mkdir test_step2

# create build.sh that echos "another step" inside the container
echo 'echo "another step"' > test_step2/build.sh

# copy test directory into container and run build.sh
balic build -n test -d test_step2

Pack the built container:

# pack test lxc container into rootfs.tar.gz
balic pack -n test -o rootfs.tar.gz

Destroy the container when no longer needed:

# destroy test lxc container
balic destroy -n test

Full workflow:

balic create -n test                 # creates lxc container names test
balic prepare -n test -d build_dir   # run prepare.sh inside the build_dir
balic build -n test -d build_dir     # builds test lxc container using content of build_dir
balic build -n test -d build_dir2    # builds test lxc container using content of build_dir2
balic build -n test -d build_dir3    # builds test lxc container using content of build_dir3
...
balic pack -n test -o rootfs.tar.gz  # packs test lxc container into rootfs.tar.gz
balic destroy -n test                # destroy test lxc container

Use environment input parameter for build and prepare commands:

# to run `build.sh environment` or `prepare.sh environment` use -e input parameter
balic prepare -n test -d test -e production
balic build -n test -d test -e production

Ie. whatever you specify as environment ends up as $1 in build.sh / prepare.sh.

Documentation

Source of the documentaton is available in the Balic repository https://gitlab.com/markuz/balic/tree/master/docs/source

Development

Pull requests welcomed.

Balic git repository is available at https://gitlab.com/markuz/balic

For more information, see https://gitlab.com/markuz/balic/-/blob/master/docs/source/development.rst

License

BSD 3-clause Clear License

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

balic-0.0.7.tar.gz (10.4 kB view details)

Uploaded Source

Built Distribution

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

balic-0.0.7-py2.py3-none-any.whl (11.1 kB view details)

Uploaded Python 2Python 3

File details

Details for the file balic-0.0.7.tar.gz.

File metadata

  • Download URL: balic-0.0.7.tar.gz
  • Upload date:
  • Size: 10.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for balic-0.0.7.tar.gz
Algorithm Hash digest
SHA256 1902ddf8cb6d50f952b8c03e701ed60279419c9d0db5a22805ad9433621fc95d
MD5 af0ff8c1cd53e5f6e5d33d8592f4a4db
BLAKE2b-256 ac506365548797765efc1e43c588816ac1ccb720fc542cabe15862cc8fd4c61d

See more details on using hashes here.

File details

Details for the file balic-0.0.7-py2.py3-none-any.whl.

File metadata

  • Download URL: balic-0.0.7-py2.py3-none-any.whl
  • Upload date:
  • Size: 11.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for balic-0.0.7-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b63376ca727a6cb75d0097dadc811df42d641284a70abf67b32a02f76915b83e
MD5 9949717338ad0ea38636e690ca244600
BLAKE2b-256 d7538f042e4e43da26ecc1ef09a1084b8706345d64909a68c446df1002b81d62

See more details on using hashes here.

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