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

112 lines
3.7 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
# 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](images/SateLD.png)
#### Chat
## Faire des diagrammes
En particulier vous pouvez utiliser [mermaid](https://mermaidjs.github.io/) :
```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` :
```java
public interface ClientHandler {
public void handle();
}
```
et des résultats :
```bash
[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>
```