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

[docs] Prepare docs #328

Merged
merged 27 commits into from
Aug 15, 2024
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
9b38831
initial outline
colleenmcginnis Jul 10, 2024
e44e2a2
align with other distro docs
colleenmcginnis Jul 12, 2024
24a80bb
align with other languages
colleenmcginnis Jul 15, 2024
ca8fc23
clean up code comments, align with other distro docs
colleenmcginnis Jul 17, 2024
ce09010
reframe generated guide as migration guide
colleenmcginnis Jul 22, 2024
0ad5009
update intro, add questions
colleenmcginnis Jul 24, 2024
bcd7053
update getting started
colleenmcginnis Jul 25, 2024
16435f0
update configuration file
colleenmcginnis Jul 25, 2024
df5d7d2
lint content
colleenmcginnis Jul 25, 2024
b448968
address feedback from @bmorelli25
colleenmcginnis Jul 25, 2024
22c264d
translate from asciidoc to markdown
colleenmcginnis Jul 31, 2024
597a8a1
merge intro content and README content, link to docs from README
colleenmcginnis Aug 2, 2024
a7bea62
adjust for github audience
colleenmcginnis Aug 2, 2024
907bf1d
fix some formatting
colleenmcginnis Aug 2, 2024
c0b561c
update docs automation
colleenmcginnis Aug 2, 2024
14028dc
update reference to automation
colleenmcginnis Aug 2, 2024
be1578a
Update README.md
colleenmcginnis Aug 8, 2024
c651698
update naming
colleenmcginnis Aug 13, 2024
5118a24
address feedback from @mdbirnstiehl
colleenmcginnis Aug 13, 2024
0e35f17
Merge branch 'main' into prep-docs
colleenmcginnis Aug 13, 2024
e181c25
update link text
colleenmcginnis Aug 13, 2024
59685f5
one more for to of
colleenmcginnis Aug 13, 2024
7b4daff
fix ConfigurationExporterTest to generate markdown instead of asciidoc
jackshirazi Aug 14, 2024
603fdd3
apply suggestions from code review
colleenmcginnis Aug 14, 2024
b524161
update download section
colleenmcginnis Aug 14, 2024
08fbe23
apply suggestions from code review
colleenmcginnis Aug 15, 2024
419d641
Merge branch 'main' into prep-docs
colleenmcginnis Aug 15, 2024
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
131 changes: 131 additions & 0 deletions docs/configuration.asciidoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,131 @@
////
Goal of this doc:
Provide a complete reference of all available configuration options and where/how they can be set. (Any Elastic-specific configuration options are listed directly. General OpenTelemetry configuration options are linked.)

Assumptions we're comfortable making about the reader:
* They are familiar with Elastic
* They are familiar with OpenTelemetry
////

[[configuration]]
== Configure

:language: Java
:language_lc: java
:distro_name: Elastic Distribution for OpenTelemetry {language}

include::release-status.asciidoc[]

////
TO DO: How do users set configuration options?
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
////
[discrete]
[[configure-methods]]
=== Configuration methods

////
TO DO:
Are there multiple ways to set configuration options?
For example, can they use environment variables OR a config file?
If there are, what are they and why would you use each method?
Where/how do you use each method?
Provide an example to illustrate the syntax.
////
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved

////
TO DO:
If configuration options are defined using multiple methods,
which one takes precedence over the other(s)?
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
////

[discrete]
[[configuration-options]]
=== Configuration options

Because the Elastic Distribution for OpenTelemetry Java ("the distro") is an extension of the https://github.com/open-telemetry/opentelemetry-java-instrumentation[OpenTelemetry Java agent], it supports both:

* General OpenTelemetry SDK configuration options
* Elastic-specific configuration options that are only available when using the distro

[discrete]
[[configure-otel-sdk-options]]
==== OpenTelemetry SDK configuration options

////
TO DO:
Is this true?
Are there any options that aren't supported?
Any options that shouldn't be used?
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
////
The distro supports all configuration options listed in the https://opentelemetry.io/docs/languages/sdk-configuration/general/[OpenTelemetry General SDK Configuration documentation].

////
TO DO:
Are there Elastic-specific custom configuration options
in addition to the general OpenTelemetry SDK
configuration options? Or are all the customizations
"behind the scenes"?
If not, you can delete this section.
////
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
[discrete]
[[configure-distro-options]]
==== Elastic-specific configuration options
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved

The distro supports the following Elastic-specific options:

////
List config options
////

////
TO DO:
Are there multiple authentication methods when sending data to Elastic?
If not, delete this section.
////
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
[discrete]
[[configure-auth-methods]]
=== Authentication methods
Copy link
Contributor

