Sangat umum dijumpai bahwa developer tidak menggunakan arsitektur formal, tanpa arsitektur yang jelas dan terdefinisi dengan baik sebelum mulai menuliskan kode, alhasil dengan praktik ini sekumpulan kode yang telah dirangkai tidak terorganisir dengan baik, tidak memiliki peran dan bahkan tidak jelas hubungannya satu dengan yang lain. Oleh karena itu untuk software architect atau developer baiknya mendifinisikan terlebih dahulu terkait dengan arsitektur yang akan digunakan sebelum menuliskan kode. Layered architecture adalah arsiktetur yang paling common digunakan oleh developer.
Layared architecture atau yang paling sering dijuluki sebagai dengan nama n-tier architecture pattern. Arsitektur ini diorganisir dalam beberapa layer yang mana masing-masing layer memiliki peranan dan tanggung jawab tersendiri. Pada umumnya terdiri dari 4 layer yaitu Presentation, Business, Persistence dan Database layer. Namun bisa ditambah juga ya layernya sesuai dengan kebutuhan pengembangan. Presentation layer biasanya bertanggung jawab untuk menerima request dan menampilkan response kepada client melalui UI.
Contoh kasus ketika : get customer data. Presentation layer tidak perlu tahu cara megambil data customer dari database, cukup menampilkan hasilnya saja.
Hal yang paling utama dalam arsitektur layered adalah bagaimana masing-masing layer itu tertutup. Maksudnya gimana ya tertutup? Artinya request berpindah dari satu layer ke layer lain, contohnya seperti dari presentation layer ke business layer dst.
Nah kalau seperti ini kenapa bukan dari presentation layer meneruskan request ke database layer untuk mendapatkan data customer pada kasus diatas? . Nah inilah yang dinamakan isolasi layer, pada pattern ini masing-masing layer terisolasi maksudnya adalah perubahan yang dibuat dalam satu lapisan arsitektur tidak berdampak pada layer yang lain. Ketika Anda menjadikan Presentation layer direct ke Database layer maka yang akan terjadi akan berdampak perubahan ke layer yang lain seperti persistency/database layer dan akan sangat bergantungan erat untuk setiap perubahan ( tightly coupled) dan banyak dependensi ke component lain yang mengakibatkan arsitektur tipe ini sangat mahal dan sulit dalam melakukan pengembangan(Perubahan kedepannya)
Anggaplah sekarang Anda ingin mengembangkan Aplikasi untuk mendapatkan informasi customer, maka secara arsitektur layer akan tampak interaksi masing-masing layer seperti gambar dibawah:
Pelanggan mengirimkan request melalui UI ( Presentation Layer) kemudian Presentation layer meneruskan request ke Business Layer untuk mendapatkan informasi customer dan melanjutkan command tersebut ke Persistance Layer yang akan melakukan interaksi ke database terkait dengan informasi pelanggan yang namanya siapa atau emailnya siapa atau bahkan lengkap dengan profile pelanggan tersebut dan kemudian meneruskan informasi tersebut yang dibungkus dalam UI pada presentation layer kepada pengguna.
Pastinya masing-masing layer memiliki keunggulan masing-masing yang dapat kita pertimbangkan dari beberapa indikator dibawah ini.
Overall Agility : Rendah
Kemampuan untuk meresponse dengan cepat untuk perubahan enviroment. Karena layered ini biasanya digunakan di Monolith nature yang masing-masing componentnya sangat bergantung satu dengan yang lain.
Easy of Deployment : Rendah
Setiap bagian kecil perubahan dari satu komponen akan berdampak bagi komponen lainnya, yang mengakibatkan perlunya waktu dan plan untuk melakukan re-deployment.
Testability : Tinggi
Karena masing-masing komponen memiliki peranan/tanggung jawab yang spesifik sehingga mudah untuk melakukan test.
Performance : Rendah
Karena request harus melewati berbagai layer untuk memenuhi request
Scalability : Rendah
Karena arsitektur ini dibangun dengan pattern yang monolith dan sangat bergantungan antara satu layer dengan yg lain.
Easy of Development: Tinggi
Pattern ini mudah untuk dipelajari dan tidak kompleks untuk di implementasi.
Hmm.. Sounds good kalau untuk arsitektur yang performancenya bagus apa ya? Yuk di sesi selanjutnya akan kita ulas ya.
Source : O’reilly Software Architecture Patterns
Hi there, ChatGPT is very familiar and become the hottest technology generation now a days.…
When it comes to writing code, there are a lot of factors to consider. You…
ES6, also known as ECMAScript 2015, is a major update to the JavaScript language that…
In today's fast-paced business environment, the ability to quickly respond to changing market conditions and…
Keunggulan development team adalah yang selalu update terhadap perkembangan teknologi, trend pengembangan terbaru dan pada…
Database Management System atau kerap kali disebutkan dengan DMBS ini adalah software/tools yang digunakan untuk…