paint-brush
Bir ildə AWS ilə necə 1 milyon dollar qazanmaq olartərəfindən@gianpicolonna
65,525 oxunuşlar
65,525 oxunuşlar

Bir ildə AWS ilə necə 1 milyon dollar qazanmaq olar

tərəfindən Gianpi Colonna5m2024/04/28
Read on Terminal Reader
Read this story w/o Javascript

Çox uzun; Oxumaq

AWS bulud xərclərinizi 90% azaldın! Xərcləri optimallaşdırmaq üçün 4 addımı öyrənin: fərziyyələrə etiraz edin, resursları tənzimləyin, Graviton nümunələrindən istifadə edin və istifadəyə nəzarət edin.

Company Mentioned

Mention Thumbnail
featured image - Bir ildə AWS ilə necə 1 milyon dollar qazanmaq olar
Gianpi Colonna HackerNoon profile picture
0-item
1-item


Əgər siz tez varlanmaq sxemi ilə varlanacağınızı düşünərək bu səhifəyə girmisinizsə, sizi məyus etdiyim üçün üzr istəyirəm. Bu məqalə daha çox bulud xərclərinizi 1 milyon dollar azaltmaq barədə danışacaq. Bununla, siz mahiyyətcə əlavə bir milyon dollar gəlir əldə etmiş olacaqsınız – bu gəliri AWS ilə necə varlanmaq barədə onlayn kursumu almağa sərf edə bilərsiniz ( kursu buradan keçid ).



Şirkətlərin layihələrinin başlanğıcında bulud dəyəri çox vaxt nəzərə alınmır və nəzərə alınmır. 2021-ci ildə HashiCorp sorğusu göstərdi ki, şirkətlərin demək olar ki, 40%-i 2021-ci ildə bulud xərclərinə həddindən artıq pul xərcləyib [ 1 ]. 2023-cü ildə demək olar ki, bütün şirkətlər (94%) buludda pul xərclədiklərini etiraf etdilər [ 1 ] və bulud xərclərinin ən azı 30%-i boşa getdi [ 2 ]. 2022-ci ildə bulud xərcləri demək olar ki, 500 milyard dollar idi - buna görə də biz ildə 150 milyard dollar israfından danışırıq!


Bu, təkcə əldən verilmiş gəlirlərdən deyil, həm də zəif davamlılıq təcrübələrindən narahatdır. 150 milyard dollar enerji sərfiyyatı!


Bu tapıntılar yüksək buludlu yetkinlikdən aşağı buludlu yetkinliyə qədər böyük müəssisələri, eləcə də kiçik müəssisələri əhatə edir. Bu, AWS-ə aiddir, lakin eyni prinsiplər istənilən digər bulud provayderinə tətbiq edilə bilər. Beləliklə, işinizin hər hansı bir hissəsi buluddadırsa, bu məqalə sizin üçündür.


Mən məlumat mühəndisi nöqteyi-nəzərindən danışıram, lakin eyni öyrənmələr digər proqram mühəndisliyi təcrübələrinə də tətbiq oluna bilər.

Gəlin içəri girək.


Bir il ərzində bulud xərclərinə 1 milyon dollar xərcləmək üçün nə lazımdır?

Bu cür bulud hesabı adətən qlobal miqyasda milyonlarla müştəri ilə fəaliyyət göstərən çox böyük müəssisələrlə məhdudlaşır.


Sizə bir fikir vermək üçün, 1 milyon dollarlıq bulud fakturası Spark ETL işinin ilin 365 günü ərzində 24x7 saatda ~1,5 Tb işlənməsi nəticəsində yarana bilər. Başqa bir misal, dünyanın bir çox yerindən gündə milyardlarla sorğu alan bir tətbiq ola bilər.


Böyük bir müəssisədə bu ölçüdə yüzlərlə proqram var və nəticədə bulud provayderləri ilə milyard dollarlıq müqavilələr bağlanır. Məsələn, Airbnb 2019-cu ilin sonunda beş il ərzində bulud resurslarına 1,2 milyard dollar xərcləmək öhdəliyi götürmüşdü [3 ].


Expedia-da biz optimallaşdırma təcrübələrini tətbiq etməklə ildə 1,1 milyon dollara başa gələn məlumat emalı ETL-nin xərclərini ildə cəmi 100.000 dollara endirdik. Bu, 91% xərclərin azalmasıdır!


Bütün şirkətlərin belə böyük ölçüdə tətbiqləri yoxdur, ancaq tək bir proqram və ya bütün şirkətiniz üçün bulud xərclərinizi 90% azaltdığınızı təsəvvür edin.



Qənaət etməyə necə başlayaq?

ADDIM 1: Dizayn fərziyyələrinizə etiraz edin

Gedin və ən bahalı tətbiqlərinizin siyahısını əldə edin və dizayn fərziyyələrinizə etiraz edin .

  • 99,999% əlçatanlığı və sub-millisaniyə gecikməsi olan, lakin real olaraq istifadəçilər 99% əlçatanlıq və yüzlərlə millisaniyəlik gecikmə ilə kifayət qədər yaxşı olacaq bir proqram qurursunuz?
  • Siz milyardlarla cərgədən ibarət verilənlər toplusu yaradırsınız, lakin istifadəçilər yalnız bəzi tədbirlərdən istifadə edəcəklər?
  • Siz real vaxtda məlumat əldə edirsiniz, lakin məlumatlar gündə yalnız bir dəfə təhlil edilir?
  • Siz keşi hər 10 saniyədən bir təzələyirsiniz, lakin o, həqiqətən günlər ərzində dəyişir?


