Skip to content

Sample Flask Application to demonstrate OpenTelemetry instrumentation

Notifications You must be signed in to change notification settings

deosu/sample-flask-app

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Prerequisite

SigNoz should be installed in your local machine or any server. To install SigNoz follow the instructions at https://signoz.io/docs/deployment/docker/

Simple Python Flask Program with MongoDB

To show how you can see metrics for External calls and DB calls in Python app, we have created a sample app which uses a database (MongoDB) so that the example is more realistic

If you already have Mongo daemon running, you can skip the following step to install Mongo

Download MongoDB for:

Run instructions for sending data to SigNoz

pip3 install -r requirements.txt
opentelemetry-bootstrap --action=install
OTEL_RESOURCE_ATTRIBUTES=service.name=pythonApp OTEL_EXPORTER_OTLP_ENDPOINT="http://<IP of SigNoz>:4317" opentelemetry-instrument python3 app.py

For example: <IP of SigNoz> will be localhost if you are running SigNoz in your localhost. For other installations you can use the same IP where SigNoz is accessible.

Our web server is running in the port 5000 by default. Browse http://localhost:5000 to send requests to this flask server and check the metrics and trace data at http://<IP of SigNoz>:3000

Trobleshooting

If you face any problem in instrumenting with OpenTelemetry, refer to docs at https://signoz.io/docs/instrumentation/python

Run using Docker

  1. Run MongoDB using below command:
docker run --rm --name my-mongo -it -dp 27017:27017 mongo:latest
  1. Run sample-flask-app using docker image
docker run -e MONGO_HOST='IP_MONGO_HOST' -e OTEL_RESOURCE_ATTRIBUTES='service.name=pythonApp' -e OTEL_EXPORTER_OTLP_ENDPOINT='http://<IP of SigNoz>:4317' -dp 5000:5000 signoz/sample-flask-app:latest 

IP_MONGO_HOST will be docker.for.mac.localhost when running in localhost on Mac

Optional Build docker image

docker build --no-cache -t signoz/sample-flask-app:latest .

About

Sample Flask Application to demonstrate OpenTelemetry instrumentation

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 46.5%
  • Python 35.0%
  • CSS 12.2%
  • Dockerfile 3.9%
  • JavaScript 2.4%