We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
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
Virtual thread pinning in procedure calling
Hi, I am using Java 21, spring boot 3.3.2
When I enable virtual threads and -Djdk.tracePinnedThreads=short I got virtual thread pinning and deadlock my requests.
virtual threads
-Djdk.tracePinnedThreads=short
The pinning log :
Thread[#179,ForkJoinPool-1-worker-28,5,CarrierThreads] org.springframework.jdbc.core.simple.AbstractJdbcCall.compile(AbstractJdbcCall.java:298) <== monitors:1
I review the code there used synchronized in method level. Could we change it to java locking library.
public final synchronized void compile() throws InvalidDataAccessApiUsageException { if (!isCompiled()) { if (getProcedureName() == null) { throw new InvalidDataAccessApiUsageException("Procedure or Function name is required"); } try { this.jdbcTemplate.afterPropertiesSet(); } catch (IllegalArgumentException ex) { throw new InvalidDataAccessApiUsageException(ex.getMessage()); } compileInternal(); this.compiled = true; if (logger.isDebugEnabled()) { logger.debug("SqlCall for " + (isFunction() ? "function" : "procedure") + " [" + getProcedureName() + "] compiled"); } } }
The text was updated successfully, but these errors were encountered:
@jhoeller Can I optimize this problem? I will use CAS lock free processing for this scenario.
Sorry, something went wrong.
jhoeller
Successfully merging a pull request may close this issue.
Virtual thread pinning in procedure calling
Hi, I am using Java 21, spring boot 3.3.2
When I enable
virtual threads
and-Djdk.tracePinnedThreads=short
I got virtual thread pinning and deadlock my requests.The pinning log :
I review the code there used synchronized in method level. Could we change it to java locking library.
The text was updated successfully, but these errors were encountered: