<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: efoscarini</title>
    <description>The latest articles on DEV Community by efoscarini (@efoscarini).</description>
    <link>https://dev.to/efoscarini</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F517588%2Fb70a7894-1155-472c-b6cc-890478bb7804.jpg</url>
      <title>DEV Community: efoscarini</title>
      <link>https://dev.to/efoscarini</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/efoscarini"/>
    <language>en</language>
    <item>
      <title>Primeiros Passos com RabbitMQ</title>
      <dc:creator>efoscarini</dc:creator>
      <pubDate>Tue, 08 Dec 2020 11:39:34 +0000</pubDate>
      <link>https://dev.to/efoscarini/primeiros-passos-com-rabbitmq-3p9</link>
      <guid>https://dev.to/efoscarini/primeiros-passos-com-rabbitmq-3p9</guid>
      <description>&lt;p&gt;&lt;strong&gt;RabbitMQ&lt;/strong&gt; é um dos mais populares &lt;em&gt;message brokers&lt;/em&gt; de código fonte aberto disponíveis no mercado. Fornece um mecanismo para comunicação assíncrona entre processos. Permite que mensagens, enviadas por um produtor (&lt;em&gt;producer&lt;/em&gt;), sejam recebidas e armazenadas numa fila para que possam ser consumidas por um receptor (&lt;em&gt;consumer&lt;/em&gt;).&lt;/p&gt;

&lt;p&gt;Este artigo apresenta uma maneira simples e rápida (&lt;strong&gt;sem reinventar a roda!&lt;/strong&gt; e com menos código possível) para criar uma fila, enviar e consumir mensagens do RabbitMQ, utilizando-se de componentes disponíveis no Spring Boot. &lt;/p&gt;

&lt;p&gt; &lt;/p&gt;

&lt;h3&gt;
  
  
  &lt;strong&gt;Rodando o RabbitMQ&lt;/strong&gt;
&lt;/h3&gt;

&lt;p&gt;Para rodar localmente pode-se optar por instalar na sua máquina ou rodar direto de um container. No site (&lt;a href="//encurtador.com.br/bdvDP"&gt;RabbitMQ/download&lt;/a&gt;) é possível escolher algumas opções de instalações para diferentes sistemas operacionais, ou até mesmo para rodar direto da &lt;em&gt;cloud&lt;/em&gt;.&lt;/p&gt;

&lt;p&gt;Outra opção é rodar através de uma imagem &lt;em&gt;Docker&lt;/em&gt;, a qual utilizei para este artigo: &lt;br&gt;
&lt;code&gt;docker run -it --rm --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3-management&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;O RabbitMQ possui uma UI de administração, que deve ser instalada separadamente, muito útil para avaliar o estado das filas, número de mensagens, conexões ou até mesmo para apagar a fila e/ou suas mensagens. A imagem Docker acima já vem com o &lt;em&gt;RabbitMQ Management&lt;/em&gt; disponível e pode ser acessada através da URL &lt;a href="http://localhost:15672" rel="noopener noreferrer"&gt;http://localhost:15672&lt;/a&gt;, utilizando usuário e senha padrões &lt;strong&gt;guest&lt;/strong&gt;/&lt;strong&gt;guest&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt; &lt;/p&gt;
&lt;h3&gt;
  
  
  &lt;strong&gt;Spring Boot&lt;/strong&gt;
&lt;/h3&gt;

&lt;p&gt;Para darmos os primeiros passos com RabbitMQ, vamos iniciar criando um projeto SpringBoot com &lt;em&gt;Spring initializr&lt;/em&gt;: &lt;a href="https://start.spring.io/" rel="noopener noreferrer"&gt;https://start.spring.io/&lt;/a&gt; (tudo inicia aqui!!)&lt;/p&gt;

&lt;p&gt;Selecionar as dependências: Spring Web e Spring for RabbitMQ.&lt;/p&gt;

&lt;p&gt;Após fazer o download do projeto, descompactar e abrir na sua IDE de preferência. Para este demo utilizei &lt;em&gt;IntelliJ Community edition&lt;/em&gt; e &lt;em&gt;OpenJDK&lt;/em&gt; 11.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Código fonte:&lt;/strong&gt; &lt;a href="https://github.com/efoscarini/rabbitmq-getting-started" rel="noopener noreferrer"&gt;https://github.com/efoscarini/rabbitmq-getting-started&lt;/a&gt;&lt;/p&gt;

