All Projects → mafintosh → Mkcontainer

mafintosh / Mkcontainer

Licence: mit
Lightweight container builder for Linux backed by make and systemd-nspawn

Programming Languages

javascript
184084 projects - #8 most used programming language

mkcontainer

Lightweight container builder for Linux backed by make and systemd-nspawn.

npm install -g mkcontainer

Usage

First make sure you have systemd-nspawn installed.

Then make a Containerfile which has a format similar to a Dockerfile

FROM ubuntu:xenial
RUN rm -f /etc/resolv.conf && echo '8.8.8.8' > /etc/resolv.conf
RUN apt-get update
RUN apt-get install -y git vim curl
RUN curl -fs https://raw.githubusercontent.com/mafintosh/node-install/master/install | sh
RUN node-install 8.9.1

The above Containerfile installs Ubuntu 16.04 (xenial), then updates the name server so dns works, and installs git, vim, curl and node 8.9.1.

To make a container from that Containerfile simply cd into the same dir and run

mkcontainer

This should produce a Makefile, that is automatically run and a container called container.img. The container is around 4GB but should be sparse (see ls -lsh for the actual size)

If you run mkcontainer again the build should be cached. Similar to docker, when you update a line in the Containerfile you cache invalidate every line below it. There is a global cache for each layer stored in ~/.mkcontainer

To run the produced container do sudo systemd-nspawn -a -i container.img /bin/bash

Containerfile

The Containerfile currently understands the following primitives

  • FROM os:version - will bootstrap your container. os can be Ubuntu, Arch and Debian currently. Note that `Arch doesn't have a version.
  • RUN cmd - run a shell command inside the container
  • COPY from to - copy a file into the container. to should be an absolute path.

License

MIT

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].