If you're running services in Kubernetes we recommend you use the official container images from New Relic.
There are three container images you can use depending on how you plan on using Flex:
- To run Flex only to monitor services running in Kubernetes, use the newrelic/infrastructure container image. This image only contains the Infrastructure agent, and the Docker and Flex integrations. You will not be able to perform service discovery or use other New Relic integrations.
- To run Flex alongside other New Relic integrations, use the newrelic/infrastructure-bundle container image. This adds all the other New Relic integrations. For more information see New Relic integrations.
- If you also want to monitor your Kubernetes cluster, use the newrelic/infrastructure-k8s container image. This image adds all the integrations, including the Kubernetes integration.
The preferred way to configure Flex (and other New Relic integrations) in Kubernetes is through a Config Map.
Configurations can go embedded in the Infrastructure agent config file, or live as standalone config files that you can test separately and link from the main integrations config file.
What approach to follow is up to you.
Assuming that you have installed the Kubernetes integration following the official instructions, you should have the Infrastructure agent running in your cluster, as well as two configMaps:
nri-default-integration-cfg
: config map used to enable the New Relic Kubernetes integration. Can be removed if you do not want to use this integration.nri-integration-cfg-example
: config map used to enable other integrations. You should this config map to enable Flex and other New Relic integrations.
To enable Flex, create a data
section in the config map and add an Infrastructure agent integration configuration under data
:
apiVersion: v1
kind: ConfigMap
metadata:
name: nri-integration-cfg-example
namespace: default
data:
nri-flex.yml: |
integrations:
- name: nri-flex
config:
name: example
apis:
- event_type: ExampleSample
url: https://my-host:8443/admin/metrics.json
To get a quick, first picture of a Flex configuration file, follow our basic step-by-step tutorial or check existing config files under /examples.
You can store the Flex configuration files in a separate YAML file (for example, after developing and testing a config file) and reference it by replacing config
with the config_template_path
property, which contains the path to a Flex configuration file.
The linking equivalent of the previous config map would contain:
apiVersion: v1
kind: ConfigMap
metadata:
name: nri-integration-cfg-example
namespace: default
data:
nri-flex.yml: |
integrations:
- name: nri-flex
config_template_path: /path/to/flex/integration.yml # Reference to a separate Flex config file
While this works, you would either have to create a new config map with the contents of the external file and mount it into the container, or modify the original container image to include the file.
You can also add multiple Flex configurations to the config map. There are two ways to do this:
- Add multiple Flex entries to the same configuration:
apiVersion: v1
kind: ConfigMap
metadata:
name: nri-integration-cfg-example
namespace: default
data:
nri-flex.yml: |
integrations:
- name: nri-flex-1
config:
name: example
apis:
- event_type: ExampleSample
url: https://my-host:8443/admin/metrics.json
- name: nri-flex-2
config:
name: other-example
apis:
- event_type: OtherExampleSample
url: https://my-other-host:8080/metrics.json
- Add distinct config map entries, one per configuration:
apiVersion: v1
kind: ConfigMap
metadata:
name: nri-integration-cfg-example
namespace: default
data:
nri-flex-1.yml: |
integrations:
- name: nri-flex-1
config:
name: example
apis:
- event_type: ExampleSample
url: https://my-host:8443/admin/metrics.json
nri-flex-2.yml: |
integrations:
- name: nri-flex-2
config:
name: other-example
apis:
- event_type: OtherExampleSample
url: https://my-other-host:8080/metrics.json
There are no distinctive advantages of using one over the other: choose according to your needs and preferences.
For an example of a deployment manifest, see the k8s example.