This is a cache of https://www.elastic.co/guide/en/apm/agent/android/current/automatic-instrumentation.html. It is a snapshot of the page at 2025-10-21T00:50:29.900+0000.
Automatic instrumentation | APM Android Agent Reference [<strong>1</strong>.x] | Elastic
IMPORTANT: This documentation is no longer updated. Refer to Elastic's version policy and the latest documentation.

Automatic instrumentation

edit

The agent has an opt-in functionality that automatically generates telemetry on your behalf. This allows you to get telemetry data for supported targets without having to write manual instrumentation.

How it works

edit

Installation

edit

Install the automatic instrumentations youR17;d like to use.

Specific targets are supported for automatic instrumentation, each with its own Gradle plugin for installation. To install a supported automatic instrumentation, follow these steps:

  1. Choose a supported instrumentation.
  2. Add its Gradle plugin to your project in the same location where the agent is added.
  3. Initialize the agent the same way you would without using automatic instrumentation. Automatic instrumentations will get installed during the agent initialization without having to write extra code.

Compilation behavior

edit

Some automatic instrumentations perform "byte code instrumentation" (also called byte code weaving), where your applicationR17;s code (including code from the libraries it uses) is modified at compile-time. This automates code changes that you would otherwise need to make manually.

Byte code instrumentation is a common technique which may already be used in your project for use cases such as code optimization through R8. While useful, code instrumentation can make compilation take longer to complete. Because of this, the agent provides a way to exclude specific build types in your app from byte code changes, similar to what isMinifyEnabled does with R8 functionalities.

Configuration

edit

For some large projects (including dependencies), you can avoid the added compilation time caused by the compilation behavior by excluding build types that donR17;t need the functionality. Use the following configuration to do so:

// Your app's build.gradle.kts file
plugins {
    // ...
    id("co.elastic.otel.android.agent")
}

// ...

elasticAgent {
    bytecodeInstrumentation.disableForBuildTypes.set(listOf("debug")) 
}
  1. By default, the disableForBuildTypes list is empty. Add any build type names for which you want to disable byte code instrumentation.

Disabling byte code instrumentation will cause the automatic instrumentations that need it to not work properly on the affected build type. This shouldnR17;t cause issues to your appR17;s functionality in general, it will only affect the agentR17;s ability to automatically collect telemetry.

Supported instrumentations

edit

OkHttp

edit

Creates spans for outgoing HTTP requests that are made using the OkHttp library. This also includes tools that rely on OkHttp to work, such as Retrofit.

Gradle plugin
edit
plugins {
    id("co.elastic.otel.android.instrumentation.okhttp") version "[latest_version]" 
}
  1. You can find the latest version here.