Bütün bu suallar ən vacib suala qayıdır: proqram necə istifadə olunacaq? Onun mövcud olması üçün biznes dəyəri nədir? Tətbiq bizə verilən məqsədə çatmaqda necə kömək edir?


Əlbəttə ki, bütün bu cavablar çox vaxt layihənin əvvəlində qeyri-müəyyən olur; lakin buna görə dizayn həmişə iterativ bir proses olmalıdır - dəyişikliklərin mümkün qədər qüsursuz baş verməsinə imkan verir. Mühəndislər təkamül və dəyişikliyi qəbul etməli, tətbiqin inkişafını təsirlə uyğunlaşdırmalıdırlar.


ADDIM 2: İnfrastruktur resurslarınızı ehtiyaclarınıza uyğunlaşdırın

İkinci addım tətbiqi lazımi resurslarla təmin etmək və lazımi infrastruktura uyğunlaşdırmaqdan ibarətdir.


Bir mühəndis olaraq bulud xərclərinin necə hesablandığından xəbərdar olun. Məsələn, AWS klaster qiymətinə təklif verə biləcəyiniz spot nümunələri təqdim edir — bu, xüsusilə də xətaya dözümlü və çevik tətbiqləriniz varsa faydalıdır. Mümkünsə, onlardan istifadə edin — AWS xərclərin 90%-ə qədər azaldığını iddia edir [ 4 ].


Müraciət etmək istədiyiniz bəzi digər mülahizələr bunlardır:

  • Müştərilərə qlobal miqyasda xidmət edirsiniz, yoxsa yalnız bir coğrafi ərazidə? Dünyada yaşamaq üçün həqiqətən infrastrukturunuza ehtiyacınız varmı və ya onu müştəri bazanıza daha yaxın yerləşdirə bilərsinizmi?
  • Klaster nümunələrinizi həddən artıq təmin edirsiniz? Lazımsız xərclər olmadan pik yükləri idarə etmək üçün kifayət qədər tutumun olmasını təmin etməyə çalışın. Resursları faktiki tələb əsasında dinamik şəkildə tənzimləmək üçün avtomatik miqyasdan istifadə edin, boş resurslar üçün artıq ödənişin qarşısını alın.
  • Əgər data və Spark ilə işləyirsinizsə, Spark konsepsiyalarını və tənzimləmələrini başa düşdüyünüzə əmin olun! Bunu etmirsinizsə, aşağıdakı resurslara nəzər salın [ 5 ] [ 6 ] [ 7 ] [ 8 ] [ 9 ].

ADDIM 3: AWS Graviton nümunələrindən istifadə edin

AWS Graviton nümunələrindən istifadə edərkən heç bir çatışmazlıq yoxdur və ya çox azdır. AWS ən sərfəli prosessorların yaradılmasına böyük sərmayə qoyub. Siz sadəcə intel əsaslı prosessordan ARM əsaslı prosessora keçid etməklə bulud xərclərini 40%-ə qədər azalda bilərsiniz [ 10 ].


Bunun üçün yeganə xəbərdarlıq, tətbiqinizin Graviton-un işlədiyi ARM əsaslı prosessorlara uyğun olmasıdır. RDS və ya OpenSearch kimi idarə olunan xidmətlə məşğul olursunuzsa, onda keçiddə heç bir çətinlik yoxdur — AWS əsas ƏS və tətbiq uyğunluğu ilə məşğul olur. Öz tətbiqinizi qurursunuzsa, istifadə etdiyiniz dildən asılı olaraq paketi yenidən tərtib etməli ola bilərsiniz - Java və digər dillər heç bir dəyişiklik tələb etmir, Python isə bir qədər diqqət tələb edir.


ADDIM 4: Xərclərinizə nəzarət edin və xərclər barədə məlumatlı olun

Nəhayət, gözlənilməz zirvələr və sürprizlər üçün xərclərinizi izləməyi unutmayın. Tətbiqinizin 0-cı günündəki xərc 170-ci günün dəyərindən fərqli olacaq. Dəyişiklikləri izlədiyinizə əmin olun və dəyişikliyin nə üçün baş verdiyini anladığınızdan əmin olun: bu, s3 yaddaş xərclərini yığırmı, yoxsa birdəfəlikdir sünbül?


Lazımi xəbərdarlıqları və əməliyyat təlimatlarını qurun !


Əsas odur ki, şöbə, layihə və ya ətraf mühitə görə xərcləri izləmək üçün xərc bölgüsü etiketlərini tətbiq edin. Xərcləri izləmək mümkün olmayan və ya müxtəlif log sistemləri arasında uzun səyahət tələb edən məlumat bataqlığı yaratmaq riskindən çəkinin. İstənilən tətbiq dəyərinə qayıtmaq tez və sadə olmalıdır.


Son fikirlər

Harada işlədiyinizdən asılı olmayaraq, yeni funksiyaların çatdırılmasını cari funksiyaların optimallaşdırılması ilə balanslaşdırmaq çətindir. Kimə işıq sürətində yeni qeyri-adi xüsusiyyətləri təqdim etmək üçün təzyiq edilməyib.


Bununla belə, həm mühəndislər, həm də menecerlər üçün cari layihələri ilə bağlı düşünülmüş və fəal qərarlar qəbul etmələri, riskləri və imkanları effektiv şəkildə idarə etmələri vacibdir.