-
Notifications
You must be signed in to change notification settings - Fork 134
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
jmx scraper with sdk autoconfig #1651
base: main
Are you sure you want to change the base?
Conversation
…ontrib into sdk-autoconfig
@@ -24,7 +24,6 @@ public class JmxScraperContainer extends GenericContainer<JmxScraperContainer> { | |||
private final String endpoint; | |||
private final Set<String> targetSystems; | |||
private String serviceUrl; | |||
private int intervalMillis; |
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.
[for reviewer] this is never changed for tests, so we can use the minimal hard-coded value of 1s.
static void propagateToSystemProperties(Properties properties) { | ||
for (Map.Entry<Object, Object> entry : properties.entrySet()) { | ||
String key = entry.getKey().toString(); | ||
String value = entry.getValue().toString(); | ||
if (key.startsWith("javax.net.ssl.keyStore") || key.startsWith("javax.net.ssl.trustStore")) { | ||
if (System.getProperty(key) == null) { | ||
System.setProperty(key, value); | ||
} | ||
} | ||
} | ||
} |
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.
[for reviewer] propagation of system properties is only used to set the java keystore/truststore options from the program arguments/standard input to the global JVM settings, so it was simpler to move it here. In practice this will likely be tested when we add tests with custom keystore/truststore by setting those configuration options from the standard input or the properties file.
|
||
package io.opentelemetry.contrib.jmxscraper.config; | ||
|
||
public class ConfigurationException extends Exception { |
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.
[for reviewer] there is already a similarly named runtime exception in the SDK autoconfiguration, so reusing it makes more sense and avoid ambiguity.
if (exportInterval == null || exportInterval.isNegative() || exportInterval.isZero()) { | ||
// if not explicitly set, use default value of 1 minute as defined in specification | ||
scraperConfig.samplingInterval = Duration.ofMinutes(1); | ||
} else { | ||
scraperConfig.samplingInterval = exportInterval; |
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.
[for reviewer] we have to do this because we don't have access to the default value that will be used by the SDK when an explicit value is not present.
|
||
@Override | ||
public Map<String, String> apply(ConfigProperties config) { | ||
Map<String, String> result = new HashMap<>(); |
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.
[for reviewer] the returned map contains the configuration items that will be explicitly set/overriden so that they can be later read by the SDK initialization. In addition to that we use this to build an instance of JmxScraperConfig
from the provided ConfigProperties
that will later be used to configure the jmx scraper.
Regarding the question of default logger -- I think we should continue to be consistent with the sdk and default to exporting otlp to localhost. 👍🏻 If a user needs to see details/logging they should be able to opt-into that I think. |
I agree here, staying consistent with the SDK defaults would provide a more consistent experience. Also:
Thus I'll align with the SDK unless we have a clear use-case that justifies it. |
jmx-scraper/src/main/java/io/opentelemetry/contrib/jmxscraper/config/PropertiesSupplier.java
Show resolved
Hide resolved
jmx-scraper/src/main/java/io/opentelemetry/contrib/jmxscraper/JmxScraper.java
Outdated
Show resolved
Hide resolved
jmx-scraper/src/main/java/io/opentelemetry/contrib/jmxscraper/JmxScraper.java
Outdated
Show resolved
Hide resolved
jmx-scraper/src/main/java/io/opentelemetry/contrib/jmxscraper/JmxScraper.java
Outdated
Show resolved
Hide resolved
jmx-scraper/src/main/java/io/opentelemetry/contrib/jmxscraper/config/JmxScraperConfig.java
Outdated
Show resolved
Hide resolved
jmx-scraper/src/main/java/io/opentelemetry/contrib/jmxscraper/config/PropertiesCustomizer.java
Outdated
Show resolved
Hide resolved
jmx-scraper/README.md
Outdated
| `otel.jmx.username` | user name for JMX connection | | ||
| `otel.jmx.password` | password for JMX connection | |
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.
Doesn't have to be in this PR of course, but it might be nice to have an indication of which configs are required/optional and/or what the default values are.
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 tried to do that with dedicated column but this wasn't looking great because
- there is only a single mandatory option for the remote URL
- other arguments are mandatory depending on the context (authentication enabled on remote JVM, if there is already a target system set or a custom yaml file used).
This is why I decided to document this mostly in the config option descriptions, I've clarified that for jmx authentication in d237a56
* Exception indicating something is wrong with the provided arguments or reading the configuration | ||
* from them | ||
*/ | ||
public class InvalidArgumentException extends Exception { |
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.
Is this really providing any benefit over the built-in jdk IllegalArgumentException
?
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.
The main benefit is that it's a checked exception and that it forces the caller to take care of it. However, given the very limited scope this has, we could definitely replace it with the IllegalArgumentException
which is a runtime exception if you think that makes things less confusing.
targetSystem.forEach( | ||
s -> { | ||
if (!AVAILABLE_TARGET_SYSTEMS.contains(s)) { | ||
throw new ConfigurationException("unsupported target system: '" + s + "'"); |
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.
Doesn't this get hidden because it's buried within a closure within forEach
?
Could consider switching to if(!targetSystem.stream().allMatch(AVAILABLE_TARGET_SYSTEMS.contains(s)) ...
or similar? Maybe a filter if the detailed logging of which system is necessary.
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.
The exception does not get hidden here, this case is covered by the JmxScraperConfigTest#shouldFailValidation_invalidTargetSystem
test case.
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.
Had a few minor comments but LGTM! Stoked to have this autoconfig power.
Refactor jmx scraper configuration to use autoconfiguration.
This provides the following benefits:
Now only the the
otel.metric.export.interval
SDK configuration should be used to define the metric sampling and export interval, compatibility is provided with existingotel.jmx.interval.milliseconds
when needed.When
otel.metric.export.interval
is not set, the default of 1 minute is applied which remains consistent with the SDK implementation and specification.The ability to provide configuration through standard input, external properties and the JVM system properties have been preserved.
To be discussed
otlp
to align with the SDK default value, or should we keep thelogging
as we have currently when it's not set. Settinglogging
here by default mostly benefits onboarding as users can see what is being captured, but requires to explicitly includeotlp
which is set by default for the SDK autoconfiguration.Follow-up tasks
In instrumentation (JMX insights), the
otel.jmx.config
option provides the path to a list of custom YAML metrics definitions, we currently useotel.jmx.custom.scraping.config
which does not allow to use a list. Dealing with this was left outside of this PR and will be handled by this #1662.