paint-brush
Cómo ganar 1 millón de dólares con AWS en un añopor@gianpicolonna
65,465 lecturas
65,465 lecturas

Cómo ganar 1 millón de dólares con AWS en un año

por Gianpi Colonna5m2024/04/28
Read on Terminal Reader

Demasiado Largo; Para Leer

¡Reduzca los costos de la nube de AWS en un 90 %! Aprenda 4 pasos para optimizar el gasto: desafiar suposiciones, ajustar recursos, usar instancias de Graviton y monitorear el uso.
featured image - Cómo ganar 1 millón de dólares con AWS en un año
Gianpi Colonna HackerNoon profile picture
0-item
1-item


Si llegaste a esta página pensando que te harías rico con algún plan para hacerte rico rápidamente, lamento decepcionarte. Este artículo más bien hablará sobre cómo reducir sus facturas de costos de la nube en $1 millón. Al hacer eso, básicamente habrá generado un millón de dólares adicionales en ingresos, que puede gastar comprando mi curso en línea sobre cómo hacerse rico con AWS ( enlace al curso aquí ).



El costo de la nube a menudo se pasa por alto y no se contabiliza al comienzo de los proyectos de las empresas. La encuesta de HashiCorp de 2021 encontró que casi el 40% de las empresas gastaron de más en costos de la nube en 2021 [ 1 ]. En 2023, casi todas las empresas (94 %) admitieron que estaban desperdiciando dinero en la nube [ 1 ] y que al menos el 30 % del coste de la nube se desperdició [ 2 ]. El gasto en la nube fue de casi 500 mil millones de dólares en 2022; por lo tanto, ¡estamos hablando de 150 mil millones de dólares desperdiciados al año!


No sólo se trata de una preocupación por la pérdida de ingresos, sino también por malas prácticas de sostenibilidad. ¡150 mil millones de dólares de energía desperdiciada!


Estos hallazgos involucran tanto a empresas grandes como a las más pequeñas, desde la madurez de la nube alta hasta la madurez de la nube baja. Se refiere a AWS, pero se pueden aplicar los mismos principios a cualquier otro proveedor de la nube. Entonces, si alguna parte de su trabajo se realiza en la nube, este artículo es para usted.


Hablo desde la perspectiva de un ingeniero de datos, pero los mismos aprendizajes se pueden aplicar a otras prácticas de ingeniería de software.

Vamos a sumergirnos.


¿Qué se necesita para gastar 1 millón de dólares en costos de nube en un año?

Este tipo de factura de la nube suele estar restringida a empresas muy grandes que operan globalmente con millones de clientes.


Para darle una idea, una factura en la nube de $1 millón puede resultar de un trabajo de Spark ETL que procesa ~1,5 Tb por hora, 24 horas al día, 7 días a la semana, durante los 365 días del año. Otro ejemplo podría ser una aplicación que recibe miles de millones de solicitudes al día desde múltiples ubicaciones en el mundo.


En una gran empresa, hay cientos de aplicaciones de este tamaño, lo que da lugar a contratos por miles de millones de dólares con proveedores de nube. Por ejemplo, Airbnb se había comprometido a gastar 1.200 millones de dólares en recursos de la nube durante cinco años a finales de 2019 [3 ].


En Expedia reducimos los costos de un ETL de procesamiento de datos que cuesta $1,1 millones de dólares al año a tan solo $100.000 al año mediante la implementación de prácticas de optimización. ¡¡Eso es una reducción de costos del 91 %!!


No todas las empresas tienen aplicaciones de un tamaño tan grande, pero imagine reducir el costo de la nube en un 90 % solo para una sola aplicación o para toda su empresa.



¿Cómo empezamos a ahorrar?

PASO 1: desafíe sus suposiciones de diseño

Vaya y obtenga una lista de sus aplicaciones más caras y desafíe sus suposiciones de diseño .

  • ¿Está creando una aplicación que tiene una disponibilidad del 99,999 % y una latencia inferior a milisegundos pero, en realidad, los usuarios serían lo suficientemente buenos con una disponibilidad del 99 % y una latencia de cientos de milisegundos?
  • ¿Está creando conjuntos de datos con miles de millones de filas pero los usuarios solo usarían agregaciones de algunas de las medidas?
  • ¿Está obteniendo datos en tiempo real pero los datos solo se analizan una vez al día?
  • ¿Estás actualizando el caché cada 10 segundos pero en realidad solo cambia a lo largo de los días?


Todas estas preguntas vuelven a la pregunta más importante: ¿cómo se va a utilizar la aplicación? ¿Cuál es el valor comercial para que exista? ¿Cómo nos ayuda la aplicación a conseguir un objetivo determinado?


Por supuesto, todas estas respuestas muchas veces no están claras al comienzo de un proyecto; pero es por eso que el diseño siempre debe ser un proceso iterativo, permitiendo que los cambios se produzcan de la manera más fluida posible. Los ingenieros deben aceptar la evolución y el cambio, alineando el desarrollo de aplicaciones con el impacto.


PASO 2: Ajuste los recursos de su infraestructura a sus necesidades

El segundo paso consiste en proporcionar a la aplicación los recursos adecuados y ajustarla a la infraestructura adecuada.


Como ingeniero, tenga en cuenta cómo se calculan los costos de la nube. Por ejemplo, AWS proporciona instancias puntuales en las que puede ofertar por el precio del clúster; esto es particularmente útil si tiene aplicaciones flexibles y tolerantes a fallas. Úselos si puede: AWS afirma reducir hasta un 90% los costos [ 4 ].


Algunas otras consideraciones que quizás desee abordar son:

  • ¿Atiende a clientes a nivel mundial o solo en un área geográfica? ¿Realmente necesita su infraestructura para vivir en todo el mundo o puede instalarla más cerca de su base de clientes?
  • ¿Está sobreaprovisionando sus instancias de clúster? Intente asegurarse de que haya suficiente capacidad para manejar cargas máximas sin costos innecesarios. Utilice el escalado automático para ajustar dinámicamente los recursos en función de la demanda real, evitando pagos excesivos por recursos inactivos.
  • Si está trabajando con datos y Spark, asegúrese de comprender los conceptos y ajustes de Spark. Si no es así, eche un vistazo a los siguientes recursos [ 5 ] [ 6 ] [ 7 ] [ 8 ] [ 9 ].

PASO 3: Utilice instancias de AWS Graviton

Hay pocos o ningún inconveniente al utilizar instancias de AWS Graviton. AWS ha invertido mucho en la creación de los procesadores más rentables. Puede obtener hasta un 40% de reducción en el gasto en la nube simplemente cambiando de un procesador basado en Intel a un procesador basado en ARM [ 10 ].


La única advertencia es que su aplicación debe ser compatible con los procesadores basados en ARM en los que se ejecuta Graviton. Si se trata de un servicio administrado como RDS u OpenSearch, entonces no hay ninguna complicación en el cambio: AWS se ocupa del sistema operativo subyacente y la compatibilidad de las aplicaciones. Si está creando su propia aplicación, es posible que deba volver a compilar el paquete según el lenguaje que esté utilizando: Java y otros lenguajes no requieren cambios, mientras que Python requiere cierta atención.


PASO 4: Supervise sus gastos y eduque sobre la concienciación sobre los costos

Por último, no olvide seguir controlando sus costos para detectar picos inesperados y sorpresas. El costo del día 0 de su aplicación será diferente del costo del día 170. Asegúrese de realizar un seguimiento de los cambios y de comprender por qué se produce el cambio: ¿está acumulando costos de almacenamiento de s3 o es solo una única vez? ¿espiga?


¡Configure las alertas y guías operativas necesarias !


Es importante destacar que implemente etiquetas de asignación de costos para realizar un seguimiento del gasto por departamento, proyecto o entorno. Evite el riesgo de crear un pantano de datos donde el costo sea imposible de rastrear o requiera un largo viaje a través de diferentes sistemas de registro. Debería ser rápido y sencillo volver al costo de cualquier aplicación determinada.


Pensamientos finales

Dondequiera que trabaje, es difícil equilibrar la entrega de nuevas funciones con la optimización de las actuales. ¿Quién no se ha sentido presionado para ofrecer nuevas funciones extravagantes a la velocidad de la luz?


Sin embargo, es fundamental que tanto los ingenieros como los directivos tomen decisiones deliberadas y proactivas sobre sus proyectos actuales, gestionando riesgos y oportunidades de forma eficaz.