- Видео 41
- Просмотров 39 254
Adam Gardner
Австралия
Добавлен 13 окт 2018
The channel for Observability, OpenTelemetry and DevOps content.
What I learn, I share. Join me in the learning journey and let's learn together.
agardner.net
What I learn, I share. Join me in the learning journey and let's learn together.
agardner.net
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.
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
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!)
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
great one mate , looking forward for more upcoming video on prometheus and grafana. 👍👍
GitHub: github.com/agardnerIT/fastapi-plus-prometheus
great video once again , please keep continue on the prometheus series . great lecture
Thanks! The Prometheus content seems useful to people so I’ll put more on the list. LMK anything in particular you’d like.
Great video mate , keep making such content , if possible its integration with k8s such as eks with kube prometheus stack would be really helpful
Thank you so much for the kind words. I’ve put that on my todo list. Keep the ideas coming!
Thank you so much !
You're welcome!
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.
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?
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.
GitHub Repo with code samples: github.com/agardnerIT/prometheus-service-discovery
GitHub repo for hands on: github.com/agardnerIT/prometheus-hands-on-json-exporter
Git repo: github.com/agardnerIT/prometheus-for-beginners
Well explained.
Thanks!
Thank you for this video
Best explanation of open telemetry I've come across yet!
Thanks!
Thanks for the example & explanation , is there a link to the source code ?
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 ?
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.
Excellent content with clarity and nice pace.
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
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.
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.
As always greate video frim Adam about Fluebt Bit, is there any chance for a video about sending syslog messages to Fluent Bit?
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?
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
Best video and best explanation! thanks for the nice explanation.
Very good explanation of the core components of the OpenTelemtry Collector! I'm already looking forward to new content on this!
Very well explained 👍
Thank you 🙂
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
Awesome, thank you!
This was a very good video !
Thank you!
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 .
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
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
did you confuse http vs grpc with tcp vs websocket? I thought grpc is where you define the schema for compact serialization and unmarshaling
why do you need "as span" if you aren't using `span` later?
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
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?"
@@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
annoying music
I like the music, sets a cadence to the video, just needs to be lowered a bit :)
Thank you very much. Was able to replicate the same in Windows.
Glad it helped!
You instrumented the app, but didn't uninstrument it. FastAPIInstrumentor().uninstrument_app(app) Ain't it necessary.
Learning new items Thanks 🙏 for this video 📸 With Love from India 🇮🇳
I’m happy you found this useful. Let me know if you find any cool projects that I should review!
I'm new to open telemetry and this was very informative
So glad you found it useful.
Hi @adam, couple of months back, I mailed you regarding Otel collaboration
Sorry, I missed that. What collaboration?
cool story
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.
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
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. :(
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/
@@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.
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.
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.
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?
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
@@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?
Hi, thanks for the video. Could you explain the difference between OpenTelemetry Collector and jaeger-collector?
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.
thank you. gg
Wow Greate Video!, but you didn't mention how you jave installed the OpenTelemtry Collector, did you ran it on a Container?
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/
i searched for "opentelemetry python" and only your channel results were relevant - so you can keep on extending this series - also create playlist
Thank you. Please do suggest content you’d like to see and if I know enough about it, I’ll do it
agree - music is distracting - video content is good
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
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!
Please cut out the background music. Very useful video otherwise.
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)?
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).