# Початок роботи

LLMS index: [llms.txt](/llms.txt)

---

> [!NOTE]
>
> Ви також можете використовувати [Java агент](../../agent) для інструментування вашого Spring Boot застосунку. Для переваг та недоліків дивіться [інструментування Java без коду](..).

## Сумісність {#compatibility}

Завантажувач OpenTelemetry Spring Boot працює з Spring Boot 2.6+ та 3.1+, а також з нативними застосунками-образами Spring Boot. Репозиторій [opentelemetry-java-examples/spring-native](https://github.com/open-telemetry/opentelemetry-java-examples/tree/main/spring-native) містить приклад застосунку з нативним образом Spring Boot, інструментованого за допомогою OpenTelemetry Spring Boot стартера.

## Управління залежностями {#dependency-management}

Bill of Material ([BOM](https://maven.apache.org/guides/introduction/introduction-to-dependency-mechanism.html#bill-of-materials-bom-poms)) гарантує, що версії залежностей (включаючи транзитивні) узгоджені.

Щоб забезпечити узгодження версій усіх залежностей OpenTelemetry, ви повинні імпортувати BOM `opentelemetry-instrumentation-bom` при використанні OpenTelemetry стартера.

> [!NOTE]
>
> При використанні Maven, імпортуйте BOM OpenTelemetry перед будь-якими іншими BOM у вашому проєкті. Наприклад, якщо ви імпортуєте BOM `spring-boot-dependencies`, ви повинні оголосити його після BOM OpenTelemetry.
>
> Gradle вибирає [останні версії](https://docs.gradle.org/current/userguide/dependency_resolution.html#2_perform_conflict_resolution) залежностей при використанні декількох BOM, тому порядок BOM не важливий.

Наступний приклад показує, як імпортувати BOM OpenTelemetry за допомогою Maven:

```xml
<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>io.opentelemetry.instrumentation</groupId>
            <artifactId>opentelemetry-instrumentation-bom</artifactId>
            <version>2.26.1</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>
```

З Gradle та Spring Boot, ви маєте два способи імпортувати BOM.

Ви можете використовувати нативну підтримку BOM Gradle, додавши `dependencies`:

```kotlin
import org.springframework.boot.gradle.plugin.SpringBootPlugin

plugins {
  id("java")
  id("org.springframework.boot") version "3.2.O"
}

dependencies {
  implementation(platform(SpringBootPlugin.BOM_COORDINATES))
  implementation(platform("io.opentelemetry.instrumentation:opentelemetry-instrumentation-bom:2.26.1"))
}
```

Інший спосіб з Gradle — використовувати втулок `io.spring.dependency-management` та імпортувати BOM у `dependencyManagement`:

```kotlin
plugins {
  id("java")
  id("org.springframework.boot") version "3.2.O"
  id("io.spring.dependency-management") version "1.1.0"
}

dependencyManagement {
  imports {
    mavenBom("io.opentelemetry.instrumentation:opentelemetry-instrumentation-bom:2.26.1")
  }
}
```

> [!NOTE]
>
> Будьте обережні, щоб не змішувати різні способи конфігурації з Gradle. Наприклад, не використовуйте `implementation(platform("io.opentelemetry.instrumentation:opentelemetry-instrumentation-bom:2.26.1"))` з втулком `io.spring.dependency-management`.

### Залежність OpenTelemetry Starter {#opentelemetry-starter-dependency}

Додайте залежність, наведену нижче, щоб увімкнути OpenTelemetry стартер.

OpenTelemetry стартер використовує OpenTelemetry Spring Boot [автоконфігурацію](https://docs.spring.io/spring-boot/reference/using/auto-configuration.html).

   <ul class="nav nav-tabs" id="tabs-4" role="tablist">
  <li class="nav-item">
      <button class="nav-link active"
          id="tabs-04-00-tab" data-bs-toggle="tab" data-bs-target="#tabs-04-00" role="tab"
          data-td-tp-persist="maven (`pom.xml`)" aria-controls="tabs-04-00" aria-selected="true">
        Maven (<code>pom.xml</code>)
      </button>
    </li><li class="nav-item">
      <button class="nav-link"
          id="tabs-04-01-tab" data-bs-toggle="tab" data-bs-target="#tabs-04-01" role="tab"
          data-td-tp-persist="gradle (`build.gradle`)" aria-controls="tabs-04-01" aria-selected="false">
        Gradle (<code>build.gradle</code>)
      </button>
    </li>
</ul>

<div class="tab-content" id="tabs-4-content">
    <div class="tab-body tab-pane fade show active"
        id="tabs-04-00" role="tabpanel" aria-labelled-by="tabs-04-00-tab" tabindex="4">
        <div class="highlight"><pre tabindex="0" class="chroma"><code class="language-xml" data-lang="xml"><span class="line"><span class="cl"><span class="nt">&lt;dependency&gt;</span>
</span></span><span class="line"><span class="cl">    <span class="nt">&lt;groupId&gt;</span>io.opentelemetry.instrumentation<span class="nt">&lt;/groupId&gt;</span>
</span></span><span class="line"><span class="cl">    <span class="nt">&lt;artifactId&gt;</span>opentelemetry-spring-boot-starter<span class="nt">&lt;/artifactId&gt;</span>
</span></span><span class="line"><span class="cl"><span class="nt">&lt;/dependency&gt;</span>
</span></span></code></pre></div>
    </div>
    <div class="tab-body tab-pane fade"
        id="tabs-04-01" role="tabpanel" aria-labelled-by="tabs-04-01-tab" tabindex="4">
        <div class="highlight"><pre tabindex="0" class="chroma"><code class="language-kotlin" data-lang="kotlin"><span class="line"><span class="cl"><span class="n">implementation</span><span class="p">(</span><span class="s2">&#34;io.opentelemetry.instrumentation:opentelemetry-spring-boot-starter&#34;</span><span class="p">)</span>
</span></span></code></pre></div>
    </div>
</div>
