Files
ipd-tp-4/README.md
2025-04-22 16:31:33 +02:00

3.7 KiB
Raw Blame History

Squelette du TP

Utilisation

Pour utiliser ce tp vous devez :

  1. le forker via le lien fork ci-dessus.
  2. Votre repository doit être privé. Vous devez le partager avec votre encadrant de TP.
  3. vous obtiendrez un nouveau lien : par exemple git@gitlab.istic.univ-rennes1.fr:monpseudo/....
  4. Dans le workspace d'eclipse faites git clone git@gitlab.istic.univ-rennes1.fr:monpseudo/... avec l'url précédente.
  5. Ouvrez le workspace dans eclipse.
  6. Utilisez Import> "Existing Maven Projects".
  7. Selectionnez le projet et validez.

Vous devriez avoir une version du projet dans votre propre compte gitlab.

Vous pouvez le partager avec votre binome et l'encadrant de TP.

Rapport

Votre rapport doit être écrit ici en markdown. :/ Vous trouverez la syntaxe de markdown ici : https://docs.gitlab.com/ee/user/markdown.html Placez vos images dans le répertoire images si nécessaire.

Binôme :

Thibaut ROCHAS, Tuan Minh VU

Introduction

On a utilisé CloudAMQP, qui semblait être la solution la plus simple pour commencer le TP rapidement. Les exemples ont tous été testés, avec notre serveur RabitMQ. Avec laide des exemples et du cours, on a pu faire la partie Date sans grande difficulté. Ensuite, le chat nétait pas très compliqué, on a fait le bonus espion.

Déroulement du TP

Exemples

Pour les exemples il suffisait simplement de remplacer "localhost" dans le setHost du ConnectionFactory par lURL de notre serveur RabbitMQ.

Le premier exemple envoie juste un seul message "Hello World", et on enregistre dans le receveur une action à effectuer à chaque message, ici il affiche simplement le message.

Sur le 2ème exemple, lenvoyeur NewTask prend ces arguments, les concatène en un message quil envoie au worker, qui va effectuer une action à chaque message reçu : il affiche le message puis attend 1 seconde pour chaque point dans le message reçu, et affiche "done" quand il a fini.

Lexemple 3 prend encore des arguments, il envoie à tous les Receveurs car le type déchange est "fanout", ici le receveur affiche simplement le message.

Dans lexemple 4, on utilise le type déchange "direct", avec des topics, il faut donc aussi fournir le topic en argument en plus du message pour lenvoyeur, et le receveur on lui fournit les topics quil doit sabonner.

Lexemple 5 fait la même chose que le 4, mais avec un type déchange "topic", il y a donc une hiérarchie dans les topics. Le dernier exemple est une communication RPC, le client envoie un message et le serveur répond en fonction de ce message.

Date

A partir de l'exemple 3, on envoi simpelment la date, avec le même échange de type fanout. Pour généré la date on fait simplement une fonction getDate() qui return (new Date()).toString(); Le reste est identique à tuto3.java

Pour la version de partages d'un même file

Texte alternatif

Chat

Faire des diagrammes

En particulier vous pouvez utiliser mermaid :

sequenceDiagram
    participant Alice
    participant Bob
    Alice->John: Hello John, how are you?
    loop Healthcheck
        John->John: Fight against hypochondria
    end
    Note right of John: Rational thoughts <br/>prevail...
    John-->Alice: Great!
    John->Bob: How about you?
    Bob-->John: Jolly good!

Insérer du code

Insérer du code :

public interface ClientHandler {
    public void handle();
}

et des résultats :

[yo@capybara dkgr]$ nc google.fr 80
PWET /
HTTP/1.0 400 Bad Request
Content-Type: text/html; charset=UTF-8
Referrer-Policy: no-referrer
Content-Length: 1555
Date: Mon, 21 Jan 2019 12:18:02 GMT

<!DOCTYPE html>
<html lang=en>
  <meta charset=utf-8>