Arsitektur Perangkat Lunak & Pengenalan Desain

Arsitektur sistem menggambarkan komponen utamanya, hubungan (struktur), dan bagaimana mereka berinteraksi satu sama lain. Arsitektur dan desain perangkat lunak mencakup beberapa faktor pendukung seperti strategi Bisnis, atribut kualitas, dinamika manusia, desain, dan lingkungan TI.

Kami dapat memisahkan Arsitektur dan Desain Perangkat Lunak menjadi dua fase berbeda: Arsitektur Perangkat Lunak dan Desain Perangkat Lunak. DiArchitecture, keputusan nonfungsional dibuat dan dipisahkan oleh persyaratan fungsional. Dalam Desain, persyaratan fungsional terpenuhi.

Arsitektur Perangkat Lunak

Arsitektur berfungsi sebagai a blueprint for a system. Ini memberikan abstraksi untuk mengelola kompleksitas sistem dan membangun mekanisme komunikasi dan koordinasi antar komponen.

  • Ini mendefinisikan a structured solution untuk memenuhi semua persyaratan teknis dan operasional, sekaligus mengoptimalkan atribut kualitas umum seperti kinerja dan keamanan.

  • Lebih lanjut, ini melibatkan serangkaian keputusan penting tentang organisasi yang terkait dengan pengembangan perangkat lunak dan masing-masing keputusan ini dapat berdampak besar pada kualitas, pemeliharaan, kinerja, dan keberhasilan keseluruhan produk akhir. Keputusan ini terdiri dari -

    • Pemilihan elemen struktural dan antarmuka yang digunakan untuk menyusun sistem.

    • Perilaku seperti yang ditentukan dalam kolaborasi di antara elemen tersebut.

    • Komposisi elemen struktural dan perilaku tersebut menjadi subsistem yang besar.

    • Keputusan arsitektur selaras dengan tujuan bisnis.

    • Gaya arsitektur memandu organisasi.

Desain perangkat lunak

Desain perangkat lunak menyediakan a design planyang menjelaskan elemen-elemen sistem, bagaimana mereka cocok, dan bekerja sama untuk memenuhi kebutuhan sistem. Tujuan memiliki rencana desain adalah sebagai berikut -

  • Untuk menegosiasikan persyaratan sistem, dan untuk menetapkan harapan dengan pelanggan, pemasaran, dan personel manajemen.

  • Bertindak sebagai cetak biru selama proses pengembangan.

  • Pandu tugas implementasi, termasuk desain terperinci, pengkodean, integrasi, dan pengujian.

Itu datang sebelum desain rinci, pengkodean, integrasi, dan pengujian dan setelah analisis domain, analisis persyaratan, dan analisis risiko.

Tujuan Arsitektur

Tujuan utama dari arsitektur adalah untuk mengidentifikasi persyaratan yang mempengaruhi struktur aplikasi. Arsitektur yang tertata dengan baik mengurangi risiko bisnis yang terkait dengan pembangunan solusi teknis dan membangun jembatan antara persyaratan bisnis dan teknis.

Beberapa tujuan lainnya adalah sebagai berikut -

  • Tunjukkan struktur sistem, tetapi sembunyikan detail implementasinya.

  • Sadarilah semua kasus penggunaan dan skenario.

  • Cobalah untuk memenuhi kebutuhan berbagai pemangku kepentingan.

  • Tangani persyaratan fungsional dan kualitas.

  • Kurangi tujuan kepemilikan dan tingkatkan posisi pasar organisasi.

  • Meningkatkan kualitas dan fungsionalitas yang ditawarkan oleh sistem.

  • Meningkatkan kepercayaan eksternal baik dalam organisasi atau sistem.

Batasan

