Pro dan Kontra Perpindahan Prime Video ke Arsitektur Monolitik: Apakah Sepadan dengan Risikonya?

May 08 2023
Memotong Biaya atau Mengorbankan Fleksibilitas? Amazon Prime Video baru-baru ini mengalihkan layanan pemantauan video langsungnya dari layanan mikro ke monolit, menghasilkan pengurangan biaya sebesar 90%. Mari selami lebih dalam arsitekturnya dan coba pahami motivasi di balik langkah di luar sekadar menghemat biaya, dan tentukan apakah itu benar-benar arsitektur layanan mikro atau layanan makro.

Memotong Biaya atau Mengorbankan Fleksibilitas?

Amazon Prime Video baru-baru ini mengalihkan layanan pemantauan video langsungnya dari layanan mikro ke monolit, menghasilkan pengurangan biaya sebesar 90%.

Mari selami lebih dalam arsitekturnya dan coba pahami motivasi di balik langkah di luar sekadar menghemat biaya, dan tentukan apakah itu benar-benar arsitektur layanan mikro atau layanan makro.

Terminologi yang sering digunakan:

VMS (layanan pemantauan video) : Alat ini memungkinkan amazon untuk secara otomatis mengidentifikasi masalah kualitas perseptual (misalnya, memblokir korupsi atau masalah sinkronisasi audio/video) dan memicu proses untuk memperbaikinya

MCS (layanan konverter media) : Ini mengubah aliran audio/video input ke bingkai atau buffer audio yang didekripsi yang dikirim ke detektor

Detektor cacat : Ini mengeksekusi algoritme yang menganalisis bingkai dan buffer audio secara waktu nyata untuk mencari cacat (seperti pembekuan video, kerusakan pemblokiran, atau masalah sinkronisasi audio/video) dan mengirim pemberitahuan waktu nyata setiap kali ditemukan cacat

Arsitektur Tanpa Server Terdistribusi Awal

Diagram di atas adalah arsitektur tanpa server awal untuk layanan pemantauan video langsung yang dibangun menggunakan fungsi langkah AWS dengan AWS Lambda yang berperan sebagai orkestrator.

Mari kita uraikan langkah demi langkah untuk pemahaman yang lebih baik. (fyi: beberapa hipotesis dianggap karena kurangnya info/kejelasan yang diberikan di artikel asli)

  • Langkah pertama melibatkan aplikasi klien mengunggah aliran audio atau video ke layanan konversi media dan memicu fungsi langkah untuk memulai konversi secara sinkron.
  • Untuk mencapai ini, alat harus dijalankan di sisi konsumen untuk mendekode aliran audio/video terenkripsi yang masuk (dengan asumsi tidak disebutkan di blog) sebelum mengirimkannya ke layanan konversi media.
  • Setelah konversi selesai, MCS menyimpan aliran audio/video di bucket s3 dan memicu panggilan ke layanan pendeteksi cacat yang berjalan secara paralel dan hasil gabungan disimpan lagi di bucket S3 dan juga didorong ke topik SNS agar konsumen yang ditargetkan dapat mengambil tindakan yang sesuai.
  • Seluruh sistem dibangun menggunakan arsitektur tanpa server (AWS Step Functions dan Lambda) dan arsitektur layanan mikro (MCS dan detektor cacat), dengan biaya utama berasal dari alur kerja orkestrasi dan transfer data antar komponen terdistribusi. Belum lagi, ada hambatan penskalaan terkait untuk hot live stream dengan desain saat ini

Arsitektur Monolit

Arsitektur yang diperbarui untuk memantau sistem dengan semua komponen berjalan di dalam satu tugas Amazon ECS.

