From 39cdc39d2b6338d67e7f68cc2fa2d1420c02e1bc Mon Sep 17 00:00:00 2001 From: iwilltry42 Date: Tue, 1 Feb 2022 15:12:22 +0100 Subject: [PATCH] fix: mutex on ensureToolsNode to avoid duplicate container name causing error --- pkg/client/tools.go | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/pkg/client/tools.go b/pkg/client/tools.go index e328d79af..777ed38ae 100644 --- a/pkg/client/tools.go +++ b/pkg/client/tools.go @@ -382,7 +382,13 @@ func runToolsNode(ctx context.Context, runtime runtimes.Runtime, cluster *k3d.Cl return node, nil } +var EnsureToolsNodeMutex sync.Mutex + func EnsureToolsNode(ctx context.Context, runtime runtimes.Runtime, cluster *k3d.Cluster) (*k3d.Node, error) { + // Mutex to prevent simultaneous creation of two tools-nodes, e.g. due to slow network connection cause the image pulling to take too long + // FIXME: could be prevented completely by having a smarter image pre-pulling mechanism + EnsureToolsNodeMutex.Lock() + defer EnsureToolsNodeMutex.Unlock() var toolsNode *k3d.Node toolsNode, err := runtime.GetNode(ctx, &k3d.Node{Name: fmt.Sprintf("%s-%s-tools", k3d.DefaultObjectNamePrefix, cluster.Name)})