Arsitektur perangkat lunak masih merupakan disiplin ilmu yang muncul dalam rekayasa perangkat lunak. Ini memiliki batasan berikut -

  • Kurangnya alat dan cara standar untuk merepresentasikan arsitektur.

  • Kurangnya metode analisis untuk memprediksi apakah arsitektur akan menghasilkan implementasi yang memenuhi persyaratan.

  • Kurangnya kesadaran akan pentingnya desain arsitektur untuk pengembangan perangkat lunak.

  • Kurangnya pemahaman tentang peran arsitek perangkat lunak dan komunikasi yang buruk di antara para pemangku kepentingan.

  • Kurangnya pemahaman tentang proses desain, pengalaman desain dan evaluasi desain.

Peran Arsitek Perangkat Lunak

Arsitek Perangkat Lunak memberikan solusi yang dapat dibuat dan dirancang oleh tim teknis untuk keseluruhan aplikasi. Seorang arsitek perangkat lunak harus memiliki keahlian di bidang berikut -

Keahlian Desain

  • Ahli dalam desain perangkat lunak, termasuk beragam metode dan pendekatan seperti desain berorientasi objek, desain yang digerakkan oleh peristiwa, dll.

  • Pimpin tim pengembangan dan koordinasikan upaya pengembangan untuk integritas desain.

  • Harus dapat meninjau proposal desain dan tradeoff di antara mereka sendiri.

Keahlian Domain

  • Ahli dalam sistem yang sedang dikembangkan dan merencanakan evolusi perangkat lunak.

  • Membantu dalam proses investigasi kebutuhan, memastikan kelengkapan dan konsistensi.

  • Mengkoordinasikan definisi model domain untuk sistem yang sedang dikembangkan.

Keahlian Teknologi

  • Ahli tentang teknologi yang tersedia yang membantu dalam implementasi sistem.

  • Mengkoordinasikan pemilihan bahasa pemrograman, framework, platform, database, dll.

Keahlian Metodologis

  • Ahli dalam metodologi pengembangan perangkat lunak yang dapat diadopsi selama SDLC (Software Development Life Cycle).

  • Pilih pendekatan yang tepat untuk pengembangan yang membantu seluruh tim.

Peran Tersembunyi Arsitek Perangkat Lunak

  • Memfasilitasi pekerjaan teknis di antara anggota tim dan memperkuat hubungan kepercayaan dalam tim.

  • Spesialis informasi yang berbagi pengetahuan dan memiliki pengalaman luas.

  • Lindungi anggota tim dari kekuatan eksternal yang akan mengganggu mereka dan mengurangi nilai proyek.

Kiriman Arsitek

  • Serangkaian tujuan fungsional yang jelas, lengkap, konsisten, dan dapat dicapai

  • Deskripsi fungsional sistem, dengan setidaknya dua lapisan dekomposisi

  • Konsep sistem

  • Desain dalam bentuk sistem, dengan setidaknya dua lapisan dekomposisi

  • Sebuah gagasan tentang waktu, atribut operator, dan rencana implementasi dan operasi

  • Dokumen atau proses yang memastikan dekomposisi fungsional diikuti, dan bentuk antarmuka dikontrol

Atribut Kualitas

Kualitas adalah ukuran keunggulan atau keadaan bebas dari kekurangan atau cacat. Atribut kualitas adalah properti sistem yang terpisah dari fungsionalitas sistem.

Menerapkan atribut kualitas memudahkan untuk membedakan sistem yang baik dari yang buruk. Atribut adalah faktor keseluruhan yang memengaruhi perilaku waktu proses, desain sistem, dan pengalaman pengguna.

Mereka dapat diklasifikasikan sebagai -

Atribut Kualitas Statis

Mencerminkan struktur sistem dan organisasi, yang terkait langsung dengan arsitektur, desain, dan kode sumber. Mereka tidak terlihat oleh pengguna akhir, tetapi mempengaruhi biaya pengembangan dan pemeliharaan, misalnya: modularitas, kemampuan pengujian, pemeliharaan, dll.

Atribut Kualitas Dinamis

Merefleksikan perilaku sistem selama pelaksanaannya. Mereka secara langsung terkait dengan arsitektur sistem, desain, kode sumber, konfigurasi, parameter penerapan, lingkungan, dan platform.

Mereka terlihat oleh pengguna akhir dan ada saat runtime, misalnya throughput, ketahanan, skalabilitas, dll.

Skenario Kualitas

Skenario kualitas menentukan bagaimana mencegah kesalahan menjadi kegagalan. Mereka dapat dibagi menjadi enam bagian berdasarkan spesifikasi atributnya -

  • Source - Entitas internal atau eksternal seperti orang, perangkat keras, perangkat lunak, atau infrastruktur fisik yang menghasilkan stimulus.

  • Stimulus - Kondisi yang perlu diperhatikan saat masuk ke sistem.

  • Environment - Stimulus terjadi dalam kondisi tertentu.

  • Artifact - Seluruh sistem atau beberapa bagian seperti prosesor, saluran komunikasi, penyimpanan persisten, proses, dll.

  • Response - Suatu aktivitas yang dilakukan setelah datangnya stimulus seperti mendeteksi kesalahan, memulihkan dari kesalahan, menonaktifkan sumber peristiwa, dll.

  • Response measure - Harus mengukur respon yang terjadi sehingga persyaratan dapat diuji.

Atribut Kualitas Umum

Tabel berikut mencantumkan atribut kualitas umum yang harus dimiliki arsitektur perangkat lunak -

Kategori Atribut Kualitas Deskripsi
Kualitas Desain Integritas Konseptual Mendefinisikan konsistensi dan koherensi dari keseluruhan desain. Ini termasuk cara komponen atau modul dirancang.
Pemeliharaan Kemampuan sistem untuk mengalami perubahan dengan tingkat kemudahan.
Dapat digunakan kembali Mendefinisikan kemampuan komponen dan subsistem agar sesuai untuk digunakan dalam aplikasi lain.
Kualitas Run-time Interoperabilitas Kemampuan suatu sistem atau sistem yang berbeda untuk beroperasi dengan sukses dengan mengkomunikasikan dan bertukar informasi dengan sistem eksternal lain yang ditulis dan dijalankan oleh pihak eksternal.
Pengelolaan Menentukan seberapa mudah bagi administrator sistem untuk mengelola aplikasi.
Keandalan Kemampuan sistem untuk tetap beroperasi dari waktu ke waktu.
Skalabilitas Kemampuan sistem untuk menangani peningkatan beban tanpa memengaruhi kinerja sistem atau kemampuan untuk segera diperbesar.
Keamanan Kemampuan sistem untuk mencegah tindakan berbahaya atau tidak disengaja di luar penggunaan yang dirancang.
Performa Indikasi ketanggapan sistem untuk menjalankan tindakan apa pun dalam interval waktu tertentu.
Ketersediaan Menentukan proporsi waktu sistem berfungsi dan berfungsi. Ini dapat diukur sebagai persentase dari total waktu henti sistem selama periode yang telah ditentukan.
Kualitas Sistem Dukungan Kemampuan sistem untuk memberikan informasi berguna untuk mengidentifikasi dan menyelesaikan masalah jika gagal berfungsi dengan benar.
Testabilitas Mengukur seberapa mudahnya membuat kriteria pengujian untuk sistem dan komponennya.
Kualitas Pengguna Kegunaan Menentukan seberapa baik aplikasi memenuhi persyaratan pengguna dan konsumen dengan bersikap intuitif.
Kualitas Arsitektur Ketepatan Akuntabilitas untuk memenuhi semua persyaratan sistem.
Kualitas Non-runtime Portabilitas Kemampuan sistem untuk berjalan di bawah lingkungan komputasi yang berbeda.
Keutuhan Kemampuan untuk membuat komponen sistem yang dikembangkan secara terpisah bekerja sama dengan benar.
Modifikasi Kemudahan setiap sistem perangkat lunak dapat mengakomodasi perubahan pada perangkat lunaknya.
Atribut kualitas bisnis Biaya dan jadwal Biaya sistem sehubungan dengan waktu ke pasar, masa pakai proyek yang diharapkan & pemanfaatan warisan.
Kemampuan pemasaran Penggunaan sistem sehubungan dengan persaingan pasar.