Debat Monolith v/s Layanan Mikro
Ada banyak diskusi yang terjadi di dunia Monolith v/s Microservices. Sebagian besar awal karir saya dihabiskan untuk membangun monolit dan tentu saja ketika arsitektur berorientasi layanan mulai mengakar, kami mengadopsinya dengan ukuran kesuksesan yang baik.
Pengalaman saya
Saya tidak perlu terdengar keren di sini dan melontarkan hal-hal seperti hukum Conway kepada orang-orang. Pengalaman saya yang terbatas telah mengajari saya bahwa kami memiliki individu, tim kecil dan tim besar, yang jelas diberi tanggung jawab atas modul tertentu (sebut saja layanan jika Anda mau). Sebagai bagian dari tanggung jawab mereka, mereka harus melakukan hal berikut:
- Mereka harus memilikinya
- Mereka harus mempertahankannya
- Mereka harus berkomunikasi tentang hal itu
- Buat API yang dapat dioperasikan yang menghormati kontrak
- Uji perangkat lunak mereka sendiri
- Perhatikan tes integrasi
- Dapat menentukan cara menerapkan barang-barang mereka di lingkungan
- Debug dan yang terpenting lacak panggilan dalam skema keseluruhan hal.
Ini bukan tentang Monolith atau Layanan Mikro
Benar-benar tidak ada peluru perak. Tidak ada sudut pandang yang pasti untuk menggunakan layanan mikro atau menggunakan monolit. Siapa pun yang berbicara tentang satu arah atau yang lain tidak memiliki niat yang salah dalam mencoba mempengaruhi Anda tetapi dengan hormat, setiap organisasi dan tim pengembangannya akan berbeda, persyaratan mereka akan berbeda, bagaimana mereka perlu berkembang atau mendukung layanan/perangkat baru akan berbeda. Anda harus berada di kursi pengemudi dalam memahami organisasi Anda sendiri terlebih dahulu sebelum secara membabi buta mengadopsi pandangan apa pun tentang perusahaan besar atau pemberi pengaruh.
Tidak ada gunanya organisasi mana pun yang kurang menghargai kebutuhan untuk mengelola tim orang, mengaturnya, otomatisasi, pengujian, memberi tim kebebasan dan fleksibilitas untuk memilih alat dan tetap menjaga mereka disiplin dan banyak lagi.
Kesampingkan sejenak monolit dan layanan mikro. Apakah Anda menangani masalah mendasar seperti komunikasi tim, hierarki, pengambilan keputusan, disiplin dan kebersihan rekayasa perangkat lunak, cakupan pengujian, otomatisasi, otonomi, dan lainnya? Pikirkan tentang itu sejenak.
Apa yang saya rekomendasikan?
Dalam buku saya, saya lebih suka melihat aplikasi secara keseluruhan dan pada dasarnya mengapa aplikasi itu ada? Setelah Anda mendapatkan jawaban tersebut, lihat apa saja kasus penggunaan atau perjalanan pengguna pelanggan yang berinteraksi dengan pengguna dengan aplikasi Anda? Bagi saya, akhirnya turun ke berikut:
- Anda memerlukan proses yang efisien (sepenuhnya otomatis atau tidak) untuk mengembangkan dan menerapkan aplikasi Anda di berbagai lingkungan dan dapat memindahkan versi di antaranya.
- Anda memerlukan proses yang efisien untuk melacak perubahan kode sumber Anda ke apa yang telah diterapkan dalam produksi.
- Akhirnya dan yang paling penting, ketika hal buruk terjadi dan yang akan terjadi, apakah Anda memiliki kemampuan untuk melacak dan melacak apa yang terjadi, menemukan komponen yang menyebabkan masalah, men-debug secara efisien dan memahami akar penyebab dan kemudian memiliki proses untuk meluncurkan perubahan untuk mengurangi pengguna yang terkena dampak.
Sekarang jika monolit dan / atau arsitektur layanan mikro dapat membantu Anda mengatasinya, mengingat kendala organisasi Anda, ikuti itu. Anda bukan Google, Facebook, Microsoft, Amazon dan mereka bukan Anda. Anda bahkan tidak perlu langsung membandingkan diri Anda dengan organisasi lain, yang mungkin lebih pintar, gesit, atau ciri-ciri tersebut.
Yang perlu Anda lakukan adalah dengan semangat yang sebenarnya, adalah membangun budaya yang sehat di organisasi Anda yang terbuka untuk diskusi dan mulai mengukur apa yang direkomendasikan oleh DORA :
- Saatnya Memulihkan Layanan
- Ubah Tingkat Kegagalan
- Waktu Pimpin untuk Perubahan
- Frekuensi Penerapan.
Komentar penutup saya adalah fokus pada apa yang membuat Anda mengirimkan perangkat lunak Anda secara efisien (biaya, operasi, dan semua yang disertakan). Segala sesuatu yang lain seperti debat Berita jam 9 malam.