From c64c575abb1d71c070d37840758ffbfa8fbf5c58 Mon Sep 17 00:00:00 2001 From: Chris F Ravenscroft Date: Sun, 26 Jul 2015 17:05:06 -0700 Subject: [PATCH] Now with cgroup support --- bocker | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/bocker b/bocker index ab2c89a..b6300ad 100755 --- a/bocker +++ b/bocker @@ -1,6 +1,6 @@ #!/usr/bin/env bash set -o errexit -o nounset -o pipefail; shopt -s nullglob -btrfs_path='/var/bocker'; +btrfs_path='/var/bocker'; cgroups='cpu,cpuacct,cpuset,memory'; $(cgget -h &> /dev/null) && CGX="cgexec -g $cgroups" || CGX='_=' function bocker_check() { btrfs subvolume list "$btrfs_path" | grep -qw "$1" && echo 0 || echo 1 } @@ -18,6 +18,7 @@ fi function bocker_rm() { #HELP Delete an image or container:\nBOCKER rm [[ "$(bocker_check "$1")" == 1 ]] && echo "No container named '$1' exists" && exit 1 btrfs subvolume delete "$btrfs_path/$1" > /dev/null +cgdelete -g $cgroups:/$1 &> /dev/null || true echo "Removed: $1" } function bocker_images() { #HELP List images:\nBOCKER images @@ -28,9 +29,8 @@ done } function bocker_ps() { #HELP List containers:\nBOCKER ps echo -e "CONTAINER_ID\t\tCOMMAND" -for ps in "$btrfs_path"/ps_*; do - ps=$(basename "$ps") - echo -e "$ps\t\t$(cat "$btrfs_path/$ps/$ps.cmd")" +for ps in $(ls -dtr "$btrfs_path"/ps_*); do + bps=${ps##/*/}; echo -e "$bps\t\t$(cat "$btrfs_path/$bps/$bps.cmd")" done } function bocker_run() { #HELP Create a container:\nBOCKER run /dev/null echo 'nameserver 8.8.8.8' > "$btrfs_path/$uuid"/etc/resolv.conf echo "$cmd" > "$btrfs_path/$uuid/$uuid.cmd" -ip netns exec netns_"$uuid" "unshare" -fp --mount-proc "chroot" \ +cgcreate -g $cgroups:/$uuid && cgset -r cpuset.cpus=0-$(($(grep vendor_id /proc/cpuinfo | wc -l)-1)) $uuid && cgset -r cpuset.mems=0 $uuid &> /dev/null || true +$CGX:$uuid ip netns exec netns_"$uuid" "unshare" -fp --mount-proc "chroot" \ "$btrfs_path/$uuid" /bin/sh -c "/bin/mount -t proc proc /proc && $cmd" \ 2>&1 | tee "$btrfs_path/$uuid/$uuid.log" || true ip link del dev veth0_"$uuid"