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

Emulate effects of j.u.l.Logger.setLevel #3125

Merged
merged 3 commits into from
Nov 21, 2024

Conversation

ppkarwasz
Copy link
Contributor

Some libraries rely on j.u.l.Logger.getLevel returning the value that was set using j.u.l.Logger.setLevel.

This PR changes #2353 so that:

  • By default, the effective configuration of the logging backend is not modified by log4j-jul.
  • Calling setLevel modifies the return value of getLevel. Both these methods should not be used in user code, because the effective level of a logger should be checked with j.u.l.isLoggable instead. Therefore, I don't see any potential problems with these modifications.

Closes #3119

Some libraries rely on `j.u.l.Logger.getLevel` returning the value that was set using `j.u.l.Logger.setLevel`.

This PR changes #2353 so that:

- By default, the **effective** configuration of the logging backend is not modified by `log4j-jul`.
- Calling `setLevel` modifies the return value of `getLevel`. Both these methods should **not** be used in user code, because the **effective** level of a logger should be checked with `j.u.l.isLoggable` instead. Therefore, I don't see any potential problems with these modifications.

Closes #3119
@ppkarwasz
Copy link
Contributor Author

Anticipating other similar problems with the j.u.l.Logger methods, what do you think about implementing in term of "WARN + super" also the: setFilter, addHandler, removeHandler, setUseParentHandler? We can still keep the current implementation for setParent (throwing).

The setResourceBundle method, on the other hand, should probably be implemented differently: after it is called, we need to replace the message factory used by the JUL bridge with one the uses the specified bundle.

ppkarwasz referenced this pull request in openjdk/nashorn Nov 21, 2024
@ppkarwasz ppkarwasz merged commit 52dbb47 into 2.x Nov 21, 2024
9 checks passed
@ppkarwasz ppkarwasz deleted the fix/2.x/3119_set_level_call_parent branch November 21, 2024 10:14
@ppkarwasz
Copy link
Contributor Author

@kangarko,

Can you check if the latest 2.25.0-SNAPSHOT solves your problem with Nashorn? The URL of our Maven snapshot repository is on our download page.

@kangarko
Copy link

@ppkarwasz appreciated it, unfortunately we rely on the Velocity software which uses said library, I found out the problem started since of this commit: PaperMC/Velocity@f2d6e14

I do not see them using log4j2, my question is can I do something on my end? I am essentially developing a plugin for velocity which can add libraries to Velocity classpath, so I think I have some options on my end too. Thanks!

@kangarko
Copy link

@ppkarwasz could you please provide nashorn-core snapshot, instead? Because production is affected since October, I could just use the snapshot for now. Many thanks.

@ppkarwasz
Copy link
Contributor Author

ppkarwasz commented Nov 21, 2024

@kangarko,

I am not a Nashorn maintainer, sorry.

PaperMC does use log4j-jul: see the libs.version.toml file. You need to bump the version to 2.25.0-SNAPSHOT and recompile.

@kangarko
Copy link

kangarko commented Nov 21, 2024

Gotcha, thanks for the that, I have passed them the relevant information. I am unfortunately not a Paper maintainer either.

@ppkarwasz
Copy link
Contributor Author

ppkarwasz commented Nov 21, 2024

@kangarko,

The workaround for this bug was provided by the reporter in this comment:

The solution for now is to set

-Dlog4j2.julLoggerAdapter=org.apache.logging.log4j.jul.CoreLoggerAdapter

You can de facto apply that right now on prod.

@kangarko
Copy link

@ppkarwasz Thank you, you made my day with this fix!!!

I will add a note to our customers so that they can adjust their server system properties for now.

@kangarko
Copy link

kangarko commented Dec 4, 2024

@ppkarwasz I took the initiative and tried making a pull request, however upon using the snapshot version I am getting this issue when compiling:

Execution failed for task ':velocity-proxy-log4j2-plugin:compileJava'.
> java.lang.IllegalArgumentException: The `GraalVmProcessor` annotation processor is missing the required `log4j.graalvm.groupId` and `log4j.graalvm.artifactId` options.
  The generation of GraalVM reflection metadata for your Log4j Plugins will be disabled.

