Skip to content
This repository has been archived by the owner on Jul 18, 2024. It is now read-only.
/ newrelic-istio-adapter Public archive

This adapter is used to upload telemetry data which is collected by Istio Envoy proxy to NewRelic backend. It is different from compiled in adapters. You can run it as a separated process out of mixer process. The adapter communicates with Mixer, parse and send metric data to the real backend -- NewRelic.

License

Notifications You must be signed in to change notification settings

IBM/newrelic-istio-adapter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 

Repository files navigation

gRPC adapter for New Relic

This adapter is used to upload telemetry data to NewRelic backend. It is different from compiled in adapters. You can run it as a separated process out of mixer process. The adapter communicates with Mixer, parse and send metric data to the real backend -- NewRelic.

prerequisite

The data in New Relic will be presented as Insight Events. So you need to know the account id and get an insert key. You can follow this doc to get your account id. And follow this doc to get an insert key.

build

CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -a -installsuffix cgo -o nristioadapter

running as a binary file

You can run the adapter outside the k8s. Just make sure the network policy allows your k8s cluster to talk with gRPC adapter. Suppose that the compiled executable file name is nristioadapter. you should start up the adapter like this.

./nristioadapter --maxworkers 1024 --port 12345

The adapter uses a job/worker pattern to handle the request from mixer. Parameter --maxworkers points how many workers in the pool. Parameter --port shows which port should the adapter listen on.

apply config model in istio

You can reference sample_operator_cfg.yaml. Replace the address section below.

connection:
  address: "[::]:49951"

Replace the [::] with hostname or IP address of the host which adapter is running at. Replace 49951 with the real port of adapter.

deploy as a POD inside k8s

The adapter can work as a POD in k8s. You can refer the yaml under kube directory. Firstly you need to create a secret for account id and insert key. Account id and insert key should be base64 encoded. Then you can apply the secret.yaml, deployment.yaml and service.yaml.

Note: if you deploy the adapter as POD, you should config the handler using service name instead of hostname/IP address as binary file mode. It should follow k8s dns pattern:

$servicename.$namespace.svc.cluster.local:$port

eg.

connection:
  address:nristio.default.svc.cluster.local:8888

validate

Access any endpoint inside k8s with an envoy proxy side car. If the configuration is correct there should be some telemetry data generated. Login to your New Relic account and jump to insights view. Click data explorer and check the drop down list of events. If there is a new Custom Event called IstioMetrics then everything works.

About

This adapter is used to upload telemetry data which is collected by Istio Envoy proxy to NewRelic backend. It is different from compiled in adapters. You can run it as a separated process out of mixer process. The adapter communicates with Mixer, parse and send metric data to the real backend -- NewRelic.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published