Dalam arsitektur yang diperbarui, sebagian besar komponen tetap sama (MCS, Detektor, Orkestrator), satu-satunya perubahan signifikan adalah komponen telah dikonsolidasikan menjadi satu instance ECS. Tapi apa artinya ini, dan bagaimana pengaruhnya terhadap sistem? Mari kita hancurkan.

  • Orkestrasi yang sebelumnya mahal dan menggunakan fungsi langkah AWS dan Lambda, telah diganti dengan lapisan orkestrasi baru. Hal ini memungkinkan kontrol komponen yang lebih baik dalam satu instans, menghasilkan penghematan biaya yang signifikan.
  • Konverter media (MCS) sebelumnya berjalan sebagai layanan mikro tetapi sekarang telah dipindahkan ke satu instans ECS. Perubahan ini memungkinkan konversi dan penyimpanan data secara lokal di tumpukan aktif, menghasilkan pemrosesan yang lebih cepat dan peningkatan kinerja.
  • Terakhir, detektor, yang menggunakan model ML untuk mendeteksi cacat pada aliran audio/video, juga telah dipindahkan ke satu instans ECS. Meskipun ini berarti kehilangan kemampuan skalabilitas horizontal, penghematan biaya membuatnya menjadi tradeoff yang berharga. Namun, perlu diperhatikan bahwa detektor dapat pecah di bawah beban tinggi, jadi masih ada beberapa potensi tantangan yang harus diatasi
  • Pro: pemotongan biaya karena panggilan read write tier-1 bucket S3 ekstra tidak diperlukan lagi serta fungsi AWS Step dan operasi mahal Lambda untuk orkestrasi telah diganti dengan komponen individual.
  • Cons: Kehilangan skalabilitas horizontal (misalnya Detektor juga berjalan dalam instance ECS tunggal). Kehilangan Fleksibilitas karena di masa mendatang akan ada banyak konsumen untuk streaming audio/video yang saat ini terhubung erat ke detektor.
pendekatan untuk menerapkan lebih banyak detektor ke layanan

Arsitektur monolitik sebelumnya memiliki masalah besar kehilangan skalabilitas horizontal, terutama untuk detektor, dalam satu instans ECS. Namun desain makro + monolit yang baru telah mengatasi masalah ini. Mari selami lebih dalam untuk melihat caranya.

  • Detektor hanya dapat diskalakan secara vertikal dalam satu instans ECS untuk mengatasi instans layanan monolit ini akan diduplikasi dengan subset parameterisasi dari detektor di berbagai kluster ECS dan lapisan orkestra ringan menggunakan AWS lambda untuk distribusi permintaan.
  • Dalam desain di atas kita masih kehilangan beberapa fleksibilitas. Saat ini hanya ada satu konsumen streaming audio/video pendeteksi yang di masa mendatang akan datang banyak konsumen yang mungkin memerlukan perubahan dalam pendekatan desain.

Dalam dunia pengembangan perangkat lunak, tidak ada solusi yang cocok untuk semua atau supremasi desain antara layanan mikro dan arsitektur monolitik. Dalam kasus perpindahan Prime Video ke desain monolitik, ini menghasilkan pengurangan biaya yang signifikan hingga 90% dan menyatu dengan baik dengan kasus penggunaannya.

Namun, penting untuk dicatat bahwa jika beberapa konsumen untuk streaming audio/video muncul atau layanan MCS itu sendiri tidak dapat disimpan dalam satu instans ECS karena ukuran buffer, maka desain saat ini mungkin perlu dievaluasi ulang. Sebagai insinyur perangkat lunak, penting untuk terus menilai dan menyesuaikan desain kami untuk memenuhi persyaratan yang berubah dan mengoptimalkan biaya dan kinerja.

Referensi

  • Blog video utama Amazon ( Meningkatkan layanan pemantauan audio/video Prime Video dan mengurangi biaya sebesar 90% — Prime Video Tech )

Terima kasih telah menjadi bagian dari komunitas kami! Sebelum kamu pergi:

  • Tepuk tangan untuk ceritanya dan ikuti penulisnya
  • Lihat lebih banyak konten di publikasi Level Up Coding
  • Kursus wawancara coding gratis ⇒ Lihat Kursus
  • Ikuti kami: Twitter | LinkedIn | Buletin