forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
This patch is inspired by the discussion at http://lkml.org/lkml/2007/4/11/187 and implements per cgroup statistics as suggested by Andrew Morton in http://lkml.org/lkml/2007/4/11/263. The patch is on top of 2.6.21-mm1 with Paul's cgroups v9 patches (forward ported) This patch implements per cgroup statistics infrastructure and re-uses code from the taskstats interface. A new set of cgroup operations are registered with commands and attributes. It should be very easy to *extend* per cgroup statistics, by adding members to the cgroupstats structure. The current model for cgroupstats is a pull, a push model (to post statistics on interesting events), should be very easy to add. Currently user space requests for statistics by passing the cgroup file descriptor. Statistics about the state of all the tasks in the cgroup is returned to user space. TODO's/NOTE: This patch provides an infrastructure for implementing cgroup statistics. Based on the needs of each controller, we can incrementally add more statistics, event based support for notification of statistics, accumulation of taskstats into cgroup statistics in the future. Sample output # ./cgroupstats -C /cgroup/a sleeping 2, blocked 0, running 1, stopped 0, uninterruptible 0 # ./cgroupstats -C /cgroup/ sleeping 154, blocked 0, running 0, stopped 0, uninterruptible 0 If the approach looks good, I'll enhance and post the user space utility for the same Feedback, comments, test results are always welcome! [[email protected]: build fix] Signed-off-by: Balbir Singh <[email protected]> Cc: Paul Menage <[email protected]> Cc: Jay Lan <[email protected]> Signed-off-by: Andrew Morton <[email protected]> Signed-off-by: Linus Torvalds <[email protected]>
- Loading branch information
Balbir Singh
authored and
Linus Torvalds
committed
Oct 19, 2007
1 parent
c2e2c7f
commit 846c7bb
Showing
7 changed files
with
241 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
Control Groupstats is inspired by the discussion at | ||
http://lkml.org/lkml/2007/4/11/187 and implements per cgroup statistics as | ||
suggested by Andrew Morton in http://lkml.org/lkml/2007/4/11/263. | ||
|
||
Per cgroup statistics infrastructure re-uses code from the taskstats | ||
interface. A new set of cgroup operations are registered with commands | ||
and attributes specific to cgroups. It should be very easy to | ||
extend per cgroup statistics, by adding members to the cgroupstats | ||
structure. | ||
|
||
The current model for cgroupstats is a pull, a push model (to post | ||
statistics on interesting events), should be very easy to add. Currently | ||
user space requests for statistics by passing the cgroup path. | ||
Statistics about the state of all the tasks in the cgroup is returned to | ||
user space. | ||
|
||
NOTE: We currently rely on delay accounting for extracting information | ||
about tasks blocked on I/O. If CONFIG_TASK_DELAY_ACCT is disabled, this | ||
information will not be available. | ||
|
||
To extract cgroup statistics a utility very similar to getdelays.c | ||
has been developed, the sample output of the utility is shown below | ||
|
||
~/balbir/cgroupstats # ./getdelays -C "/cgroup/a" | ||
sleeping 1, blocked 0, running 1, stopped 0, uninterruptible 0 | ||
~/balbir/cgroupstats # ./getdelays -C "/cgroup" | ||
sleeping 155, blocked 0, running 1, stopped 0, uninterruptible 2 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
/* cgroupstats.h - exporting per-cgroup statistics | ||
* | ||
* Copyright IBM Corporation, 2007 | ||
* Author Balbir Singh <[email protected]> | ||
* | ||
* This program is free software; you can redistribute it and/or modify it | ||
* under the terms of version 2.1 of the GNU Lesser General Public License | ||
* as published by the Free Software Foundation. | ||
* | ||
* This program is distributed in the hope that it would be useful, but | ||
* WITHOUT ANY WARRANTY; without even the implied warranty of | ||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | ||
*/ | ||
|
||
#ifndef _LINUX_CGROUPSTATS_H | ||
#define _LINUX_CGROUPSTATS_H | ||
|
||
#include <linux/taskstats.h> | ||
|
||
/* | ||
* Data shared between user space and kernel space on a per cgroup | ||
* basis. This data is shared using taskstats. | ||
* | ||
* Most of these states are derived by looking at the task->state value | ||
* For the nr_io_wait state, a flag in the delay accounting structure | ||
* indicates that the task is waiting on IO | ||
* | ||
* Each member is aligned to a 8 byte boundary. | ||
*/ | ||
struct cgroupstats { | ||
__u64 nr_sleeping; /* Number of tasks sleeping */ | ||
__u64 nr_running; /* Number of tasks running */ | ||
__u64 nr_stopped; /* Number of tasks in stopped state */ | ||
__u64 nr_uninterruptible; /* Number of tasks in uninterruptible */ | ||
/* state */ | ||
__u64 nr_io_wait; /* Number of tasks waiting on IO */ | ||
}; | ||
|
||
/* | ||
* Commands sent from userspace | ||
* Not versioned. New commands should only be inserted at the enum's end | ||
* prior to __CGROUPSTATS_CMD_MAX | ||
*/ | ||
|
||
enum { | ||
CGROUPSTATS_CMD_UNSPEC = __TASKSTATS_CMD_MAX, /* Reserved */ | ||
CGROUPSTATS_CMD_GET, /* user->kernel request/get-response */ | ||
CGROUPSTATS_CMD_NEW, /* kernel->user event */ | ||
__CGROUPSTATS_CMD_MAX, | ||
}; | ||
|
||
#define CGROUPSTATS_CMD_MAX (__CGROUPSTATS_CMD_MAX - 1) | ||
|
||
enum { | ||
CGROUPSTATS_TYPE_UNSPEC = 0, /* Reserved */ | ||
CGROUPSTATS_TYPE_CGROUP_STATS, /* contains name + stats */ | ||
__CGROUPSTATS_TYPE_MAX, | ||
}; | ||
|
||
#define CGROUPSTATS_TYPE_MAX (__CGROUPSTATS_TYPE_MAX - 1) | ||
|
||
enum { | ||
CGROUPSTATS_CMD_ATTR_UNSPEC = 0, | ||
CGROUPSTATS_CMD_ATTR_FD, | ||
__CGROUPSTATS_CMD_ATTR_MAX, | ||
}; | ||
|
||
#define CGROUPSTATS_CMD_ATTR_MAX (__CGROUPSTATS_CMD_ATTR_MAX - 1) | ||
|
||
#endif /* _LINUX_CGROUPSTATS_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters