Logo

dev-resources.site

for different kinds of informations.

O que são microservices (microsserviços)?

Published at
11/25/2023
Categories
microservices
Author
Natália Oliveira
Categories
1 categories in total
microservices
open
O que são microservices (microsserviços)?

Esse texto são anotações breves tiradas do vídeo sobre microsevices do canal TechWorld with Nana. As anotações são sobre os seguintes tópicos:

  • Arquitetura em monolito
  • O que são microsserviços
  • Microsserviços, CI/CD, polyrepo e monorepo

Arquitetura em monolito

Quando falamos em um monilito em tech estamos nos referindo a uma arquitetura onde o código inteiro de uma aplicação é uma unidade. Aqui, tudo é desenvolvido, deployado e escalado como uma unidade, e uma stack só.

Alguns desafios da arquitetura de monolito:

  • A aplicação se torna complexa demais para entender
  • As partes da aplicação se tornam muito entrelaçadas
  • Só dá para escalar a aplicação inteira, mesmo que só faça sentido escalar uma parte específica
  • Demora no release

Como possível solução desses desafios surgiu a arquitetura de microsserviços (em inglês, microservices).

O que são microsserviços?

Microsserviços são aplicações que seguem uma arquitetura onde uma aplicação é dividida entre serviços menores, independentes, que podem ter stacks diferentes, sendo desenvolvidos, deployados e escalados separadamente.

Para se comunicar entre si, é comum que microsserviços utilizem chamadas de APIs. Outra forma de comunicação é através de message brokers, como o RabbitMQ, onde temos filas no modelo publish/subscribe. Além disso, a comunicação pode ser feita também através de service mesh, que é um serviço que lida com toda a lógica de comunicação entre os microsserviços.

Alguns desafios de microsserviços:

  • Configurar a comunicação entre esses diversos serviços
  • Conseguir monitorar todos os múltiplos serviços entre servidores

Microsserviços, CI/CD, polyrepo e monorepo

Polyrepo é uma estratégia de gerência de código onde criamos vários repositórios, cada um com seu tracking de Git, por exemplo, e com isso acabamos por ter vários pipelines de CI/CD (continuous integration/continous deployment). É muito comum em empresas que seguem a arquitetura em microsserviços.

Por outro lado, a estratégia de monorepo nos faz lidar somente com um CI/CD pipeline, já que teremos várias pastas, com cada serviço, mas sendo trackeadas por um único controle de versão, por exemplo.

Fontes:
Microservices explained - the What, Why and How?, por TechWorld with Nana

Esse texto não tem intenção de esgotar o tema. Acrescente nos comentários, e também aponte erros quando os identificar.

Featured ones: