GithubHelp home page GithubHelp logo

isabella232 / dropwizard-metrics-newrelic Goto Github PK

View Code? Open in Web Editor NEW

This project forked from newrelic/dropwizard-metrics-newrelic

0.0 0.0 0.0 220 KB

Implementation of a DropWizard metrics Reporter that sends data as dimensional metrics to New Relic

License: Apache License 2.0

Shell 0.32% Java 95.45% Kotlin 4.23%

dropwizard-metrics-newrelic's Introduction

Community Plus header

New Relic Dropwizard reporter

A Dropwizard metrics reporter for sending dimensional metrics to New Relic using the New Relic Java Telemetry SDK.

For the juicy details on how Dropwizard metrics are mapped to New Relic dimensional metrics, please visit the exporter specs documentation repo.

How To Use

gradle

Add required build.gradle dependencies to your project:

implementation("com.newrelic.telemetry:dropwizard-metrics-newrelic:0.7.0")
implementation("com.newrelic.telemetry:telemetry-core:0.13.2")
implementation("com.newrelic.telemetry:telemetry-http-okhttp:0.13.2")

If you do not want to depend on okhttp, you can remove the dependency on telemetry-http-okhttp, but you will need to construct a MetricBatchSender instance using its builder and provide your own implementation of the com.newrelic.telemetry.http.HttpPoster interface.

MetricBatchSender sender = MetricBatchSender.builder().httpPoster(<your implementation>);

Note: to use the sample code below, you will need the telemetry-http-okhttp library mentioned above. It provides implementations communicating via HTTP using the okhttp libraries, respectively.

Start the reporter

Early in the lifecycle of your application, you will want to create and start a NewRelicReporter.

The YOUR_SECRET_API_KEY is referring to your New Relic Event API insert key or license key. For more information and how to obtain a key, visit our docs.

MetricRegistry metricRegistry = new MetricRegistry(); // If you're already using dropwizard-metrics you may already have one of these.
...
String apiKey = System.getenv("YOUR_SECRET_API_KEY");

// For US region: https://metric-api.newrelic.com/metric/v1
// For EU region: https://metric-api.eu.newrelic.com/metric/v1
String ingestURI = System.getenv("METRIC_INGEST_URI");

SenderConfiguration senderConfiguration = MetricBatchSender.configurationBuilder()
        .apiKey(apiKey)
        .useLicenseKey(true) // Optional if using a license key instead of an insert key
        .endpoint(URI.create(ingestURI).toURL())
        .httpPoster(new OkHttpPoster(Duration.ofSeconds(2)))
        .build();

MetricBatchSender metricBatchSender = MetricBatchSender.create(senderConfiguration);

Attributes commonAttributes = new Attributes()
            .put("host", InetAddress.getLocalHost().getHostName())
            .put("appName", "Your Application Name Here")
            .put("other", "any other common attributes you wish");
            
NewRelicReporter reporter = NewRelicReporter.build(metricRegistry, metricBatchSender)
        .commonAttributes(commonAttributes)
        .build();
        
reporter.start(15, TimeUnit.SECONDS);

Customizing Reported Metrics

If you would like to customize the way metric names or attributes are reported to New Relic, you will want to supply customizers to the NewRelicReporterBuilder.

Consider metrics with tags encoded in their names, formatted like so: "metricName[tag:value,othertag:othervalue]", you might set up a reporter to report the metric name as metricName and add merge of the key/value pairs in name with the commonAttributes.

MetricRegistry metricRegistry = new MetricRegistry(); // If you're already using dropwizard-metrics you may already have one of these.
...
String apiKey = "<YOUR_SECRET_API_KEY>";
MetricBatchSender metricBatchSender = MetricBatchSenderFactory
                .fromHttpImplementation(OkHttpPoster::new)
                .createBatchSender(apiKey);

Attributes commonAttributes = new Attributes()
            .put("host", InetAddress.getLocalHost().getHostName())
            .put("appName", "Your Application Name Here")
            .put("other", "any other common attributes you wish");

