Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[apm] Update content related to mobile APM agents for GA #3507

Merged
merged 3 commits into from
Jan 12, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,17 @@ The chart below outlines the compatibility between different versions of Elastic
.1+|**APM AWS Lambda extension**
|`1.x` |≥ `8.2`

// Need APM integration version
// Android
.1+|**Android agent**
|`0.x` |

// Go
.2+|**Go agent**
|`1.x` |≥ `6.5`
|`2.x` |≥ `6.5`

// Update for 1.x?
// iOS
.1+|**iOS agent**
|`0.x` |≥ `7.14`
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
Expand Down Expand Up @@ -48,4 +54,5 @@ The chart below outlines the compatibility between different versions of Elastic
.2+|**JavaScript RUM agent**
|`4.x` |≥ `6.5`
|`5.x` |≥ `7.0`

|====
3 changes: 2 additions & 1 deletion docs/en/observability/apm/anonymous-auth.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -12,10 +12,11 @@ The APM Server's default response to these these requests depends on its configu
|No API key or secret token is configured | Anonymous requests are accepted by the APM Server.
|====

// Add reference to Android?
In some cases, however, it makes sense to allow both authenticated and anonymous requests.
For example, it isn't possible to authenticate requests from front-end services as
the secret token or API key can't be protected. This is the case with the Real User Monitoring (RUM)
agent running in a browser, or the iOS/Swift agent running in a user application.
agent running in a browser, or the Android or iOS/Swift agent running in a user application.
However, you still likely want to authenticate requests from back-end services.
To solve this problem, you can enable anonymous authentication in the APM Server to allow the
ingestion of unauthenticated client-side APM data while still requiring authentication for server-side services.
Expand Down
5 changes: 4 additions & 1 deletion docs/en/observability/apm/api-keys.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -98,9 +98,12 @@ image::images/apm-ui-api-key.png[{apm-app} API key]
You can now apply your newly created API keys in the configuration of each of your APM agents.
See the relevant agent documentation for additional information:

// Not relevant for RUM and iOS
// Not relevant for RUM
// but is it now relevant for iOS and Android?
* *Android*: {apm-android-ref}/configuration.html[`apiKey`]
* *Go agent*: {apm-go-ref}/configuration.html#config-api-key[`ELASTIC_APM_API_KEY`]
* *.NET agent*: {apm-dotnet-ref}/config-reporter.html#config-api-key[`ApiKey`]
* *iOS*: {apm-ios-ref}/configuration.html#withApiKey[`withApiKey`]
* *Java agent*: {apm-java-ref}/config-reporter.html#config-api-key[`api_key`]
* *Node.js agent*: {apm-node-ref}/configuration.html#api-key[`apiKey`]
* *PHP agent*: {apm-php-ref-v}/configuration-reference.html#config-api-key[`api_key`]
Expand Down
1 change: 1 addition & 0 deletions docs/en/observability/apm/apm-server-down.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ Some agents have internal queues or buffers that will temporarily store data if
As a general rule of thumb, queues fill up quickly. Assume data will be lost if APM Server goes down.
Adjusting these queues/buffers can increase the agent's overhead, so use caution when updating default values.

// * **Android agent** - ??
* **Go agent** - Circular buffer with configurable size:
{apm-go-ref}/configuration.html#config-api-buffer-size[`ELASTIC_APM_BUFFER_SIZE`].
// * **iOS agent** - ??
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,11 @@ image:./binary-yes-fm-yes.svg[supported deployment methods]
Most options on this page are supported by all APM Server deployment methods.
****

// Add reference to Android?
Elastic APM agents can send unauthenticated (anonymous) events to the APM Server.
An event is considered to be anonymous if no authentication token can be extracted from the incoming request.
This is useful for agents that run on clients, like the Real User Monitoring (RUM)
agent running in a browser, or the iOS/Swift agent running in a user application.
agent running in a browser, or the Android or iOS/Swift agent running in a user application.

