Skip to content

[statsd] Add graalvm native-image support via resource-config.json #84

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

Merged
merged 1 commit into from
Jun 26, 2025

Conversation

rbygrave
Copy link
Contributor

Refer to upstream PR - DataDog/java-dogstatsd-client#270

This is needed to support native-image compilation. The dogstatsd/version.properties resource is read when creating the NonBlockingStatsDClient at:

NonBlockingStatsDClient.(NonBlockingStatsDClient.java:309)

Adding the META-INF/native-image/com.datadoghq/dogstatsd-client/resource-config.json is the fix to
avoid the following stack trace.

Exception in thread "main" com.timgroup.statsd.StatsDClientException: Failed to start StatsD client
at com.timgroup.statsd.NonBlockingStatsDClient.(NonBlockingStatsDClient.java:348)
at com.timgroup.statsd.NonBlockingStatsDClient.(NonBlockingStatsDClient.java:374)
at com.timgroup.statsd.NonBlockingStatsDClientBuilder.build(NonBlockingStatsDClientBuilder.java:211)
at io.avaje.metrics.statsd.StatsdBuilder.build(StatsdBuilder.java:99)
... truncated
Caused by: java.lang.NullPointerException: inStream parameter is null
at [email protected]/java.util.Objects.requireNonNull(Objects.java:246)
at [email protected]/java.util.Properties.load(Properties.java:409)
at com.timgroup.statsd.NonBlockingStatsDClient.(NonBlockingStatsDClient.java:309)
... 11 more

@rbygrave rbygrave self-assigned this Jun 26, 2025
@rbygrave rbygrave merged commit d88e167 into master Jun 26, 2025
2 checks passed
@rbygrave rbygrave deleted the feature/native-image-statsd branch June 26, 2025 23:16
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.

1 participant