Skip to content
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

refactor(instrumentation-mysql2): improve performance of getSpanName using substring #2470

Merged

Conversation

geotry
Copy link
Contributor

@geotry geotry commented Oct 10, 2024

Which problem is this PR solving?

We noticed that getSpanName() from instrumentation-mysql2 was taking non-negligeable time from our profiler in production, considering that it's in a critical path.

This PR replaces split() by substring() to avoid instanciating a new array everytime.

Here is a benchmark with the difference before and after (~20 times faster for me): https://jsbm.dev/YtumA6nRNvjVJ

Short description of the changes

Use substring() with indexOf() instead of split() to extract the SQL verb from a sql query. It also checks for queries with no spaces like "COMMIT" and fallback to return the raw query.

@geotry geotry requested a review from a team as a code owner October 10, 2024 10:44
Copy link

linux-foundation-easycla bot commented Oct 10, 2024

CLA Signed

The committers listed above are authorized under a signed CLA.

@github-actions github-actions bot added pkg:instrumentation-mysql2 pkg-status:unmaintained This package is unmaintained. Only bugfixes may be acceped until a new owner has been found. labels Oct 10, 2024
@maryliag
Copy link
Contributor

Would you mind doing the same change on the other mysql package, to keep consistency: https://github.com/open-telemetry/opentelemetry-js-contrib/blob/main/plugins/node/opentelemetry-instrumentation-mysql/src/utils.ts#L118

Copy link
Contributor

This package does not have an assigned component owner and is considered unmaintained. As such this package is in feature-freeze and this PR will be closed with 14 days unless a new owner or a sponsor (a member of @open-telemetry/javascript-approvers) for the feature is found. It is the responsibility of the author to find a sponsor for this feature.
Are you familiar with this package? Consider becoming a component owner.

Copy link

codecov bot commented Oct 11, 2024

Codecov Report

Attention: Patch coverage is 77.77778% with 2 lines in your changes missing coverage. Please review.

Project coverage is 90.86%. Comparing base (d056d21) to head (07a9d46).
Report is 1 commits behind head on main.

Files with missing lines Patch % Lines
...e/opentelemetry-instrumentation-mysql/src/utils.ts 80.00% 1 Missing ⚠️
.../opentelemetry-instrumentation-mysql2/src/utils.ts 75.00% 1 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #2470      +/-   ##
==========================================
- Coverage   90.88%   90.86%   -0.02%     
==========================================
  Files         159      159              
  Lines        7844     7849       +5     
  Branches     1616     1621       +5     
==========================================
+ Hits         7129     7132       +3     
- Misses        715      717       +2     
Files with missing lines Coverage Δ
...e/opentelemetry-instrumentation-mysql/src/utils.ts 95.65% <80.00%> (-2.08%) ⬇️
.../opentelemetry-instrumentation-mysql2/src/utils.ts 94.44% <75.00%> (-2.53%) ⬇️

@david-luna
Copy link
Contributor

@geotry

Thanks for contributing to OpenTelemetry :)

Could you run npm run lint:fix and push the changes to pass all checks?

@geotry
Copy link
Contributor Author

geotry commented Oct 11, 2024

thanks for the review

@maryliag I implemented the change in instrumentation-mysql, but it was slightly different as it was returning the full query string in case of an object instead of just the verb. I'm not sure wether it's safe or not to apply this change as a test was failing.

I also fixed the lint issues, sorry about that @david-luna

@geotry geotry force-pushed the refactor/mysql2-improve-span-name branch from 81e955b to ddd8401 Compare October 14, 2024 10:43
@maryliag
Copy link
Contributor

Thank you for updating the other package too! 😄
I'm waiting for a maintainer to approve the workflows so we can see what is failing and get a fix for it, then we can get this merged

@david-luna david-luna merged commit 25e53d6 into open-telemetry:main Oct 23, 2024
22 of 23 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
pkg:instrumentation-mysql pkg:instrumentation-mysql2 pkg-status:unmaintained:autoclose-scheduled pkg-status:unmaintained This package is unmaintained. Only bugfixes may be acceped until a new owner has been found.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants