From 669fd060848263c44e93e141ed82c65e54bd1e80 Mon Sep 17 00:00:00 2001 From: Matthew Slipper Date: Wed, 16 Oct 2024 16:16:04 -0600 Subject: [PATCH] fix: add suffix to fluentd configurator We run Kurtosis in our CI pipeline. Multiple processes create Kurtosis enclaves concurrenctly. When the timing is just right, it can lead to a race condition where the fluentbit configurator container sticks around and no further enclaves can be created until we manually delete the fluentbit container. This PR adds a suffix to the configurator container so that it is isolated from other concurrent runs. --- .../fluentbit_configuration_creator.go | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/container-engine-lib/lib/backend_impls/docker/docker_kurtosis_backend/logs_collector_functions/implementations/fluentbit/fluentbit_configuration_creator.go b/container-engine-lib/lib/backend_impls/docker/docker_kurtosis_backend/logs_collector_functions/implementations/fluentbit/fluentbit_configuration_creator.go index 9beba41cf7..d713300b46 100644 --- a/container-engine-lib/lib/backend_impls/docker/docker_kurtosis_backend/logs_collector_functions/implementations/fluentbit/fluentbit_configuration_creator.go +++ b/container-engine-lib/lib/backend_impls/docker/docker_kurtosis_backend/logs_collector_functions/implementations/fluentbit/fluentbit_configuration_creator.go @@ -4,18 +4,20 @@ import ( "bytes" "context" "fmt" + "text/template" + "time" + "github.com/kurtosis-tech/kurtosis/container-engine-lib/lib/backend_impls/docker/docker_manager" + "github.com/kurtosis-tech/kurtosis/container-engine-lib/lib/uuid_generator" "github.com/kurtosis-tech/stacktrace" "github.com/sirupsen/logrus" - "text/template" - "time" ) const ( // We use this image and version because we already are using this in other projects so there is a high probability // that the image is in the local machine's cache - configuratorContainerImage = "alpine:3.17" - configuratorContainerName = "kurtosis-fluentbit-configurator" + configuratorContainerImage = "alpine:3.17" + configuratorContainerNamePrefix = "kurtosis-fluentbit-configurator" shBinaryFilepath = "/bin/sh" shCmdFlag = "-c" @@ -54,9 +56,16 @@ func (fluent *fluentbitConfigurationCreator) CreateConfiguration( volumeName: configDirpathInContainer, } + uuid, err := uuid_generator.GenerateUUIDString() + if err != nil { + return stacktrace.Propagate(err, "An error occurred generating a UUID for the configurator container name") + } + + containerName := fmt.Sprintf("%s-%s", configuratorContainerNamePrefix, uuid) + createAndStartArgs := docker_manager.NewCreateAndStartContainerArgsBuilder( configuratorContainerImage, - configuratorContainerName, + containerName, targetNetworkId, ).WithEntrypointArgs( entrypointArgs,