From d64d606de6d000c2ab732d3f4dc7ba2e007c3b10 Mon Sep 17 00:00:00 2001 From: Tobias Stadler Date: Fri, 29 Jan 2021 19:59:39 +0100 Subject: [PATCH] Added support for generating 128 bit trace ids (#254) Signed-off-by: Tobias Stadler --- src/jaegertracing/Config.cpp | 6 +++++ src/jaegertracing/Config.h | 10 ++++++++- src/jaegertracing/ConfigTest.cpp | 8 +++++++ src/jaegertracing/Tracer.h | 2 +- src/jaegertracing/TracerTest.cpp | 26 ++++++++++++++++++++++ src/jaegertracing/testutils/TracerUtil.cpp | 2 ++ 6 files changed, 52 insertions(+), 2 deletions(-) diff --git a/src/jaegertracing/Config.cpp b/src/jaegertracing/Config.cpp index abf28bcc..9dc9e68f 100644 --- a/src/jaegertracing/Config.cpp +++ b/src/jaegertracing/Config.cpp @@ -32,6 +32,12 @@ void Config::fromEnv() _disabled = disabled.second; } + const auto traceId128Bit = + utils::EnvVariable::getBoolVariable(kJAEGER_JAEGER_TRACEID_128BIT_ENV_PROP); + if (traceId128Bit.first) { + _traceId128Bit = traceId128Bit.second; + } + const auto serviceName = utils::EnvVariable::getStringVariable(kJAEGER_SERVICE_NAME_ENV_PROP); if (!serviceName.empty()) { diff --git a/src/jaegertracing/Config.h b/src/jaegertracing/Config.h index 2c9f0a32..186246a4 100644 --- a/src/jaegertracing/Config.h +++ b/src/jaegertracing/Config.h @@ -34,6 +34,7 @@ class Config { static constexpr auto kJAEGER_SERVICE_NAME_ENV_PROP = "JAEGER_SERVICE_NAME"; static constexpr auto kJAEGER_TAGS_ENV_PROP = "JAEGER_TAGS"; static constexpr auto kJAEGER_JAEGER_DISABLED_ENV_PROP = "JAEGER_DISABLED"; + static constexpr auto kJAEGER_JAEGER_TRACEID_128BIT_ENV_PROP = "JAEGER_TRACEID_128BIT"; #ifdef JAEGERTRACING_WITH_YAML_CPP @@ -48,6 +49,8 @@ class Config { const auto disabled = utils::yaml::findOrDefault(configYAML, "disabled", false); + const auto traceId128Bit = + utils::yaml::findOrDefault(configYAML, "traceid_128bit", false); const auto samplerNode = configYAML["sampler"]; const auto sampler = samplers::Config::parse(samplerNode); const auto reporterNode = configYAML["reporter"]; @@ -58,12 +61,13 @@ class Config { const auto baggageRestrictions = baggage::RestrictionsConfig::parse(baggageRestrictionsNode); return Config( - disabled, sampler, reporter, headers, baggageRestrictions, serviceName); + disabled, traceId128Bit, sampler, reporter, headers, baggageRestrictions, serviceName); } #endif // JAEGERTRACING_WITH_YAML_CPP explicit Config(bool disabled = false, + bool traceId128Bit = false, const samplers::Config& sampler = samplers::Config(), const reporters::Config& reporter = reporters::Config(), const propagation::HeadersConfig& headers = @@ -73,6 +77,7 @@ class Config { const std::string& serviceName = "", const std::vector& tags = std::vector()) : _disabled(disabled) + , _traceId128Bit(traceId128Bit) , _serviceName(serviceName) , _tags(tags) , _sampler(sampler) @@ -84,6 +89,8 @@ class Config { bool disabled() const { return _disabled; } + bool traceId128Bit() const { return _traceId128Bit; } + const samplers::Config& sampler() const { return _sampler; } const reporters::Config& reporter() const { return _reporter; } @@ -103,6 +110,7 @@ class Config { private: bool _disabled; + bool _traceId128Bit; std::string _serviceName; std::vector< Tag > _tags; samplers::Config _sampler; diff --git a/src/jaegertracing/ConfigTest.cpp b/src/jaegertracing/ConfigTest.cpp index 225d8e31..3e3562d5 100644 --- a/src/jaegertracing/ConfigTest.cpp +++ b/src/jaegertracing/ConfigTest.cpp @@ -33,6 +33,7 @@ TEST(Config, testParse) { constexpr auto kConfigYAML = R"cfg( disabled: true +traceid_128bit: true sampler: type: probabilistic param: 0.001 @@ -62,6 +63,7 @@ disabled: true { Config::parse(YAML::Load(R"cfg( disabled: false +traceid_128bit: false sampler: 1 reporter: 2 headers: 3 @@ -103,6 +105,7 @@ TEST(Config, testFromEnv) tags.emplace_back("my.app.version", std::string("1.2.3")); Config config(false, + false, samplers::Config("probabilistic", 0.7, "http://host34:57/sampling", @@ -146,6 +149,8 @@ TEST(Config, testFromEnv) testutils::EnvVariable::setEnv("JAEGER_SERVICE_NAME", "AService"); testutils::EnvVariable::setEnv("JAEGER_TAGS", "hostname=foobar,my.app.version=4.5.6"); + testutils::EnvVariable::setEnv("JAEGER_TRACEID_128BIT", "true"); + config.fromEnv(); ASSERT_EQ(std::string("http://host34:56567"), config.reporter().endpoint()); @@ -171,6 +176,8 @@ TEST(Config, testFromEnv) ASSERT_EQ(false, config.disabled()); + ASSERT_EQ(true, config.traceId128Bit()); + testutils::EnvVariable::setEnv("JAEGER_DISABLED", "TRue"); // case-insensitive testutils::EnvVariable::setEnv("JAEGER_AGENT_PORT", "445"); @@ -190,6 +197,7 @@ TEST(Config, testFromEnv) testutils::EnvVariable::setEnv("JAEGER_SERVICE_NAME", ""); testutils::EnvVariable::setEnv("JAEGER_TAGS", ""); testutils::EnvVariable::setEnv("JAEGER_DISABLED", ""); + testutils::EnvVariable::setEnv("JAEGER_TRACE_ID_128BIT", ""); } } // namespace jaegertracing diff --git a/src/jaegertracing/Tracer.h b/src/jaegertracing/Tracer.h index 8d204267..65c611a0 100644 --- a/src/jaegertracing/Tracer.h +++ b/src/jaegertracing/Tracer.h @@ -82,7 +82,7 @@ class Tracer : public opentracing::Tracer, const std::shared_ptr& logger, metrics::StatsFactory& statsFactory) { - return make(serviceName, config, logger, statsFactory, 0); + return make(serviceName, config, logger, statsFactory, config.traceId128Bit() ? kGen128BitOption : 0); } static std::shared_ptr make(const std::string& serviceName, diff --git a/src/jaegertracing/TracerTest.cpp b/src/jaegertracing/TracerTest.cpp index 3d5d8889..584dd64c 100644 --- a/src/jaegertracing/TracerTest.cpp +++ b/src/jaegertracing/TracerTest.cpp @@ -325,6 +325,7 @@ TEST(Tracer, testConstructorFailure) TEST(Tracer, testDisabledConfig) { Config config(true, + false, samplers::Config(), reporters::Config(), propagation::HeadersConfig(), @@ -470,6 +471,7 @@ TEST(Tracer, testTracerTags) tags.emplace_back("my.app.version", std::string("1.2.3")); Config config( + false, false, samplers::Config( "const", 1, "", 0, samplers::Config::Clock::duration()), @@ -552,4 +554,28 @@ TEST(Tracer, testTracerSpanSelfRefWithOtherRefs) tracer->Close(); } +TEST(Tracer, testTracerWithTraceId128Bit) +{ + Config config( + false, + true, + samplers::Config( + "const", 1, "", 0, samplers::Config::Clock::duration()), + reporters::Config(0, std::chrono::milliseconds(100), false, "", ""), + propagation::HeadersConfig(), + baggage::RestrictionsConfig(), + "test-service", + std::vector()); + + auto tracer = Tracer::make(config); + + opentracing::StartSpanOptions options; + std::unique_ptr span(static_cast( + tracer->StartSpanWithOptions("test-operation", options).release())); + + auto traceID = span->context().traceID(); + + ASSERT_GT(traceID.high(), 0); +} + } // namespace jaegertracing diff --git a/src/jaegertracing/testutils/TracerUtil.cpp b/src/jaegertracing/testutils/TracerUtil.cpp index ffa65c1f..f2f5001b 100644 --- a/src/jaegertracing/testutils/TracerUtil.cpp +++ b/src/jaegertracing/testutils/TracerUtil.cpp @@ -39,6 +39,7 @@ std::shared_ptr installGlobalTracer() samplingServerURLStream << "http://" << handle->_mockAgent->samplingServerAddress().authority(); Config config( + false, false, samplers::Config("const", 1, @@ -61,6 +62,7 @@ std::shared_ptr buildTracer(const std::string& endpoint) { std::ostringstream samplingServerURLStream; Config config( + false, false, samplers::Config("const", 1,