Skip to content

Commit

Permalink
nodeCreate: do not copy memory limit from node of different role (fixes
Browse files Browse the repository at this point in the history
  • Loading branch information
iwilltry42 committed Dec 17, 2021
1 parent 0c57cf2 commit e2c20b8
Showing 1 changed file with 10 additions and 4 deletions.
14 changes: 10 additions & 4 deletions pkg/client/node.go
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ func NodeAddToCluster(ctx context.Context, runtime runtimes.Runtime, node *k3d.N
l.Log().Debugf("Didn't find node with role '%s' in cluster '%s'. Choosing any other node (and using defaults)...", node.Role, cluster.Name)
node.Cmd = k3d.DefaultRoleCmds[node.Role]
for _, existingNode := range cluster.Nodes {
if existingNode.Role != k3d.LoadBalancerRole { // any role except for the LoadBalancer role
if existingNode.Role == k3d.AgentRole || existingNode.Role == k3d.ServerRole { // only K3s nodes
srcNode = existingNode
break
}
Expand All @@ -114,12 +114,18 @@ func NodeAddToCluster(ctx context.Context, runtime runtimes.Runtime, node *k3d.N
* -> remove fields that are not safe to copy as they break something down the stream
*/

// sanitize fields that mismatch between roles
if srcNode.Role != node.Role {
l.Log().Debugf("Dropping some fields from source node because it's not of the same role (%s != %s)...", srcNode.Role, node.Role)
srcNode.Memory = "" // memory settings are scoped per role (--servers-memory/--agents-memory)
}

// TODO: I guess proper deduplication can be handled in a cleaner/better way or at the infofaker level at some point
for _, forbiddenMount := range util.DoNotCopyVolumeSuffices {
for i, mount := range node.Volumes {
for i, mount := range srcNode.Volumes {
if strings.Contains(mount, forbiddenMount) {
l.Log().Tracef("Dropping copied volume mount %s to avoid issues...", mount)
node.Volumes = util.RemoveElementFromStringSlice(node.Volumes, i)
l.Log().Tracef("Dropping volume mount %s from source node to avoid issues...", mount)
srcNode.Volumes = util.RemoveElementFromStringSlice(srcNode.Volumes, i)
}
}
}
Expand Down

0 comments on commit e2c20b8

Please sign in to comment.