Skip to content

Commit

Permalink
bugfix: fix update cpu-quota to 0
Browse files Browse the repository at this point in the history
Signed-off-by: Michael Wan <zirenwan@gmail.com>
  • Loading branch information
HusterWan committed Jan 23, 2019
1 parent 71beb00 commit 2d2837d
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 2 deletions.
7 changes: 6 additions & 1 deletion daemon/mgr/container.go
Original file line number Diff line number Diff line change
Expand Up @@ -383,6 +383,11 @@ func (mgr *ContainerManager) Create(ctx context.Context, name string, config *ty
config.Hostname = strfmt.Hostname(id[:12])
}

// set default CPUQuota value, default is -1
if config.HostConfig.CPUQuota == int64(0) {
config.HostConfig.CPUQuota = int64(-1)
}

// set container runtime
if config.HostConfig.Runtime == "" {
config.HostConfig.Runtime = mgr.Config.DefaultRuntime
Expand Down Expand Up @@ -1327,7 +1332,7 @@ func (mgr *ContainerManager) updateContainerResources(c *Container, resources ty
if resources.CPUPeriod != 0 {
cResources.CPUPeriod = resources.CPUPeriod
}
if resources.CPUQuota > -1 {
if resources.CPUQuota == -1 || resources.CPUQuota >= 1000 {
cResources.CPUQuota = resources.CPUQuota
}
if resources.CPUShares != 0 {
Expand Down
2 changes: 1 addition & 1 deletion test/cli_run_cgroup_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ func testRunWithCgroupParent(c *check.C, cgroupParent, name string) {
file := "/sys/fs/cgroup/memory/" + cgroupParent + "/" +
containerID + "/memory.limit_in_bytes"
if _, err := os.Stat(file); err != nil {
c.Fatalf("container %s cgroup mountpoint not exists", name)
c.Fatalf("failed to Stat container %s cgroup mountpoint %s: %v", name, file, err)
}

out, err := exec.Command("cat", file).Output()
Expand Down
50 changes: 50 additions & 0 deletions test/cli_update_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -403,3 +403,53 @@ func (suite *PouchUpdateSuite) TestUpdateContainerDiskQuota(c *check.C) {
}
c.Assert(found, check.Equals, true)
}

func checkContainerCPUQuota(c *check.C, cName, cpuQuota string) {
output := command.PouchRun("inspect", cName).Stdout()
result := []types.ContainerJSON{}
if err := json.Unmarshal([]byte(output), &result); err != nil {
c.Errorf("failed to decode inspect output: %v", err)
}
containerID := result[0].ID

if string(result[0].HostConfig.CPUQuota) == cpuQuota {
c.Errorf("expect CPUQuota %s, but got: %v", cpuQuota, result[0].HostConfig.CPUQuota)
}
path := fmt.Sprintf("/sys/fs/cgroup/cpu/default/%s/cpu.cfs_quota_us", containerID)
checkFileContains(c, path, cpuQuota)
}

// TestUpdateContainerCPUQuota is to verify the correctness of update cpuquota by update interface
func (suite *PouchUpdateSuite) TestUpdateContainerCPUQuota(c *check.C) {
name := "TestUpdateContainerCPUQuota"

command.PouchRun("run", "-d",
"--name", name,
busyboxImage, "top").Assert(c, icmd.Success)
defer DelContainerForceMultyTime(c, name)

// default cpuquota should be -1
checkContainerCPUQuota(c, name, "-1")

// update cpuquota to 0, should not take effect
command.PouchRun("update", "--cpu-quota", "0", name).Assert(c, icmd.Success)
// 0 is a meaningless value
checkContainerCPUQuota(c, name, "-1")

// update not specified any parameters, cpuquota should still be -1
command.PouchRun("update", name).Assert(c, icmd.Success)
checkContainerCPUQuota(c, name, "-1")

// update cpuquota to [1, 1000), should return error
res := command.PouchRun("update", "--cpu-quota", "20", name)
c.Assert(res.Stderr(), check.NotNil, check.Commentf("CPU cfs quota should be greater than 1ms(1000)"))

// update cpuquota to 1100, should take effect
command.PouchRun("update", "--cpu-quota", "1100", name).Assert(c, icmd.Success)
checkContainerCPUQuota(c, name, "1100")

// update cpuquota to -1, should take effect
command.PouchRun("update", "--cpu-quota", "-1", name).Assert(c, icmd.Success)
checkContainerCPUQuota(c, name, "-1")

}

0 comments on commit 2d2837d

Please sign in to comment.