kaniko/vendor/github.com/containerd/cgroups
Gabriel Nützi 323e616a67
fix: Refactor `LayersMap` to correct old strange code behavior (#2066)
* fix: Correct flatten function in layers

- Added a test.
- Cache current image, track deletes in `whiteouts` as well as normal adds in `layers`.
- Fix ugly delete behavior of `layerHashCache`.
  Delete it when crerating a new snapshot.
- Slight cleanup in `snapshot.go`.
- Format ugly `WalkFS` function.

* fix: Add symbolic link changes  to Hasher and CacheHasher

* fix: Better log messages

* fix(ci): Integration tests

* fix(ci): Add `--no-cache` to docker builds

* fix(ci): Pass credentials for error integration test

* np: Missing .gitignore in `hack`

* np: Capitalize every log message

- Correct some linting.

* fix: Key function

- Merge only last layer onto `currentImage`.

* fix: Remove old obsolete `cacheHasher`
2022-05-17 20:30:58 -04:00
..
stats/v1 Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
v2 fix: Refactor `LayersMap` to correct old strange code behavior (#2066) 2022-05-17 20:30:58 -04:00
.gitignore Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
LICENSE Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
Makefile Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
Protobuild.toml Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
README.md Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
Vagrantfile Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
blkio.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
cgroup.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
control.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
cpu.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
cpuacct.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
cpuset.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
devices.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
errors.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
freezer.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
hierarchy.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
hugetlb.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
memory.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
named.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
net_cls.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
net_prio.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
opts.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
paths.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
perf_event.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
pids.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
rdma.go Bump github.com/containerd/containerd from 1.5.9 to 1.6.0 (#1948) 2022-02-22 01:41:08 +05:30
state.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
subsystem.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
systemd.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
ticks.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
utils.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00
v1.go Bump github.com/docker/docker to latest release (#1866) 2022-01-14 15:58:32 -05:00

README.md

cgroups

Build Status codecov GoDoc Go Report Card

Go package for creating, managing, inspecting, and destroying cgroups. The resources format for settings on the cgroup uses the OCI runtime-spec found here.

Examples

Create a new cgroup

This creates a new cgroup using a static path for all subsystems under /test.

  • /sys/fs/cgroup/cpu/test
  • /sys/fs/cgroup/memory/test
  • etc....

It uses a single hierarchy and specifies cpu shares as a resource constraint and uses the v1 implementation of cgroups.

shares := uint64(100)
control, err := cgroups.New(cgroups.V1, cgroups.StaticPath("/test"), &specs.LinuxResources{
    CPU: &specs.CPU{
        Shares: &shares,
    },
})
defer control.Delete()

Create with systemd slice support

control, err := cgroups.New(cgroups.Systemd, cgroups.Slice("system.slice", "runc-test"), &specs.LinuxResources{
    CPU: &specs.CPU{
        Shares: &shares,
    },
})

Load an existing cgroup

control, err = cgroups.Load(cgroups.V1, cgroups.StaticPath("/test"))

Add a process to the cgroup

if err := control.Add(cgroups.Process{Pid:1234}); err != nil {
}

Update the cgroup

To update the resources applied in the cgroup

shares = uint64(200)
if err := control.Update(&specs.LinuxResources{
    CPU: &specs.LinuxCPU{
        Shares: &shares,
    },
}); err != nil {
}

Freeze and Thaw the cgroup

if err := control.Freeze(); err != nil {
}
if err := control.Thaw(); err != nil {
}

List all processes in the cgroup or recursively

processes, err := control.Processes(cgroups.Devices, recursive)

Get Stats on the cgroup

stats, err := control.Stat()

By adding cgroups.IgnoreNotExist all non-existent files will be ignored, e.g. swap memory stats without swap enabled

stats, err := control.Stat(cgroups.IgnoreNotExist)

Move process across cgroups

This allows you to take processes from one cgroup and move them to another.

err := control.MoveTo(destination)

Create subcgroup

subCgroup, err := control.New("child", resources)

Registering for memory events

This allows you to get notified by an eventfd for v1 memory cgroups events.

event := cgroups.MemoryThresholdEvent(50 * 1024 * 1024, false)
efd, err := control.RegisterMemoryEvent(event)
event := cgroups.MemoryPressureEvent(cgroups.MediumPressure, cgroups.DefaultMode)
efd, err := control.RegisterMemoryEvent(event)
efd, err := control.OOMEventFD()
// or by using RegisterMemoryEvent
event := cgroups.OOMEvent()
efd, err := control.RegisterMemoryEvent(event)

Attention

All static path should not include /sys/fs/cgroup/ prefix, it should start with your own cgroups name

Project details

Cgroups is a containerd sub-project, licensed under the Apache 2.0 license. As a containerd sub-project, you will find the:

information in our containerd/project repository.