Choose a reason for hiding this comment

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

This section needs to be the same as the content for OTEL_EXPORTER_OTLP_HEADERS in https://www.elastic.co/guide/en/observability/current/apm-open-telemetry-direct.html#apm-instrument-apps-otel

It will be the same for all agents. Maybe it can be a generic doc fragment that gets included in each agent doc?


When sending data to Elastic, there are two ways you can authenticate: using a secret token or using an APM agent key.

[discrete]
[[configure-secret-token]]
==== Use a secret token

// TO DO: What is this?
// ??

// TO DO:Why would you choose this method?
// ??

// TO DO:How do you authenticate using this method?
// ??

[discrete]
[[configure-api-key]]
==== Use an APM agent key (API key)

// ✅ What is this?
It is also possible to authenticate to an Elastic Observability endpoint using
an _APM agent key_. These are revocable API keys.

// TO DO: Why would you choose this method?
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
// ??

// ✅ How do you authenticate using this method?
To create and manage APM Agent keys in Kibana:

. Go to *APM Settings*.
. Select the *Agent Keys* tab.

When using an APM Agent key, the `OTEL_EXPORTER_OTLP_HEADERS` is set using a
different auth schema (`ApiKey` rather than `Bearer`). For example:

////
TO DO: Code example
////


:!language:
:!language_lc:
:!distro_name:
25 changes: 24 additions & 1 deletion docs/configure.asciidoc
Original file line number Diff line number Diff line change
@@ -1,5 +1,28 @@
////
I'm confused about the goal of this doc.

With a title like "Configure" I expected to see a list of the
valid configuration options. Instead it seems to be a list of
APM Java agent configuration options, and how to update them
to migrate from the agent to the distro.

Is the intention of this doc to be a migration guide from the APM Java
agent to the Elastic Distribution for OpenTelemetry Java?
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
////

[[configure]]
== Configure
== Migrate?
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved

// I'll add this to the automation if we're sure we want this on every page.
:language: Java
:language_lc: java
:distro_name: Elastic Distribution for OpenTelemetry {language}

include::release-status.asciidoc[]

:!language:
:!language_lc:
:!distro_name:

////
This file is auto generated. Please only make changes in `configure.asciidoc.ftl`
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
Expand Down
159 changes: 154 additions & 5 deletions docs/get-started.asciidoc
Original file line number Diff line number Diff line change
@@ -1,23 +1,172 @@
////
Goal of this doc:
The user is able to successfully see data from their Java application make it to the Elastic UI via the Elastic Distribution for OpenTelemetry Java

Assumptions we're comfortable making about the reader:
* They are familiar with Elastic
* They are familiar with OpenTelemetry
* They have Java installed
////

[[get-started]]
== Get started

This guide shows you how to use the Elastic Distribution for OpenTelemetry Java to instrument your Java application and send OpenTelemetry data to an Elastic Observability deployment.
:language: Java
:language_lc: java
:distro_name: Elastic Distribution for OpenTelemetry {language}

include::release-status.asciidoc[]

This guide shows you how to use the Elastic Distribution for OpenTelemetry {language} ("the distro") to instrument your {language} application and send OpenTelemetry data to an Elastic Observability deployment.
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved

