Saya sedang mencari solusi baru yang sifatnya sangat modular dan ingin membuat struktur yang mendukung desain itu untuk memudahkan ekspansi di masa depan, pemisahan masalah yang jelas, perizinan berdasarkan modul, dll. Sebagian besar dari apa yang saya miliki ditemukan di web tentang aplikasi modular atau komposit UI-sentris, berfokus pada Silverlight, WPF, dll. Dalam kasus saya, saya mengembangkan aplikasi layanan WCF yang akan dikonsumsi oleh pengembang lain yang bekerja pada berbagai proyek UI.
Latar Belakang
Tujuan dari proyek saya adalah untuk menciptakan sumber logika bisnis / domain terpusat untuk mendukung beberapa aplikasi bisnis kami yang saat ini menduplikasi proses, aturan, dll. Dan sementara tidak semua manfaat modularitas akan tercapai, saya ingin memanfaatkan kesempatan untuk membangun kerangka kerja yang akan memanfaatkan bagian-bagian yang dapat kita manfaatkan.
Saya sudah memulai desain dengan melihat API yang diekspos oleh aplikasi layanan. Jelas bahwa layanan dapat dipisahkan sepanjang garis modular yang saya pertimbangkan. Misalnya, saya akan memiliki layanan FinanceService, InventoryService, PersonnelService, dll. Yang mengelompokkan operasi layanan saya untuk memberikan kohesi yang tinggi dalam API sambil menjaga sambungan tetap rendah sehingga klien hanya perlu mengonsumsi layanan yang berkaitan dengan aplikasi mereka.
Masuk akal bagi saya bahwa saya kemudian dapat memiliki modul terpisah untuk masing-masing layanan ini, seperti MyApp.Finance, MyApp.Inventory, My.Personnel dan sebagainya. Masalah lintas sektoral dan tipe bersama akan ada di majelis bersama MyApp. Dari sini saya sedikit terikat.
(Oh, saya harus menyebutkan bahwa saya akan menggunakan wadah IoC untuk Dependency Injection untuk menjaga aplikasi tetap digabungkan. Saya tidak akan menyebutkan yang mana karena saya tidak ingin membuka kotak Pandora!)
Di MyApp.ServiceHost, saya akan membuat file host layanan (.svc) yang sesuai dengan setiap modul, FinanceService.svc misalnya. Host layanan memerlukan nama layanan yang sesuai dengan informasi dalam file konfigurasi yang berisi antarmuka yang mendefinisikan kontrak layanan. Konfigurasi IoC kemudian digunakan untuk memetakan implementasi konkret dari antarmuka yang akan digunakan.
1. Haruskah lapisan layanan mengimplementasikan API dan mendelegasikan ke modul atau haruskah modul mandiri (dalam arti mengandung semua yang terkait dengan modul itu, termasuk implementasi layanan)?
Salah satu cara untuk mendekati masalah adalah memiliki "modul" MyApp.Services yang berisi implementasi kontrak layanan. Setiap kelas layanan hanya mendelegasikan ke kelas lain di modul yang sesuai yang berisi logika domain untuk operasi. Misalnya, kelas FinanceService WCF di MyApp.Services mendelegasikan ke antarmuka lain yang diimplementasikan dalam modul Keuangan untuk melaksanakan operasi. Ini akan memungkinkan saya untuk mempertahankan fasad layanan yang tipis dan 'plug-in' implementasi ke implementasi layanan dan menghilangkan kebutuhan modul untuk khawatir tentang WCF, misalnya.
Di sisi lain, mungkin lebih disukai untuk memiliki setiap modul mandiri karena memiliki antarmuka dan implementasinya. Host layanan merujuk ke antarmuka kontrak layanan yang ditemukan dalam modul dan IoC dikonfigurasi untuk menggunakan implementasi yang sesuai dari modul juga. Ini berarti bahwa menambahkan modul baru dapat dilakukan tanpa perubahan pada lapisan layanan selain menambahkan file .svc baru dan informasi konfigurasi IoC.
Saya sedang memikirkan dampaknya jika saya beralih dari standar WCF ke antarmuka layanan yang tenang atau mungkin pergi ke layanan RIA atau sesuatu. Jika setiap modul berisi implementasi kontrak layanan, maka saya harus membuat perubahan di setiap modul jika saya mengubah teknologi atau pendekatan layanan. Tetapi, jika fasad adalah modulnya sendiri, maka saya hanya perlu menukar bagian itu untuk melakukan perubahan. Modul-modul kemudian harus mengimplementasikan kontrak (antarmuka) yang berbeda, mungkin ditentukan dalam perakitan bersama ???
2. Apa cara terbaik untuk menangani sumber daya berbagi antar modul dan / atau dependensi antar modul?
Ambil, misalnya, operasi Penerimaan. Pada blush on pertama masuk akal bahwa ini masuk ke modul Persediaan karena menerima barang adalah fungsi persediaan. Namun, ada juga aspek keuangan yang mengharuskan kita menghasilkan Tanda Terima dan mengesahkan pembayaran.
Di satu sisi, saya akan berharap untuk menggunakan beberapa jenis peristiwa / pesan domain untuk mengkomunikasikan operasi. Modul Inventaris memunculkan GoodsReceivedEvent yang ditangani oleh modul Keuangan untuk menghasilkan Kwitansi dan memulai proses pembayaran. Namun, ini berarti bahwa modul Keuangan perlu tahu tentang item inventaris yang diterima. Saya hanya dapat merujuk mereka dengan ID tetapi bagaimana jika saya membutuhkan informasi tambahan untuk Kwitansi, seperti nama dan / atau deskripsi, biaya unit, dll? Apakah masuk akal bagi setiap modul untuk memiliki versi mereka sendiri dari item inventaris yang dirancang sesuai dengan kebutuhan modul itu? Dalam hal itu, modul Keuangan harus melakukan pencarian sendiri atas barang-barang inventaris ketika menangani GoodsReceivedEvent.
...
Saya menggunakan contoh ini dengan sengaja karena saya telah banyak bekerja dengan berbagai sistem ERP dan tahu mereka dirancang dengan jenis modularitas ini - saya hanya tidak tahu caranya. Saya juga tidak secara eksplisit menyebutkannya di atas, tetapi saya lebih memilih untuk mengikuti prinsip-prinsip Desain Domain Driven dalam merancang solusi dan percaya bahwa jenis modularitas ini pas untuk area tersebut.
Setiap bantuan membuat kepala saya melilit ini sangat dihargai.