opentelemetry-cpp/examples/otlp/http_log_main.cc

169 lines
5.3 KiB
C++

// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
#include <iostream>
#include <memory>
#include <string>
#include <utility>
#include "opentelemetry/exporters/otlp/otlp_environment.h"
#include "opentelemetry/exporters/otlp/otlp_http.h"
#include "opentelemetry/exporters/otlp/otlp_http_exporter_factory.h"
#include "opentelemetry/exporters/otlp/otlp_http_exporter_options.h"
#include "opentelemetry/exporters/otlp/otlp_http_log_record_exporter_factory.h"
#include "opentelemetry/exporters/otlp/otlp_http_log_record_exporter_options.h"
#include "opentelemetry/logs/logger_provider.h"
#include "opentelemetry/sdk/common/global_log_handler.h"
#include "opentelemetry/sdk/logs/exporter.h"
#include "opentelemetry/sdk/logs/logger_provider.h"
#include "opentelemetry/sdk/logs/logger_provider_factory.h"
#include "opentelemetry/sdk/logs/processor.h"
#include "opentelemetry/sdk/logs/provider.h"
#include "opentelemetry/sdk/logs/simple_log_record_processor_factory.h"
#include "opentelemetry/sdk/trace/exporter.h"
#include "opentelemetry/sdk/trace/processor.h"
#include "opentelemetry/sdk/trace/provider.h"
#include "opentelemetry/sdk/trace/simple_processor_factory.h"
#include "opentelemetry/sdk/trace/tracer_provider.h"
#include "opentelemetry/sdk/trace/tracer_provider_factory.h"
#include "opentelemetry/trace/tracer_provider.h"
#ifdef BAZEL_BUILD
# include "examples/common/logs_foo_library/foo_library.h"
#else
# include "logs_foo_library/foo_library.h"
#endif
namespace trace = opentelemetry::trace;
namespace otlp = opentelemetry::exporter::otlp;
namespace logs_sdk = opentelemetry::sdk::logs;
namespace logs = opentelemetry::logs;
namespace trace_sdk = opentelemetry::sdk::trace;
namespace internal_log = opentelemetry::sdk::common::internal_log;
namespace
{
opentelemetry::exporter::otlp::OtlpHttpExporterOptions trace_opts;
std::shared_ptr<opentelemetry::sdk::trace::TracerProvider> tracer_provider;
void InitTracer()
{
if (trace_opts.url.size() > 9)
{
if (trace_opts.url.substr(trace_opts.url.size() - 8) == "/v1/logs")
{
trace_opts.url = trace_opts.url.substr(0, trace_opts.url.size() - 8) + "/v1/traces";
}
else if (trace_opts.url.substr(trace_opts.url.size() - 9) == "/v1/logs/")
{
trace_opts.url = trace_opts.url.substr(0, trace_opts.url.size() - 9) + "/v1/traces";
}
else
{
trace_opts.url = opentelemetry::exporter::otlp::GetOtlpDefaultHttpTracesEndpoint();
}
}
std::cout << "Using " << trace_opts.url << " to export trace spans." << '\n';
// Create OTLP exporter instance
auto exporter = otlp::OtlpHttpExporterFactory::Create(trace_opts);
auto processor = trace_sdk::SimpleSpanProcessorFactory::Create(std::move(exporter));
tracer_provider = trace_sdk::TracerProviderFactory::Create(std::move(processor));
// Set the global trace provider
std::shared_ptr<opentelemetry::trace::TracerProvider> api_provider = tracer_provider;
trace_sdk::Provider::SetTracerProvider(api_provider);
}
void CleanupTracer()
{
// We call ForceFlush to prevent to cancel running exportings, It's optional.
if (tracer_provider)
{
tracer_provider->ForceFlush();
}
tracer_provider.reset();
std::shared_ptr<opentelemetry::trace::TracerProvider> none;
trace_sdk::Provider::SetTracerProvider(none);
}
opentelemetry::exporter::otlp::OtlpHttpLogRecordExporterOptions logger_opts;
std::shared_ptr<opentelemetry::sdk::logs::LoggerProvider> logger_provider;
void InitLogger()
{
std::cout << "Using " << logger_opts.url << " to export log records." << '\n';
logger_opts.console_debug = true;
// Create OTLP exporter instance
auto exporter = otlp::OtlpHttpLogRecordExporterFactory::Create(logger_opts);
auto processor = logs_sdk::SimpleLogRecordProcessorFactory::Create(std::move(exporter));
logger_provider = logs_sdk::LoggerProviderFactory::Create(std::move(processor));
std::shared_ptr<opentelemetry::logs::LoggerProvider> api_provider = logger_provider;
logs_sdk::Provider::SetLoggerProvider(api_provider);
}
void CleanupLogger()
{
// We call ForceFlush to prevent to cancel running exportings, It's optional.
if (logger_provider)
{
logger_provider->ForceFlush();
}
logger_provider.reset();
std::shared_ptr<logs::LoggerProvider> none;
logs_sdk::Provider::SetLoggerProvider(none);
}
} // namespace
/*
Usage:
- example_otlp_http_log
- example_otlp_http_log <URL>
- example_otlp_http_log <URL> <DEBUG>
- example_otlp_http_log <URL> <DEBUG> <BIN>
<DEBUG> = yes|no, to turn console debug on or off
<BIN> = bin, to export in binary format
*/
int main(int argc, char *argv[])
{
if (argc > 1)
{
trace_opts.url = argv[1];
logger_opts.url = argv[1];
if (argc > 2)
{
std::string debug = argv[2];
trace_opts.console_debug = debug != "" && debug != "0" && debug != "no";
}
if (argc > 3)
{
std::string binary_mode = argv[3];
if (binary_mode.size() >= 3 && binary_mode.substr(0, 3) == "bin")
{
trace_opts.content_type = opentelemetry::exporter::otlp::HttpRequestContentType::kBinary;
logger_opts.content_type = opentelemetry::exporter::otlp::HttpRequestContentType::kBinary;
}
}
}
if (trace_opts.console_debug)
{
internal_log::GlobalLogHandler::SetLogLevel(internal_log::LogLevel::Debug);
}
InitLogger();
InitTracer();
foo_library();
CleanupTracer();
CleanupLogger();
return 0;
}