Enable anonymous authentication in the APM Server to allow the
ingestion of unauthenticated client-side APM data while still requiring authentication for server-side services.
Expand Down
2 changes: 2 additions & 0 deletions docs/en/observability/apm/data-model.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,8 @@ When this occurs, the {apm-app} will display the number of spans dropped.

To configure the number of spans recorded per transaction, see the relevant Agent documentation:

// Is this still unsupported in Android and iOS?
* Android: _Not yet supported_
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
* Go: {apm-go-ref-v}/configuration.html#config-transaction-max-spans[`ELASTIC_APM_TRANSACTION_MAX_SPANS`]
* iOS: _Not yet supported_
* Java: {apm-java-ref-v}/config-core.html#config-transaction-max-spans[`transaction_max_spans`]
Expand Down
1 change: 1 addition & 0 deletions docs/en/observability/apm/data-streams.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ Or, you might create namespaces that correspond to strategic business units with

By type, the APM data streams are:

// Does `traces-apm.rum-<namespace>` also apply to Android?
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
Traces::
Traces are comprised of {apm-guide-ref}/data-model.html[spans and transactions].
Traces are stored in the following data streams:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -453,6 +453,7 @@ See the <<directory-layout,deb & rpm default paths>> for a full directory layout
// Use a tagged region to pull APM Agent information from the APM Overview
If you haven't already, you can now install APM Agents in your services!

* {apm-android-ref-v}/intro.html[Android agent]
* {apm-go-ref-v}/introduction.html[Go agent]
* {apm-ios-ref-v}/intro.html[iOS agent]
* {apm-java-ref-v}/intro.html[Java agent]
Expand Down
1 change: 1 addition & 0 deletions docs/en/observability/apm/release-notes.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ See the {kibana-ref}/release-notes.html[Kibana release notes].

**APM agents**

* {apm-android-ref-v}/release-notes.html[Android agent]
* {apm-go-ref-v}/release-notes.html[Go agent]
* {apm-ios-ref-v}/release-notes.html[iOS agent]
* {apm-java-ref-v}/release-notes.html[Java agent]
Expand Down
1 change: 1 addition & 0 deletions docs/en/observability/apm/secret-token.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ include::{apm-server-dir}/tab-widgets/secret-token-widget.asciidoc[]

Each Elastic {apm-agent} has a configuration option to set the value of the secret token:

* *Android agent*: {apm-android-ref-v}/configuration.html#secretToken[`secretToken`]
* *Go agent*: {apm-go-ref}/configuration.html#config-secret-token[`ELASTIC_APM_SECRET_TOKEN`]
* *iOS agent*: {apm-ios-ref-v}/configuration.html#secretToken[`secretToken`]
* *Java agent*: {apm-java-ref}/config-reporter.html#config-secret-token[`secret_token`]
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,17 @@
++++
<div class="tabs" data-tab-group="apm-agent-distributed-trace">
<div role="tablist" aria-label="dt">
<button role="tab"
aria-selected="false"
aria-controls="android-tab-dt-r"
id="android-dt-r">
Android
</button>
<button role="tab"
aria-selected="false"
aria-controls="go-tab-dt-r"
id="go-dt-r">
id="go-dt-r"
tabindex="-1">
Go
</button>
<button role="tab"
Expand Down Expand Up @@ -59,6 +66,17 @@
Ruby
</button>
</div>
<div tabindex="0"
role="tabpanel"
id="android-tab-dt-r"
aria-labelledby="android-dt-r"
hidden="">
++++

include::distributed-trace-receive.asciidoc[tag=android]

++++
</div>
<div tabindex="0"
role="tabpanel"
id="go-tab-dt-r"
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
// tag::android[]

_Not applicable._

// end::android[]

// tag::go[]

