Skip to main content

A small wrapper for creating LXD system containers for development purposes.

Project description

dev-lxc

This is a tidy little Python script I use when I want to quickly create an LXD system container for development purposes. It mounts the current directory in the home directory of the instance.

Installation

It's a single script file. Make sure you have LXD installed and Python 3.10 or higher. Get the file, make it executable, and put it on your PATH somewhere.

Basic Usage

Create an instance

Create an instance using a specific Ubuntu series, by codename:

dev_lxc create jammy

The instance name is generated from the current directory, so you can only have one instance of each series per directory. Names will clash.

If you have a valid YAML file for configuring the instance (nice for if you want it to start with certain packages installed):

dev_lxc create jammy --config ./my-config.yaml

Open a shell in an instance

Once you've created an instance, you can spin up a shell in it:

dev_lxc shell jammy

The default user (ubuntu) should be uid-mapped to your user, so file permissions should be okay.

Exec a command in an instance

dev_lxc exec jammy 'echo "hello"'

This executes using bash, so try not to get too fancy. You can also provide environment variables:

dev_lxc exec jammy 'echo "hello $MITCH"' --env MITCH="mitchell"

Stop or Start an instance

dev_lxc stop jammy

Stops the instance from running. Most other commands (shell, exec) should start the instance if it's stopped before running.

dev_lxc start jammy

Starts it up again.

Remove Instance

dev_lxc remove jammy

This deletes the instance. It is gone for good.

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

dev_lxc-0.4.4.tar.gz (5.6 kB view details)

Uploaded Source

Built Distribution

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

dev_lxc-0.4.4-py3-none-any.whl (6.6 kB view details)

Uploaded Python 3

File details

Details for the file dev_lxc-0.4.4.tar.gz.

File metadata

  • Download URL: dev_lxc-0.4.4.tar.gz
  • Upload date:
  • Size: 5.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.12.3 Linux/6.17.0-1011-oem

File hashes

Hashes for dev_lxc-0.4.4.tar.gz
Algorithm Hash digest
SHA256 a1f5fed485f9d7856502aa50fc41a3e8836fd8e03deb53871e66e40fe4184721
MD5 fafc019652b9a00dcda1b9d2a2559ef8
BLAKE2b-256 6fce5df7881336eda7fbdd1e42cb7486fd75059ca9082b1e3a6c4de092a10257

See more details on using hashes here.

File details

Details for the file dev_lxc-0.4.4-py3-none-any.whl.

File metadata

  • Download URL: dev_lxc-0.4.4-py3-none-any.whl
  • Upload date:
  • Size: 6.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.12.3 Linux/6.17.0-1011-oem

File hashes

Hashes for dev_lxc-0.4.4-py3-none-any.whl
Algorithm Hash digest
SHA256 aab6c9ea5d265752f170375fec2029365a6cce688aee96fc5c8cb1ff566f3b65
MD5 6f1a2f3d5d37193c2468c1b3079e5bc1
BLAKE2b-256 07fd3a51f09ad6f5a7472ccb6781363ca28ceb7a170f86d473aa8f793496100b

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