2
0

main.cc 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. // Copyright The OpenTelemetry Authors
  2. // SPDX-License-Identifier: Apache-2.0
  3. #include <algorithm>
  4. #include <iostream>
  5. #include <memory>
  6. #include <string>
  7. #include <type_traits>
  8. #include <utility>
  9. #include <vector>
  10. #include "opentelemetry/exporters/memory/in_memory_span_data.h"
  11. #include "opentelemetry/exporters/memory/in_memory_span_exporter_factory.h"
  12. #include "opentelemetry/exporters/ostream/span_exporter_factory.h"
  13. #include "opentelemetry/nostd/span.h"
  14. #include "opentelemetry/nostd/string_view.h"
  15. #include "opentelemetry/sdk/trace/exporter.h"
  16. #include "opentelemetry/sdk/trace/processor.h"
  17. #include "opentelemetry/sdk/trace/provider.h"
  18. #include "opentelemetry/sdk/trace/simple_processor_factory.h"
  19. #include "opentelemetry/sdk/trace/span_data.h"
  20. #include "opentelemetry/sdk/trace/tracer_provider.h"
  21. #include "opentelemetry/sdk/trace/tracer_provider_factory.h"
  22. #include "opentelemetry/trace/span_id.h"
  23. #include "opentelemetry/trace/span_metadata.h"
  24. #include "opentelemetry/trace/trace_id.h"
  25. #include "opentelemetry/trace/tracer_provider.h"
  26. #ifdef BAZEL_BUILD
  27. # include "examples/common/foo_library/foo_library.h"
  28. #else
  29. # include "foo_library/foo_library.h"
  30. #endif
  31. using opentelemetry::exporter::memory::InMemorySpanData;
  32. namespace trace_api = opentelemetry::trace;
  33. namespace trace_sdk = opentelemetry::sdk::trace;
  34. namespace
  35. {
  36. std::shared_ptr<InMemorySpanData> InitTracer()
  37. {
  38. std::shared_ptr<InMemorySpanData> data;
  39. auto exporter1 = opentelemetry::exporter::trace::OStreamSpanExporterFactory::Create();
  40. auto processor1 = trace_sdk::SimpleSpanProcessorFactory::Create(std::move(exporter1));
  41. auto exporter2 = opentelemetry::exporter::memory::InMemorySpanExporterFactory::Create(data);
  42. auto processor2 = trace_sdk::SimpleSpanProcessorFactory::Create(std::move(exporter2));
  43. std::vector<std::unique_ptr<opentelemetry::sdk::trace::SpanProcessor>> processors;
  44. processors.push_back(std::move(processor1));
  45. processors.push_back(std::move(processor2));
  46. std::shared_ptr<opentelemetry::trace::TracerProvider> provider =
  47. trace_sdk::TracerProviderFactory::Create(std::move(processors));
  48. // Set the global trace provider
  49. trace_sdk::Provider::SetTracerProvider(std::move(provider));
  50. return data;
  51. }
  52. void CleanupTracer()
  53. {
  54. std::shared_ptr<opentelemetry::trace::TracerProvider> none;
  55. trace_sdk::Provider::SetTracerProvider(none);
  56. }
  57. void dumpSpans(std::vector<std::unique_ptr<trace_sdk::SpanData>> &spans)
  58. {
  59. char span_buf[trace_api::SpanId::kSize * 2];
  60. char trace_buf[trace_api::TraceId::kSize * 2];
  61. char parent_span_buf[trace_api::SpanId::kSize * 2];
  62. std::cout << "\nSpans from memory :" << '\n';
  63. for (auto &span : spans)
  64. {
  65. std::cout << "\n\tSpan: " << '\n';
  66. std::cout << "\t\tName: " << span->GetName() << '\n';
  67. span->GetSpanId().ToLowerBase16(span_buf);
  68. span->GetTraceId().ToLowerBase16(trace_buf);
  69. span->GetParentSpanId().ToLowerBase16(parent_span_buf);
  70. std::cout << "\t\tTraceId: " << std::string(trace_buf, sizeof(trace_buf)) << '\n';
  71. std::cout << "\t\tSpanId: " << std::string(span_buf, sizeof(span_buf)) << '\n';
  72. std::cout << "\t\tParentSpanId: " << std::string(parent_span_buf, sizeof(parent_span_buf))
  73. << '\n';
  74. std::cout << "\t\tDescription: " << span->GetDescription() << '\n';
  75. std::cout << "\t\tSpan kind:"
  76. << static_cast<typename std::underlying_type<trace_api::SpanKind>::type>(
  77. span->GetSpanKind())
  78. << '\n';
  79. std::cout << "\t\tSpan Status: "
  80. << static_cast<typename std::underlying_type<trace_api::StatusCode>::type>(
  81. span->GetStatus())
  82. << '\n';
  83. }
  84. }
  85. } // namespace
  86. int main(int /* argc */, char ** /* argv */)
  87. {
  88. // Removing this line will leave the default noop TracerProvider in place.
  89. std::shared_ptr<InMemorySpanData> data = InitTracer();
  90. foo_library();
  91. auto memory_spans = data->GetSpans();
  92. dumpSpans(memory_spans);
  93. CleanupTracer();
  94. return 0;
  95. }