Skip to content

Commit

Permalink
1. Make kubelet default to 10ms for CPU quota if limit < 10m for
Browse files Browse the repository at this point in the history
backwards compat.
2. Update documentation to reflect minimum CPU limits.

Signed-off-by: Vishnu kannan <vishnuk@google.com>
  • Loading branch information
vishh committed Mar 17, 2016
1 parent 6cd8e5c commit 5165590
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 1 deletion.
1 change: 1 addition & 0 deletions docs/proposals/resource-qos.md
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ For each resource, containers can specify a resource request and limit, 0 <= req
### Compressible Resource Guarantees

- For now, we are only supporting CPU.
- Minimum CPU limit is 10 milli cores (`10m`). This a limitation of the Linux kernel.
- Containers are guaranteed to get the amount of CPU they request, they may or may not get additional CPU time (depending on the other jobs running).
- Excess CPU resources will be distributed based on the amount of CPU requested. For example, suppose container A requests for 60% of the CPU, and container B requests for 30% of the CPU. Suppose that both containers are trying to use as much CPU as they can. Then the extra 10% of CPU will be distributed to A and B in a 2:1 ratio (implementation discussed in later sections).
- Containers will be throttled if they exceed their limit. If limit is unspecified, then the containers can use excess CPU when available.
Expand Down
8 changes: 7 additions & 1 deletion pkg/kubelet/dockertools/docker.go
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,8 @@ const (
milliCPUToCPU = 1000

// 100000 is equivalent to 100ms
quotaPeriod = 100000
quotaPeriod = 100000
minQuotaPerod = 1000
)

// DockerInterface is an abstract interface for testability. It abstracts the interface of docker.Client.
Expand Down Expand Up @@ -317,6 +318,11 @@ func milliCPUToQuota(milliCPU int64) (quota int64, period int64) {
// we then convert your milliCPU to a value normalized over a period
quota = (milliCPU * quotaPeriod) / milliCPUToCPU

// quota needs to be a minimum of 1ms.
if quota < minQuotaPerod {
quota = minQuotaPerod
}

return
}

Expand Down
15 changes: 15 additions & 0 deletions pkg/kubelet/dockertools/docker_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -839,6 +839,21 @@ func TestMilliCPUToQuota(t *testing.T) {
quota: int64(0),
period: int64(0),
},
{
input: int64(5),
quota: int64(1000),
period: int64(100000),
},
{
input: int64(9),
quota: int64(1000),
period: int64(100000),
},
{
input: int64(10),
quota: int64(1000),
period: int64(100000),
},
{
input: int64(200),
quota: int64(20000),
Expand Down

1 comment on commit 5165590

@k8s-teamcity-mesosphere

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

TeamCity OSS :: Kubernetes Mesos :: 4 - Smoke Tests Build 19394 outcome was SUCCESS
Summary: Tests passed: 1, ignored: 265 Build time: 00:08:58

Please sign in to comment.