

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

# Commencer à utiliser l'exemple d'application Scorekeep
<a name="scorekeep-tutorial"></a>

**Note**  
Avis de SDK/Daemon maintenance de X-Ray — Le 25 février 2026, le AWS X-Ray SDKs/Daemon passera en mode maintenance, où les versions du SDK et du Daemon de X-Ray AWS seront limitées uniquement pour résoudre les problèmes de sécurité. Pour plus d'informations sur le calendrier de support, consultez[Chronologie du support pour le SDK et Daemon X-Ray](xray-sdk-daemon-timeline.md). Nous vous recommandons de migrer vers OpenTelemetry. Pour plus d'informations sur la migration vers OpenTelemetry, consultez la section [Migration de l'instrumentation X-Ray vers OpenTelemetry l'instrumentation](https://docs.aws.amazon.com/xray/latest/devguide/xray-sdk-migration.html).

Ce didacticiel utilise la `xray-gettingstarted` branche de l'[exemple d'application Scorekeep](xray-scorekeep.md), qui permet de CloudFormation créer et de configurer les ressources qui exécutent l'exemple d'application et le daemon X-Ray sur Amazon ECS. L'application utilise le framework Spring pour implémenter une API Web JSON et AWS SDK pour Java pour conserver les données dans Amazon DynamoDB. Un filtre de servlet intégré à l'application gère toutes les demandes entrantes traitées par l'application, et un gestionnaire de demandes sur le client du AWS SDK gère les appels en aval à DynamoDB.

Vous pouvez suivre ce didacticiel en utilisant le AWS Management Console ou le AWS CLI.