MetricAttributesCustomizer mergeAttributesFromTaggedMetricName =
    (name, metric, attributes) -> {
      Attributes tagsAsAttributes = new Attributes();

      // get a stream of each tag:value pair within the square brackets of name and add
      // each pair to the tagsAsAttributes Attributes object
      Stream.of(name.substring(name.indexOf('['), name.indexOf(']')).split(","))
          .forEach(
              str -> {
                String[] keyValuePair = str.split(":");

                tagsAsAttributes.put(keyValuePair[0], keyValuePair[1]);
              });

      return tagsAsAttributes.putAll(attributes);
    };

NewRelicReporter reporter = NewRelicReporter.build(metricRegistry, metricBatchSender)
        .commonAttributes(commonAttributes)
        // customizer to strip encoded tags from metric name
        .metricNameCustomizer(name -> name.substring(0, name.indexOf('[')))
        .metricAttributeCustomizer(mergeAttributesFromTaggedMetricName)
        .build();

reporter.start(15, TimeUnit.SECONDS);

Dropwizard integration

If you are using the actual Dropwizard REST framework, you can get a reference to the MetricRegistry from the Dropwizard Environment in order to register your reporter.
It might look something like this:

public class MyApplication extends Application<MyConfig> {

...
    @Override
    public void run(MyConfig configuration, Environment environment) {
        MetricRegistry registry = environment.metrics();
        MetricBatchSender metricBatchSender = buildMetricBatchSender(); // see above for more complete example
        NewRelicReporter reporter = NewRelicReporter.build(registry, metricBatchSender)
                .commonAttributes(commonAttributes)
                .build();
        reporter.start(15, TimeUnit.SECONDS);

        ...
    }
...
}

Dropwizard Metrics Reporter

If you have a dropwizard project and have at least dropwizard-core 0.7.X, then you can perform the following steps to automatically report metrics to New Relic.

Add the following to your dropwizard YAML config file.

metrics:
  frequency: 1 minute                       # Default is 1 second.
  reporters:
    - type: newrelic
      apiKey: <YOUR_SECRET_API_KEY>
      overrideUri:                          # Optional. Defaults to https://metric-api.newrelic.com/
      disabledMetricAttributes:             # Optional. Defaults to (none)
      commonAttributes:                     # Optional. Defaults to (none)
      includes:                             # Optional. Defaults to (all).
      excludes:                             # Optional. Defaults to (none).

Once your dropwizard application starts, your metrics should start appearing in New Relic.

Javadoc for this project can be found here: Javadocs

Building

To compile, run the tests and build the jars:

$ ./gradlew build

Find and use your data

For tips on how to find and query your data, see Find metric data.

For general querying information, see:

Support

New Relic hosts and moderates an online forum where customers can interact with New Relic employees as well as other customers to get help and share best practices. Like all official New Relic open source projects, there's a related Community topic in the New Relic Explorers Hub. You can find this project's topic/threads here:

https://discuss.newrelic.com/tags/javaagent

Contributing

We encourage your contributions to improve the New Relic Dropwizard reporter! Keep in mind that when you submit your pull request, you'll need to sign the CLA via the click-through using CLA-Assistant. You only have to sign the CLA one time per project.

If you have any questions, or to execute our corporate CLA (which is required if your contribution is on behalf of a company), drop us an email at [email protected].

A note about vulnerabilities

As noted in our security policy, New Relic is committed to the privacy and security of our customers and their data. We believe that providing coordinated disclosure by security researchers and engaging with the security community are important means to achieve our security goals.

If you believe you have found a security vulnerability in this project or any of New Relic's products or websites, we welcome and greatly appreciate you reporting it to New Relic through HackerOne.

If you would like to contribute to this project, review these guidelines.

Licensing

The New Relic Dropwizard reporter is licensed under the Apache 2.0 License.

dropwizard-metrics-newrelic's People

Contributors

breedx-nr avatar ch4ni avatar gfuller1 avatar jasonjkeller avatar jeemar avatar jeffalder avatar jkwatson avatar jstorer avatar melissaklein24 avatar sschwell avatar xixiapdx avatar zuluecho9 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.