O que é o MongoDB? um banco de dados NoSQL baseado em documentos e disparado um dos mais usados no mundo! Essa resposta está certa, embora incompleta. Há uma infinidade de recursos legais que deveriam ser levados em consideração na hora de explicar o projeto/produto.
Nesse post, que tentarei fazê-lo bem curto, vou apontar diversos links para a documentação do MongoDB. Sim, isso é um RTFM!!!
MongoDB é:
- Um banco NoSQL
- Baseado em Documentos
- Altamente escalável e performático
- Pesquise por Replicaset
- Pesquise por Sharding
- Oferece 2 modelos de consulta extremamente eficientes
- Possui Scripts ou Procedures
- E oferece um modelo especial de collections chamado GridFS
Onde quero chegar com esses dados:
Você já ouviu falar em Firebase? Se sim, então te convido a conhecer o projeto RESTHeart ele transforma o MongoDB em algo bem parecido com o que o firebase já foi. Hoje o firebase cresceu muito, mas no passado já foi simplesmente um backend para apps. O RestHeart não entragará a parte de analytics do Firebase, mas é open source, tem imagem docker e é extremamente interessante para PoC’s, ou mesmo aplicações de produção. Sua configuração é simples e te dá muita liberdade.
Se você está preocupado com escalabilidade e distribuição de carga, você deve conhecer Replicaset e Sharding, esses são os elementos que juntos farão o MongoDB escalar. Replicaset é a parte que envolve maior custo, mas sharding keys é o que mais irá lhe tomar tempo, essa é a decisão mais complexa.
Você está pensando em armazenar arquivos? MongoDB também tem uma feature super interessante chamada GridFS (Grid File System). O GridFS oferece um tipo especial de collection destinado ao trabalho com arquivos, na prática ele usa 2 coleções. É bom ler a documentação oficial (o link está acima) para compreender suas recomendações. Você precisa conhecer essa feature para compreender o trade-off na hora de escolher uma solução para armazenar arquivos e já entrego o spoiler: Não cabe bem para tudo, há implicações negativas quando estamos falando de grandes arquivos.
Não vou aprofundar mais, era só isso que eu queria apresentar: Features não comentadas, que são muito úteis e salvam seu projeto.
Então, você conhecia essas features, sabia de sua existência? Comenta aí! Quero saber se foi útil ou se essas features podem te ajudar, de repente eu crio alguma coisa que detalhe esses elementos, caso haja demanda.
0 comentários