// Need help with this example
Expand Down Expand Up @@ -35,8 +41,6 @@ transaction := apm.DefaultTracer().StartTransactionOptions("GET /", "request", o

// tag::ios[]

experimental::[]

_Not applicable._

// end::ios[]
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,17 @@
++++
<div class="tabs" data-tab-group="apm-agent-distributed-trace">
<div role="tablist" aria-label="dt">
<button role="tab"
aria-selected="false"
aria-controls="android-tab-dt"
id="android-dt">
Android
</button>
<button role="tab"
aria-selected="false"
aria-controls="go-tab-dt"
id="go-dt">
id="go-dt"
tabindex="-1">
Go
</button>
<button role="tab"
Expand Down Expand Up @@ -59,6 +66,17 @@
Ruby
</button>
</div>
<div tabindex="0"
role="tabpanel"
id="android-tab-dt"
aria-labelledby="android-dt"
hidden="">
++++

include::distributed-trace-send.asciidoc[tag=android]

++++
</div>
<div tabindex="0"
role="tabpanel"
id="go-tab-dt"
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,10 @@
// tag::android[]

_Not applicable._

// end::android[]


// tag::go[]

1. Start a transaction with
Expand Down Expand Up @@ -29,8 +36,6 @@ tracestate := traceContext.State.String()

// tag::ios[]

experimental::[]

The agent will automatically inject trace headers into network requests using `URLSessions`, but if you're using a non-standard network library you may need to manually inject them. It will be done using the OpenTelemetry APIs:

1. Create a `Setter`
Expand All @@ -39,7 +44,7 @@ The agent will automatically inject trace headers into network requests using `U

3. Inject trace context to header dictionary

4. Follow the procedure of your network library to complete the network request. Make sure to call `span.end()` when the request succeeds or fails.
4. Follow the procedure of your network library to complete the network request. Make sure to call `span.end()` when the request succeeds or fails.

[source,swift]
----
Expand All @@ -52,7 +57,7 @@ struct BasicSetter: Setter { <1>
}
}

let span : Span = ... <2>
let span : Span = ... <2>
let setter = BasicSetter()
let propagator = W3CTraceContextPropagator()
var headers = [String:String]()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,17 @@
++++
<div class="tabs" data-tab-group="apm-agent">
<div role="tablist" aria-label="Install">
<button role="tab"
aria-selected="false"
aria-controls="android-tab-install"
id="android-install">
Android
</button>
<button role="tab"
aria-selected="false"
aria-controls="go-tab-install"
id="go-install">
id="go-install"
tabindex="-1">
Go
</button>
<button role="tab"
Expand Down Expand Up @@ -73,6 +80,17 @@
OpenTelemetry
</button>
</div>
<div tabindex="0"
role="tabpanel"
id="android-tab-install"
aria-labelledby="android-install"
hidden="">
++++

include::install-agents.asciidoc[tag=android]

++++
</div>
<div tabindex="0"
role="tabpanel"
id="go-tab-install"
Expand Down
81 changes: 79 additions & 2 deletions docs/en/observability/apm/tab-widgets/install-agents.asciidoc
Original file line number Diff line number Diff line change
@@ -1,3 +1,79 @@
// tag::android[]
*Add the agent to your project*
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

By version 1.0 this process will most likely change a lot, so I'm a bit concerned about duplicating it here and possibly forgetting to update it later 😅

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@bmorelli25 do you think we should remove this until 1.0?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's a fair point, but process changes are inevitable, and I would hate not to have an Android tab on this page.

Is there a 1.0 release issue that we can add a task to so we don't forget to update this?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

My vote is to move forward with this content as-is and either open an issue or add to an issue to help us not forget to update this content as it changes.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry I was OOO, but it sounds good 👍 I created this issue which, when merged, will make this info no longer accurate.


First, add the https://plugins.gradle.org/plugin/co.elastic.apm.android[Elastic APM agent plugin] to your application's `build.gradle` file as shown below:

[source,groovy]
----
// Android app's build.gradle file
plugins {
id "com.android.application"
id "co.elastic.apm.android" version "[latest_version]" <1>
}
----
<1> The Elastic plugin declaration must be added below the Android app plugin declaration (`com.android.application`) and below the Kotlin plugin declaration (if used).

*Configure the agent*

After adding the agent plugin, configure it.
A minimal configuration sets the Elastic APM Server endpoint as shown below:

[source,groovy]
----
// Android app's build.gradle file
plugins {
//...
id "co.elastic.apm.android" version "[latest_version]" <1>
}

elasticApm {
// Minimal configuration
serverUrl = "https://your.elastic.server"

// Optional
serviceName = "your app name" <2>
serviceVersion = "0.0.0" <3>
apiKey = "your server api key" <4>
secretToken = "your server auth token" <5>
}
----
<1> You can find the latest version in the https://plugins.gradle.org/plugin/co.elastic.apm.android[Gradle plugin portal].
<2> Defaults to your `android.defaultConfig.applicationId` value.
<3> Defaults to your `android.defaultConfig.versionName` value.
<4> Defaults to null.
More info on API Keys {ref}/security-api-create-api-key.html[here].
<5> Defaults to null.

NOTE: When both `secretToken` and `apiKey` are provided, apiKey has priority and secretToken is ignored.

*Initialize the agent*

After syncing your project with the Gradle changes above, the Elastic APM agent needs to be initialized within your https://developer.android.com/reference/android/app/Application[Application class].
This example shows the simplest way to configure the agent:

[source,java]
----
// Your Application class

class MyApp extends android.app.Application {

@Override
public void onCreate() {
super.onCreate();
ElasticApmAgent.initialize(this); <1>
}
}
----
<1> Initialize the Elastic APM agent once.

All that's left is to compile and run your application.
That's it!

*Learn more in the agent reference*

Read more in the {apm-android-ref}/intro.html[APM Android Agent Reference].
// end::android[]

// tag::go[]
*Install the agent*

Expand Down Expand Up @@ -59,8 +135,6 @@ func main() {

// tag::ios[]

experimental::[]

*Add the agent dependency to your project*

Add the Elastic APM iOS Agent as a
Expand Down Expand Up @@ -139,6 +213,9 @@ class AppDelegate: UIResponder, UIApplicationDelegate {
<3> Enable TLS for Open telemetry exporters
<4> Set secret token for APM server connection

*Learn more in the agent reference*

Read more in the {apm-ios-ref}/intro.html[APM iOS Agent Reference].
// end::ios[]

// ***************************************************
Expand Down
1 change: 1 addition & 0 deletions docs/en/observability/apm/troubleshoot-apm.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ For additional help with other APM components, see the links below.

* {fleet-guide}/troubleshooting-intro.html[*{fleet} and {agent}* troubleshooting]
* {kibana-ref}/troubleshooting.html[*{apm-app}* troubleshooting]
* {apm-android-ref-v}/troubleshooting.html[*Android agent* troubleshooting]
* {apm-dotnet-ref-v}/troubleshooting.html[*.NET agent* troubleshooting]
* {apm-go-ref-v}/troubleshooting.html[*Go agent* troubleshooting]
* {apm-ios-ref-v}/troubleshooting.html[*iOS agent* troubleshooting]
Expand Down
1 change: 1 addition & 0 deletions docs/en/observability/apm/version.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ include::{asciidoc-dir}/../../shared/versions/stack/{source_branch}.asciidoc[]

// Agent link attributes
// Used in conjunction with the stack attributes found here: https://github.com/elastic/docs/tree/7d62a6b66d6e9c96e4dd9a96c3dc7c75ceba0288/shared/versions/stack
:apm-android-ref-v: https://www.elastic.co/guide/en/apm/agent/android/{apm-android-branch}
:apm-dotnet-ref-v: https://www.elastic.co/guide/en/apm/agent/dotnet/{apm-dotnet-branch}
:apm-go-ref-v: https://www.elastic.co/guide/en/apm/agent/go/{apm-go-branch}
:apm-ios-ref-v: https://www.elastic.co/guide/en/apm/agent/swift/{apm-ios-branch}
Expand Down
Loading