-
Notifications
You must be signed in to change notification settings - Fork 674
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
SOLR-17531: Use new unified GC log options #2815
base: main
Are you sure you want to change the base?
Conversation
Starting from JDK 9, G1 is the default GC. This commit fixes the issue of unrecognized VM options.
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.
LGTM. I love that it feels like a lot of "weight" has been taken out of these scripts. Having said that, I wonder if you should drop a note to dev@solr.apache.org asking for another set of eyes? Since GC is a dark art! With no tests!
Is this PR mostly about removing redundancy, or is it changing the effective defaults to be more in line with best-practices? e.g. G1GC - are we moving away from it towards something else, or is it merely disappearing from our scripts because the JVM itself uses it as a default, etc. |
I tried to keep the settings the same and remove redundancy / update to new notation. G1GC is the default GC since Java 9. With Java 21 we also have Generational ZGC which could be a nice feature to enable, but I am not familiar enough to tune the configuration. This is also why I was looking for GC experts to improve the existing configuration and make sure the config I "migrated" is free of bugs. In JDK 17 support for some JDK 8 log-related configs has been dropped. See https://confluence.atlassian.com/confkb/unrecognized-jvm-gc-options-when-using-jdk-11-17-1002472841.html for details. |
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 I prefer the GC being explicit instead of relying on whatever JDK value is the default. The logging cleanup configs look good, but I would keep the G1GC configs.
I was thinking the same when I was editing it, thinking that if the defaults may change under certain circumstances, then we will not have a "reproducible" state. But for the same reason we would have to include all other defaults as well. I tried to understand why this was added in the first place, and it seemed to be some pre JDK 9 stuff, where G1GC was not the default GC and had to be configured explicitly. Since we had a lot of legacy JDK configuration, I decided to remove it during the cleanup. Not sure if there were other reasons though, as I never had to configure the JDK before (besides memory). |
https://issues.apache.org/jira/browse/SOLR-13394 is where g1 was changed to be the default. I still think we should be explicit about using G1GC and make an explicit change away from it not just to what the JDK defaults to. |
I agree with what Kevin said. Basically, explicitly enable G1GC because it's a rather important choice to not make an explicit decision on. But otherwise, no need to configure what doesn't need to be configured. |
467e78e
to
e46d13e
Compare
Since this PR is only addressing GC log options now, should we address other related issues here as well? We could resolve the following outdated PRs: |
https://issues.apache.org/jira/browse/SOLR-17531
Description
This is a follow-up to #2792 for fixing issues and cleaning up
GC_LOG_OPTS
configurations.Solution
Use the new unified GC logging configuration.
Tests
No tests were added due to it's complexity. If you have any recommendations for how to test GC configurations, please let me know.
Checklist
Please review the following and check all that apply:
main
branch../gradlew check
.