Adam Gardner
Adam Gardner
  • Видео 41
  • Просмотров 39 254
PROMETHEUS Metrics for your Python FastAPI App
In this video I will show you how to instrument a Python FastAPI to emit or send Prometheus Metrics. I also show those same metrics being captured in Prometheus.
Code Samples: See Git Repo in pinned comment.
Просмотров: 55

Видео

OpenTelemetry Semantic Conventions Best Practices
Просмотров 8719 часов назад
In this video I respond to a reddit thread regarding the user of OpenTelemetry Semantic conventions vs. a "roll your own" approach and recommend some best practices.
Store ANYTHING on DockerHub
Просмотров 9021 час назад
Dockerhub and other container registries are no longer just for your applications. You can store ANYTHING in a registry using the CNCF project ORAS.
Prometheus Service Discovery
Просмотров 7921 час назад
In this video I describe what Prometheus service discovery is and two ways to do it. File based service discovery and service discovery via a custom made Python and FastAPI targets endpoint server. This is another hands on video. Git Repo: See Pinned Comment Timestamps 00:00 Prometheus Service Discovery Overview 00:15 Video Summary and Outcomes 00:34 What is Service Discovery? 01:47 Hands On 03...
Monitor JSON APIs like a PRO in 9 minutes using Prometheus json_exporter
Просмотров 120День назад
This video demonstrates, with a hands on tutorial, how to use Prometheus to monitor any JSON endpoint using the Prometheus json_exporter. Once you know this, you can scrape and monitor any JSON API endpoint easily in Prometheus Git repo in pinned comment. Timestamps 00:00 Hello 00:20 Architecture 01:23 Hands On 01:57 Start JSON Web Server 02:28 Download json_exporter 02:52 json_exporter configu...
Brand new to Prometheus? Watch THIS!
Просмотров 24314 дней назад
Take your first steps with the CNCF project Prometheus. This video really is for absolute beginners with no prior knowledge required. Timestamps 00:00 Intro 00:06 What You Will Achieve in this video 00:31 What is Prometheus? 00:55 The Prometheus Components 01:37 Pull vs. Push 02:43 Pulling metrics = Scraping metrics 03:00 Prometheus Metric Types 03:08 Counter Metric 03:34 Summaries and Histogra...
Chaos Engineering: The C word
Просмотров 5921 день назад
I discuss Chaos engineering and why I believe that it needs a new name. A rebrand. A fresh start. What is currently known as chaos engineering is incredibly valid and valuable - but we're not doing the discipline any favours by using the C word. Timestamps 00:00 Intro 01:27 What is Chaos Engineering? 01:58 Best tools to start with Chaos Engineering 02:42 The importance of Observability 03:17 Ch...
OpenTelemetry filestats receiver [in 5 minutes]
Просмотров 3683 месяца назад
Hands on with the OpenTelemetry filestats receiver in five minutes. filestats receiver: github.com/open-telemetry/opentelemetry-collector-contrib/tree/main/receiver/filestatsreceiver OpenObserve: openobserve.io Chapters 00:00 Introduction 00:52 Default Metrics 01:04 file.mtime 01:34 file.size 01:40 Optional Metrics 01:48 file.atime 01:55 file.ctime 02:20 Configure the collector 02:52 Enabling o...
Which OpenTelemetry Collector Distribution?
Просмотров 6575 месяцев назад
Which OpenTelemetry collector distribution should you choose? What are the choices? Use official core, contrib or Kubernetes version? Go for a vendor provided distribution? Build your own using the OpenTelemetry Collector Builder (OCB?) Timestamps 00:00 Intro 00:09 What is a collector distribution? 00:36 Understanding the components of a collector distribution 01:39 OpenTelemetry official distr...
OpenTelemetry Collector: EVERYTHING you need to know [to get started]
Просмотров 3,8 тыс.5 месяцев назад
This video covers everything you need to know if you're new to the OpenTelemetry collector. In it I discuss the components: receivers, processors, exporters, pipelines, connectors and extensions. Timestamps 00:00 Intro 00:27 What is the OpenTelemetry collector? 00:51 How do you run an OpenTelemetry collector? 00:58 Collector standalone binary 01:11 Collector container image 01:18 Collector on K...
Use CURL for OpenTelemetry Logs?? YES!
Просмотров 2286 месяцев назад
Yes! You really can use curl to send OpenTelemetry logs! This is the easy button. Send a curl to an OpenTelemetry collector and get a log line into your observability system. Transcript Open telemetry, metrics, logs, traces, processors, receivers. Where is the easy button? I just want to send a log line in and see something. Let's get straight to it. Now, everyone has curl, so what I really wan...
FastAPI and requests [Python] with OpenTelemetry in 2 lines of code!
Просмотров 1,2 тыс.6 месяцев назад
How to instrument Python FastAPI and requests modules automatically in just two lines of code. Transcript Fast API and the requests module are two of the most popular pieces of the Python ecosystem. A while ago, I did a video on how to manually instrument with open telemetry, but you know, times have moved on and there are really good auto instrumenters now. So in this video, I'm going to show ...
OpenTelemetry filelog receiver + OpenObserve: Any logs to any destination!
Просмотров 1,4 тыс.6 месяцев назад
Use the OpenTelemetry collector's filelog receiver to grab any log, from anywhere and send it to any system you want (or multiple backends simultaneously). This video will show you how. Timestamps 00:00 The Status Quo: Manually processing log files 00:30 Manually looking at individual log files does not scale! 00:45 OpenTelemetry's collector and filelog receiver to the rescue 00:50 Gotcha! Don'...
Redis in Python in under 4 minutes for beginners
Просмотров 3216 месяцев назад
Here's how to use Python in Redis in under 4 minutes. This video will get you started with the very basics of working with Redis in Python. You'll also see cache busting techniques (aka automated removal of values from Redis after a set amount of time). This video is meant for beginners to get you up and running as quickly as possible. Sections 00:00 Intro 00:09 Installation 00:36 Definition of...
Spans vs. Traces in OpenTelemetry: Which is Which?
Просмотров 1,1 тыс.7 месяцев назад
This quick tips video discusses the differences between spans and traces in OpenTelemetry
OpenTelemetry and Python: Manually create complex traces
Просмотров 4867 месяцев назад
OpenTelemetry and Python: Manually create complex traces
OpenTelemetry and Python: Sending spans from Python to Jaeger via an OpenTelemetry Collector
Просмотров 1,5 тыс.8 месяцев назад
OpenTelemetry and Python: Sending spans from Python to Jaeger via an OpenTelemetry Collector
OpenTelemetry & Python: Manually set Span Status, Span Attributes and Span Events
Просмотров 1 тыс.9 месяцев назад
OpenTelemetry & Python: Manually set Span Status, Span Attributes and Span Events
OpenTelemetry & Python: Manual Instrumentation for Beginners
Просмотров 3,3 тыс.9 месяцев назад
OpenTelemetry & Python: Manual Instrumentation for Beginners
Helm Plugin 101: How to create a Helm Plugin
Просмотров 253Год назад
Helm Plugin 101: How to create a Helm Plugin
tracepusher v0.8.0 release notes
Просмотров 135Год назад
tracepusher v0.8.0 release notes
Perform a SQL Injection Attack (and how to avoid in your code!)
Просмотров 382Год назад
Perform a SQL Injection Attack (and how to avoid in your code!)
tracepusher v0.7.0 released
Просмотров 95Год назад
tracepusher v0.7.0 released
Logpusher in action
Просмотров 201Год назад
Logpusher in action
tracepusher v0.6 release notes
Просмотров 53Год назад
tracepusher v0.6 release notes
Tracing Gitlab Pipelines with OpenTelemetry
Просмотров 1,2 тыс.Год назад
Tracing Gitlab Pipelines with OpenTelemetry
Get Started with Fluent Bit in 2 minutes
Просмотров 4,7 тыс.Год назад
Get Started with Fluent Bit in 2 minutes
OpenTelemetry, OpenFeature, CloudEvents, CDEvents and OCSF
Просмотров 782Год назад
OpenTelemetry, OpenFeature, CloudEvents, CDEvents and OCSF
Docker and OCI Image Analysis: Dive Project Intro
Просмотров 469Год назад
Docker and OCI Image Analysis: Dive Project Intro
Pyrsia Overview and Hands On in 5 minutes
Просмотров 802 года назад
Pyrsia Overview and Hands On in 5 minutes

