blob: 1ee9caf29e576c0a8a89927fb9cced2ed5521c60 [file] [log] [blame]
Tejun Heo65731572014-04-25 18:28:02 -04001
2Cgroup unified hierarchy
3
4April, 2014 Tejun Heo <tj@kernel.org>
5
6This document describes the changes made by unified hierarchy and
7their rationales. It will eventually be merged into the main cgroup
8documentation.
9
10CONTENTS
11
121. Background
132. Basic Operation
14 2-1. Mounting
15 2-2. cgroup.subtree_control
16 2-3. cgroup.controllers
173. Structural Constraints
18 3-1. Top-down
19 3-2. No internal tasks
Tejun Heo8a0792e2015-06-18 16:54:28 -0400204. Delegation
21 4-1. Model of delegation
22 4-2. Common ancestor rule
235. Other Changes
24 5-1. [Un]populated Notification
25 5-2. Other Core Changes
Tejun Heo6abc8ca2015-08-04 15:20:55 -040026 5-3. Controller File Conventions
27 5-3-1. Format
28 5-3-2. Control Knobs
29 5-4. Per-Controller Changes
30 5-4-1. blkio
31 5-4-2. cpuset
32 5-4-3. memory
Tejun Heo8a0792e2015-06-18 16:54:28 -0400336. Planned Changes
34 6-1. CAP for resource control
Tejun Heo65731572014-04-25 18:28:02 -040035
36
371. Background
38
39cgroup allows an arbitrary number of hierarchies and each hierarchy
40can host any number of controllers. While this seems to provide a
41high level of flexibility, it isn't quite useful in practice.
42
43For example, as there is only one instance of each controller, utility
44type controllers such as freezer which can be useful in all
45hierarchies can only be used in one. The issue is exacerbated by the
46fact that controllers can't be moved around once hierarchies are
47populated. Another issue is that all controllers bound to a hierarchy
48are forced to have exactly the same view of the hierarchy. It isn't
49possible to vary the granularity depending on the specific controller.
50
51In practice, these issues heavily limit which controllers can be put
52on the same hierarchy and most configurations resort to putting each
53controller on its own hierarchy. Only closely related ones, such as
54the cpu and cpuacct controllers, make sense to put on the same
55hierarchy. This often means that userland ends up managing multiple
56similar hierarchies repeating the same steps on each hierarchy
57whenever a hierarchy management operation is necessary.
58
59Unfortunately, support for multiple hierarchies comes at a steep cost.
60Internal implementation in cgroup core proper is dazzlingly
61complicated but more importantly the support for multiple hierarchies
62restricts how cgroup is used in general and what controllers can do.
63
64There's no limit on how many hierarchies there may be, which means
65that a task's cgroup membership can't be described in finite length.
66The key may contain any varying number of entries and is unlimited in
67length, which makes it highly awkward to handle and leads to addition
68of controllers which exist only to identify membership, which in turn
69exacerbates the original problem.
70
71Also, as a controller can't have any expectation regarding what shape
72of hierarchies other controllers would be on, each controller has to
73assume that all other controllers are operating on completely
74orthogonal hierarchies. This makes it impossible, or at least very
75cumbersome, for controllers to cooperate with each other.
76
77In most use cases, putting controllers on hierarchies which are
78completely orthogonal to each other isn't necessary. What usually is
79called for is the ability to have differing levels of granularity
80depending on the specific controller. In other words, hierarchy may
81be collapsed from leaf towards root when viewed from specific
82controllers. For example, a given configuration might not care about
83how memory is distributed beyond a certain level while still wanting
84to control how CPU cycles are distributed.
85
86Unified hierarchy is the next version of cgroup interface. It aims to
87address the aforementioned issues by having more structure while
88retaining enough flexibility for most use cases. Various other
89general and controller-specific interface issues are also addressed in
90the process.
91
92
932. Basic Operation
94
952-1. Mounting
96
97Currently, unified hierarchy can be mounted with the following mount
98command. Note that this is still under development and scheduled to
99change soon.
100
101 mount -t cgroup -o __DEVEL__sane_behavior cgroup $MOUNT_POINT
102
Tejun Heoa8ddc822014-07-15 11:05:10 -0400103All controllers which support the unified hierarchy and are not bound
104to other hierarchies are automatically bound to unified hierarchy and
105show up at the root of it. Controllers which are enabled only in the
106root of unified hierarchy can be bound to other hierarchies. This
107allows mixing unified hierarchy with the traditional multiple
108hierarchies in a fully backward compatible way.
109
110For development purposes, the following boot parameter makes all
111controllers to appear on the unified hierarchy whether supported or
112not.
113
114 cgroup__DEVEL__legacy_files_on_dfl
Tejun Heoaf0ba672014-07-08 18:02:57 -0400115
116A controller can be moved across hierarchies only after the controller
117is no longer referenced in its current hierarchy. Because per-cgroup
118controller states are destroyed asynchronously and controllers may
119have lingering references, a controller may not show up immediately on
120the unified hierarchy after the final umount of the previous
121hierarchy. Similarly, a controller should be fully disabled to be
122moved out of the unified hierarchy and it may take some time for the
123disabled controller to become available for other hierarchies;
124furthermore, due to dependencies among controllers, other controllers
125may need to be disabled too.
126
127While useful for development and manual configurations, dynamically
128moving controllers between the unified and other hierarchies is
129strongly discouraged for production use. It is recommended to decide
130the hierarchies and controller associations before starting using the
131controllers.
Tejun Heo65731572014-04-25 18:28:02 -0400132
133
1342-2. cgroup.subtree_control
135
136All cgroups on unified hierarchy have a "cgroup.subtree_control" file
137which governs which controllers are enabled on the children of the
138cgroup. Let's assume a hierarchy like the following.
139
140 root - A - B - C
141 \ D
142
143root's "cgroup.subtree_control" file determines which controllers are
144enabled on A. A's on B. B's on C and D. This coincides with the
145fact that controllers on the immediate sub-level are used to
146distribute the resources of the parent. In fact, it's natural to
147assume that resource control knobs of a child belong to its parent.
148Enabling a controller in a "cgroup.subtree_control" file declares that
149distribution of the respective resources of the cgroup will be
150controlled. Note that this means that controller enable states are
151shared among siblings.
152
153When read, the file contains a space-separated list of currently
154enabled controllers. A write to the file should contain a
155space-separated list of controllers with '+' or '-' prefixed (without
156the quotes). Controllers prefixed with '+' are enabled and '-'
157disabled. If a controller is listed multiple times, the last entry
158wins. The specific operations are executed atomically - either all
159succeed or fail.
160
161
1622-3. cgroup.controllers
163
164Read-only "cgroup.controllers" file contains a space-separated list of
165controllers which can be enabled in the cgroup's
166"cgroup.subtree_control" file.
167
168In the root cgroup, this lists controllers which are not bound to
169other hierarchies and the content changes as controllers are bound to
170and unbound from other hierarchies.
171
172In non-root cgroups, the content of this file equals that of the
173parent's "cgroup.subtree_control" file as only controllers enabled
174from the parent can be used in its children.
175
176
1773. Structural Constraints
178
1793-1. Top-down
180
181As it doesn't make sense to nest control of an uncontrolled resource,
182all non-root "cgroup.subtree_control" files can only contain
183controllers which are enabled in the parent's "cgroup.subtree_control"
184file. A controller can be enabled only if the parent has the
185controller enabled and a controller can't be disabled if one or more
186children have it enabled.
187
188
1893-2. No internal tasks
190
191One long-standing issue that cgroup faces is the competition between
192tasks belonging to the parent cgroup and its children cgroups. This
193is inherently nasty as two different types of entities compete and
194there is no agreed-upon obvious way to handle it. Different
195controllers are doing different things.
196
197The cpu controller considers tasks and cgroups as equivalents and maps
198nice levels to cgroup weights. This works for some cases but falls
199flat when children should be allocated specific ratios of CPU cycles
200and the number of internal tasks fluctuates - the ratios constantly
201change as the number of competing entities fluctuates. There also are
202other issues. The mapping from nice level to weight isn't obvious or
203universal, and there are various other knobs which simply aren't
204available for tasks.
205
206The blkio controller implicitly creates a hidden leaf node for each
207cgroup to host the tasks. The hidden leaf has its own copies of all
208the knobs with "leaf_" prefixed. While this allows equivalent control
209over internal tasks, it's with serious drawbacks. It always adds an
210extra layer of nesting which may not be necessary, makes the interface
211messy and significantly complicates the implementation.
212
213The memory controller currently doesn't have a way to control what
214happens between internal tasks and child cgroups and the behavior is
215not clearly defined. There have been attempts to add ad-hoc behaviors
216and knobs to tailor the behavior to specific workloads. Continuing
217this direction will lead to problems which will be extremely difficult
218to resolve in the long term.
219
220Multiple controllers struggle with internal tasks and came up with
221different ways to deal with it; unfortunately, all the approaches in
222use now are severely flawed and, furthermore, the widely different
223behaviors make cgroup as whole highly inconsistent.
224
225It is clear that this is something which needs to be addressed from
226cgroup core proper in a uniform way so that controllers don't need to
227worry about it and cgroup as a whole shows a consistent and logical
228behavior. To achieve that, unified hierarchy enforces the following
229structural constraint:
230
231 Except for the root, only cgroups which don't contain any task may
232 have controllers enabled in their "cgroup.subtree_control" files.
233
234Combined with other properties, this guarantees that, when a
235controller is looking at the part of the hierarchy which has it
236enabled, tasks are always only on the leaves. This rules out
237situations where child cgroups compete against internal tasks of the
238parent.
239
240There are two things to note. Firstly, the root cgroup is exempt from
241the restriction. Root contains tasks and anonymous resource
242consumption which can't be associated with any other cgroup and
243requires special treatment from most controllers. How resource
244consumption in the root cgroup is governed is up to each controller.
245
246Secondly, the restriction doesn't take effect if there is no enabled
247controller in the cgroup's "cgroup.subtree_control" file. This is
248important as otherwise it wouldn't be possible to create children of a
249populated cgroup. To control resource distribution of a cgroup, the
250cgroup must create children and transfer all its tasks to the children
251before enabling controllers in its "cgroup.subtree_control" file.
252
253
Tejun Heo8a0792e2015-06-18 16:54:28 -04002544. Delegation
Tejun Heo65731572014-04-25 18:28:02 -0400255
Tejun Heo8a0792e2015-06-18 16:54:28 -04002564-1. Model of delegation
257
258A cgroup can be delegated to a less privileged user by granting write
259access of the directory and its "cgroup.procs" file to the user. Note
260that the resource control knobs in a given directory concern the
261resources of the parent and thus must not be delegated along with the
262directory.
263
264Once delegated, the user can build sub-hierarchy under the directory,
265organize processes as it sees fit and further distribute the resources
266it got from the parent. The limits and other settings of all resource
267controllers are hierarchical and regardless of what happens in the
268delegated sub-hierarchy, nothing can escape the resource restrictions
269imposed by the parent.
270
271Currently, cgroup doesn't impose any restrictions on the number of
272cgroups in or nesting depth of a delegated sub-hierarchy; however,
273this may in the future be limited explicitly.
274
275
2764-2. Common ancestor rule
277
278On the unified hierarchy, to write to a "cgroup.procs" file, in
279addition to the usual write permission to the file and uid match, the
280writer must also have write access to the "cgroup.procs" file of the
281common ancestor of the source and destination cgroups. This prevents
282delegatees from smuggling processes across disjoint sub-hierarchies.
283
284Let's say cgroups C0 and C1 have been delegated to user U0 who created
285C00, C01 under C0 and C10 under C1 as follows.
286
287 ~~~~~~~~~~~~~ - C0 - C00
288 ~ cgroup ~ \ C01
289 ~ hierarchy ~
290 ~~~~~~~~~~~~~ - C1 - C10
291
292C0 and C1 are separate entities in terms of resource distribution
293regardless of their relative positions in the hierarchy. The
294resources the processes under C0 are entitled to are controlled by
295C0's ancestors and may be completely different from C1. It's clear
296that the intention of delegating C0 to U0 is allowing U0 to organize
297the processes under C0 and further control the distribution of C0's
298resources.
299
300On traditional hierarchies, if a task has write access to "tasks" or
301"cgroup.procs" file of a cgroup and its uid agrees with the target, it
302can move the target to the cgroup. In the above example, U0 will not
303only be able to move processes in each sub-hierarchy but also across
304the two sub-hierarchies, effectively allowing it to violate the
305organizational and resource restrictions implied by the hierarchical
306structure above C0 and C1.
307
308On the unified hierarchy, let's say U0 wants to write the pid of a
309process which has a matching uid and is currently in C10 into
310"C00/cgroup.procs". U0 obviously has write access to the file and
311migration permission on the process; however, the common ancestor of
312the source cgroup C10 and the destination cgroup C00 is above the
313points of delegation and U0 would not have write access to its
314"cgroup.procs" and thus be denied with -EACCES.
315
316
3175. Other Changes
318
3195-1. [Un]populated Notification
Tejun Heo65731572014-04-25 18:28:02 -0400320
321cgroup users often need a way to determine when a cgroup's
322subhierarchy becomes empty so that it can be cleaned up. cgroup
323currently provides release_agent for it; unfortunately, this mechanism
324is riddled with issues.
325
326- It delivers events by forking and execing a userland binary
327 specified as the release_agent. This is a long deprecated method of
328 notification delivery. It's extremely heavy, slow and cumbersome to
329 integrate with larger infrastructure.
330
331- There is single monitoring point at the root. There's no way to
332 delegate management of a subtree.
333
334- The event isn't recursive. It triggers when a cgroup doesn't have
335 any tasks or child cgroups. Events for internal nodes trigger only
336 after all children are removed. This again makes it impossible to
337 delegate management of a subtree.
338
339- Events are filtered from the kernel side. A "notify_on_release"
340 file is used to subscribe to or suppress release events. This is
341 unnecessarily complicated and probably done this way because event
342 delivery itself was expensive.
343
344Unified hierarchy implements an interface file "cgroup.populated"
345which can be used to monitor whether the cgroup's subhierarchy has
346tasks in it or not. Its value is 0 if there is no task in the cgroup
347and its descendants; otherwise, 1. poll and [id]notify events are
348triggered when the value changes.
349
350This is significantly lighter and simpler and trivially allows
351delegating management of subhierarchy - subhierarchy monitoring can
352block further propagation simply by putting itself or another process
353in the subhierarchy and monitor events that it's interested in from
354there without interfering with monitoring higher in the tree.
355
356In unified hierarchy, the release_agent mechanism is no longer
357supported and the interface files "release_agent" and
358"notify_on_release" do not exist.
359
360
Tejun Heo8a0792e2015-06-18 16:54:28 -04003615-2. Other Core Changes
Tejun Heo65731572014-04-25 18:28:02 -0400362
363- None of the mount options is allowed.
364
365- remount is disallowed.
366
367- rename(2) is disallowed.
368
369- The "tasks" file is removed. Everything should at process
370 granularity. Use the "cgroup.procs" file instead.
371
372- The "cgroup.procs" file is not sorted. pids will be unique unless
373 they got recycled in-between reads.
374
375- The "cgroup.clone_children" file is removed.
376
377
Tejun Heo6abc8ca2015-08-04 15:20:55 -04003785-3. Controller File Conventions
Tejun Heo65731572014-04-25 18:28:02 -0400379
Tejun Heo6abc8ca2015-08-04 15:20:55 -04003805-3-1. Format
381
382In general, all controller files should be in one of the following
383formats whenever possible.
384
385- Values only files
386
387 VAL0 VAL1...\n
388
389- Flat keyed files
390
391 KEY0 VAL0\n
392 KEY1 VAL1\n
393 ...
394
395- Nested keyed files
396
397 KEY0 SUB_KEY0=VAL00 SUB_KEY1=VAL01...
398 KEY1 SUB_KEY0=VAL10 SUB_KEY1=VAL11...
399 ...
400
401For a writeable file, the format for writing should generally match
402reading; however, controllers may allow omitting later fields or
403implement restricted shortcuts for most common use cases.
404
405For both flat and nested keyed files, only the values for a single key
406can be written at a time. For nested keyed files, the sub key pairs
407may be specified in any order and not all pairs have to be specified.
408
409
4105-3-2. Control Knobs
411
412- Settings for a single feature should generally be implemented in a
413 single file.
414
415- In general, the root cgroup should be exempt from resource control
416 and thus shouldn't have resource control knobs.
417
418- If a controller implements ratio based resource distribution, the
419 control knob should be named "weight" and have the range [1, 10000]
420 and 100 should be the default value. The values are chosen to allow
421 enough and symmetric bias in both directions while keeping it
422 intuitive (the default is 100%).
423
424- If a controller implements an absolute resource guarantee and/or
425 limit, the control knobs should be named "min" and "max"
426 respectively. If a controller implements best effort resource
427 gurantee and/or limit, the control knobs should be named "low" and
428 "high" respectively.
429
430 In the above four control files, the special token "max" should be
431 used to represent upward infinity for both reading and writing.
432
433- If a setting has configurable default value and specific overrides,
434 the default settings should be keyed with "default" and appear as
435 the first entry in the file. Specific entries can use "default" as
436 its value to indicate inheritance of the default value.
437
438
4395-4. Per-Controller Changes
440
4415-4-1. blkio
Tejun Heo65731572014-04-25 18:28:02 -0400442
443- blk-throttle becomes properly hierarchical.
444
445
Tejun Heo6abc8ca2015-08-04 15:20:55 -04004465-4-2. cpuset
Tejun Heo65731572014-04-25 18:28:02 -0400447
448- Tasks are kept in empty cpusets after hotplug and take on the masks
449 of the nearest non-empty ancestor, instead of being moved to it.
450
451- A task can be moved into an empty cpuset, and again it takes on the
452 masks of the nearest non-empty ancestor.
453
454
Tejun Heo6abc8ca2015-08-04 15:20:55 -04004555-4-3. memory
Tejun Heo65731572014-04-25 18:28:02 -0400456
457- use_hierarchy is on by default and the cgroup file for the flag is
458 not created.
459
Johannes Weiner241994ed2015-02-11 15:26:06 -0800460- The original lower boundary, the soft limit, is defined as a limit
461 that is per default unset. As a result, the set of cgroups that
462 global reclaim prefers is opt-in, rather than opt-out. The costs
463 for optimizing these mostly negative lookups are so high that the
464 implementation, despite its enormous size, does not even provide the
465 basic desirable behavior. First off, the soft limit has no
466 hierarchical meaning. All configured groups are organized in a
467 global rbtree and treated like equal peers, regardless where they
468 are located in the hierarchy. This makes subtree delegation
469 impossible. Second, the soft limit reclaim pass is so aggressive
470 that it not just introduces high allocation latencies into the
471 system, but also impacts system performance due to overreclaim, to
472 the point where the feature becomes self-defeating.
473
474 The memory.low boundary on the other hand is a top-down allocated
475 reserve. A cgroup enjoys reclaim protection when it and all its
476 ancestors are below their low boundaries, which makes delegation of
477 subtrees possible. Secondly, new cgroups have no reserve per
478 default and in the common case most cgroups are eligible for the
479 preferred reclaim pass. This allows the new low boundary to be
480 efficiently implemented with just a minor addition to the generic
481 reclaim code, without the need for out-of-band data structures and
482 reclaim passes. Because the generic reclaim code considers all
483 cgroups except for the ones running low in the preferred first
484 reclaim pass, overreclaim of individual groups is eliminated as
485 well, resulting in much better overall workload performance.
486
487- The original high boundary, the hard limit, is defined as a strict
488 limit that can not budge, even if the OOM killer has to be called.
489 But this generally goes against the goal of making the most out of
490 the available memory. The memory consumption of workloads varies
491 during runtime, and that requires users to overcommit. But doing
492 that with a strict upper limit requires either a fairly accurate
493 prediction of the working set size or adding slack to the limit.
494 Since working set size estimation is hard and error prone, and
495 getting it wrong results in OOM kills, most users tend to err on the
496 side of a looser limit and end up wasting precious resources.
497
498 The memory.high boundary on the other hand can be set much more
499 conservatively. When hit, it throttles allocations by forcing them
500 into direct reclaim to work off the excess, but it never invokes the
501 OOM killer. As a result, a high boundary that is chosen too
502 aggressively will not terminate the processes, but instead it will
503 lead to gradual performance degradation. The user can monitor this
504 and make corrections until the minimal memory footprint that still
505 gives acceptable performance is found.
506
507 In extreme cases, with many concurrent allocations and a complete
508 breakdown of reclaim progress within the group, the high boundary
509 can be exceeded. But even then it's mostly better to satisfy the
510 allocation from the slack available in other groups or the rest of
511 the system than killing the group. Otherwise, memory.max is there
512 to limit this type of spillover and ultimately contain buggy or even
513 malicious applications.
514
515- The original control file names are unwieldy and inconsistent in
516 many different ways. For example, the upper boundary hit count is
517 exported in the memory.failcnt file, but an OOM event count has to
518 be manually counted by listening to memory.oom_control events, and
519 lower boundary / soft limit events have to be counted by first
520 setting a threshold for that value and then counting those events.
521 Also, usage and limit files encode their units in the filename.
522 That makes the filenames very long, even though this is not
523 information that a user needs to be reminded of every time they type
524 out those names.
525
526 To address these naming issues, as well as to signal clearly that
527 the new interface carries a new configuration model, the naming
528 conventions in it necessarily differ from the old interface.
529
530- The original limit files indicate the state of an unset limit with a
531 Very High Number, and a configured limit can be unset by echoing -1
532 into those files. But that very high number is implementation and
533 architecture dependent and not very descriptive. And while -1 can
534 be understood as an underflow into the highest possible value, -2 or
535 -10M etc. do not work, so it's not consistent.
536
Johannes Weinerd2973692015-02-27 15:52:04 -0800537 memory.low, memory.high, and memory.max will use the string "max" to
538 indicate and set the highest possible value.
Tejun Heo65731572014-04-25 18:28:02 -0400539
Tejun Heo8a0792e2015-06-18 16:54:28 -04005406. Planned Changes
Tejun Heo65731572014-04-25 18:28:02 -0400541
Tejun Heo8a0792e2015-06-18 16:54:28 -04005426-1. CAP for resource control
Tejun Heo65731572014-04-25 18:28:02 -0400543
544Unified hierarchy will require one of the capabilities(7), which is
545yet to be decided, for all resource control related knobs. Process
546organization operations - creation of sub-cgroups and migration of
547processes in sub-hierarchies may be delegated by changing the
548ownership and/or permissions on the cgroup directory and
549"cgroup.procs" interface file; however, all operations which affect
550resource control - writes to a "cgroup.subtree_control" file or any
551controller-specific knobs - will require an explicit CAP privilege.
552
553This, in part, is to prevent the cgroup interface from being
554inadvertently promoted to programmable API used by non-privileged
555binaries. cgroup exposes various aspects of the system in ways which
556aren't properly abstracted for direct consumption by regular programs.
557This is an administration interface much closer to sysctl knobs than
558system calls. Even the basic access model, being filesystem path
559based, isn't suitable for direct consumption. There's no way to
560access "my cgroup" in a race-free way or make multiple operations
561atomic against migration to another cgroup.
562
563Another aspect is that, for better or for worse, the cgroup interface
564goes through far less scrutiny than regular interfaces for
565unprivileged userland. The upside is that cgroup is able to expose
566useful features which may not be suitable for general consumption in a
567reasonable time frame. It provides a relatively short path between
568internal details and userland-visible interface. Of course, this
569shortcut comes with high risk. We go through what we go through for
570general kernel APIs for good reasons. It may end up leaking internal
571details in a way which can exert significant pain by locking the
572kernel into a contract that can't be maintained in a reasonable
573manner.
574
575Also, due to the specific nature, cgroup and its controllers don't
576tend to attract attention from a wide scope of developers. cgroup's
577short history is already fraught with severely mis-designed
578interfaces, unnecessary commitments to and exposing of internal
579details, broken and dangerous implementations of various features.
580
581Keeping cgroup as an administration interface is both advantageous for
582its role and imperative given its nature. Some of the cgroup features
583may make sense for unprivileged access. If deemed justified, those
584must be further abstracted and implemented as a different interface,
585be it a system call or process-private filesystem, and survive through
586the scrutiny that any interface for general consumption is required to
587go through.
588
589Requiring CAP is not a complete solution but should serve as a
590significant deterrent against spraying cgroup usages in non-privileged
591programs.