Allow JMX Insight reuse for remote connections #12178
Merged
+214
−182
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
When trying to reuse JMX Insight implementation in contrib (open-telemetry/opentelemetry-java-contrib#1445), the current implementation assumes that only local instances of
MBeanServer
are used, so we need to enable reusing it for remote connections.Fortunately as
MBeanServer
(1) extendsMBeanServerConnection
(2), this mostly requires to replace (1) with (2).PR initially opened as draft and does not need review for now until we have validated it works as we expect for remote connections with related PR.
For example, for a JVM configured with JMX to listen on
localhost:9999
with the following JVM arguments:The following example code allows to capture metrics from this JVM (at least for metric registration, proper end-to-end testing will be required on consumer side).