Last active
September 5, 2019 23:31
-
-
Save alexhrescale/474d55635154e6b2cd6362c3bb403faf to your computer and use it in GitHub Desktop.
nix environment for container builders using buildah, podman
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
let | |
pkgs = import <nixpkgs> {}; | |
stdenv = pkgs.stdenv; | |
in stdenv.mkDerivation rec { | |
name = "env"; | |
env = pkgs.buildEnv { name = name; paths = buildInputs; }; | |
buildInputs = [ | |
pkgs.buildah | |
pkgs.conmon | |
pkgs.podman | |
pkgs.runc | |
pkgs.shadow | |
pkgs.skopeo | |
pkgs.slirp4netns | |
]; | |
shellHook = '' | |
# <setup for buildah toolchain> | |
sudo mkdir -p /etc/containers | |
cat <<EOF | sudo tee /etc/containers/policy.json | |
{ | |
"default": [ | |
{ | |
"type": "insecureAcceptAnything" | |
} | |
] | |
} | |
cat <<EOF | sudo tee /etc/containers/registries.conf | |
[registries.search] | |
registries = [ 'docker.io' ] | |
EOF | |
# documentation for this is very disorganized at this point | |
# see https://github.com/containers/libpod/blob/master/docs/libpod.conf.5.md | |
cat <<EOF | tee $HOME/podman.conf | |
conmon_path = [ "$(which conmon)" ] | |
events_logger = "file" | |
[runtimes] | |
runc = [ "$(which runc)" ] | |
EOF | |
echo $(whoami):100000:65536 | sudo tee /etc/sub{u,g}id | |
head /etc/subuid /etc/subgid | |
sudo chown root: $(which new{u,g}idmap) | |
sudo chmod 4555 $(which new{u,g}idmap) | |
ls -l $(which new{u,g}idmap) | |
function docker() { | |
podman --config $HOME/podman.conf $* | |
} | |
docker --version | |
# </setup for buildah toolchain> | |
''; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment