Aplicaciones para
1M de usuarios
Victor Aguilar
victor.aguilar@grow.mobi
Victor Aguilar C.
victor.aguilar@grow.mobi
Past leader de comunidades como GDG La Paz y Docker La Paz, actualmente.
Senior Backend Dev en Grow Mobility
Aclaración
Hablaremos acerca cómo crear una aplicación para un millón de usuarios desde un punto de vista totalmente técnico.
No hablaremos de cómo tener un million de usuarios, o de como tener una idea que logre un millón de usuarios
Feb
Nov
20k+
2M+
Active users
7 Paises
+
29+ Ciudades
Los dos grandes retos en proyectos con muchos usuarios
Incrementar las funcionalidades pero no la deuda tecnica
Que el proyecto no muera a medida que hay más usuario
Mantenibilidad
Disponibilidad
¿Que considerar?
CONSTRUCCIÓN
DISTRIBUCIÓN
Como sobrellevar esos retos
Mantenibilidad
Disponibilidad
La Construcción
DEL PROYECTO
1. Usar una arquitectura para escalar desde el Inicio
2. Evitar un unico punto de fallo
Desacoplamiento o API First
3. Usar cache, pero sabiamente
Cache
Server
request
response
original fetch
browser cache
Un cache es como el poder, si lo usas sin control, puede terminar volviendote loco
- Yo
Solo hay dos cosas difíciles en las Ciencias de la computación:
cómo nombrar variables e invalidar cache
- Phil Karlton
4. Optimizar la obtención de Datos, siempre
La mayor parte del tiempo transcurrido desde un request hasta un response tiene que ver con consultas a las bases de datos
5. Rastrear todo, en especial los errores
Bug
Feature
o como dice la banda agregar logs a todo
6. Hacer pruebas por amor de Dios,
muchas pruebas
Unitarias
Funcionales
Integración
UI
Carga
etc ...
Haz pruebas, te aseguro que tu yo del futuro de lo agradecera
P R U E B A S
Para que no se les olvide
7. Asincrono cuando sea necesario
8. Prepararse para los fallos,
Rollbacks Rapidos
a este consejo yo le llamo el invitado especial, Murphy
El Despliegue
DEL PROYECTO
Tipos de escalabilidad
VERTICAL
HORIZONTAL
Primeros Recursos
1 - 1000
Dominio
Servidores
Base de Datos
Alta Disponibilidad
Multiples Servidores
Balanceo de Carga
1000+
Performance & Monitoring
10k ~ 100k
Indexing
Cache
Object Storage
CDNs
Combine NoSQL
Automation
500.000+
Auto Scaling
Auto Provisioning
Infra as Code
Arquitecture Improvements
1M+
Queues
Notifications
Serverless
SOA
Microservices
Victor Aguilar C.
victor.aguilar@grow.mobi
Past leader de comunidades como GDG La Paz y Docker La Paz, actualmente.
Senior Backend Dev en Grow Mobility
¿Preguntas?
@vicobits
Aplicaciones para 1M de usuarios
By Victor Aguilar
Aplicaciones para 1M de usuarios
Como hacer aplicaciones escalables
- 231