# Démarrage rapide

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

---

<div class="alert alert-primary" role="alert"><div class="h4 alert-heading" role="heading">Note</div>



Vous pouvez également utiliser l'[agent Java](../../agent) pour instrumenter
votre application Spring Boot. Pour les avantages et les inconvénients,
consultez [Instrumentation Java Zero-code](..).

</div>


## Compatibilité {#compatibility}

Le Spring Boot starter OpenTelemetry fonctionne avec Spring Boot 2.6+ et 3.1+,
et les images d'applications natives à Spring Boot. Le dépôt
[opentelemetry-java-examples/spring-native](https://github.com/open-telemetry/opentelemetry-java-examples/tree/main/spring-native)
contient un exemple d'image d'application native à Spring Boot instrumentée à
l'aide du Spring Boot OpenTelemetry starter.

## Gestion des dépendances {#dependency-management}

Une nomenclature
([BOM](https://maven.apache.org/guides/introduction/introduction-to-dependency-mechanism.html#bill-of-materials-bom-poms))
garantit que les versions des dépendances (y compris transitives) sont alignées.

Pour garantir l'alignement des versions sur toutes les dépendances
OpenTelemetry, vous devez importer la nomenclature
`opentelemetry-instrumentation-bom` lors de l'utilisation du starter
OpenTelemetry.

<div class="alert alert-primary" role="alert"><div class="h4 alert-heading" role="heading">Note</div>



Lors de l'utilisation de Maven, importez les nomenclatures OpenTelemetry avant
toute autre dans votre projet. Par exemple, si vous importez la nomenclature
`spring-boot-dependencies`, vous devez la déclarer après les nomenclatures
OpenTelemetry.

Gradle sélectionne la
[dernière version](https://docs.gradle.org/current/userguide/dependency_resolution.html#2_perform_conflict_resolution)
d'une dépendance lorsque plusieurs nomenclatures sont utilisées, donc l'ordre
des nomenclatures n'est pas important.

</div>


L'exemple suivant montre comment importer les nomenclatures OpenTelemetry en
utilisant 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>
```

Avec Gradle et Spring Boot, vous avez deux façons d'importer une nomenclature.

Vous pouvez utiliser le support natif de Gradle pour les nomenclatures en
ajoutant des `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"))
}
```

L'autre façon avec Gradle est d'utiliser le plugin
`io.spring.dependency-management` et d'importer les nomenclatures dans
`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")
  }
}
```

<div class="alert alert-primary" role="alert"><div class="h4 alert-heading" role="heading">Note</div>



Faites attention à ne pas mélanger les différentes manières de configurer les
choses avec Gradle. Par exemple, n'utilisez pas
`implementation(platform("io.opentelemetry.instrumentation:opentelemetry-instrumentation-bom:2.26.1"))`
avec le plugin `io.spring.dependency-management`.

</div>


### Dépendance du starter OpenTelemetry {#opentelemetry-starter-dependency}

Ajoutez la dépendance ci-dessous pour activer le starter OpenTelemetry.

Le starter OpenTelemetry utilise l'autoconfiguration
[Spring Boot](https://docs.spring.io/spring-boot/reference/using/auto-configuration.html).

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

<div class="tab-content" id="tabs-6-content">
    <div class="tab-body tab-pane fade show active"
        id="tabs-06-00" role="tabpanel" aria-labelled-by="tabs-06-00-tab" tabindex="6">
        <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-06-01" role="tabpanel" aria-labelled-by="tabs-06-01-tab" tabindex="6">
        <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>
