<?xml version="1.0"?>
<?xml-stylesheet type="text/css" href="http://linux-vserver.at/skins/common/feed.css?303"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
		<id>http://linux-vserver.at/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Arekm</id>
		<title>Linux-VServer - User contributions [en]</title>
		<link rel="self" type="application/atom+xml" href="http://linux-vserver.at/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Arekm"/>
		<link rel="alternate" type="text/html" href="http://linux-vserver.at/Special:Contributions/Arekm"/>
		<updated>2026-04-10T05:03:56Z</updated>
		<subtitle>User contributions</subtitle>
		<generator>MediaWiki 1.20.2</generator>

	<entry>
		<id>http://linux-vserver.at/util-vserver:Cgroups</id>
		<title>util-vserver:Cgroups</title>
		<link rel="alternate" type="text/html" href="http://linux-vserver.at/util-vserver:Cgroups"/>
				<updated>2009-10-06T17:15:58Z</updated>
		
		<summary type="html">&lt;p&gt;Arekm: /* cgroup and CFS based CPU hard limiting that replaces sched_hard */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Draft - Cgroups and vservers ==&lt;br /&gt;
&lt;br /&gt;
to make cgroups works with vserver your kernel must have the following settings:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
CONFIG_CGROUPS=y&lt;br /&gt;
# CONFIG_CGROUP_DEBUG is not set&lt;br /&gt;
# CONFIG_CGROUP_NS is not set&lt;br /&gt;
CONFIG_CGROUP_FREEZER=y&lt;br /&gt;
CONFIG_CGROUP_DEVICE=y&lt;br /&gt;
CONFIG_CGROUP_SCHED=y&lt;br /&gt;
CONFIG_CGROUP_CPUACCT=y&lt;br /&gt;
CONFIG_CGROUP_MEM_RES_CTLR=y&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Or in the menu:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
[*] Control Group support                               [ ]   Example debug cgroup subsystem&lt;br /&gt;
[ ]   Namespace cgroup subsystem&lt;br /&gt;
[*]   control group freezer subsystem&lt;br /&gt;
[*]   Device controller for cgroups&lt;br /&gt;
[*]   Cpuset support&lt;br /&gt;
[*] Group CPU scheduler&lt;br /&gt;
[*]   Group scheduling for SCHED_OTHER&lt;br /&gt;
[ ]   Group scheduling for SCHED_RR/FIFO&lt;br /&gt;
      Basis for grouping tasks (Control groups)  ---&amp;gt;&lt;br /&gt;
