lwtrace_example2.cpp 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. #include <library/cpp/lwtrace/control.h>
  2. #include <library/cpp/lwtrace/all.h>
  3. #include <library/cpp/getopt/last_getopt.h>
  4. #include <google/protobuf/text_format.h>
  5. #include <util/stream/file.h>
  6. #define LWTRACE_EXAMPLE_PROVIDER(PROBE, EVENT, GROUPS, TYPES, NAMES) \
  7. PROBE(StartupProbe, GROUPS(), TYPES(), NAMES()) \
  8. PROBE(IterationProbe, GROUPS(), TYPES(i64, double), NAMES("n", "result")) \
  9. PROBE(DurationProbe, GROUPS(), TYPES(ui64, i64, double), NAMES("duration", "n", "result")) \
  10. PROBE(ResultProbe, GROUPS(), TYPES(double), NAMES("factN")) \
  11. PROBE(AfterInputProbe, GROUPS(), TYPES(i32), NAMES("n")) \
  12. /**/
  13. LWTRACE_DECLARE_PROVIDER(LWTRACE_EXAMPLE_PROVIDER)
  14. LWTRACE_DEFINE_PROVIDER(LWTRACE_EXAMPLE_PROVIDER)
  15. THolder<NLWTrace::TManager> traceManager;
  16. struct TConfig {
  17. bool UnsafeLWTrace;
  18. TString TraceRequestPath;
  19. };
  20. void InitLWTrace(TConfig& cfg) {
  21. traceManager.Reset(new NLWTrace::TManager(*Singleton<NLWTrace::TProbeRegistry>(), cfg.UnsafeLWTrace));
  22. }
  23. void AddLWTraceRequest(TConfig& cfg) {
  24. TString queryStr = TUnbufferedFileInput(cfg.TraceRequestPath).ReadAll();
  25. NLWTrace::TQuery query;
  26. google::protobuf::TextFormat::ParseFromString(queryStr, &query);
  27. traceManager->New("TraceRequest1", query);
  28. }
  29. class TLogReader {
  30. public:
  31. void Push(TThread::TId tid, const NLWTrace::TCyclicLog::TItem& item) {
  32. Cout << "tid=" << tid << " probe=" << item.Probe->Event.Name;
  33. if (item.Timestamp != TInstant::Zero()) {
  34. Cout << " time=" << item.Timestamp;
  35. }
  36. if (item.SavedParamsCount > 0) {
  37. TString paramValues[LWTRACE_MAX_PARAMS];
  38. item.Probe->Event.Signature.SerializeParams(item.Params, paramValues);
  39. Cout << " params: ";
  40. for (size_t i = 0; i < item.SavedParamsCount; ++i) {
  41. Cout << " " << item.Probe->Event.Signature.ParamNames[i] << "=" << paramValues[i];
  42. }
  43. }
  44. Cout << Endl;
  45. }
  46. };
  47. void DisplayLWTraceLog() {
  48. Cout << "LWTrace log:" << Endl;
  49. TLogReader reader;
  50. traceManager->ReadLog("TraceRequest1", reader);
  51. }
  52. long double Fact(i64 n) {
  53. if (n < 0) {
  54. ythrow yexception() << "N! is undefined for negative N (" << n << ")";
  55. }
  56. double result = 1;
  57. for (; n > 1; --n) {
  58. GLOBAL_LWPROBE(LWTRACE_EXAMPLE_PROVIDER, IterationProbe, n, result);
  59. GLOBAL_LWPROBE_DURATION(LWTRACE_EXAMPLE_PROVIDER, DurationProbe, n, result);
  60. result *= n;
  61. }
  62. return result;
  63. }
  64. void FactorialCalculator() {
  65. GLOBAL_LWPROBE(LWTRACE_EXAMPLE_PROVIDER, StartupProbe);
  66. i32 n;
  67. Cout << "Enter a number: ";
  68. TString str;
  69. Cin >> n;
  70. GLOBAL_LWPROBE(LWTRACE_EXAMPLE_PROVIDER, AfterInputProbe, n);
  71. double factN = Fact(n);
  72. Cout << n << "! = " << factN << Endl << Endl;
  73. GLOBAL_LWPROBE(LWTRACE_EXAMPLE_PROVIDER, ResultProbe, factN);
  74. }
  75. int main(int argc, char** argv) {
  76. TConfig cfg;
  77. using namespace NLastGetopt;
  78. TOpts opts = NLastGetopt::TOpts::Default();
  79. opts.AddLongOption('u', "unsafe-lwtrace",
  80. "allow destructive LWTrace actions")
  81. .OptionalValue(ToString(true))
  82. .DefaultValue(ToString(false))
  83. .StoreResult(&cfg.UnsafeLWTrace);
  84. opts.AddLongOption('f', "trace-request",
  85. "specify a file containing LWTrace request")
  86. .DefaultValue("example_query.tr")
  87. .StoreResult(&cfg.TraceRequestPath);
  88. opts.AddHelpOption('h');
  89. TOptsParseResult res(&opts, argc, argv);
  90. InitLWTrace(cfg);
  91. AddLWTraceRequest(cfg);
  92. FactorialCalculator();
  93. DisplayLWTraceLog();
  94. return 0;
  95. }