Skip to content
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
75 changes: 75 additions & 0 deletions cgroups/cgroup.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,16 @@

import os
import getpass
import subprocess
from subprocess import Popen, PIPE

from cgroups.common import BASE_CGROUPS, CgroupsException
from cgroups.user import create_user_cgroups

HIERARCHIES = [
'cpu',
'memory',
'blkio',
]
MEMORY_DEFAULT = -1
CPU_DEFAULT = 1024
Expand Down Expand Up @@ -48,6 +51,10 @@ def __init__(self, name, hierarchies='all', user='current'):
if not os.path.exists(cgroup):
os.mkdir(cgroup)
self.cgroups[hierarchy] = cgroup
# Blkio related members
self.devName = None
self.devMaj = None
self.devMin = None

def _get_cgroup_file(self, hierarchy, file_name):
return os.path.join(self.cgroups[hierarchy], file_name)
Expand Down Expand Up @@ -168,6 +175,14 @@ def _format_memory_value(self, unit, limit=None):
value = limit * 1024 * 1024 * 1024
return value

def _get_device_major_minor(self, devName):
devPath = "/dev/" + devName
proc = Popen(['ls', '-l', devPath], stdout=PIPE)
p2 = Popen(['cut', '-d', " ", '-f', '5'], stdin=proc.stdout, stdout=PIPE)
p3 = Popen(['cut', '-d', ",", '-f', '1'], stdin=p2.stdout, stdout=PIPE)
proc = Popen(['ls', '-l', devPath], stdout=PIPE)
p4 = Popen(['cut', '-d', " ", '-f', '6'], stdin=proc.stdout, stdout=PIPE)
return p3.stdout.read().decode("utf-8").strip('\n'), p4.stdout.read().decode("utf-8").strip('\n')

def set_memory_limit(self, limit=None, unit='megabytes'):
if 'memory' in self.cgroups:
Expand All @@ -191,3 +206,63 @@ def memory_limit(self):
return value
else:
return None

# BLKIO

def set_blkio_dev(self, devName=None):
if 'blkio' in self.cgroups:
self.devName = devName
self.devMaj, self.devMin = self._get_device_major_minor(self.devName)

def blkio_dev(self):
if 'blkio' in self.cgroups and self.devName != None:
return self.devName
else:
return None

def set_blkio_read_limit(self, limit=None, unit='megabytes'):
if 'blkio' in self.cgroups and self.devName != None:
value = self._format_memory_value(unit, limit)
blkio_read_bps_file = self._get_cgroup_file(
'blkio', 'blkio.throttle.read_bps_device')
with open(blkio_read_bps_file, 'w+') as f:
f.write('{}:{} {}'.format(self.devMaj, self.devMin, value))
else:
raise CgroupsException(
'BLKIO hierarchy not available in this cgroup \
or devName is not set')

def blkio_read_limit(self):
if 'blkio' in self.cgroups and self.devName != None:
read_limit_file = self._get_cgroup_file(
'blkio', 'blkio.throttle.read_bps_device')
with open(read_limit_file, 'r+') as f:
value = f.read().split('\n')[0]
value = value.split(' ')[1]
return value
else:
return None

def set_blkio_write_limit(self, limit=None, unit='megabytes'):
if 'blkio' in self.cgroups and self.devName != None:
value = self._format_memory_value(unit, limit)
blkio_write_bps_file = self._get_cgroup_file(
'blkio', 'blkio.throttle.write_bps_device')
with open(blkio_write_bps_file, 'w+') as f:
f.write('{}:{} {}'.format(self.devMaj, self.devMin, value))
else:
raise CgroupsException(
'BLKIO hierarchy not available in this cgroup \
or devName is not set')

def blkio_write_limit(self):
if 'blkio' in self.cgroups and self.devName != None:
write_limit_file = self._get_cgroup_file(
'blkio', 'blkio.throttle.write_bps_device')
with open(write_limit_file, 'r+') as f:
value = f.read().split('\n')[0]
value = value.split(' ')[1]
return value
else:
raise CgroupsException(
'BLKIO hierarchy not available in this cgroup')