main.cc 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. // Copyright The OpenTelemetry Authors
  2. // SPDX-License-Identifier: Apache-2.0
  3. #include <stdint.h>
  4. #include <stdio.h>
  5. #include <chrono>
  6. #include <iostream>
  7. #include <string>
  8. #include <thread>
  9. #include <utility>
  10. #include "opentelemetry/exporters/ostream/span_exporter_factory.h"
  11. #include "opentelemetry/nostd/shared_ptr.h"
  12. #include "opentelemetry/sdk/resource/resource.h"
  13. #include "opentelemetry/sdk/trace/batch_span_processor_factory.h"
  14. #include "opentelemetry/sdk/trace/batch_span_processor_options.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/tracer_provider.h"
  19. #include "opentelemetry/sdk/trace/tracer_provider_factory.h"
  20. #include "opentelemetry/trace/provider.h"
  21. #include "opentelemetry/trace/tracer.h"
  22. #include "opentelemetry/trace/tracer_provider.h"
  23. constexpr int kNumSpans = 10;
  24. namespace trace_api = opentelemetry::trace;
  25. namespace resource = opentelemetry::sdk::resource;
  26. namespace trace_sdk = opentelemetry::sdk::trace;
  27. namespace trace_exporter = opentelemetry::exporter::trace;
  28. namespace
  29. {
  30. void InitTracer()
  31. {
  32. auto exporter = trace_exporter::OStreamSpanExporterFactory::Create();
  33. // CONFIGURE BATCH SPAN PROCESSOR PARAMETERS
  34. trace_sdk::BatchSpanProcessorOptions options{};
  35. // We make the queue size `KNumSpans`*2+5 because when the queue is half full, a preemptive notif
  36. // is sent to start an export call, which we want to avoid in this simple example.
  37. options.max_queue_size = kNumSpans * 2 + 5;
  38. // Time interval (in ms) between two consecutive exports.
  39. options.schedule_delay_millis = std::chrono::milliseconds(3000);
  40. // We export `kNumSpans` after every `schedule_delay_millis` milliseconds.
  41. options.max_export_batch_size = kNumSpans;
  42. resource::ResourceAttributes attributes = {{"service", "test_service"},
  43. {"version", static_cast<uint32_t>(1)}};
  44. auto resource = resource::Resource::Create(attributes);
  45. auto processor = trace_sdk::BatchSpanProcessorFactory::Create(std::move(exporter), options);
  46. std::shared_ptr<opentelemetry::trace::TracerProvider> provider =
  47. trace_sdk::TracerProviderFactory::Create(std::move(processor), resource);
  48. // Set the global trace provider.
  49. trace_sdk::Provider::SetTracerProvider(provider);
  50. }
  51. void CleanupTracer()
  52. {
  53. std::shared_ptr<opentelemetry::trace::TracerProvider> none;
  54. trace_sdk::Provider::SetTracerProvider(none);
  55. }
  56. opentelemetry::nostd::shared_ptr<trace_api::Tracer> get_tracer()
  57. {
  58. auto provider = trace_api::Provider::GetTracerProvider();
  59. return provider->GetTracer("foo_library");
  60. }
  61. void StartAndEndSpans()
  62. {
  63. for (int i = 1; i <= kNumSpans; ++i)
  64. {
  65. get_tracer()->StartSpan("Span " + std::to_string(i));
  66. }
  67. }
  68. } // namespace
  69. int main(int /* argc */, char ** /* argv */)
  70. {
  71. // Removing this line will leave the default noop TracerProvider in place.
  72. InitTracer();
  73. std::cout << "Creating first batch of " << kNumSpans << " spans and waiting 3 seconds ...\n";
  74. StartAndEndSpans();
  75. std::this_thread::sleep_for(std::chrono::milliseconds(3000 + 50));
  76. // The spans should now be exported.
  77. std::cout << "....Exported!\n\n\n";
  78. // Do the same again
  79. std::cout << "Creating second batch of " << kNumSpans << " spans and waiting 3 seconds ...\n";
  80. StartAndEndSpans();
  81. std::this_thread::sleep_for(std::chrono::milliseconds(3000 + 50));
  82. std::cout << "....Exported!\n\n\n";
  83. // Shutdown and drain queue
  84. StartAndEndSpans();
  85. printf("Shutting down and draining queue.... \n");
  86. std::this_thread::sleep_for(std::chrono::milliseconds(2000));
  87. // We invoke the processor destructor
  88. // which in turn invokes the processor Shutdown(), which finally drains the queue of ALL
  89. // its spans.
  90. CleanupTracer();
  91. return 0;
  92. }