**Topics**
+ [Conditions préalables](#xray-gettingstarted-prereqs)
+ [Installez l'application Scorekeep à l'aide de CloudFormation](#xray-gettingstarted-deploy)
+ [Génération de données de suivi](#xray-gettingstarted-generate-traces)
+ [Consultez la carte de suivi dans le AWS Management Console](#xray-gettingstarted-console)
+ [Configuration des notifications Amazon SNS](#xray-gettingstarted-notifications)
+ [Exploration de l'exemple d'application](#xray-gettingstarted-sample)
+ [Facultatif : stratégie de moindre privilège](#xray-gettingstarted-security)
+ [Nettoyage](#xray-gettingstarted-cleanup)
+ [Étapes suivantes](#xray-gettingstarted-nextsteps)

## Conditions préalables
<a name="xray-gettingstarted-prereqs"></a>

Ce didacticiel permet CloudFormation de créer et de configurer les ressources qui exécutent l'exemple d'application et le daemon X-Ray. Les prérequis suivants sont requis pour installer et exécuter le didacticiel : 

1. Si vous utilisez un utilisateur IAM avec des autorisations limitées, ajoutez les politiques utilisateur suivantes dans la console [IAM](https://console.aws.amazon.com/iam) : 
   + `AWSCloudFormationFullAccess`— pour accéder et utiliser CloudFormation
   + `AmazonS3FullAccess`— pour télécharger un fichier modèle à CloudFormation l'aide du AWS Management Console
   + `IAMFullAccess`— pour créer les rôles d'instance Amazon ECS et Amazon EC2
   + `AmazonEC2FullAccess`— pour créer les ressources Amazon EC2
   + `AmazonDynamoDBFullAccess`— pour créer les tables DynamoDB
   + `AmazonECS_FullAccess`— pour créer des ressources Amazon ECS
   + `AmazonSNSFullAccess`— pour créer la rubrique Amazon SNS
   + `AWSXrayReadOnlyAccess`— pour obtenir l'autorisation de consulter la carte de suivi et les traces dans la console X-Ray

1. Pour exécuter le didacticiel à l'aide de AWS CLI, [installez la version 2.7.9 ou ultérieure de la CLI](https://docs.aws.amazon.com/cli/latest/userguide/getting-started-install.html) et [configurez la CLI](https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-quickstart.html#cli-configure-quickstart-config) avec l'utilisateur de l'étape précédente. Assurez-vous que la région est configurée lors de la configuration AWS CLI avec l'utilisateur. Si aucune région n'est configurée, vous devrez l'ajouter `--region AWS-REGION` à chaque commande de la CLI. 

1. Assurez-vous que [Git](https://github.com/git-guides/install-git) est installé afin de cloner l'exemple de dépôt d'applications. 

1. Utilisez l'exemple de code suivant pour cloner la `xray-gettingstarted` branche du référentiel Scorekeep : 

   ```
   git clone https://github.com/aws-samples/eb-java-scorekeep.git xray-scorekeep -b xray-gettingstarted
   ```

## Installez l'application Scorekeep à l'aide de CloudFormation
<a name="xray-gettingstarted-deploy"></a>

------
#### [ AWS Management Console ]

**Installez l'exemple d'application à l'aide du AWS Management Console**

1. Ouvrez la [console CloudFormation](https://console.aws.amazon.com/cloudformation/).

1. Choisissez **Créer une pile**, puis choisissez **Avec de nouvelles ressources** dans le menu déroulant.

1. Dans la section **Spécifier un modèle**, sélectionnez **Charger un modèle de fichier**.

1. Sélectionnez **Choisir un fichier**, accédez au `xray-scorekeep/cloudformation` dossier créé lorsque vous avez cloné le dépôt git, puis choisissez le `cf-resources.yaml` fichier.

1. Choisissez **Next (Suivant)** pour continuer.

1. Entrez `scorekeep` dans la zone de texte **Nom de la pile**, puis choisissez **Suivant** au bas de la page pour continuer. Notez que le reste de ce didacticiel suppose que la pile est nommée`scorekeep`.

1. Faites défiler la page des **options de configuration de la pile** vers le bas et choisissez **Suivant** pour continuer.

1. Faites défiler la page de **révision** vers le bas, cochez la case indiquant que des ressources IAM CloudFormation peuvent être créées avec des noms personnalisés, puis choisissez **Create** stack.

1. La CloudFormation pile est en cours de création. L'état de la pile `CREATE_IN_PROGRESS` durera environ cinq minutes avant de passer à`CREATE_COMPLETE`. L'état sera actualisé régulièrement, ou vous pouvez actualiser la page.

------
#### [ AWS CLI ]

**Installez l'exemple d'application à l'aide du AWS CLI**

1. Accédez au `cloudformation` dossier du `xray-scorekeep` référentiel que vous avez cloné plus tôt dans le didacticiel :

   ```
   cd xray-scorekeep/cloudformation/
   ```

1. Entrez la AWS CLI commande suivante pour créer la CloudFormation pile :

   ```
   aws cloudformation create-stack --stack-name scorekeep --capabilities "CAPABILITY_NAMED_IAM" --template-body file://cf-resources.yaml
   ```

1. Attendez que l'état de la CloudFormation pile soit `CREATE_COMPLETE` rétabli, ce qui prendra environ cinq minutes. Utilisez la AWS CLI commande suivante pour vérifier l'état :

   ```
   aws cloudformation describe-stacks --stack-name scorekeep --query "Stacks[0].StackStatus"
   ```

------

## Génération de données de suivi
<a name="xray-gettingstarted-generate-traces"></a>

L'exemple d'application inclut une application web frontale. Utilisez l'application Web pour générer du trafic vers l'API et envoyer des données de suivi à X-Ray. Tout d'abord, récupérez l'URL de l'application Web à l'aide du AWS Management Console ou du AWS CLI :

------
#### [ AWS Management Console ]

**Trouvez l'URL de l'application à l'aide du AWS Management Console**

1. Ouvrez la [console CloudFormation](https://console.aws.amazon.com/cloudformation/).

1. Choisissez la `scorekeep` pile dans la liste.

1. Choisissez l'onglet **Sorties** sur la page de `scorekeep` pile, puis choisissez le lien `LoadBalancerUrl` URL pour ouvrir l'application Web.

------
#### [ AWS CLI ]

**Trouvez l'URL de l'application à l'aide du AWS CLI**

1. Utilisez la commande suivante pour afficher l'URL de l'application Web :

   ```
   aws cloudformation describe-stacks --stack-name scorekeep --query "Stacks[0].Outputs[0].OutputValue"
   ```

1. Copiez cette URL et ouvrez-la dans un navigateur pour afficher l'application Web Scorekeep.

------

**Utiliser l'application Web pour générer des données de suivi**

1. Choisissez **Create** pour créer un utilisateur et une session.

1. Saisissez un **nom de jeu**, définissez les **règles** sur **Tic Tac Toe**, puis choisissez **Create** pour créer un jeu.

1. Choisissez **Play** pour lancer le jeu.

1. Choisissez une case pour jouer et modifier l'état du jeu.

Chacune de ces étapes génère des requêtes HTTP adressées à l'API et des appels en aval à DynamoDB pour lire et écrire les données relatives à l'utilisateur, à la session, au jeu, au déplacement et à l'état.

## Consultez la carte de suivi dans le AWS Management Console
<a name="xray-gettingstarted-console"></a>

Vous pouvez consulter la carte de suivi et les traces générées par l'exemple d'application dans X-Ray et CloudWatch les consoles.

------
#### [ X-Ray console ]

**Utiliser la console X-Ray**

1. Ouvrez la page de traçage de la [console X-Ray](https://console.aws.amazon.com/xray/home#/service-map).

1. La console affiche une représentation du graphe de service généré par X-Ray à partir des données de suivi envoyées par l'application. Assurez-vous d'ajuster la période de la carte de trace si nécessaire, afin de vous assurer qu'elle affichera toutes les traces depuis le premier démarrage de l'application Web.  
![\[Période de la carte X-Ray Trace\]](http://docs.aws.amazon.com/fr_fr/xray/latest/devguide/images/xray-console-time-period-15-minutes.png)

La carte de trace montre le client de l'application Web, l'API exécutée dans Amazon ECS et chaque table DynamoDB utilisée par l'application. Chaque demande à l'application, jusqu'à un nombre maximal de demandes configurables par seconde, est suivi lorsqu'il atteint l'API, génère des demandes aux services en aval, et se termine.

Vous pouvez choisir n'importe quel nœud dans le graphique de services pour afficher les suivis des demandes ayant généré du trafic vers ce nœud. Actuellement, le nœud Amazon SNS est jaune. Explorez ce nœud pour savoir pourquoi.

![\[Page cartographique de suivi de la console X-Ray\]](http://docs.aws.amazon.com/fr_fr/xray/latest/devguide/images/scorekeep-gettingstarted-servicemap-before-ECS.png)


**Pour trouver la cause de l'erreur**

1. Choisissez le nœud nommé **SNS**. Le panneau des détails du nœud s'affiche.

1. Choisissez **View traces (Afficher les suivis)** pour accéder à l'écran **Trace overview (Présentation des suivis)**.

1. Choisissez le suivi depuis la **Trace list (Liste des suivis)**. Ce suivi n'est pas associé à une méthode ou une URL, car il a été enregistré au démarrage et non en réponse à une demande entrante.  
![\[Sélection d'un suivi à partir de la liste des suivis\]](http://docs.aws.amazon.com/fr_fr/xray/latest/devguide/images/scorekeep-gettingstarted-tracelist-sns.png)

1. Cliquez sur l'icône d'état d'erreur dans le segment Amazon SNS au bas de la page, pour ouvrir la page **Exceptions** du sous-segment SNS.  
![\[Choisissez l'icône d'état d'erreur pour ouvrir la page des exceptions pour le sous-segment Amazon SNS\]](http://docs.aws.amazon.com/fr_fr/xray/latest/devguide/images/scorekeep-gettingstarted-timeline-sns-ecs.png)

1. Le SDK X-Ray capture automatiquement les exceptions émises par les clients du AWS SDK instrumentés et enregistre la trace de la pile.  
![\[Onglet Exceptions affichant les exceptions capturées et le suivi de la pile enregistré\]](http://docs.aws.amazon.com/fr_fr/xray/latest/devguide/images/scorekeep-gettingstarted-exception.png)

------
#### [ CloudWatch console ]

**Utiliser la CloudWatch console**

1. Ouvrez la page de [carte de trace X-Ray](https://console.aws.amazon.com/cloudwatch/home#xray:service-map/map) de la CloudWatch console.

1. La console affiche une représentation du graphe de service généré par X-Ray à partir des données de suivi envoyées par l'application. Assurez-vous d'ajuster la période de la carte de trace si nécessaire, afin de vous assurer qu'elle affichera toutes les traces depuis le premier démarrage de l'application Web.  
![\[CloudWatch tracer la période de la carte\]](http://docs.aws.amazon.com/fr_fr/xray/latest/devguide/images/cw-console-service-map-time-period-15-minutes.png)

La carte de trace montre le client de l'application Web, l'API exécutée dans Amazon EC2 et chaque table DynamoDB utilisée par l'application. Chaque demande à l'application, jusqu'à un nombre maximal de demandes configurables par seconde, est suivi lorsqu'il atteint l'API, génère des demandes aux services en aval, et se termine.

Vous pouvez choisir n'importe quel nœud dans le graphique de services pour afficher les suivis des demandes ayant généré du trafic vers ce nœud. Actuellement, le nœud Amazon SNS est orange. Explorez ce nœud pour savoir pourquoi.

![\[Page cartographique de suivi de la console X-Ray\]](http://docs.aws.amazon.com/fr_fr/xray/latest/devguide/images/scorekeep-gettingstarted-cw-servicemap-before-ECS.png)


**Pour trouver la cause de l'erreur**

1. Choisissez le nœud nommé **SNS**. Le panneau de détails du nœud SNS s'affiche sous la carte.

1. Choisissez **Afficher les traces** pour accéder à la page **Traces**.

1. Ajoutez le bas de la page, choisissez la trace dans la liste des **traces**. Ce suivi n'est pas associé à une méthode ou une URL, car il a été enregistré au démarrage et non en réponse à une demande entrante.  
![\[Sélection d'un suivi à partir de la liste des suivis\]](http://docs.aws.amazon.com/fr_fr/xray/latest/devguide/images/scorekeep-gettingstarted-cw-tracelist-sns-ecs.png)

1. Choisissez le sous-segment Amazon SNS en bas de la chronologie des segments, puis cliquez sur l'onglet **Exceptions correspondant au sous-segment SNS pour afficher les détails des exceptions**.  
![\[Afficher l'onglet Exceptions pour le sous-segment Amazon SNS\]](http://docs.aws.amazon.com/fr_fr/xray/latest/devguide/images/scorekeep-gettingstarted-cw-timeline-sns-ecs.png)

------

La cause indique que l'adresse e-mail fournie dans un appel vers `createSubscription` effectué dans la classe `WebConfig` n'était pas valide. Dans la section suivante, nous allons résoudre ce problème.

## Configuration des notifications Amazon SNS
<a name="xray-gettingstarted-notifications"></a>

Scorekeep utilise Amazon SNS pour envoyer des notifications lorsque les utilisateurs terminent un jeu. Lorsque l'application démarre, elle essaie de créer un abonnement pour une adresse e-mail définie dans un paramètre de CloudFormation pile. Cet appel échoue actuellement. Configurez un e-mail de notification pour activer les notifications et résoudre les défaillances mises en évidence sur la carte de suivi.

------
#### [ AWS Management Console ]

**Pour configurer les notifications Amazon SNS à l'aide du AWS Management Console**

1. Ouvrez la [console CloudFormation](https://console.aws.amazon.com/cloudformation/).

1. Cliquez sur le bouton radio situé à côté du nom de la `scorekeep` pile dans la liste, puis sélectionnez **Mettre à jour**.

1. Assurez-vous que **l'option Utiliser le modèle actuel** est sélectionnée, puis cliquez sur **Suivant** sur la page **Mettre à jour la pile**.

1. Recherchez le paramètre **Email** dans la liste et remplacez la valeur par défaut par une adresse e-mail valide.  
![\[Mettre à jour la configuration des e-mails\]](http://docs.aws.amazon.com/fr_fr/xray/latest/devguide/images/scorekeep-cf-email-update.png)

1. Faites défiler la page vers le bas, puis choisissez **Next** (Suivant).

1. Faites défiler la page de **révision** vers le bas, cochez la case indiquant que des ressources IAM CloudFormation peuvent être créées avec des noms personnalisés, puis choisissez **Update** stack.

1. La CloudFormation pile est en cours de mise à jour. L'état de la pile `UPDATE_IN_PROGRESS` durera environ cinq minutes avant de passer à`UPDATE_COMPLETE`. L'état sera actualisé régulièrement, ou vous pouvez actualiser la page.

------
#### [ AWS CLI ]

**Pour configurer les notifications Amazon SNS à l'aide du AWS CLI**

1. Accédez au `xray-scorekeep/cloudformation/` dossier que vous avez créé précédemment et ouvrez le `cf-resources.yaml` fichier dans un éditeur de texte.

1. Recherchez la `Default` valeur dans le paramètre **Email** et remplacez-la par *UPDATE\$1ME* une adresse e-mail valide.

   ```
   Parameters:
     Email:
       Type: String
       Default: UPDATE_ME # <- change to a valid abc@def.xyz email address
   ```

1. Dans le `cloudformation` dossier, mettez à jour la CloudFormation pile à l'aide de la AWS CLI commande suivante : 

   ```
   aws cloudformation update-stack --stack-name scorekeep --capabilities "CAPABILITY_NAMED_IAM" --template-body file://cf-resources.yaml
   ```

1. Attendez que l'état de la CloudFormation pile soit `UPDATE_COMPLETE` rétabli, ce qui prendra quelques minutes. Utilisez la AWS CLI commande suivante pour vérifier l'état :

   ```
   aws cloudformation describe-stacks --stack-name scorekeep --query "Stacks[0].StackStatus"
   ```

------

Lorsque la mise à jour est terminée, Scorekeep redémarre et crée un abonnement à la rubrique SNS. Vérifiez votre adresse e-mail et confirmez l'abonnement pour voir les mises à jour lorsque vous terminez un jeu. Ouvrez la carte de suivi pour vérifier que les appels à SNS n'échouent plus.

## Exploration de l'exemple d'application
<a name="xray-gettingstarted-sample"></a>

L'exemple d'application est une API Web HTTP en Java configurée pour utiliser le SDK X-Ray pour Java. Lorsque vous déployez l'application avec le CloudFormation modèle, elle crée les tables DynamoDB, le cluster Amazon ECS et les autres services nécessaires pour exécuter Scorekeep sur ECS. Un fichier de définition de tâche pour ECS est créé via CloudFormation. Ce fichier définit les images de conteneur utilisées par tâche dans un cluster ECS. Ces images sont obtenues auprès de l'ECR public officiel de X-Ray. L'image du conteneur de l'API scorekeep contient l'API compilée avec Gradle. L'image de conteneur du conteneur frontal Scorekeep sert le frontend à l'aide du serveur proxy nginx. Ce serveur achemine les demandes vers des chemins commençant par /api vers l'API.

Pour instrumenter les demandes HTTP, l'application ajoute le `TracingFilter` fourni par le kit de développement logiciel.

**Example src/main/java/scorekeep/WebConfig.java - filtre de servlet**  

```
import javax.servlet.Filter;
import [com.amazonaws.xray.javax.servlet.AWSXRayServletFilter](https://docs.aws.amazon.com/xray-sdk-for-java/latest/javadoc/com/amazonaws/xray/javax/servlet/AWSXRayServletFilter.html);
...

@Configuration
public class WebConfig {

  @Bean
  public Filter TracingFilter() {
    return new AWSXRayServletFilter("Scorekeep");
  }
...
```

Ce filtre envoie des données de suivi sur toutes les demandes entrantes servies par l'application, y compris l'URL de demande, la méthode, le statut de réponse, l'heure de début et de fin.

L'application effectue également des appels en aval à DynamoDB à l'aide du. AWS SDK pour Java Pour instrumenter ces appels, l'application utilise simplement les sous-modules AWS liés au SDK comme dépendances, et le SDK X-Ray pour Java instrumente automatiquement tous les clients du SDK. AWS 

L'application utilise `Docker` pour créer le code source sur instance avec le fichier `Gradle Docker Image` et le `Scorekeep API Dockerfile` fichier pour exécuter le fichier JAR exécutable généré par Gradle. `ENTRYPOINT` 

**Example utilisation de Docker pour créer via Gradle Docker Image**  

```
docker run --rm -v /PATH/TO/SCOREKEEP_REPO/home/gradle/project -w /home/gradle/project gradle:4.3 gradle build
```

**Example POINT D'ENTRÉE Dockerfile**  

```
ENTRYPOINT [ "sh", "-c", "java -Dserver.port=5000 -jar scorekeep-api-1.0.0.jar" ]
```

Le fichier `build.gradle` télécharge les sous-modules du kit de développement logiciel à partir de Maven pendant la compilation en les déclarant comme des dépendances.

**Example build.gradle - dépendances**  

```
...
dependencies {
    compile("org.springframework.boot:spring-boot-starter-web")
    testCompile('org.springframework.boot:spring-boot-starter-test')
    compile('com.amazonaws:aws-java-sdk-dynamodb')
    compile("com.amazonaws:aws-xray-recorder-sdk-core")
    compile("com.amazonaws:aws-xray-recorder-sdk-aws-sdk")
    compile("com.amazonaws:aws-xray-recorder-sdk-aws-sdk-instrumentor")
    ...
}
dependencyManagement {
    imports {
        mavenBom("com.amazonaws:aws-java-sdk-bom:1.11.67")
        mavenBom("com.amazonaws:aws-xray-recorder-sdk-bom:2.11.0")
    }
}
```

Les sous-modules principaux, AWS SDK et AWS SDK Instrumentor sont tout ce qui est nécessaire pour instrumenter automatiquement tous les appels en aval effectués avec le SDK. AWS 

Pour relayer les données de segment brutes vers l'API X-Ray, le daemon X-Ray doit écouter le trafic sur le port UDP 2000. *Pour ce faire, l'application fait exécuter le daemon X-Ray dans un conteneur qui est déployé parallèlement à l'application Scorekeep sur ECS en tant que conteneur annexe.* Consultez la rubrique consacrée au [daemon X-Ray](xray-daemon.md) pour plus d'informations.

**Example Définition du conteneur X-Ray Daemon dans une définition de tâche ECS**  

```
...
Resources:
  ScorekeepTaskDefinition:
    Type: AWS::ECS::TaskDefinition
    Properties: 
      ContainerDefinitions: 
      ...
      
      - Cpu: '256'
        Essential: true
        Image: amazon/aws-xray-daemon
        MemoryReservation: '128'
        Name: xray-daemon
        PortMappings: 
          - ContainerPort: '2000'
            HostPort: '2000'
            Protocol: udp
      ...
```

Le SDK X-Ray pour Java fournit une classe `AWSXRay` nommée qui fournit l'enregistreur global, `TracingHandler` que vous pouvez utiliser pour instrumenter votre code. Vous pouvez configurer l'enregistreur mondial pour personnaliser le `AWSXRayServletFilter` qui crée des segments pour les appels HTTP entrants. L'exemple inclut un bloc statique dans la classe `WebConfig` qui configure l'enregistreur mondial avec des plug-ins et des règles d'échantillonnage.

**Example src/main/java/scorekeep/WebConfig.java - enregistreur**  

```
import com.amazonaws.xray.AWSXRay;
import com.amazonaws.xray.AWSXRayRecorderBuilder;
import com.amazonaws.xray.javax.servlet.AWSXRayServletFilter;
import com.amazonaws.xray.plugins.ECSPlugin;
import com.amazonaws.xray.plugins.EC2Plugin;
import com.amazonaws.xray.strategy.sampling.LocalizedSamplingStrategy;
...

@Configuration
public class WebConfig {
  ...
  
  static {
    AWSXRayRecorderBuilder builder = AWSXRayRecorderBuilder.standard().withPlugin(new ECSPlugin()).withPlugin(new EC2Plugin());

    URL ruleFile = WebConfig.class.getResource("/sampling-rules.json");
    builder.withSamplingStrategy(new LocalizedSamplingStrategy(ruleFile));

    AWSXRay.setGlobalRecorder(builder.build());
    ...
    
  }
}
```

Cet exemple utilise le générateur pour charger des règles d'échantillonnage à partir d'un fichier nommé `sampling-rules.json`. Les règles d'échantillonnage déterminent le taux auquel le kit SDK enregistre des segments pour les demandes entrantes. 

**Example src/main/java/resources/sampling-rules.json**  

```
{
  "version": 1,
  "rules": [
    {
      "description": "Resource creation.",
      "service_name": "*",
      "http_method": "POST",
      "url_path": "/api/*",
      "fixed_target": 1,
      "rate": 1.0
    },
    {
      "description": "Session polling.",
      "service_name": "*",
      "http_method": "GET",
      "url_path": "/api/session/*",
      "fixed_target": 0,
      "rate": 0.05
    },
    {
      "description": "Game polling.",
      "service_name": "*",
      "http_method": "GET",
      "url_path": "/api/game/*/*",
      "fixed_target": 0,
      "rate": 0.05
    },
    {
      "description": "State polling.",
      "service_name": "*",
      "http_method": "GET",
      "url_path": "/api/state/*/*/*",
      "fixed_target": 0,
      "rate": 0.05
    }
  ],
  "default": {
    "fixed_target": 1,
    "rate": 0.1
  }
}
```

Le fichier de règles d'échantillonnage définit quatre règles personnalisées et une règle par défaut. Pour chaque demande entrante, le kit SDK évalue les règles personnalisées dans l'ordre dans lequel elles sont définies. Le kit de développement logiciel (SDK) applique la première règle qui correspond à la méthode, au chemin et au nom de service de la demande. Pour Scorekeep, la première règle intercepte toutes les demandes POST (appels de création de ressource) en appliquant un objectif fixé à une demande par seconde et un taux de 1,0 ou 100 % des demandes une fois l'objectif fixé atteint.

Les trois autres règles personnalisées appliquent un taux de 5 %, sans aucun objectif fixé concernant les lectures de session, de jeu et d'état (demandes GET). Il s'ensuit une réduction du nombre de suivis pour les appels périodiques émis automatiquement par le service frontal à quelques secondes d'intervalle pour vérifier que le contenu est à jour. Pour toutes les autres demandes, le fichier définit un taux par défaut d'une demande par seconde et un taux de 10 %.

L'exemple d'application indique également comment utiliser des fonctionnalités avancées, telles que l'instrumentation manuelle d'un client de kit de développement logiciel, la création de sous-segments supplémentaires et des appels HTTP sortants. Pour de plus amples informations, veuillez consulter [AWS X-Ray exemple d'application](xray-scorekeep.md).

## Facultatif : stratégie de moindre privilège
<a name="xray-gettingstarted-security"></a>

 Les conteneurs Scorekeep ECS accèdent aux ressources en utilisant des politiques d'accès complet, telles que `AmazonSNSFullAccess` et. `AmazonDynamoDBFullAccess` L'utilisation de politiques d'accès complet n'est pas la meilleure pratique pour les applications de production. L'exemple suivant met à jour la politique DynamoDB IAM afin d'améliorer la sécurité de l'application. Pour en savoir plus sur les meilleures pratiques de sécurité dans les politiques IAM, consultez la section [Gestion des identités et des accès pour AWS X-Ray](security-iam.md).

**Example Modèle cf-resources.yaml Définition du rôle ECSTask**  

```
ECSTaskRole:
    Type: AWS::IAM::Role
    Properties:
      AssumeRolePolicyDocument:
        Version: "2012-10-17"		 	 	 
        Statement: 
          - 
            Effect: "Allow"
            Principal: 
              Service: 
                - "ecs-tasks.amazonaws.com"
            Action: 
              - "sts:AssumeRole"
      ManagedPolicyArns:
        - "arn:aws:iam::aws:policy/AmazonDynamoDBFullAccess"
        - "arn:aws:iam::aws:policy/AmazonSNSFullAccess"
        - "arn:aws:iam::aws:policy/AWSXrayFullAccess"
      RoleName: "scorekeepRole"
```

Pour mettre à jour votre politique, vous devez d'abord identifier l'ARN de vos ressources DynamoDB. Vous utilisez ensuite l'ARN dans une politique IAM personnalisée. Enfin, vous devez appliquer cette politique à votre profil d'instance.

**Pour identifier l'ARN de votre ressource DynamoDB :**

1. Ouvrez la [console DynamoDB](https://console.aws.amazon.com/dynamodbv2).

1. Choisissez **Tables** dans la barre de navigation de gauche.

1. Choisissez l'une des options `scorekeep-*` pour afficher la page détaillée du tableau.

1. Dans l'onglet **Vue d'ensemble**, choisissez **Informations supplémentaires** pour développer la section et afficher le nom de la ressource Amazon (ARN). Copiez cette valeur.

1. Insérez l'ARN dans la politique IAM suivante, en remplaçant les `AWS_ACCOUNT_ID` valeurs `AWS_REGION` et par votre région et votre identifiant de compte spécifiques. Cette nouvelle politique n'autorise que les actions spécifiées, au lieu de la `AmazonDynamoDBFullAccess` politique qui autorise n'importe quelle action.  
**Example**  

------
#### [ JSON ]

****  

   ```
   {
       "Version":"2012-10-17",		 	 	 
       "Statement": [
           {
               "Sid": "ScorekeepDynamoDB",
               "Effect": "Allow",
               "Action": [
                   "dynamodb:PutItem",
                   "dynamodb:UpdateItem",
                   "dynamodb:DeleteItem",
                   "dynamodb:GetItem",
                   "dynamodb:Scan",
                   "dynamodb:Query"
               ],
               "Resource": "arn:aws:dynamodb:us-east-1:111122223333:table/scorekeep-*"
           }
       ]
   }
   ```

------

   Les tables créées par l'application suivent une convention de dénomination cohérente. Vous pouvez utiliser ce `scorekeep-*` format pour indiquer tous les tableaux Scorekeep.

**Modifiez votre politique IAM**

1. Ouvrez le [rôle de tâche Scorekeep (ScorekeepRole) depuis la console IAM](https://console.aws.amazon.com/iamv2/home#/roles/details/scorekeepRole).

1. Cochez la case située à côté de la `AmazonDynamoDBFullAccess` politique, puis choisissez **Supprimer** pour supprimer cette politique. 

1. Choisissez **Ajouter des autorisations**, puis **Joindre des politiques**, et enfin **Créer une politique**.

1. Choisissez l'onglet **JSON** et collez la politique créée ci-dessus.

1. Choisissez **Next : Tags** au bas de la page.

1. Choisissez **Suivant : Révision** au bas de la page.

1. Pour **Nom**, attribuez un nom à la politique.

1. Choisissez **Créer une politique** au bas de la page. 

1. Attachez la politique nouvellement créée au `scorekeepRole` rôle. L'entrée en vigueur de la politique ci-jointe peut prendre quelques minutes.

Si vous avez attaché la nouvelle politique au `scorekeepRole` rôle, vous devez la détacher avant de supprimer la CloudFormation pile, car cette politique attachée empêchera la suppression de la pile. La politique peut être automatiquement détachée en la supprimant.

**Supprimer votre politique IAM personnalisée**

1. Ouvrez la [console IAM](https://console.aws.amazon.com/iam).

1. Choisissez **Politiques** dans la barre de navigation de gauche.

1. Recherchez le nom de stratégie personnalisée que vous avez créé plus tôt dans cette section, puis cliquez sur le bouton radio à côté du nom de la stratégie pour le mettre en évidence.

1. Choisissez le menu déroulant **Actions**, puis sélectionnez **Supprimer**.

1. Tapez le nom de la politique personnalisée, puis choisissez **Supprimer** pour confirmer la suppression. Cela détachera automatiquement la politique du `scorekeepRole` rôle.

## Nettoyage
<a name="xray-gettingstarted-cleanup"></a>

Pour supprimer les ressources de l'application Scorekeep, procédez comme suit :

**Note**  
Si vous avez créé et joint des politiques personnalisées à l'aide de la section précédente de ce didacticiel, vous devez supprimer la politique de la pile `scorekeepRole` avant de supprimer la CloudFormation pile.

------
#### [ AWS Management Console ]

**Supprimez l'exemple d'application à l'aide du AWS Management Console**

1. Ouvrez la [console CloudFormation](https://console.aws.amazon.com/cloudformation/).

1. Cliquez sur le bouton radio situé à côté du nom de la `scorekeep` pile dans la liste, puis sélectionnez **Supprimer**.

1. La CloudFormation pile est en train d'être supprimée. L'état de la pile `DELETE_IN_PROGRESS` durera quelques minutes jusqu'à ce que toutes les ressources soient supprimées. L'état sera actualisé régulièrement, ou vous pouvez actualiser la page.

------
#### [ AWS CLI ]

**Supprimez l'exemple d'application à l'aide du AWS CLI**

1. Entrez la AWS CLI commande suivante pour supprimer la CloudFormation pile :

   ```
   aws cloudformation delete-stack --stack-name scorekeep
   ```

1. Attendez que la CloudFormation pile n'existe plus, ce qui prendra environ cinq minutes. Utilisez la AWS CLI commande suivante pour vérifier l'état :

   ```
   aws cloudformation describe-stacks --stack-name scorekeep --query "Stacks[0].StackStatus"
   ```

------

## Étapes suivantes
<a name="xray-gettingstarted-nextsteps"></a>

Apprenez-en plus sur X-Ray dans le chapitre suivant,[AWS X-Ray concepts](xray-concepts.md).

Pour instrumenter votre propre application, apprenez-en plus sur le SDK X-Ray pour Java ou sur l'un des autres logiciels de X-Ray SDKs :
+ **SDK X-Ray pour Java —** [AWS X-Ray SDK pour Java](xray-sdk-java.md)
+ **Kit de développement X-Ray pour Node.js —** [AWS Kit de développement X-Ray pour Node.js](xray-sdk-nodejs.md)
+ **Kit de développement X-Ray pour .NET —** [AWS X-Ray SDK pour .NET](xray-sdk-dotnet.md)

Pour exécuter le daemon X-Ray en local ou en mode actif AWS, consultez[AWS X-Ray daemon](xray-daemon.md).

Pour contribuer à l'exemple d'application sur GitHub, voir [eb-java-scorekeep](https://github.com/awslabs/eb-java-scorekeep/tree/xray-gettingstarted).