[NOTE]
====
As an OpenTelemetry SDK, the distro supports sending data to any OpenTelemetry protocol (OTLP) endpoint (https://opentelemetry.io/docs/collector/[OpenTelemetry Collector]), but this guide assumes you are sending data to Elastic.
====

////
✅ What the user needs to know and/or do before they install the distro
////
[discrete]
[[get-started-prerequisites]]
=== Prerequisites

Before getting started:

// Familiarity with OpenTelemetry
* *Familiarize yourself with the OpenTelemetry SDK.* The distro is a lightweight wrapper around the OpenTelemetry SDK. You should be broadly familiar with the OpenTelemetry SDK concepts and instrumenting applications using the Microsoft diagnostic APIs. If you are not familiar with this, start with the https://opentelemetry.io/docs/languages/net[OpenTelemetry SDK documentation].
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
+
* *Set up Elastic Observability*. You'll need somewhere to send the gathered OpenTelemetry data, so it can be viewed and analyzed. This doc assumes you're using an https://www.elastic.co/observability[Elastic Observability] cloud deployment. You can use an existing one or set up a new one.
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
+
[[elastic-observability-setup]]
[%collapsible]
.*Expand for setup instructions*
====
This section shows how to create an https://www.elastic.co/observability[Elastic Observability] cloud deployment and get the data you need to configure the distro to send data to it.

. Register at https://cloud.elastic.co/registration[cloud.elastic.co], if you haven't already. This supports starting **free trial**.
. After registering, click *Create deployment* at `<https://cloud.elastic.co/home>`.
. Once that is created, click *Open* to visit your Kibana home page, e.g. `https://{DEPLOYMENT_NAME}.kb.{REGION}.cloud.es.io/app/home#/getting_started`.
====

////
TO DO:
Anything else they need to do/have/know?
For example, any dependencies (including specific supported Java versions)?
////

////
✅ How to install the distro
////
[discrete]
[[get-started-install]]
=== Install

. Download the latest release https://mvnrepository.com/artifact/co.elastic.otel/elastic-otel-javaagent/latest[here].
. Run the distro by using the `-javaagent:` JVM argument with the path to the distro jar:
////
✅ Step-by-step instructions
////
To get started with the distro:

. Download the https://mvnrepository.com/artifact/co.elastic.otel/elastic-otel-javaagent/latest[latest release].
. Run the distro using the `-javaagent:` JVM argument with the path to the distro jar:
+
[source,bash]
----
java -javaagent:/path/to/agent.jar \
-jar myapp.jar
----

////
✅ Any additional info related to installation
////
[NOTE]
.The Elastic distro and the OpenTelemetry SDK
====
The distro includes a transitive dependency on the OpenTelemetry SDK, so you do not _need_ to add the
OpenTelemetry SDK package to your project directly. However, you _can_ explicitly add the OpenTelemetry SDK as a dependency if you want to opt into newer SDK versions. If you do this, the OpenTelemetry SDK dependency must
be defined _before_ the {distro_name} is defined.
====

////
✅ Start-to-finish operation
////
[discrete]
[[get-started-send-data]]
=== Send data to Elastic

After installing the distro, configure and initialize it to start
sending data to Elastic.

////
TO DO:
Are there any dependencies that need to be installed in addition to the distro?
If yes, does it matter in what order dependencies are defined?
If no, delete this section.
////
[discrete]
[[get-started-add-dependencies]]
==== Add dependencies

colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
////
Step-by-step instructions
////

////
TO DO:
What does the _minimal_ configuration / setup look like?
Are there any configuration options that are _required_?
////
[discrete]
[[get-started-configure]]
=== Configure
==== Configure the distro

////
Step-by-step instructions
////
colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved

////
TO DO:
Does the user need to do something after configuring the distro
for data to start being sent Elastic?
If no, delete this section.
////
[discrete]
[[get-started-initialization]]
==== Initialize the distro

colleenmcginnis marked this conversation as resolved.
Show resolved Hide resolved
////
Step-by-step instructions
////

////
Optional: Add an image
////

////
TO DO:
What should they expect to see after running this?
How do they know it worked as expected?
////
[discrete]
[[get-started-view-traces]]
=== View traces

To view the traces, you can use the Elastic APM UI:

////
Step-by-step instructions
////

Copy link
Contributor

Choose a reason for hiding this comment

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

This will be generic to all agents. Basically open the APM UI and look at the services listed to find your service. We probably have this in a dozen places in the docs, so maybe we should have this centralized somewhere?

////
✅ What they should do next
////
[discrete]
[[get-started-next-steps]]
=== Next steps

* <<configuration,Configure the distro>> to send data to Elastic.
* Learn more about viewing and interpreting data in the {observability-guide}/apm.html[Observability guide].
Copy link
Member

Choose a reason for hiding this comment

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

I wonder if we can link to a more actionable page (or pages). This link kinda drops the user at a useless landing page with generic info.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I agree. I was thinking of linking to a page related to the APM UI, but we'll need to merge elastic/observability-docs#3723 first.


See <<configure>>.
:!language:
:!language_lc:
:!distro_name:
5 changes: 3 additions & 2 deletions docs/index.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,14 @@ include::{asciidoc-dir}/../../shared/attributes.asciidoc[]

ifdef::env-github[]
NOTE: For the best reading experience,
please view this documentation at https://www.elastic.co/guide/en/apm/agent/java[elastic.co]
please view this documentation at https://www.elastic.co/guide/en/apm/open-telemetry/java[elastic.co]
endif::[]

= Elastic Distribution for OpenTelemetry Java

ifndef::env-github[]
include::./landing-page.asciidoc[]
include::./intro.asciidoc[]
include::./get-started.asciidoc[]
include::./configuration.asciidoc[]
include::./configure.asciidoc[]
endif::[]
Loading
Loading