read me en cours

This commit is contained in:
trochas
2025-04-22 16:30:56 +02:00
parent 7829971974
commit 29cc56d238
3 changed files with 51 additions and 0 deletions

View File

@@ -37,14 +37,29 @@ Ensuite, le chat nétait pas très compliqué, on a fait le bonus espion.
#### 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

BIN
images/DateLD.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 95 KiB

View File

@@ -0,0 +1,36 @@
package fr.istic.chat;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.DeliverCallback;
public class chat {
private static final String EXCHANGE_NAME = "topic_log";
public static void main(String[] argv) throws Exception {
ConnectionFactory factory = new ConnectionFactory();
factory.setUri("amqps://cyvthtfj:O8LmaXkX5mVB0oFZN9TobaK8rX9wEhol@whale.rmq.cloudamqp.com/cyvthtfj");
Connection connection = factory.newConnection();
Channel channel = connection.createChannel();
String message = "";
if(false){
channel.basicPublish(EXCHANGE_NAME, argv[0], null, message.getBytes("UTF-8"));
}
String queueName = channel.queueDeclare().getQueue();
DeliverCallback deliverCallback = (consumerTag, delivery) -> {
String message2 = new String(delivery.getBody(), "UTF-8");
System.out.println(" [x] Received '" + message2 + "'");
};
channel.basicConsume(queueName, true, deliverCallback, consumerTag -> {
});
}
}