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

Use a virtual threads friendly pool with Jackson #4920

Merged
merged 2 commits into from
Jan 24, 2024

Conversation

mariofusco
Copy link
Contributor

This pull request is a follow up of the work done to make the internal pool used by Jackson configurable and pluggable. It is not intended to be merged until Jackson 2.16 won't be released. Also this is the porting of the same pull request sent to quarkus.

@vietj vietj added this to the 4.5.0 milestone Oct 26, 2023
@vietj
Copy link
Member

vietj commented Oct 26, 2023

merge is on hold until 2.16.0 is released

@vietj
Copy link
Member

vietj commented Nov 15, 2023

@mariofusco @franz1981 we will release 4.5.0 this week, I'm assuming we cannot yet merge this PR ?

@mariofusco
Copy link
Contributor Author

@mariofusco @franz1981 we will release 4.5.0 this week, I'm assuming we cannot yet merge this PR ?

The final release of Jackson 2.16 is not out yet ( see https://central.sonatype.com/artifact/com.fasterxml.jackson.core/jackson-core/versions ) so, unless it is ok for you to depend on that 2.16.0-rc1, I'm afraid that this PR cannot be merged yet.

@vietj
Copy link
Member

vietj commented Nov 15, 2023 via email

@vietj vietj modified the milestones: 4.5.0, 4.5.1 Nov 15, 2023
@magicprinc
Copy link
Contributor

As you know, Jackson 2.16.0 is released
https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-core/2.16.0

@mariofusco
Copy link
Contributor Author

@vietj I think that this is ready to be merged now. I bumped the jackson version with this other PR vert-x3/vertx-dependencies#157

@franz1981
Copy link
Contributor

@mariofusco Please add some tests to be sure that it works as expected; by mocking the thread id(s) and verifying it hits/distribute the requests and/or reuse the same pool, if expected

Copy link
Contributor

@franz1981 franz1981 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@mariofusco Please add some tests to be sure that it works as expected (including not getting any weird array index out of bound exception); by mocking the thread id(s) and verifying it hits/distribute the requests and/or reuse the same pool, if expected.

Additionally, add something (I would use a counter into the node(s)) to report the current size of the pool;
this type of telemetry will help to troubleshoot errors.

Decide if it makes sense to add a fastthreadlocal-only version to replace the current existing one too, and give vertx users a boost without relying on the existing implementation from Jackson (which uses SoftRef too, bleah!)

@mariofusco
Copy link
Contributor Author

@franz1981 I implemented what you suggested and added a couple of simple tests. Please let me know if there is something more that I could check or improve.

@mariofusco
Copy link
Contributor Author

@vietj @franz1981 is this ok to be merged?

@mariofusco
Copy link
Contributor Author

@vietj @franz1981 I modified my test case to use virtual threads if they are available and completely skip the test otherwise. Please let me know if there is something else to be done here. If not I don't see any further reason to hold this pull request.

Copy link
Contributor

@franz1981 franz1981 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM well done @mariofusco !

@mariofusco
Copy link
Contributor Author

Hi @vietj is there any other outstanding issue why you're holding this PR? (not rushing, just checking if I missed to do something)

@vietj vietj modified the milestones: 4.5.1, 4.5.2 Dec 13, 2023
Copy link
Member

@vietj vietj left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A couple of minor improvements

@mariofusco
Copy link
Contributor Author

A couple of minor improvements

@vietj I addressed one and replied to the other.

@vietj
Copy link
Member

vietj commented Jan 11, 2024

@mariofusco can you squash everything in a single commit with a nice commit message :-) ?

@franz1981
Copy link
Contributor

@mariofusco last thing; please can you write a draft PR in quarkus to make sure everything here is done for there?

@vietj
Copy link
Member

vietj commented Jan 15, 2024

@mariofusco I see some activity on this PR, is it safe to merge ?

@mariofusco
Copy link
Contributor Author

@mariofusco I see some activity on this PR, is it safe to merge ?

@vietj I squashed everything as you asked, but now I'm also testing the Quarkus integration as suggested by @franz1981 ( see quarkusio/quarkus#38196 ). Please just give me a bit of time to check that it is also working as expected.

@mariofusco
Copy link
Contributor Author

@vietj @franz1981 I'm sorry, but I tested this integration and found a serious bug in jackson-databind, see quarkusio/quarkus#38196 (comment)

I'm afraid that this pull request cannot be merged yet, till the problem won't be fixed in jackson and for sure we cannot use jackson 2.16.1 for this.

@vietj
Copy link
Member

vietj commented Jan 15, 2024

thanks for raising this @mariofusco so for now it will be on hold

@mariofusco
Copy link
Contributor Author

@vietj @franz1981 @geoand I further investigated the problem, found the root cause and with my last commit made my hybrid pool compatible with jackson-databind behaviour. I also test that with this fix all Quarkus integration tests in the jackson extension are green.

I'm still discussing with @cowtowncoder if what jackson-databind does is correct or not, or if we can find a way to improve it. Anyway with my fix that discussion is now unrelated with this pool implementation and now I believe that it is totally safe to merge this as it is.

@vietj if it is ok for you, please feel free merging this pull request.

@mariofusco
Copy link
Contributor Author

Hi @vietj, the problem that I found is now fixed in Jackson, but as I wrote in my former comment, with my last commit I found a solution that works even without that fix and I checked that this behaves correctly also on the quarkus integration side. Is there any outstanding work here or any other reason why you're still holding this pull request?

@vietj vietj merged commit 52b7e89 into eclipse-vertx:4.x Jan 24, 2024
7 checks passed
@vietj
Copy link
Member

vietj commented Jan 24, 2024

@mariofusco merged, thanks for the contribution, can you port this to master branch ?

@mariofusco
Copy link
Contributor Author

@mariofusco merged, thanks for the contribution, can you port this to master branch ?

@vietj see #5084

@vietj
Copy link
Member

vietj commented Jan 31, 2024 via email

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants