From 4ccc1b58bcbaec99fbdc7e3cc22d094eea47749c Mon Sep 17 00:00:00 2001 From: Tim Gross Date: Thu, 3 Oct 2024 16:15:00 -0400 Subject: [PATCH] fix data race in node upsert While testing with agents built with the race-detection option enabled, I encountered a data race while draining a node. When we upsert a node we copy the `NodeResources` struct and then perform a fixup for backwards compatibility of the topology struct. This fixup was being executed on the original struct and not the copy, which means we're uselessly fixing up the wrong struct and we're corrupting the state store in the process (albeit harmlessly, I suspect). Fix the data race by calling the method on the correct pointer. --- .changelog/24127.txt | 3 +++ nomad/structs/structs.go | 8 ++++---- 2 files changed, 7 insertions(+), 4 deletions(-) create mode 100644 .changelog/24127.txt diff --git a/.changelog/24127.txt b/.changelog/24127.txt new file mode 100644 index 00000000000..b872196d0b4 --- /dev/null +++ b/.changelog/24127.txt @@ -0,0 +1,3 @@ +```release-note:bug +state: Fixed a bug where compatibility updates for node topology for nodes older than 1.7.0 were not being correctly applied +``` diff --git a/nomad/structs/structs.go b/nomad/structs/structs.go index 79f900b6e19..6f3ab818c16 100644 --- a/nomad/structs/structs.go +++ b/nomad/structs/structs.go @@ -2251,7 +2251,7 @@ func (n *Node) Canonicalize() { n.SchedulingEligibility = NodeSchedulingEligible } - // COMPAT remove in 1.9+ + // COMPAT remove in 1.10+ // In v1.7 we introduce Topology into the NodeResources struct which the client // will fingerprint. Since the upgrade path must cover servers that get upgraded // before clients which will send the old struct, we synthesize a pseudo topology @@ -3262,9 +3262,9 @@ func (n *NodeResources) Copy() *NodeResources { } } - // COMPAT remove in 1.9+ + // COMPAT remove in 1.10+ // apply compatibility fixups covering node topology - n.Compatibility() + newN.Compatibility() return newN } @@ -3326,7 +3326,7 @@ func (n *NodeResources) Merge(o *NodeResources) { } } - // COMPAT remove in 1.9+ + // COMPAT remove in 1.10+ // apply compatibility fixups covering node topology n.Compatibility() }