Skip to content

Commit

Permalink
Add more docs, split auto-instrumentation.md into auto-instrumentatio…
Browse files Browse the repository at this point in the history
…n-introduction.md, auto-instrumentation-install.md
  • Loading branch information
jvoravong committed Apr 4, 2023
1 parent 5423bc9 commit f2f8ed2
Show file tree
Hide file tree
Showing 7 changed files with 335 additions and 31 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).

### Added

- Add support for Operator based Java auto-instrumentation [#701](https://github.com/signalfx/splunk-otel-collector-chart/pull/701)
- Add experimental support for deploying OpenTelemetry Operator as a subchart [#691](https://github.com/signalfx/splunk-otel-collector-chart/pull/691)
- Improve documentation about providing tokens as Kubernetes secrets [#707](https://github.com/signalfx/splunk-otel-collector-chart/pull/691)

Expand Down
4 changes: 4 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
.PHONY: cert-manager
cert-manager:
bash ./ci_scripts/setup_cert_manager.sh

.PHONY: render
render:
bash ./examples/render-examples.sh
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -220,6 +220,10 @@ helm delete my-splunk-otel-collector
To fully configure the Helm chart, see the [advanced
configuration](docs/advanced-configuration.md).

## Auto-instrumentation

For setting up auto-instrumentation, see the [auto-instrumentation-introduction.md](docs/auto-instrumentation-introduction.md).

## Contributing

We welcome feedback and contributions from the community! Please see our ([contribution guidelines](CONTRIBUTING.md)) for more information on how to get involved.
Expand Down
279 changes: 279 additions & 0 deletions docs/auto-instrumentation-install.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,279 @@
# Auto-instrumentation

The process of adding observability code to your application so that it produces telemetry data is known as
instrumentation. There are two main approaches to instrumentation in OpenTelemetry: auto-instrumentation and manual
instrumentation.

Auto-instrumentation

- Usually is the easiest way to setup instrumentation for applications
- OpentTelemetry leverages Kubernetes to implement auto-instrumentation in such a way that your applications can be
instrumented not by updating the application source code but rather by utilizing Kubernetes resources.
- Supports a subset of instrumentation libraries compared to manual instrumentation

Manual Instrumentation

- Takes more setup effort compared to auto-instrumentation but offers more customizability
- Requires editing application source code to include pre-built OpenTelemetry instrumentation libraries
- Supports more instrumentation libraries and customization of the exported telemetry data compared to
auto-instrumentation

In particular, auto-instrumentation is useful for applications that use widely popular frameworks and libraries, as
these frameworks often have pre-built instrumentation capabilities already available.

## Getting started with auto-instrumentation

### 1. If the cert-manager available in the cluster, deploy it

The cert-manager adds certificates and certificate issuers as resource types in Kubernetes clusters, and simplifies the
process of obtaining, renewing and using those certificates. You can use the following make commands to deploy the
cert-manager.

```
make cert-manager
# If make is not availabe, you can use these commands.
kubectl get pods -l app=cert-manager --all-namespaces
kubectl apply -f https://github.com/cert-manager/cert-manager/releases/download/v1.10.0/cert-manager.yaml
```

### 2. Deploy the Helm Chart with the Operator enabled

You can pass `--set operator.enabled=true` when deploying the chart to enable the operator. You can also use commands
like in the following example.

```
VALUES_FILE=examples/enable-operator-and-auto-instrumentation/enable-operator-and-auto-instrumentation-values.yaml
helm install splunk-otel-collector \
-f $VALUES_FILE \
-n monitoring \
helm-charts/splunk-otel-collector
```

### 3. Deploy the opentelemetry.io/v1alpha1 Instrumentation

This Instrumentation object is a spec to configure what instrumentation libraries to use for instrumentation. An
Instrumentation object must be available to the target pod for auto-instrumentation to function. Here is an example
of a Instrumentation yaml file and how to install it.

<details open>
<summary>Expand for sample splunk-instrumentation.yaml</summary>

```yaml
# splunk-instrumentation.yaml
apiVersion: opentelemetry.io/v1alpha1
kind: Instrumentation
metadata:
name: splunk-instrumentation
spec:
exporter:
endpoint: http://$(SPLUNK_OTEL_AGENT):4317
propagators:
- tracecontext
- baggage
- b3
dotnet:
env:
- name: SPLUNK_OTEL_AGENT
valueFrom:
fieldRef:
apiVersion: v1
fieldPath: status.hostIP
- name: OTEL_EXPORTER_OTLP_ENDPOINT
value: http://$(SPLUNK_OTEL_AGENT):4317
- name: OTEL_TRACES_EXPORTER
value: otlp
```
</details>
```
# Install
kubectl apply -f splunk-instrumentation.yaml
# Check the current deployed values
kubectl get otelint -o yaml
```

### 4. Verify all the OpenTelemetry resources (collector, operator, webhook, instrumentation) are deployed successfully

<details open>
<summary>Expand for sample output to verify against</summary>

```
kubectl get pods -n monitoring
# NAME READY
# STATUS RESTARTS AGE
# splunk-otel-collector-agent-9ccgn 2/2 Running 0 3m
# splunk-otel-collector-agent-ft4xc 2/2 Running 0 3m
# splunk-otel-collector-k8s-cluster-receiver-56f7c9cf5b-mgsbj 1/1 Running 0 3m
# splunk-otel-collector-operator-6dffc898df-5jjkp 2/2 Running 0 3m
kubectl get mutatingwebhookconfiguration.admissionregistration.k8s.io -n monitoring
# NAME WEBHOOKS AGE
# cert-manager-webhook 1 8m
# splunk-otel-collector-operator-mutation 3 2m
kubectl get otelinst -n spring-petclinic
# NAME AGE ENDPOINT
# splunk-instrumentation 3m http://$(SPLUNK_OTEL_AGENT):4317
```

</details>

### 5. Instrument application by setting an annotation

An _inject instrumentation_ annotation can be added to the following.
- Namespace: All pods within that namespace will be instrumented.
- Pod Spec Objects: PodSpec objects that are available as part of Deployment,
Statefulset, or other resources can be annotated.
following values.
- "true" - inject and Instrumentation resource from the namespace.
- "my-instrumentation" - name of Instrumentation CR instance in the current
namespace.
- "my-other-namespace/my-instrumentation" - name and namespace of.
Instrumentation CR instance in another namespace.
- "false" - do not inject.

### 6. Check out the results at [Splunk Observability APM](https://app.us1.signalfx.com/#/apm)

The trace and metrics data should populate the APM dashboard.To better
visualize this example as a whole, we have also included a an image
of what the APM dashboard should look like and a architecture diagram to show
how everything is set up.

## Learn by example

- [Java Spring Clinic Example](../examples/enable-operator-and-auto-instrumentation/README.md)

## How does auto-instrumentation work?

OpenTelemetry offers auto-instrumentation by using an
[operator](https://kubernetes.io/docs/concepts/extend-kubernetes/operator/)
in a Kubernetes environment. An operator is a method of packaging, deploying, and managing Kubernetes applications.
In the context of setting up observability in a Kubernetes environment, an operator simplifies the management of
application auto-instrumentation, making it easier to gain valuable insights into application performance.

With this Splunk OTel Collector chart, the
[OpenTelemetry Operator](https://github.com/open-telemetry/opentelemetry-operator#opentelemetry-auto-instrumentation-injection)
can be deployed (by configuring `operator.enabled=true`) to your cluster and start auto-instrumenting your applications.
The chart and operator are two separate applications, but when used together they enable powerful telemetry data
related features for users.

The OpenTelemetry operator implement a
[MutatingAdmissionWebhook](https://kubernetes.io/docs/reference/access-authn-authz/admission-controllers/#mutatingadmissionwebhook)
that allows the operator to modify pod specs when a pod is created or updated. MutatingAdmissionWebhooks are
essentially part of the cluster control-plane, they functionally work by intercepting and modifying requests to the
Kubernetes API server after the request is authorized but before being persisted. MutatingAdmissionWebhooks are required
to be served via HTTPS, we use the Linux Foundation [cert-manager](https://cert-manager.io/docs/installation/kubectl/)
application to generate proper certificates.

For our Observability use case, the webhook modifies a pod to inject auto-instrumentation libraries into
the application container.

What does this really look like in practice? Let's describe the Java use case for this. I've deployed the chart with
everything needed to set up auto-instrumentation and I want to instrument my Java application.

- The operator auto-instruments my the application by injecting the Splunk OTel Java library
(Javaagent) into the application container via an OpenTelemetry init container that copies the Javaagent into a volume
that is mounted to the application container.
- The operator configures the SDK by injecting environment variables into the application container. The
JAVA_TOOL_OPTIONS environment variable is used to set the JVM to use the injected Javaagent.

Below is a breakdown of the main and related components involved in auto-instrumentation:

<details open>
<summary>Splunk OTel Collector Chart</summary>

- Description
- A Helm chart used to deploy the collector and related resources.
- The Splunk OTel Collector Chart is responsible for deploying the Splunk OTel collector (agent and gateway mode) and
the OpenTelemetry Operator.

</details>

<details open>
<summary>OpenTelemetry Operator</summary>

- Description
- The OpenTelemetry Operator is responsible for setting up auto-instrumentation for Kubernetes pods.
- The auto-instrumented applications are configured to send data to either a collector agent, collector gateway, or
Splunk backend ingestion endpoint.
- Has the capability to a particular kind of OpenTelemetry
native [collectors](https://github.com/open-telemetry/opentelemetry-collector),
however using this capability to manage the collectors deployed by the Splunk OTel Collector Chart is not supported.
- Optionally deployed as a subchart located
at: https://github.com/open-telemetry/opentelemetry-helm-charts/tree/main/charts/opentelemetry-operator
- _The OpenTelemetry Operator Chart is owned and maintained by the OpenTelemetry Community, Splunk provides best
effort support with issues related OpenTelemetry Operator Chart._
- Sub-components
- Mutating Admission Webhook
- Dependencies
- Cert Manager

</details>

<details open>
<summary> Kubernetes Object - opentelemetry.io/v1alpha1 Instrumentation </summary>

- Description
- A Kubernetes object used to configure auto-instrumentation settings for applications at the namespace or pod level.
- Documentation
- https://github.com/open-telemetry/opentelemetry-operator/blob/main/docs/api.md#instrumentation

</details>

<details open>
<summary>OpenTelemetry SDK</summary>

- Description
- The SDK is the implementation of the OpenTelemetry API.
- It's responsible for processing the telemetry data generated by the application and sending it to the configured
backend.
- The SDK typically consists of exporters, processors, and other components that handle the data before it is sent to
the backend.
- _The OpenTelemetry Operator is owned and maintained by the OpenTelemetry Community, Splunk provides best effort
support with issues related to the native OpenTelemetry Operator._
- Documentation
- [OpenTelemetry Tracing SDK](https://opentelemetry.io/docs/reference/specification/trace/sdk/)

</details>

<details open>

<summary>OpenTelemetry Instrumentation Libraries</summary>

- Description:
- OpenTelemetry auto-instrumentation still relies on instrumentation libraries for specific frameworks, libraries, or
components of your application.
- These libraries generate telemetry data when your application uses the instrumented components.
- Splunk, OpenTelemetry, and other vendors produce instrumentation libraries to.
- Documentation
- https://opentelemetry.io/docs/instrumentation/

In the table below current instrumentation libraries are listed, if they are supported, and how compatible they are
with Splunk customer content.
_The native OpenTelemetry instrumentation libraries are owned and maintained by the OpenTelemetry Community, Splunk
provides best effort support with issues related to native OpenTelemetry instrumentation libraries._

| Instrumentation Library | Distribution | Status | Supported | Splunk Content Compatability | Code Repo | Image Repo |
|-------------------------|---------------|---------------------|------------------|------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| java | Splunk | Generally Available | Yes | Completely | [Link](github.com/signalfx/splunk-otel-java) | ghcr.io/signalfx/splunk-otel-java/splunk-otel-java |
| dotnet | Splunk | Coming Soon | | | [Link](github.com/signalfx/splunk-otel-dotnet) | |
| nodejs | Splunk | Coming Soon | | | [Link](github.com/signalfx/splunk-otel-nodejs) | |
| python | Splunk | Coming Soon | | | [Link](github.com/signalfx/splunk-otel-python) | |
| apache-httpd | Splunk | Coming Soon | | | [Link](github.com/signalfx/splunk-otel-apache-httpd) | |
| java | OpenTelemetry | Generally Available | Yes | Mostly | [Link](https://github.com/open-telemetry/opentelemetry-java-instrumentation) | ghcr.io/open-telemetry/opentelemetry-operator/autoinstrumentation-java |
| dotnet | OpenTelemetry | Generally Available | Needs Validation | | [Link](https://github.com/open-telemetry/opentelemetry-dotnet-instrumentation) | ghcr.io/open-telemetry/opentelemetry-operator/autoinstrumentation-dotnet |
| nodejs | OpenTelemetry | Generally Available | Needs Validation | | [Link](https://github.com/open-telemetry/opentelemetry-nodejs-instrumentation) | ghcr.io/open-telemetry/opentelemetry-operator/autoinstrumentation-nodes |
| python | OpenTelemetry | Generally Available | Needs Validation | | [Link](https://github.com/open-telemetry/opentelemetry-java-instrumentation) | ghcr.io/open-telemetry/opentelemetry-operator/autoinstrumentation-java |
| apache-httpd | OpenTelemetry | Generally Available | Needs Validation | | [Link](https://github.com/open-telemetry/opentelemetry-apache-httpd-instrumentation) | ghcr.io/open-telemetry/opentelemetry-operator/autoinstrumentation-apache-httpd |

</details>

### Documentation Resources

- https://developers.redhat.com/devnation/tech-talks/using-opentelemetry-on-kubernetes
- https://github.com/open-telemetry/opentelemetry-operator/blob/main/README.md
- https://github.com/open-telemetry/opentelemetry-operator/blob/main/docs/api.md#instrumentation
- https://github.com/open-telemetry/opentelemetry-operator/blob/main/README.md#opentelemetry-auto-instrumentation-injection
- https://github.com/open-telemetry/opentelemetry-operator/blob/main/README.md#use-customized-or-vendor-instrumentation
43 changes: 43 additions & 0 deletions docs/auto-instrumentation-introduction.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
# Getting started with the Collector with Operator Auto-instrumentation

Auto-instrumentation helps you to easily add observability code to your application, enabling it to produce telemetry data. OpenTelemetry offers two main approaches to instrumentation: auto-instrumentation and manual instrumentation.

## Instrumentation Approaches

### Auto-Instrumentation
- Simple setup process
- Utilizes Kubernetes resources for implementation
- Only supports a subset of instrumentation libraries

### Manual Instrumentation
- More setup effort required
- Greater customizability
- Supports more instrumentation libraries and customization of telemetry data

Auto-instrumentation is particularly useful for applications using popular frameworks and libraries with pre-built instrumentation capabilities.

## Auto-Instrumentation Process Overview

OpenTelemetry auto-instrumentation is achieved using an [operator](https://kubernetes.io/docs/concepts/extend-kubernetes/operator/) in a Kubernetes environment. The operator simplifies management of application auto-instrumentation, making it easier to gain insights into application performance.

When using the Splunk OTel Collector chart with the [OpenTelemetry Operator](https://github.com/open-telemetry/opentelemetry-operator#opentelemetry-auto-instrumentation-injection), you can deploy auto-instrumentation to your cluster and instrument your applications.

### Components Involved

- **Splunk OTel Collector Chart**: Deploys the collector and related resources, including the OpenTelemetry Operator.
- **OpenTelemetry Operator**: Manages auto-instrumentation of Kubernetes applications.
- **Instrumentation Libraries**: Generates telemetry data when your application uses instrumented components.
- **Kubernetes Object - opentelemetry.io/v1alpha1 Instrumentation**: Configures auto-instrumentation settings for applications.

## Splunk OTel Auto-instrumentation

### Quick Start
To use auto-instrumentation via the operator, these are the high-level steps:

1. Deploy OpenTelemetry infrastructure to your Kubernetes cluster, this includes cert-manager, Splunk OTel Collector, OpenTelemetry Operator, and Auto-Instrumentation Spec.
2. Apply annotations at the pod or namespace level for the Operator to know which pods to apply auto-instrumentation to.
3. Now, allow the Operator to do the work. As Kuberenetes api requests for create and update annotated pods are processed, the Operator will intercept and alter those requests so that the internal pod application containers are instrumented.

### More Information

For more technical documentation please see: [auto-instrumentation-install.md](auto-instrumentation-install.md)
Loading

0 comments on commit f2f8ed2

Please sign in to comment.