[*] Simple CPU accounting cgroup subsystem&lt;br /&gt;
[*] Resource counters&lt;br /&gt;
[*] Memory Resource Controller for Control Groups&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
Note about this from the list:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;gt; &amp;gt; I currently have the CONFIG_CGROUP_NS option set in my kernels. Does  &lt;br /&gt;
&amp;gt; &amp;gt; this mean add extra namespace support, or I am preventing the Cgroup  &lt;br /&gt;
&amp;gt; &amp;gt; based scheduling from working by enabling it? Should I unset it and  &lt;br /&gt;
&amp;gt; &amp;gt; rebuild?&lt;br /&gt;
&lt;br /&gt;
yes, with CGROUP_NS enabled, you basically block&lt;br /&gt;
the 'normal' cgroup scheduling which is used by&lt;br /&gt;
util-vserver, and have to handle the croup namespace&lt;br /&gt;
yourself ...&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
You must have the /dev/cgroup mounted with the 'cpu' option. For exemple for cpuset, memory and cpu cgroup handling:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;(root)&amp;gt; grep cgroup  /etc/fstab&lt;br /&gt;
cpuset  /dev/cgroup     cgroup  rw,cpuset,cpu,memory    0       0&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
Then you must create on you guest /etc/vservers/&amp;lt;guest&amp;gt;/cgroup/ all the files put here will be copied to the guest cgroup when created. The doc for cgroup is not on the great flower page but in the source of the latests utils. You can have a default cgroup directory for all guest that can be overrided by each guest's cgroup directory.&lt;br /&gt;
&lt;br /&gt;
== Draft - Distributing cpu shares with cgroups ==&lt;br /&gt;
&lt;br /&gt;
From what i gathered in sched-design-CFS.txt [http://people.redhat.com/mingo/cfs-scheduler/sched-design-CFS.txt]&lt;br /&gt;
&lt;br /&gt;
This is simply done by adjusting the cpu.shares. Just do:&lt;br /&gt;
&lt;br /&gt;
echo '512' &amp;gt; /dev/cgroup/&amp;lt;guest name&amp;gt;/cpu.shares&lt;br /&gt;
&lt;br /&gt;
The share you get is equal to the guest's share divided by the sum of the cpu shares of all the guest. So for exemple :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
vserver guest 1 =&amp;gt; 512   &lt;br /&gt;
vserver guest 2 =&amp;gt; 512&lt;br /&gt;
vserver guest 3 =&amp;gt; 2048&lt;br /&gt;
vserver guest 4 =&amp;gt; 512&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
so you have a total of 3584 cpu shares (2048+512+512+512) , then you get :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
vserver guest 1 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
vserver guest 2 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
vserver guest 3 =&amp;gt; 2048 / 3584 = 57% cpu&lt;br /&gt;
vserver guest 4 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Note that this is fair scheduling and this will not enfore HARD limit (as far as i know).&lt;br /&gt;
&lt;br /&gt;
== Making share permanent with util vserver ==&lt;br /&gt;
&lt;br /&gt;
You must use the &amp;quot;cgroup&amp;quot; directory. You can apply defaults to all vservers or choose different settings for each guest:&lt;br /&gt;
&lt;br /&gt;
* /etc/vservers/.default/cgroup    , this directory contains settings applying to all guest when they start&lt;br /&gt;
* /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup , this directory contains settings for the guest when it starts.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Exemple :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
mkdir /etc/vservers/.defaults/cgroup&lt;br /&gt;
mkdir /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup&lt;br /&gt;
echo '2048' &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.shares&lt;br /&gt;
# if you use those then enable them if not put 0 instead of 1&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpuset.cpus&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpuset.mems&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Note that /etc/vservers is an exemple, in my Aqueos install i use /usr/local/etc/vservers but /etc/vservers seems to be the defaults for the classic installs.&lt;br /&gt;
&lt;br /&gt;
Regards,&lt;br /&gt;
Ghislain.&lt;br /&gt;
&lt;br /&gt;
== cgroup and CFS based CPU hard limiting that replaces sched_hard ==&lt;br /&gt;
&lt;br /&gt;
This feature is currently avilable in patch-2.6.31.2-vs2.3.0.36.15.diff.&lt;br /&gt;
&lt;br /&gt;
Example for 2/5th of the all cpu power, or 40%&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
# force CFS hard limit&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_hard_limit&lt;br /&gt;
# time assigned to guest (in us)&lt;br /&gt;
echo 200000 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_runtime_us&lt;br /&gt;
# in each specified period (in us)&lt;br /&gt;
echo 500000 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_period_us&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Arekm</name></author>	</entry>

	<entry>
		<id>http://linux-vserver.at/util-vserver:Cgroups</id>
		<title>util-vserver:Cgroups</title>
		<link rel="alternate" type="text/html" href="http://linux-vserver.at/util-vserver:Cgroups"/>
				<updated>2009-10-06T17:11:55Z</updated>
		
		<summary type="html">&lt;p&gt;Arekm: /* cgroup and CFS based CPU hard limiting that replaces sched_hard */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Draft - Cgroups and vservers ==&lt;br /&gt;
&lt;br /&gt;
to make cgroups works with vserver your kernel must have the following settings:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
CONFIG_CGROUPS=y&lt;br /&gt;
# CONFIG_CGROUP_DEBUG is not set&lt;br /&gt;
# CONFIG_CGROUP_NS is not set&lt;br /&gt;
CONFIG_CGROUP_FREEZER=y&lt;br /&gt;
CONFIG_CGROUP_DEVICE=y&lt;br /&gt;
CONFIG_CGROUP_SCHED=y&lt;br /&gt;
CONFIG_CGROUP_CPUACCT=y&lt;br /&gt;
CONFIG_CGROUP_MEM_RES_CTLR=y&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Or in the menu:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
[*] Control Group support                               [ ]   Example debug cgroup subsystem&lt;br /&gt;
[ ]   Namespace cgroup subsystem&lt;br /&gt;
[*]   control group freezer subsystem&lt;br /&gt;
[*]   Device controller for cgroups&lt;br /&gt;
[*]   Cpuset support&lt;br /&gt;
[*] Group CPU scheduler&lt;br /&gt;
[*]   Group scheduling for SCHED_OTHER&lt;br /&gt;
[ ]   Group scheduling for SCHED_RR/FIFO&lt;br /&gt;
      Basis for grouping tasks (Control groups)  ---&amp;gt;&lt;br /&gt;
[*] Simple CPU accounting cgroup subsystem&lt;br /&gt;
[*] Resource counters&lt;br /&gt;
[*] Memory Resource Controller for Control Groups&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
Note about this from the list:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;gt; &amp;gt; I currently have the CONFIG_CGROUP_NS option set in my kernels. Does  &lt;br /&gt;
&amp;gt; &amp;gt; this mean add extra namespace support, or I am preventing the Cgroup  &lt;br /&gt;
&amp;gt; &amp;gt; based scheduling from working by enabling it? Should I unset it and  &lt;br /&gt;
&amp;gt; &amp;gt; rebuild?&lt;br /&gt;
&lt;br /&gt;
yes, with CGROUP_NS enabled, you basically block&lt;br /&gt;
the 'normal' cgroup scheduling which is used by&lt;br /&gt;
util-vserver, and have to handle the croup namespace&lt;br /&gt;
yourself ...&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
You must have the /dev/cgroup mounted with the 'cpu' option. For exemple for cpuset, memory and cpu cgroup handling:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;(root)&amp;gt; grep cgroup  /etc/fstab&lt;br /&gt;
cpuset  /dev/cgroup     cgroup  rw,cpuset,cpu,memory    0       0&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
Then you must create on you guest /etc/vservers/&amp;lt;guest&amp;gt;/cgroup/ all the files put here will be copied to the guest cgroup when created. The doc for cgroup is not on the great flower page but in the source of the latests utils. You can have a default cgroup directory for all guest that can be overrided by each guest's cgroup directory.&lt;br /&gt;
&lt;br /&gt;
== Draft - Distributing cpu shares with cgroups ==&lt;br /&gt;
&lt;br /&gt;
From what i gathered in sched-design-CFS.txt [http://people.redhat.com/mingo/cfs-scheduler/sched-design-CFS.txt]&lt;br /&gt;
&lt;br /&gt;
This is simply done by adjusting the cpu.shares. Just do:&lt;br /&gt;
&lt;br /&gt;
echo '512' &amp;gt; /dev/cgroup/&amp;lt;guest name&amp;gt;/cpu.shares&lt;br /&gt;
&lt;br /&gt;
The share you get is equal to the guest's share divided by the sum of the cpu shares of all the guest. So for exemple :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
vserver guest 1 =&amp;gt; 512   &lt;br /&gt;
vserver guest 2 =&amp;gt; 512&lt;br /&gt;
vserver guest 3 =&amp;gt; 2048&lt;br /&gt;
vserver guest 4 =&amp;gt; 512&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
so you have a total of 3584 cpu shares (2048+512+512+512) , then you get :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
vserver guest 1 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
vserver guest 2 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
vserver guest 3 =&amp;gt; 2048 / 3584 = 57% cpu&lt;br /&gt;
vserver guest 4 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Note that this is fair scheduling and this will not enfore HARD limit (as far as i know).&lt;br /&gt;
&lt;br /&gt;
== Making share permanent with util vserver ==&lt;br /&gt;
&lt;br /&gt;
You must use the &amp;quot;cgroup&amp;quot; directory. You can apply defaults to all vservers or choose different settings for each guest:&lt;br /&gt;
&lt;br /&gt;
* /etc/vservers/.default/cgroup    , this directory contains settings applying to all guest when they start&lt;br /&gt;
* /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup , this directory contains settings for the guest when it starts.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Exemple :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
mkdir /etc/vservers/.defaults/cgroup&lt;br /&gt;
mkdir /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup&lt;br /&gt;
echo '2048' &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.shares&lt;br /&gt;
# if you use those then enable them if not put 0 instead of 1&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpuset.cpus&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpuset.mems&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Note that /etc/vservers is an exemple, in my Aqueos install i use /usr/local/etc/vservers but /etc/vservers seems to be the defaults for the classic installs.&lt;br /&gt;
&lt;br /&gt;
Regards,&lt;br /&gt;
Ghislain.&lt;br /&gt;
&lt;br /&gt;
== cgroup and CFS based CPU hard limiting that replaces sched_hard ==&lt;br /&gt;
&lt;br /&gt;
This feature is currently avilable in patch-2.6.31.2-vs2.3.0.36.15.diff.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
# force CFS hard limit&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_hard_limit&lt;br /&gt;
# time assigned to guest (in us)&lt;br /&gt;
echo 200000 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_runtime_us&lt;br /&gt;
# in each specified period (in us)&lt;br /&gt;
echo 500000 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_period_us&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Arekm</name></author>	</entry>

	<entry>
		<id>http://linux-vserver.at/util-vserver:Cgroups</id>
		<title>util-vserver:Cgroups</title>
		<link rel="alternate" type="text/html" href="http://linux-vserver.at/util-vserver:Cgroups"/>
				<updated>2009-10-06T17:10:25Z</updated>
		
		<summary type="html">&lt;p&gt;Arekm: /* cgroup and CFS based CPU hard limiting that replaces sched_hard */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Draft - Cgroups and vservers ==&lt;br /&gt;
&lt;br /&gt;
to make cgroups works with vserver your kernel must have the following settings:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
CONFIG_CGROUPS=y&lt;br /&gt;
# CONFIG_CGROUP_DEBUG is not set&lt;br /&gt;
# CONFIG_CGROUP_NS is not set&lt;br /&gt;
CONFIG_CGROUP_FREEZER=y&lt;br /&gt;
CONFIG_CGROUP_DEVICE=y&lt;br /&gt;
CONFIG_CGROUP_SCHED=y&lt;br /&gt;
CONFIG_CGROUP_CPUACCT=y&lt;br /&gt;
CONFIG_CGROUP_MEM_RES_CTLR=y&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Or in the menu:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
[*] Control Group support                               [ ]   Example debug cgroup subsystem&lt;br /&gt;
[ ]   Namespace cgroup subsystem&lt;br /&gt;
[*]   control group freezer subsystem&lt;br /&gt;
[*]   Device controller for cgroups&lt;br /&gt;
[*]   Cpuset support&lt;br /&gt;
[*] Group CPU scheduler&lt;br /&gt;
[*]   Group scheduling for SCHED_OTHER&lt;br /&gt;
[ ]   Group scheduling for SCHED_RR/FIFO&lt;br /&gt;
      Basis for grouping tasks (Control groups)  ---&amp;gt;&lt;br /&gt;
[*] Simple CPU accounting cgroup subsystem&lt;br /&gt;
[*] Resource counters&lt;br /&gt;
[*] Memory Resource Controller for Control Groups&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
Note about this from the list:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;gt; &amp;gt; I currently have the CONFIG_CGROUP_NS option set in my kernels. Does  &lt;br /&gt;
&amp;gt; &amp;gt; this mean add extra namespace support, or I am preventing the Cgroup  &lt;br /&gt;
&amp;gt; &amp;gt; based scheduling from working by enabling it? Should I unset it and  &lt;br /&gt;
&amp;gt; &amp;gt; rebuild?&lt;br /&gt;
&lt;br /&gt;
yes, with CGROUP_NS enabled, you basically block&lt;br /&gt;
the 'normal' cgroup scheduling which is used by&lt;br /&gt;
util-vserver, and have to handle the croup namespace&lt;br /&gt;
yourself ...&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
You must have the /dev/cgroup mounted with the 'cpu' option. For exemple for cpuset, memory and cpu cgroup handling:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;(root)&amp;gt; grep cgroup  /etc/fstab&lt;br /&gt;
cpuset  /dev/cgroup     cgroup  rw,cpuset,cpu,memory    0       0&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
Then you must create on you guest /etc/vservers/&amp;lt;guest&amp;gt;/cgroup/ all the files put here will be copied to the guest cgroup when created. The doc for cgroup is not on the great flower page but in the source of the latests utils. You can have a default cgroup directory for all guest that can be overrided by each guest's cgroup directory.&lt;br /&gt;
&lt;br /&gt;
== Draft - Distributing cpu shares with cgroups ==&lt;br /&gt;
&lt;br /&gt;
From what i gathered in sched-design-CFS.txt [http://people.redhat.com/mingo/cfs-scheduler/sched-design-CFS.txt]&lt;br /&gt;
&lt;br /&gt;
This is simply done by adjusting the cpu.shares. Just do:&lt;br /&gt;
&lt;br /&gt;
echo '512' &amp;gt; /dev/cgroup/&amp;lt;guest name&amp;gt;/cpu.shares&lt;br /&gt;
&lt;br /&gt;
The share you get is equal to the guest's share divided by the sum of the cpu shares of all the guest. So for exemple :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
vserver guest 1 =&amp;gt; 512   &lt;br /&gt;
vserver guest 2 =&amp;gt; 512&lt;br /&gt;
vserver guest 3 =&amp;gt; 2048&lt;br /&gt;
vserver guest 4 =&amp;gt; 512&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
so you have a total of 3584 cpu shares (2048+512+512+512) , then you get :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
vserver guest 1 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
vserver guest 2 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
vserver guest 3 =&amp;gt; 2048 / 3584 = 57% cpu&lt;br /&gt;
vserver guest 4 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Note that this is fair scheduling and this will not enfore HARD limit (as far as i know).&lt;br /&gt;
&lt;br /&gt;
== Making share permanent with util vserver ==&lt;br /&gt;
&lt;br /&gt;
You must use the &amp;quot;cgroup&amp;quot; directory. You can apply defaults to all vservers or choose different settings for each guest:&lt;br /&gt;
&lt;br /&gt;
* /etc/vservers/.default/cgroup    , this directory contains settings applying to all guest when they start&lt;br /&gt;
* /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup , this directory contains settings for the guest when it starts.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Exemple :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
mkdir /etc/vservers/.defaults/cgroup&lt;br /&gt;
mkdir /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup&lt;br /&gt;
echo '2048' &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.shares&lt;br /&gt;
# if you use those then enable them if not put 0 instead of 1&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpuset.cpus&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpuset.mems&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Note that /etc/vservers is an exemple, in my Aqueos install i use /usr/local/etc/vservers but /etc/vservers seems to be the defaults for the classic installs.&lt;br /&gt;
&lt;br /&gt;
Regards,&lt;br /&gt;
Ghislain.&lt;br /&gt;
&lt;br /&gt;
== cgroup and CFS based CPU hard limiting that replaces sched_hard ==&lt;br /&gt;
&lt;br /&gt;
This feature is currently avilable in patch-2.6.31.2-vs2.3.0.36.15.diff.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
# force CFS hard limit&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_hard_limit&lt;br /&gt;
# time assigned to guest (in us)&lt;br /&gt;
echo 500000 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_runtime_us&lt;br /&gt;
# in each specified period (in us)&lt;br /&gt;
echo 200000 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_period_us&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Arekm</name></author>	</entry>

	<entry>
		<id>http://linux-vserver.at/util-vserver:Cgroups</id>
		<title>util-vserver:Cgroups</title>
		<link rel="alternate" type="text/html" href="http://linux-vserver.at/util-vserver:Cgroups"/>
				<updated>2009-10-06T17:09:53Z</updated>
		
		<summary type="html">&lt;p&gt;Arekm: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Draft - Cgroups and vservers ==&lt;br /&gt;
&lt;br /&gt;
to make cgroups works with vserver your kernel must have the following settings:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
CONFIG_CGROUPS=y&lt;br /&gt;
# CONFIG_CGROUP_DEBUG is not set&lt;br /&gt;
# CONFIG_CGROUP_NS is not set&lt;br /&gt;
CONFIG_CGROUP_FREEZER=y&lt;br /&gt;
CONFIG_CGROUP_DEVICE=y&lt;br /&gt;
CONFIG_CGROUP_SCHED=y&lt;br /&gt;
CONFIG_CGROUP_CPUACCT=y&lt;br /&gt;
CONFIG_CGROUP_MEM_RES_CTLR=y&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Or in the menu:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
[*] Control Group support                               [ ]   Example debug cgroup subsystem&lt;br /&gt;
[ ]   Namespace cgroup subsystem&lt;br /&gt;
[*]   control group freezer subsystem&lt;br /&gt;
[*]   Device controller for cgroups&lt;br /&gt;
[*]   Cpuset support&lt;br /&gt;
[*] Group CPU scheduler&lt;br /&gt;
[*]   Group scheduling for SCHED_OTHER&lt;br /&gt;
[ ]   Group scheduling for SCHED_RR/FIFO&lt;br /&gt;
      Basis for grouping tasks (Control groups)  ---&amp;gt;&lt;br /&gt;
[*] Simple CPU accounting cgroup subsystem&lt;br /&gt;
[*] Resource counters&lt;br /&gt;
[*] Memory Resource Controller for Control Groups&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
Note about this from the list:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;gt; &amp;gt; I currently have the CONFIG_CGROUP_NS option set in my kernels. Does  &lt;br /&gt;
&amp;gt; &amp;gt; this mean add extra namespace support, or I am preventing the Cgroup  &lt;br /&gt;
&amp;gt; &amp;gt; based scheduling from working by enabling it? Should I unset it and  &lt;br /&gt;
&amp;gt; &amp;gt; rebuild?&lt;br /&gt;
&lt;br /&gt;
yes, with CGROUP_NS enabled, you basically block&lt;br /&gt;
the 'normal' cgroup scheduling which is used by&lt;br /&gt;
util-vserver, and have to handle the croup namespace&lt;br /&gt;
yourself ...&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
You must have the /dev/cgroup mounted with the 'cpu' option. For exemple for cpuset, memory and cpu cgroup handling:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;(root)&amp;gt; grep cgroup  /etc/fstab&lt;br /&gt;
cpuset  /dev/cgroup     cgroup  rw,cpuset,cpu,memory    0       0&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
Then you must create on you guest /etc/vservers/&amp;lt;guest&amp;gt;/cgroup/ all the files put here will be copied to the guest cgroup when created. The doc for cgroup is not on the great flower page but in the source of the latests utils. You can have a default cgroup directory for all guest that can be overrided by each guest's cgroup directory.&lt;br /&gt;
&lt;br /&gt;
== Draft - Distributing cpu shares with cgroups ==&lt;br /&gt;
&lt;br /&gt;
From what i gathered in sched-design-CFS.txt [http://people.redhat.com/mingo/cfs-scheduler/sched-design-CFS.txt]&lt;br /&gt;
&lt;br /&gt;
This is simply done by adjusting the cpu.shares. Just do:&lt;br /&gt;
&lt;br /&gt;
echo '512' &amp;gt; /dev/cgroup/&amp;lt;guest name&amp;gt;/cpu.shares&lt;br /&gt;
&lt;br /&gt;
The share you get is equal to the guest's share divided by the sum of the cpu shares of all the guest. So for exemple :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
vserver guest 1 =&amp;gt; 512   &lt;br /&gt;
vserver guest 2 =&amp;gt; 512&lt;br /&gt;
vserver guest 3 =&amp;gt; 2048&lt;br /&gt;
vserver guest 4 =&amp;gt; 512&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
so you have a total of 3584 cpu shares (2048+512+512+512) , then you get :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
vserver guest 1 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
vserver guest 2 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
vserver guest 3 =&amp;gt; 2048 / 3584 = 57% cpu&lt;br /&gt;
vserver guest 4 =&amp;gt; 512 / 3584 = 14%  cpu&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;br/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Note that this is fair scheduling and this will not enfore HARD limit (as far as i know).&lt;br /&gt;
&lt;br /&gt;
== Making share permanent with util vserver ==&lt;br /&gt;
&lt;br /&gt;
You must use the &amp;quot;cgroup&amp;quot; directory. You can apply defaults to all vservers or choose different settings for each guest:&lt;br /&gt;
&lt;br /&gt;
* /etc/vservers/.default/cgroup    , this directory contains settings applying to all guest when they start&lt;br /&gt;
* /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup , this directory contains settings for the guest when it starts.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Exemple :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
mkdir /etc/vservers/.defaults/cgroup&lt;br /&gt;
mkdir /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup&lt;br /&gt;
echo '2048' &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.shares&lt;br /&gt;
# if you use those then enable them if not put 0 instead of 1&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpuset.cpus&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpuset.mems&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Note that /etc/vservers is an exemple, in my Aqueos install i use /usr/local/etc/vservers but /etc/vservers seems to be the defaults for the classic installs.&lt;br /&gt;
&lt;br /&gt;
Regards,&lt;br /&gt;
Ghislain.&lt;br /&gt;
&lt;br /&gt;
== cgroup and CFS based CPU hard limiting that replaces sched_hard ==&lt;br /&gt;
&lt;br /&gt;
This feature is currently avilable in patch-2.6.31.2-vs2.3.0.36.15.diff.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
# force CFS hard limit&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_hard_limit&lt;br /&gt;
# time assigned to guest (in us)&lt;br /&gt;
echo 500000 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_runtime_us&lt;br /&gt;
# in each specified period (in us)&lt;br /&gt;
echo 1 &amp;gt; /etc/vservers/&amp;lt;guestname&amp;gt;/cgroup/cpu.cfs_period_us&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Arekm</name></author>	</entry>

	</feed>