Skip to content

Commit

Permalink
Add OOM adjustment flag to hostconfig via swarmctl cli
Browse files Browse the repository at this point in the history
Signed-off-by: plaurent <patrick@saint-laurent.us>
  • Loading branch information
psaintlaurent committed Jun 5, 2024
1 parent c1c857e commit 1dc86f3
Show file tree
Hide file tree
Showing 7 changed files with 234 additions and 160 deletions.
22 changes: 22 additions & 0 deletions api/api.pb.txt
Original file line number Diff line number Diff line change
Expand Up @@ -5803,6 +5803,13 @@ file {
type_name: ".docker.swarmkit.v1.ContainerSpec.Ulimit"
json_name: "ulimits"
}
field {
name: "oom_score_adj"
number: 30
label: LABEL_OPTIONAL
type: TYPE_INT64
json_name: "oomScoreAdj"
}
nested_type {
name: "LabelsEntry"
field {
Expand Down Expand Up @@ -11691,6 +11698,21 @@ file {
weak_dependency: 2
syntax: "proto3"
}
file {
name: "github.com/docker/swarmkit/api/test.proto"
package: "docker.swarmkit.v1"
message_type {
name: "TestService"
field {
name: "TestService"
number: 1
label: LABEL_OPTIONAL
type: TYPE_UINT64
json_name: "TestService"
}
}
syntax: "proto3"
}
file {
name: "github.com/docker/swarmkit/api/watch.proto"
package: "docker.swarmkit.v1"
Expand Down
353 changes: 193 additions & 160 deletions api/specs.pb.go

Large diffs are not rendered by default.

4 changes: 4 additions & 0 deletions api/specs.proto
Original file line number Diff line number Diff line change
Expand Up @@ -137,6 +137,8 @@ message TaskSpec {
// Placement specifies node selection constraints
Placement placement = 5;



// LogDriver specifies the log driver to use for the task. Any runtime will
// direct logs into the specified driver for the duration of the task.
Driver log_driver = 6;
Expand Down Expand Up @@ -370,6 +372,8 @@ message ContainerSpec {
// Ulimits defines the list of ulimits to set in the container. This option
// is equivalent to passing --ulimit to docker run.
repeated Ulimit ulimits = 29;

int64 oom_score_adj = 30;
}

// EndpointSpec defines the properties that can be configured to
Expand Down
3 changes: 3 additions & 0 deletions api/types.proto
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,7 @@ message ResourceRequirements {
Resources limits = 1;
Resources reservations = 2;


// Amount of swap in bytes - can only be used together with a memory limit
// -1 means unlimited
// a null pointer indicates that the default behaviour of granting twice
Expand All @@ -90,6 +91,8 @@ message ResourceRequirements {
// to the container OS's default - generally 60, or the value predefined in
// the image; set to -1 to unset a previously set value
google.protobuf.Int64Value memory_swappiness = 4;


}

message Platform {
Expand Down
10 changes: 10 additions & 0 deletions swarmd/cmd/swarmctl/service/flagparser/container.go
Original file line number Diff line number Diff line change
Expand Up @@ -76,5 +76,15 @@ func parseContainer(flags *pflag.FlagSet, spec *api.ServiceSpec) error {
}
}

if flags.Changed("oom-score-adj") {

oomScoreAdj, err := flags.GetInt64("oom-score-adj")
if err != nil {
return err
}

spec.Task.GetContainer().OomScoreAdj = oomScoreAdj
}

return nil
}
1 change: 1 addition & 0 deletions swarmd/cmd/swarmctl/service/flagparser/flags.go
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@ func AddServiceFlags(flags *pflag.FlagSet) {
flags.String("restart-delay", "5s", "delay between task restarts")
flags.Uint64("restart-max-attempts", 0, "maximum number of restart attempts (0 = unlimited)")
flags.String("restart-window", "0s", "time window to evaluate restart attempts (0 = unbound)")
flags.Int64("oom-score-adj", 0, "oom score adjustment (-1000 to 1000)")

flags.StringSlice("constraint", nil, "Placement constraint (e.g. node.labels.key==value)")

Expand Down
1 change: 1 addition & 0 deletions swarmd/dockerexec/container.go
Original file line number Diff line number Diff line change
Expand Up @@ -215,6 +215,7 @@ func (c *containerConfig) hostConfig() *enginecontainer.HostConfig {
Isolation: c.isolation(),
CapAdd: c.spec().CapabilityAdd,
CapDrop: c.spec().CapabilityDrop,
OomScoreAdj: int(c.spec().OomScoreAdj),
}

// The format of extra hosts on swarmkit is specified in:
Expand Down

0 comments on commit 1dc86f3

Please sign in to comment.