rpcdemo

module
v0.0.0-...-dd48380 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 18, 2024 License: MIT

README

rpcdemo

Demo de comunicação utilizando o protocolo de comunicação RPC (Remote Procedure Call) e gRPC, framework RPC desenvolvido pelo Google.

RPC

RPC (Remote Procedure Call) é um protocolo de comunicação que permite que uma aplicação execute um trecho de código de outra aplicação, fazendo com que processos ou sistemas distintos se comuniquem pela rede, abstraindo as complexidades de comunicação entre cliente e servidor.

Golang permite a criação de um cliente e um servidor RPC utilizando a biblioteca padrão "net/rpc". Um ponto negativo dessa abordagem é que tanto o server como o client precisam ser desenvolvidos utilizando Go como linguagem.

gRPC

gRPC (Google Remote Procedure Call) é um framework RPC desenvolvido pelo Google. Além de vantagens de performance, ele também possui suporte para múltiplas linguagens, permitindo que o client e o server sejam desenvolvidos utilizando linguagens de programação distintas.

Para isso, o protocolo deve ser definido em um arquivo .proto, onde são definidas as propriedades da request, response, métodos expostos pelo protocolo. Utilizando ferramentas específicas, esse arquivo .proto é compilado e o código para exposição dos métodos e criação de structs é gerado automaticamente, faltando apenas a criação do client e do server utilizando o package grpc.

RPC vs REST

Vantagens
  1. Comunicação por contratos com tipagem, garantindo que cliente e servidor utilizem estruturas de dados bem definidas, reduzindo chances de incompatibilidade ou erros de interpretação;

  2. Eficiência na serialização/desserialização em comparação com json;

  3. Performance e eficiência, com menor latência na comunicação.

Desvantagens
  1. Maior complexidade e curva de aprendizado, uma vez que o uso de REST é mais simples de implementar e mais difundido;

  2. Interoperabilidade limitada, exigindo o uso de linguagens iguais para client/server, ou uso de frameworks que também tem limitação de linguagens suportadas;

  3. Exige maior documentação ou convenções de usos dos métodos, enquanto REST pode oferecer mais flexibilidade e ser mais descritivo utilizando endpoints e métodos HTTP específicos.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL