Skip to content

Latest commit

 

History

History
79 lines (46 loc) · 3.08 KB

README.md

File metadata and controls

79 lines (46 loc) · 3.08 KB

Projeto de Integração RabbitMQ com Spring Boot e JavaScript para Processamento de Transações Financeiras

Este projeto ilustra a implementação de um sistema robusto para o processamento de transações financeiras, com uma aplicação produtora responsável pela leitura e publicação de transações a partir de arquivos CSV em JavaScript, e uma aplicação consumidora em Java Spring Boot, que consome essas mensagens, realiza a validação das transações através de um segundo arquivo de conciliação e persiste os dados validados em um banco de dados relacional.

Pré-requisitos

Para executar este projeto, você precisará ter instalado:

Instalação

Siga os passos abaixo para configurar o ambiente de desenvolvimento:

  1. Clone o repositório
git clone https://github.com/Alakazam-Asapcard/alakazam.git
cd alakazam
  1. Configure e inicie o RabbitMQ

Garanta que o RabbitMQ esteja instalado e em execução na sua máquina. Por padrão, o RabbitMQ inicia um servidor na porta 5672.

  1. Inicie a aplicação consumidora no Spring Boot

Você precisará estar na pasta diretório do consumidor para executar, siga os seguintes passos:

cd java-consumer
./mvnw clean package
java -jar target/java-consumer-0.0.1-SNAPSHOT.jar --spring.profiles.active=transaction,receiver --rabbitReceiver.client.duration=60000

Esta aplicação vai consumir as mensagens publicadas pelo produtor Node.js.

  1. Configure e inicie o MySQL

Garanta que o MySQl esteja instalado e em execução na sua máquina. Por padrão, o arquivo aplication.yml no caminho alakazam/java-consumer/src/main/resources utiliza o username: root e password: 123456, você precisará alterar esses dados para os que você configurou no MySQL em sua máquina.

  1. Inicie o produtor de mensagens Node.js

Você precisará estar na pasta diretório do produtor para executar, siga os seguintes passos:

cd ..
cd javascript-producer
npm install
node producer.js

Este script vai iniciar a publicação de mensagens em um canal do RabbitMQ.

Como usar

Após iniciar tanto o consumidor quanto o produtor, o sistema estará em plena operação. O produtor Node.js publicará mensagens em um canal do RabbitMQ, que serão consumidas pela aplicação Spring Boot. A lógica de processamento das mensagens pode ser ajustada conforme a necessidade do seu projeto. Caso o usuário queira utilizar um arquivo diferente, ele deve adicioná-lo à pasta INPUT com o mesmo nome do arquivo CSV anterior e executar o producer.js novamente

Autores