-
Notifications
You must be signed in to change notification settings - Fork 657
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow django to be instrumented automatically #1239
Allow django to be instrumented automatically #1239
Conversation
Django instrumentation required that OTEL_PYTHON_DJANGO_INSTRUMENT environment variable be set to "True" by users. All other instrumentations are enabled out of the box and there is no apparent reason to disable Django by default. This commit changes the logic so that Django instrumentation is applied by default. Users can set `OTEL_PYTHON_DJANGO_INSTRUMENT` env var to `"False"` to disable it.
d92c457
to
164b89c
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice!
|
||
Django's instrumentation can be disabled by setting the following environment variable. | ||
|
||
#. ``export OTEL_PYTHON_DJANGO_INSTRUMENT=False`` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I like .. envvar::
directive to keep track of all the envvars we have. Then they show up in the doc index nicely. Maybe in the module's docblock and then reference it here with :envvar:`OTEL_PYTHON_DJANGO_INSTRUMENT`
?
Related #1147
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agree but probably better if handled in a separate PR. One PR per package would provide a nice incremental improvement.
Disabling Django Instrumentation | ||
-------------------------------- | ||
|
||
Django's instrumentation can be disabled by setting the following environment variable. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Curious as to why we would expose a way to disable instrumentation where the user can simply not instrument manually/autoinstrument? Just asking because I don't think we have this mechanism for any other instrumentation.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This was inspired by the DataDog implementation. If you have the Xinstrumentation plugin installed in your virtual environment it will instrument the Xlibrary when you run auto instrumentation, regardless if the user wants it or not. I see that this has some value when testing stuff, since it is easier than uninstalling the Xinstrumentation plugin, but I don't find this to be a critical feature. Maybe we should follow the same pattern in the rest of the instrumentations or remove it from this one to be consistent?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it is helpful when auto-instrumentation comes into play especially with the bootstrap command. The flow looks something like this:
pip install opentelemetry-instrumentation
opentelemetry-instrumentation-bootstrap -a=install
opentelemetry-instrument python main.py
Since the bootstrap command does not have any way to exclude certain instrumentations, an env var like this can help selectively disable some in case users find issues. I think instead of having this for every instrumentation, we can have a single var for the instrument command that accept a comma separated values to disable instrumentations. Something like,
export OTEL_PYTHON_DISABLED_INSTRUMENTATIONS=django,psycopg2
opentelemetry-instrument python main.py
This will allow people to temporarily disable instrumentation if they want and the feature will be consolidated in a single place (instrument command).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah consistency is what I recommend. @owais I don't have a strong opinion about this, please create an issue for the other instrumentations if you do decide to keep it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
* chore: update metrics example with UpDownCounter * chore: update getting-started * chore: update README * fix: lint * Update packages/opentelemetry-metrics/README.md Co-authored-by: Daniel Dyla <dyladan@users.noreply.github.com> * Update packages/opentelemetry-metrics/README.md Co-authored-by: Daniel Dyla <dyladan@users.noreply.github.com> Co-authored-by: Daniel Dyla <dyladan@users.noreply.github.com>
Description
Django instrumentation required that OTEL_PYTHON_DJANGO_INSTRUMENT
environment variable be set to "True" by users. All other
instrumentations are enabled out of the box and there is no apparent
reason to disable Django by default. This commit changes the logic so
that Django instrumentation is applied by default. Users can set
OTEL_PYTHON_DJANGO_INSTRUMENT
env var to"False"
to disable it.Type of change
Please delete options that are not relevant.
How Has This Been Tested?
Checklist: