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.
Para executar este projeto, você precisará ter instalado:
- Node.js
- Java JDK 11 ou superior
- Maven
- RabbitMQ
- MySQL
Siga os passos abaixo para configurar o ambiente de desenvolvimento:
- Clone o repositório
git clone https://github.com/Alakazam-Asapcard/alakazam.git
cd alakazam
- 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.
- 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.
- 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.
- 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.
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