#!/bin/sh -eu # Don't mess with containers that don't have /sys/fs/cgroup configured # (lxc.mount.auto = cgroup:mixed) if touch ${LXC_ROOTFS_MOUNT}/sys/fs/cgroup/lxcfs; then rm ${LXC_ROOTFS_MOUNT}/sys/fs/cgroup/lxcfs else exit 0 fi # /proc files if [ -d @LXCFSTARGETDIR@/proc/ ]; then for entry in @LXCFSTARGETDIR@/proc/*; do [ -e "${LXC_ROOTFS_MOUNT}/proc/$(basename $entry)" ] || continue mount -n --bind $entry ${LXC_ROOTFS_MOUNT}/proc/$(basename $entry) done fi # no need for lxcfs cgroups if we have cgroup namespaces [ -n "$LXC_CGNS_AWARE" ] && [ -f /proc/self/ns/cgroup ] && exit 0 # /sys/fs/cgroup files if [ -d "${LXC_ROOTFS_MOUNT}/sys/fs/cgroup" ]; then if [ -d @LXCFSTARGETDIR@/cgroup ]; then for entry in @LXCFSTARGETDIR@/cgroup/*; do DEST=$(basename $entry) if [ "$DEST" = "name=systemd" ]; then DEST="systemd" fi if mountpoint -q ${LXC_ROOTFS_MOUNT}/sys/fs/cgroup/$DEST; then continue fi if [ ! -d ${LXC_ROOTFS_MOUNT}/sys/fs/cgroup/$DEST ]; then mkdir ${LXC_ROOTFS_MOUNT}/sys/fs/cgroup/$DEST fi mount -n --bind $entry ${LXC_ROOTFS_MOUNT}/sys/fs/cgroup/$DEST # make sure that cpu,cpuacct shows up as cpu and cpuacct # separately, else systemd is unhappy if echo $DEST | grep -q ","; then arr=$(echo $DEST | tr "," "\n") for single in $arr do if [ ! -L ${LXC_ROOTFS_MOUNT}/sys/fs/cgroup/$single ]; then ln -s $DEST ${LXC_ROOTFS_MOUNT}/sys/fs/cgroup/$single fi done fi done if [ -d ${LXC_ROOTFS_MOUNT}@LXCFSTARGETDIR@/ ]; then mount -n --bind @LXCFSTARGETDIR@ ${LXC_ROOTFS_MOUNT}@LXCFSTARGETDIR@/ fi fi fi exit 0