X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=cgroups.py;h=67b20406f39d43a7247b36e421a138a82dc486e5;hb=refs%2Fheads%2Fplanetstack;hp=cf6ca988c3c2daba6d875bb14054a57c0038f81d;hpb=615a80362868fa7a181df29c25cf8ec1a99178b2;p=nodemanager.git diff --git a/cgroups.py b/cgroups.py index cf6ca98..67b2040 100644 --- a/cgroups.py +++ b/cgroups.py @@ -8,7 +8,8 @@ import pyinotify import logger # Base dir for libvirt -BASE_DIR = '/cgroup/libvirt/' +BASE_DIR = '/sys/fs/cgroup' +SUB_SYSTEMS = ['blkio', 'freezer', 'devices', 'memory', 'cpu,cpuacct', 'cpuset'] VIRT_TECHS = ['lxc'] # Global cgroup mapping. @@ -31,45 +32,50 @@ class CgroupWatch(pyinotify.ProcessEvent): (event.name, event.path)) -logger.verbose("Cgroups: Recognizing already existing cgroups...") -for virt in VIRT_TECHS: - filenames = os.listdir(os.path.join(BASE_DIR, virt)) - for filename in filenames: - path = os.path.join(BASE_DIR, virt, filename) - if os.path.isdir(path): - CGROUPS[filename] = path +#logger.verbose("Cgroups: Recognizing already existing cgroups...") +#for virt in VIRT_TECHS: +# filenames = os.listdir(os.path.join(BASE_DIR, virt)) +# for filename in filenames: +# path = os.path.join(BASE_DIR, virt, filename) +# if os.path.isdir(path): +# CGROUPS[filename] = path -logger.verbose("Cgroups: Initializing watchers...") -wm = pyinotify.WatchManager() -notifier = pyinotify.ThreadedNotifier(wm, CgroupWatch()) -for virt in VIRT_TECHS: - wdd = wm.add_watch(os.path.join(BASE_DIR, virt), - pyinotify.IN_DELETE | pyinotify.IN_CREATE, - rec=False) -notifier.daemon = True -notifier.start() +#logger.verbose("Cgroups: Initializing watchers...") +#wm = pyinotify.WatchManager() +#notifier = pyinotify.ThreadedNotifier(wm, CgroupWatch()) +#for virt in VIRT_TECHS: +# wdd = wm.add_watch(os.path.join(BASE_DIR, virt), +# pyinotify.IN_DELETE | pyinotify.IN_CREATE, +# rec=False) +#notifier.daemon = True +#notifier.start() -def get_cgroup_path(name): - """ Returns the base path for the cgroup with a specific name """ - assert CGROUPS.has_key(name), \ - "No sliver %s managed by libvirt through cgroup!" % name - return CGROUPS[name] +def get_cgroup_paths(subsystem="cpuset"): + cpusetBase = os.path.join(BASE_DIR, subsystem, 'libvirt', 'lxc') + return filter(os.path.isdir, + map(lambda f: os.path.join(cpusetBase, f), + os.listdir(cpusetBase))) + +def get_cgroup_path(name, subsystem="cpuset"): + """ Returns the base path for the cgroup with a specific name or None.""" + return reduce(lambda a, b: b if os.path.basename(b) == name else a, + get_cgroup_paths(subsystem), None) def get_base_path(): return BASE_DIR def get_cgroups(): """ Returns the list of cgroups active at this moment on the node """ - return CGROUPS.keys() + return map(os.path.basename, get_cgroup_paths()) -def write(name, key, value): +def write(name, key, value, subsystem="cpuset"): """ Writes a value to the file key with the cgroup with name """ - base_path = get_cgroup_path(name) + base_path = get_cgroup_path(name, subsystem) with open(os.path.join(base_path, key), 'w') as f: print >>f, value -def append(name, key, value): +def append(name, key, value, subsystem="cpuset"): """ Appends a value to the file key with the cgroup with name """ - base_path = get_cgroup_path(name) + base_path = get_cgroup_path(name, subsystem) with open(os.path.join(base_path, key), 'a') as f: - print >>f, value + print >>f, value