Coder Social home page Coder Social logo

igorcastilhos / java-rabbitmq-microservice Goto Github PK

View Code? Open in Web Editor NEW
1.0 1.0 0.0 73 KB

Este projeto demonstra uma implementação eficaz de uma arquitetura de microservices utilizando Java e Spring Boot

License: MIT License

Java 100.00%
assynchronous java non-blocking queue rabbitmq spring spring-boot

java-rabbitmq-microservice's Introduction

README - Microservices Java

image

Este projeto implementa uma arquitetura de microservices usando Java, focando na comunicação assíncrona e não bloqueante entre microservices. Ele consiste em dois microservices principais:

  • User Microservice: Gerencia os usuários da plataforma.
  • Email Microservice: Envia e-mails automáticos para os usuários.

Comunicação Assíncrona e Fluxo de Trabalho

image

A comunicação entre os microservices é realizada de forma assíncrona utilizando o protocolo de mensagens. O fluxo de trabalho é descrito abaixo:

  1. Cadastro de Usuário:

    • Um cliente envia uma requisição POST /USERS para cadastrar um novo usuário.
    • O User Microservice recebe a requisição, salva os dados do usuário na base de dados e publica uma mensagem de comando em um canal de mensagens (Broker).
  2. Processamento de E-mail:

    • O Email Microservice, conectado ao mesmo canal de mensagens, aguarda as mensagens.
    • Ao receber uma mensagem, o Email Microservice envia um e-mail de boas-vindas ao usuário cadastrado e salva os dados do e-mail.
  3. Broker - RabbitMQ:

    • O RabbitMQ atua como broker, facilitando a comunicação assíncrona.
    • O User Microservice atua como Producer, enviando mensagens ao RabbitMQ.
    • O RabbitMQ encaminha as mensagens para as filas apropriadas, onde o Email Microservice, atuando como Consumer, as processa.

Tecnologias Utilizadas

  • Java 17: Linguagem de programação.
  • Maven: Ferramenta de gerenciamento de projetos.
  • Spring Boot: Framework para facilitar a configuração e execução de aplicações Java.
  • Spring Web: Para criar endpoints da API.
  • Spring Data JPA: Para transações com a base de dados.
  • Spring Validation: Para validações na entrada da API.
  • Spring AMQP: Protocolo de mensageria para comunicação assíncrona.
  • Spring Mail: Para enviar e-mails.
  • PostgreSQL: Sistema de gerenciamento de banco de dados.
  • Rabbit MQ: Sistema de mensageria para comunicação entre microservices.
  • Cloud AMQP: Serviço cloud para Rabbit MQ.
  • SMTP Gmail: Serviço de e-mail para envio de mensagens.

Conclusão

Este projeto demonstra uma implementação eficaz de uma arquitetura de microservices utilizando Java e Spring Boot, com foco na comunicação assíncrona e não bloqueante entre os serviços. A utilização do RabbitMQ como broker de mensagens permite um fluxo de trabalho eficiente e escalável.

java-rabbitmq-microservice's People

Contributors

igorcastilhos avatar

Stargazers

 avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.