I tried solving it by appending these arguments to build.gradle.kts:

tasks.withType<JavaCompile> {
    options.compilerArgs.addAll(listOf(
        "-Alog4j.graalvm.groupId=org.apache.logging.log4j",
        "-Alog4j.graalvm.artifactId=log4j-core"
    ))
}

But then all plugins on the new compiled server were printing the following error in the console:

2024-12-04T11:13:21.273591100Z VelocityControl - Task Executor #0 WARN Ignoring call to `j.u.l.Logger.setLevel(OFF)`, since the Log4j API does not provide methods to modify the underlying implementation.
To modify the configuration using JUL, use an `AbstractLoggerAdapter` appropriate for your logging implementation.
See https://logging.apache.org/log4j/3.x/log4j-jul.html#log4j.jul.loggerAdapter for more information.
2024-12-04T11:13:21.274590Z VelocityControl - Task Executor #0 WARN Ignoring call to `j.u.l.Logger.setLevel(false)`, since the Log4j API does not provide methods to modify the underlying implementation.
To modify the configuration using JUL, use an `AbstractLoggerAdapter` appropriate for your logging implementation.
See https://logging.apache.org/log4j/3.x/log4j-jul.html#log4j.jul.loggerAdapter for more information.
2024-12-04T11:13:21.276589400Z VelocityControl - Task Executor #0 WARN Ignoring call to `j.u.l.Logger.addHandler(java.util.logging.ConsoleHandler@5ce92a4a)`, since the Log4j API does not provide methods to modify the underlying implementation.
To modify the configuration using JUL, use an `AbstractLoggerAdapter` appropriate for your logging implementation.
See https://logging.apache.org/log4j/3.x/log4j-jul.html#log4j.jul.loggerAdapter for more information.

My knowledge is very limited.

If this is not too far out of scope for you, I'd appreciate if you could have a quick look of what I might be doing wrong.

@kangarko
Copy link

kangarko commented Dec 4, 2024

Whats strange is that neither my plugin nor Velocity has any calls to addHandler or setLevel

@ppkarwasz
Copy link
Contributor Author

Execution failed for task ':velocity-proxy-log4j2-plugin:compileJava'.
> java.lang.IllegalArgumentException: The `GraalVmProcessor` annotation processor is missing the required `log4j.graalvm.groupId` and `log4j.graalvm.artifactId` options.
  The generation of GraalVM reflection metadata for your Log4j Plugins will be disabled.

I tried solving it by appending these arguments to build.gradle.kts:

tasks.withType<JavaCompile> {
    options.compilerArgs.addAll(listOf(
        "-Alog4j.graalvm.groupId=org.apache.logging.log4j",
        "-Alog4j.graalvm.artifactId=log4j-core"
    ))
}

Log4j Core 2.25.0 will introduce a GraalVM annotation processor that generates the necessary GraalVM Reachability Metadata for your custom Log4j Core plugins. This is documented in the "Registering Plugins" section of our staging website.
The correct parameters to use are those of your project, e.g.:

-Alog4j.graalvm.groupId=io.github.bivashy
-Alog4j.graalvm.artifactId=velocity-proxy-log4j2-plugin

But then all plugins on the new compiled server were printing the following error in the console:

2024-12-04T11:13:21.273591100Z VelocityControl - Task Executor #0 WARN Ignoring call to `j.u.l.Logger.setLevel(OFF)`, since the Log4j API does not provide methods to modify the underlying implementation.
To modify the configuration using JUL, use an `AbstractLoggerAdapter` appropriate for your logging implementation.
See https://logging.apache.org/log4j/3.x/log4j-jul.html#log4j.jul.loggerAdapter for more information.

The call to Logger.setLevel() comes certainly from Nashorn, you can ignore it for now.
I created #3281 to add more information to the warning (like the caller of the setLevel method) and a way to disable it.

@kangarko
Copy link

kangarko commented Dec 4, 2024

Thank you @ppkarwasz!! I added the pull request, tested the server and confirmed working!

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

Successfully merging this pull request may close these issues.

log4j-jul adapter makes code throws NPEs
2 participants