Комментарии

  • @prateeksarangi9187
    @prateeksarangi9187 23 часа назад

    great one mate , looking forward for more upcoming video on prometheus and grafana. 👍👍

  • @agardnerit
    @agardnerit День назад

    GitHub: github.com/agardnerIT/fastapi-plus-prometheus

  • @prateeksarangi9187
    @prateeksarangi9187 2 дня назад

    great video once again , please keep continue on the prometheus series . great lecture

    • @agardnerit
      @agardnerit 2 дня назад

      Thanks! The Prometheus content seems useful to people so I’ll put more on the list. LMK anything in particular you’d like.

  • @prateeksarangi9187
    @prateeksarangi9187 2 дня назад

    Great video mate , keep making such content , if possible its integration with k8s such as eks with kube prometheus stack would be really helpful

    • @agardnerit
      @agardnerit 2 дня назад

      Thank you so much for the kind words. I’ve put that on my todo list. Keep the ideas coming!

  • @kingdome9031
    @kingdome9031 5 дней назад

    Thank you so much !

  • @MarkStaAna-t6n
    @MarkStaAna-t6n 5 дней назад

    Thanks for the video Adam. Just a note for anyone else wanting to give this a go for themselves. Make sure you use the opentelemetry-collector from contrib repo. This "official" collector runs on a LTS schedule so you won't get any of the cooler receivers, transformers and exporters.

  • @jscancella
    @jscancella 7 дней назад

    What's the advantage of doing it this way instead of having python update the prometheus.yml and hitting the prometheus endpoint to have it reload the config?

    • @agardnerit
      @agardnerit 7 дней назад

      Great question! The hot reload doesn't change the PID (it really is a soft reload) and you get logs with the timings. So, if you've built something, perhaps don't rush out and change it. BUT I would say that a) You've basically build the SD config mechanism yourself b) You have to maintain what you've built. c) You have to extend it for any other "sources". The service discovery option "just works" for any of the 28 _sd_config providers you can find here: prometheus.io/docs/prometheus/latest/configuration/configuration/ Imagine tomorrow your org says "we're spinning stuff up on openstack". You'd need to figure out how to retrieve the endpoints, parse stuff from open stack format to prometheus JSON then run Python regularly. In short, if it ain't broke, I can't find an obvious reason to change, but if it was me, I would just use offload the SD config burden to the Prometheus project / community and relieve myself of that burden.

  • @agardnerit
    @agardnerit 9 дней назад

    GitHub Repo with code samples: github.com/agardnerIT/prometheus-service-discovery

  • @agardnerit
    @agardnerit 12 дней назад

    GitHub repo for hands on: github.com/agardnerIT/prometheus-hands-on-json-exporter

  • @agardnerit
    @agardnerit 15 дней назад

    Git repo: github.com/agardnerIT/prometheus-for-beginners

  • @RakeshShivayyaGuttedar
    @RakeshShivayyaGuttedar Месяц назад

    Well explained.

  • @AnnabelleAYRAULT
    @AnnabelleAYRAULT Месяц назад

    Thank you for this video

  • @tomhopewell2537
    @tomhopewell2537 Месяц назад

    Best explanation of open telemetry I've come across yet!

  • @orendado
    @orendado 2 месяца назад

    Thanks for the example & explanation , is there a link to the source code ?

  • @arceus02
    @arceus02 2 месяца назад

    Hi, Thanks for the east explanation for the topics. I have one question , what would happen if we leave the processor part empty ? like would the data flowing into the metrics would be correct or not ?

    • @agardnerit
      @agardnerit 2 месяца назад

      Processors are optional. If they aren't specified, nothing happens meaning the data is not altered in any way. What you send in is what comes out again.

  • @devendrabharadwaz9580
    @devendrabharadwaz9580 2 месяца назад

    Excellent content with clarity and nice pace.

  • @arnabdhar-y7j
    @arnabdhar-y7j 2 месяца назад

    Thank You for explaining Open Telemetry in such a simple way. Just one suggestion, please lower down the background music, it can cause distraction to some viewers

  • @rupenanjaria
    @rupenanjaria 2 месяца назад

    Nice explaination: question though, when we say we can have multiple receivers (4:18), are you saying that OT collector is replaced by prometheus? as if I understand, OT collector receives data, processes (so that Prometheus can understand) and exports it. Later, prometheus will collect the data via pull.

    • @agardnerit
      @agardnerit 2 месяца назад

      Prometheus can be understood as two different things. 1) The Prometheus data syntax. By this I mean the syntax of the lines of code that describe the metrics + the fact that metrics usually live at a standard endpoint. 2) The Prometheus "product". By this I mean the software that retrieves (or accepts) metrics, stores them, visualises them etc. Here I'm explaining that the OTEL collector (instead of Prometheus) can scrape the metrics (which are formatted like 1) and send them to a backend which isn't prometheus (2). My point about multiple receivers: Prometheus (the product) only deals with metrics. It doesn't do metrics or traces. But the OTEL collector process all of those signals. So... If your backend is capable, you can send your metrics, logs and traces to the same place.

  • @oe5019
    @oe5019 2 месяца назад

    As always greate video frim Adam about Fluebt Bit, is there any chance for a video about sending syslog messages to Fluent Bit?

  • @MHamza-wx5kv
    @MHamza-wx5kv 2 месяца назад

    Thanks for the tutorial, I just have two questions, in the video where do you manage to fetch log files from the VMs? like I don't see any VM name or the IP.. or am I missing something here? Second, as per 2:21 you configured and deployed Otel Collector on each VM?

    • @agardnerit
      @agardnerit 2 месяца назад

      Correct, the collector would be deployed on each VM (or at least in a location capable of retrieving the logs if the logs were on a network share (for example). One thing to mention is that you could use the OpenTelemetry collector builder (look for the “everything you need to know to get started with the collector” video on my channel) and custom build a collector with ONLY the filelog receiver, whichever processors you want (eg batch) and the exporter you need (eg. OTLP). The resulting binary would be tiny and thus a much easier “sell” to your boss to deploy in each VM

  • @MHamza-wx5kv
    @MHamza-wx5kv 2 месяца назад

    Best video and best explanation! thanks for the nice explanation.

  • @relicfrog
    @relicfrog 3 месяца назад

    Very good explanation of the core components of the OpenTelemtry Collector! I'm already looking forward to new content on this!

  • @RolfRochen-yb6sq
    @RolfRochen-yb6sq 3 месяца назад

    Very well explained 👍

  • @mrmuli23
    @mrmuli23 3 месяца назад

    Oh man you have amazing content! thank you so much for this explanation and looking forward to more! The way you broke down the collector and in the end introduced connectors and extensions is brilliant. Keep it up

    • @agardnerit
      @agardnerit 3 месяца назад

      Awesome, thank you!

  • @LielAlmog
    @LielAlmog 3 месяца назад

    This was a very good video !

  • @SameerSalve
    @SameerSalve 3 месяца назад

    Can this send metrics back to Prometheus or VictoriaMetrics? I was trying this but it didn't work with Prometheus/VictoriaMetrics as backend. Thanks for your videos .

    • @agardnerit
      @agardnerit 3 месяца назад

      Yes, Prometheus could scrape the collector or you could use the prometheusremotewrite exporter. TBH though, these days I'd be expecting any backend to be OpenTelemetry Protocol OTLP compliant and thus the OTLP(http) exporter(s) should "just work". I have no experience with VictoriaMetrics so can't comment

  • @jscancella
    @jscancella 3 месяца назад

    Perfect video for me to share with my coworkers who don't know anything about open telemetry, thank you! Im looking forward to seeing all the specialized videos on the various collector elements

  • @zuowang5185
    @zuowang5185 3 месяца назад

    did you confuse http vs grpc with tcp vs websocket? I thought grpc is where you define the schema for compact serialization and unmarshaling

  • @zuowang5185
    @zuowang5185 3 месяца назад

    why do you need "as span" if you aren't using `span` later?

  • @amasoharnold4762
    @amasoharnold4762 4 месяца назад

    Does it mean it’s like fluentd ? I’ve been looking into logging I’ve got some backend api and a database I would like to have a webpage where I could track logs I’ve come across elk stack and I’ve now know that Logstash is a way to centralized all logs as well as fluentd but I’ve been seeing open telemetry popping of here and there during my search but I’m not sure what it is everything is so abstract that I’m seeing

    • @agardnerit
      @agardnerit 4 месяца назад

      The collector and fluentd (sidenote, I'd recommend fluentbit over fluentd) are both the middleware. OpenTelemetry is not a backend (storage) for Observability data (logs, metrics, traces etc.) so you'll still need a backend system (ELK, Dynatrace, Datadog, Opensearch etc.). Would it be helpful if I made a short explainer viideo on "what is OpenTelemetry?"

    • @amasoharnold4762
      @amasoharnold4762 4 месяца назад

      ⁠​⁠​⁠​⁠​⁠​⁠​⁠​⁠@@agardnerityes I guess that’ll be nice but I don’t know if a developer would find it useful or know what’s the use case I guess this is a very deep Devops thing which I am not I just wanted something to track logs in a nice way since I’m using docker and can’t keep running dog logs command I think I’ve been seeing this fluentbit thing as well but they aren’t a lot of resources like fluentd I didn’t even know this term flying around called observability but I guess it’s part of a broader name given to do certain things Thank you very much for your response also can I know which is the most simplest solution for my use case I just want to have a way of viewing my logs and nothing to heavy or resource intensive I’m currently dabbling with this elk thing and it seems packed with a lot of stuffs I don’t need and understand

  • @zuowang5185
    @zuowang5185 4 месяца назад

    annoying music

  • @duncdudeable
    @duncdudeable 4 месяца назад

    I like the music, sets a cadence to the video, just needs to be lowered a bit :)

  • @PrasadTupe-n3z
    @PrasadTupe-n3z 4 месяца назад

    Thank you very much. Was able to replicate the same in Windows.

  • @daddyIsBest
    @daddyIsBest 4 месяца назад

    You instrumented the app, but didn't uninstrument it. FastAPIInstrumentor().uninstrument_app(app) Ain't it necessary.

  • @navinkumar6388
    @navinkumar6388 5 месяцев назад

    Learning new items Thanks 🙏 for this video 📸 With Love from India 🇮🇳

    • @agardnerit
      @agardnerit 5 месяцев назад

      I’m happy you found this useful. Let me know if you find any cool projects that I should review!

  • @nforlife
    @nforlife 5 месяцев назад

    I'm new to open telemetry and this was very informative

    • @agardnerit
      @agardnerit 5 месяцев назад

      So glad you found it useful.

  • @akshayawate7239
    @akshayawate7239 5 месяцев назад

    Hi @adam, couple of months back, I mailed you regarding Otel collaboration

    • @agardnerit
      @agardnerit 5 месяцев назад

      Sorry, I missed that. What collaboration?

  • @mahzorimipod
    @mahzorimipod 5 месяцев назад

    cool story

  • @vivekshukla2480
    @vivekshukla2480 5 месяцев назад

    Thank you so much. How can I start the collector up? Your code in github doesn't have `otelcol` file - I would appreciate your help.

    • @agardnerit
      @agardnerit 5 месяцев назад

      I don’t add (and don’t recommend adding) large binaries to repos as it bloats the repo unnecessarily. There are many collector distributions available to choose from (that’s my next video about how you choose). But to get you going for now: download the appropriate binary from here: github.com/open-telemetry/opentelemetry-collector-releases/latest extract it and run it

  • @vivekshukla2480
    @vivekshukla2480 5 месяцев назад

    Running this `docker run -p 16686:16686 -p 4317:4317 225` produces error stating Unable to find image `225:latest` locally. I was so looking forward to getting this done, using your tutorials, but I may end up moving on to someone else's. :(

    • @agardnerit
      @agardnerit 5 месяцев назад

      That command is referencing an existing container ID because I had Jaeger running previously. Just replace 255 with jaegertracing/all-in-one:1.60 www.jaegertracing.io/docs/1.60/getting-started/

    • @vivekshukla2480
      @vivekshukla2480 5 месяцев назад

      @@agardnerit Thank you so much. How can I start the collector up? Your code in github doesn't have otelcol file - I would appreciate your help.

  • @vivekshukla2480
    @vivekshukla2480 5 месяцев назад

    My response somehow got deleted, but this video I am having trouble following, for example - starting from using the docker command to run the jaeger, so I used previous video to run the jaeger then even after jumping through hoops I could never get past the issue when I run `python app.py` command. I receive Transient error StatusCode.UNAVAILABLE encountered while exporting traces to 127.0.0.1:6004. error. Suggestion is appreciated.

    • @agardnerit
      @agardnerit 5 месяцев назад

      You need to run Jaeger AND a seperate standalone Otel collector. It’s the standalone collector that you need to configure (via the YAML file) to listen on 6004. This is because jaeger already runs a collector on 4317 / 4318 so you can’t use those ports for your standalone.

  • @vivekshukla2480
    @vivekshukla2480 5 месяцев назад

    What do I need to get `./otelcol --config=collector-config.yaml` running, in your previous videos I have not seen you install any specific tool to be able to call this command successfully, Did I miss something?

    • @agardnerit
      @agardnerit 5 месяцев назад

      Thanks. You're right actually. I missed that. I'll make a quick video explaining the different options soon. But in short, see this page: opentelemetry.io/docs/collector/installation/ There are many different distributions of the collector, the OTEL project produces a few that supposedly are optimised for particular use cases. Some vendors produce their own and you can even build your own. In these videos I use the contributors distribution. I downloaded the binary for my OS from here: github.com/open-telemetry/opentelemetry-collector-releases/releases/latest

    • @vivekshukla2480
      @vivekshukla2480 5 месяцев назад

      @@agardnerit Thank you for your quick response. I will let you know how it goes, to provide some background, I was able to follow your ruclips.net/video/5GdWixsopeg/видео.htmlsi=GIkjN1HisC-gSE6y video that let me visualize the traces. I am assuming this video will take it a step further. Am I not right?

  • @leamon9024
    @leamon9024 5 месяцев назад

    Hi, thanks for the video. Could you explain the difference between OpenTelemetry Collector and jaeger-collector?

    • @agardnerit
      @agardnerit 5 месяцев назад

      Thanks for the suggestion, I'll put this topic on my backlog! The timing of your request is interesting as the Jaeger project is looking to move more towards the OTEL Collector. IMO using the OTEL collector is the future proof decision.

  • @nrodear
    @nrodear 6 месяцев назад

    thank you. gg

  • @oe5019
    @oe5019 6 месяцев назад

    Wow Greate Video!, but you didn't mention how you jave installed the OpenTelemtry Collector, did you ran it on a Container?

    • @agardnerit
      @agardnerit 6 месяцев назад

      At 03:47 you can see I've download the otelcol-contrib collector (the OpenTelemetry contrib distribution) and am running it as a standalone binary. There are many ways to run the collector so I didn't want to go into each one. You're right though, for future videos I'll call this out more clearly. opentelemetry.io/docs/collector/installation/

  • @srsvg
    @srsvg 6 месяцев назад

    i searched for "opentelemetry python" and only your channel results were relevant - so you can keep on extending this series - also create playlist

    • @agardnerit
      @agardnerit 6 месяцев назад

      Thank you. Please do suggest content you’d like to see and if I know enough about it, I’ll do it

  • @srsvg
    @srsvg 6 месяцев назад

    agree - music is distracting - video content is good

  • @GabrielCamboim-p8s
    @GabrielCamboim-p8s 6 месяцев назад

    Just wanted to say that I've found your series very helpful. For the last week I've been trying to understand these concepts, but none of the other videos or docs that I've found helped me as you did. Keep creating content about telemetry in Python! <3

    • @agardnerit
      @agardnerit 6 месяцев назад

      Thank you so much. If you want specific content covered, let me know and if I know it, I’ll do an episode on it :) We’re all learning all of this together. Good luck!

  • @dotnetfanboy
    @dotnetfanboy 6 месяцев назад

    Please cut out the background music. Very useful video otherwise.

  • @MrBarneyDinosaur
    @MrBarneyDinosaur 7 месяцев назад

    So a span is effectively a structured log (e.g. a JSON Object), and a trace is a collection of structured logs (e.g. an array of JSON objects) - where each structured log may have different attributes (including arrays of other structured logs)?

    • @agardnerit
      @agardnerit 7 месяцев назад

      Love the comment. It's one of the reasons I make this content. To provoke thought and discussion - so keep them coming :) I've always felt a bit uneasy with the projects use of that terminology. While technically, yes, spans are structured and traces are collections of spans. I feel like this oversimplifies and may lead new users (the intended audience for this video) to equate spans == logs. That would be a mistake because then they think: "oh well, I'll just use logs as I already do". You're not wrong though, technically. At the end of the day, Observability for me is the means to provide the ability to do your job (fix / prevent the issue, generate a report for the boss etc.). Whether that takes the form of a log line, or a span, or a metric, ultimately who cares (beyond those of us who live and breath Observability).