&lt;p&gt; &lt;/p&gt;
&lt;h3&gt;
  
  
  &lt;strong&gt;O Projeto&lt;/strong&gt;
&lt;/h3&gt;

&lt;p&gt;Neste primeiro momento, vamos focar num projeto simples de &lt;em&gt;producer&lt;/em&gt; e &lt;em&gt;consumer&lt;/em&gt;.  Uma visão geral do projeto pode ser apresentada da seguinte forma:&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2F53kqjzgolaac7620dt6h.PNG" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2F53kqjzgolaac7620dt6h.PNG" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Esquema gerado via RabbitMQ simulator (&lt;a href="http://tryrabbitmq.com/" rel="noopener noreferrer"&gt;http://tryrabbitmq.com/&lt;/a&gt;).&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Producer envia uma mensagem para a &lt;em&gt;exchange&lt;/em&gt;, com a &lt;em&gt;binding-key&lt;/em&gt; “queue-a-key”, que por sua vez é encaminhada para a ”queue-a”, a qual o consumer vai estar conectado, e por fim receberá a mensagem enviada.  &lt;/p&gt;

&lt;p&gt; &lt;/p&gt;
&lt;h4&gt;
  
  
  &lt;strong&gt;Estrutura básica&lt;/strong&gt;
&lt;/h4&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fsqwu9ba2kk50ez1l3nf3.PNG" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fsqwu9ba2kk50ez1l3nf3.PNG" alt="Alt Text"&gt;&lt;/a&gt;&lt;br&gt;
Pacotes:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Config: Configuração da &lt;em&gt;Queue&lt;/em&gt; e &lt;em&gt;Exchange&lt;/em&gt;.&lt;/li&gt;
&lt;li&gt;Producer: &lt;em&gt;Controller&lt;/em&gt; expondo um serviço REST para enviar uma mensagem para fila.&lt;/li&gt;
&lt;li&gt;Consumer: &lt;em&gt;Listener&lt;/em&gt; para ler da fila.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt; &lt;/p&gt;
&lt;h4&gt;
  
  
  &lt;strong&gt;Conexão do Spring Boot com o RabbitMQ&lt;/strong&gt;
&lt;/h4&gt;

&lt;p&gt;No arquivo &lt;strong&gt;application.yml&lt;/strong&gt; adicionamos &lt;em&gt;host&lt;/em&gt; e &lt;em&gt;port&lt;/em&gt; do servidor do RabbitMQ. A &lt;em&gt;configuração padrão&lt;/em&gt; é &lt;strong&gt;localhost&lt;/strong&gt; para o &lt;em&gt;host&lt;/em&gt; e &lt;strong&gt;5672&lt;/strong&gt; como a porta. Para este projeto, alterei somente o host para apontar para a minha &lt;strong&gt;Docker machine&lt;/strong&gt;.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Quando se utiliza a &lt;strong&gt;configuração padrão&lt;/strong&gt;, não é necessário declarar esses atributos abaixo, nem mesmo &lt;em&gt;username&lt;/em&gt; e &lt;em&gt;password&lt;/em&gt;. &lt;br&gt;
Lembrando que isto é possível por causa da extensão "Spring for RabbitMQ"&lt;/p&gt;
&lt;/blockquote&gt;
&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;

spring:
  rabbitmq:
    host: 192.168.99.102
    port: 5672
    username: guest
    password: guest


&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;
&lt;p&gt; &lt;/p&gt;
&lt;h4&gt;
  
  
  &lt;strong&gt;Configuração da Queue e Exchange:&lt;/strong&gt;
&lt;/h4&gt;

&lt;p&gt;Utilizando a anotação @Configuration do Spring, vamos criar dois arquivos de configuração. O arquivo QueueConfig contém a definição da nossa &lt;em&gt;Queue&lt;/em&gt; (“queue-a”) enquanto o ExchangeConfig declara a &lt;em&gt;exchange&lt;/em&gt;, &lt;em&gt;routing key&lt;/em&gt; e o &lt;em&gt;binding&lt;/em&gt; apontando para nossa fila de testes.&lt;/p&gt;


&lt;div class="ltag_gist-liquid-tag"&gt;
  
&lt;/div&gt;



&lt;div class="ltag_gist-liquid-tag"&gt;
  
&lt;/div&gt;


&lt;p&gt; &lt;/p&gt;

&lt;h4&gt;
  
  
  &lt;strong&gt;Enviando mensagens para fila:&lt;/strong&gt;
&lt;/h4&gt;

&lt;p&gt;Vamos expor um serviço REST (método POST), na classe &lt;em&gt;SendMessageController&lt;/em&gt;, para o envio da mensagem para fila. Este serviço requer uma String como parâmetro, que será o conteúdo da mensagem.&lt;/p&gt;

&lt;p&gt;A mensagem recebida por parâmetro será enviada para a "queue-a" através do &lt;strong&gt;RabbitTemplate&lt;/strong&gt;. Observa-se que os parâmetros para envio são o nome da &lt;em&gt;exchange&lt;/em&gt; e &lt;em&gt;routing key&lt;/em&gt;, e não o nome da fila. Pois a &lt;em&gt;exchange&lt;/em&gt; será responsável por enviar para fila correta conforme a rota "queue-a-key" informada.&lt;br&gt;
&lt;/p&gt;
&lt;div class="ltag_gist-liquid-tag"&gt;
  
&lt;/div&gt;


&lt;p&gt; &lt;/p&gt;

&lt;h4&gt;
  
  
  &lt;strong&gt;Recebendo mensagens da fila:&lt;/strong&gt;
&lt;/h4&gt;

&lt;p&gt;O código do &lt;em&gt;consumer&lt;/em&gt;, QueueListener, é o mais simples de todos, pois para ler as mensagens da fila basta anotar o método com &lt;strong&gt;@RabbitListener&lt;/strong&gt; e declará-lo com um parâmetro String que será o conteúdo da mensagem.&lt;br&gt;
&lt;/p&gt;
&lt;div class="ltag_gist-liquid-tag"&gt;
  
&lt;/div&gt;


&lt;p&gt; &lt;/p&gt;

&lt;h3&gt;
  
  
  &lt;strong&gt;Como funciona tudo isso?&lt;/strong&gt;
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;A &lt;em&gt;queue/exchange&lt;/em&gt; declarados nos &lt;em&gt;beans&lt;/em&gt; de configuração (/config) são automaticamente criadas pelo Spring no momento em que a aplicação se conecta com o RabbitMQ. Neste projeto, isso ocorre no momento em que o "RabbitListner" tenta ler uma mensagem da fila pela primeira vez. Sendo assim, essas configurações são utilizadas uma única vez em seu ambiente local, contudo, quando vamos implantar em outro ambiente não precisamos nos preocupar com a criação das filas.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Nota-se que este projeto não requer qualquer configuração adicional para conexão com o RabbitMQ, apenas a propriedades do arquivo &lt;em&gt;application.yml&lt;/em&gt;. No artigo de configurações avançadas vou abordar alguns parâmetros que podem ser definidos via aplicação para melhorar a performance. &lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt; &lt;/p&gt;

&lt;h3&gt;
  
  
  &lt;strong&gt;Validando a aplicação&lt;/strong&gt;
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;Iniciar o projeto Spring Boot.
Log de inicialização conectando no RabbitMQ:
```
&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;INFO 2532 --- [nio-8080-exec-1] o.s.a.r.c.CachingConnectionFactory       : Created new connection: rabbitConnectionFactory#3f1a4795:0/SimpleConnection@5deb4b [delegate=amqp://&lt;a href="mailto:guest@192.168.99.102"&gt;guest@192.168.99.102&lt;/a&gt;:5672/, localPort= 50321]&lt;/p&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;
* Enviar uma mensagem via REST. 
Exemplo: mensagem sendo enviada para fila (Insomnia REST client):
![Alt Text](https://dev-to-uploads.s3.amazonaws.com/i/07se3mwycvk4qsuax2ds.PNG)

* Mensagem recebida e conteúdo apresentado nos logs
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Message received from queue-a: "mensagem enviada para RMQ"&lt;/p&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;&amp;amp;nbsp;
### **Próximos capítulos:**
1. Trabalhando com objetos complexos (trafegando JSON) e explorando as propriedades da mensagem
2. Fanout e Topic exchanges
3. Configuração de filas de erro (*Dead Letter Queue*) e reprocessamento
4. Configurações avançadas

### **Referências:**
- https://www.rabbitmq.com/getstarted.html
- https://start.spring.io/
- https://github.com/efoscarini/rabbitmq-getting-started
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;

</description>
      <category>rabbitmq</category>
      <category>messaging</category>
      <category>springboot</category>
    </item>
  </channel>
</rss>
