Lihat, semasa saya menikmati perkhidmatan mikro sama seperti lelaki seterusnya, adakah saya fikir ia adalah pening kepala yang besar untuk ditangani dan nyahpepijat? ya. Tetapi, seni bina perkhidmatan mikro adalah topik yang hangat di kalangan pembangun dan perekrut yang saya akan keliru untuk tidak mengotak pasir projek berskala besar saya sendiri yang siap pengeluaran sambil mengekalkan kos yang rendah atau tidak wujud sebab hei, kita semua rosak.
Tahniah! Anda telah diupah di IceToMeetYou Inc. sebagai perunding dan mereka ingin meningkatkan perisian pengurusan perkapalan semasa mereka kepada penyelesaian yang lebih tersuai. IceToMeetYou Inc. ialah syarikat permulaan yang baru mendapat kira-kira $3B dolar dalam pembiayaan untuk produk mereka yang menjual kiub ais yang diimport kepada seorang lelaki yang terperangkap di padang pasir. Perisian pengurusan tugas semasa mereka terlalu kecil dan terhad dalam fungsinya untuk mengendalikan semua penghantaran masuk lelaki ini, panggil dia Dennis, perlu memastikan smoothienya sejuk. Mereka ingin membina beberapa sistem pengurusan tugas yang boleh mengendalikan berbilang pesanan masuk daripada Dennis hingga selesai, menetapkan pesanan kepada penguin pekerja mereka yang menghantar ais, menjejaki kemajuan penguin tersebut dan menerima pemberitahuan masa nyata tentang kemas kini status. Dengan ini, Ketua Pegawai Eksekutif berkata sila berasa bebas untuk bertanya apa-apa soalan yang boleh membantu membina projek ini. Kami akan melakukan perkara itu semasa kami mula memikirkan tentang pembinaan projek…
Untuk projek ini, kami akan menggunakan tindanan teknologi berikut:
Backback: Java Spring Boot kerana ia merupakan rangka kerja yang berkuasa untuk membina REST API dan perkhidmatan mikro, menawarkan pelbagai jenis alatan seperti penemuan perkhidmatan, penggunaan awan dan Kafka untuk sistem dipacu peristiwa.
Frontend: Sudut kerana rangka kerja front-end yang mantap dengan NgRx untuk pengurusan keadaan global
Pangkalan Data: MySQL/PostgreSQL (untuk data hubungan), MongoDB (untuk data tugas)
Kemas kini masa nyata: Kafka (untuk penstriman acara) dan WebSockets
Pengerahan: Docker dan Kubernetes untuk orkestra
Ujian: JUnit, Jest dan K6 (untuk ujian beban dan prestasi)
Tujuan utama di sini adalah untuk menunjukkan semua bahagian alih apabila memikirkan tentang aplikasi web. Walaupun senarai ini tidak lengkap, matlamatnya adalah untuk merangkumi banyak asas dalam bahasa Inggeris biasa supaya proses ini boleh diulangi dan tidak ada masalah apabila memikirkan tentang aplikasi perusahaan. Untuk setiap bahagian, saya akan mempamerkan setiap langkah daripada reka bentuk kepada penggunaan untuk lulus untuk V1 MVP melalui blog mendalam, demonstrasi kod, gambar rajah, proses pemikiran dan yang paling penting, sentiasa memastikan kami menyelesaikan masalah.
→ Prinsip Reka Bentuk: Memahami dan melaksanakan prinsip perkhidmatan mikro seperti kebebasan perkhidmatan, kebolehskalaan dan toleransi kesalahan
→ Pengasingan Perkhidmatan: Bagaimana untuk mengasingkan diri ke kawasan kebimbangannya sendiri,
→ Komunikasi Antara Perkhidmatan: Memilih strategi komunikasi (REST API, Kafka, WebSockets) dan mengendalikan ketekalan data merentas perkhidmatan.
→ Pembangunan Perkhidmatan: Melaksanakan perkhidmatan individu menggunakan Spring Boot, mengendalikan titik akhir RESTful dan memastikan pengasingan kebimbangan yang betul.
→ Pengesahan & Keselamatan: Menggunakan JWT, OAuth dan Spring Security untuk pengesahan pengguna selamat dan kawalan akses berasaskan peranan.
→ Pengurusan Pangkalan Data: Menyediakan pangkalan data hubungan (MySQL/PostgreSQL) dan NoSQL (MongoDB), mengoptimumkan storan data untuk perkhidmatan mikro dan mengendalikan migrasi data.
→ Reka Bentuk Antara Muka Pengguna: Mencipta pengalaman pengguna yang lancar menggunakan Angular
→ Pengurusan Negeri: Mengendalikan keadaan aplikasi dengan NgRx untuk interaksi pengguna yang konsisten dan reaktif.
→ Penyepaduan API: Menyambungkan hujung hadapan Sudut ke perkhidmatan hujung belakang Spring Boot melalui API RESTful dan menguruskan pemindahan data dengan selamat.
→ Websockets & Event Streaming: Melaksanakan WebSockets untuk kemas kini segera dan Kafka untuk penstriman acara yang boleh dipercayai antara perkhidmatan.
→ Pemberitahuan Tolak: Menyampaikan kemas kini masa nyata kepada pengguna, memastikan pengedaran mesej yang cekap tanpa perkhidmatan yang berlebihan.
→ Ujian Beban: Menggunakan K6 untuk menilai sistem di bawah beban, mengenal pasti kesesakan dan mengoptimumkan perkhidmatan mikro untuk prestasi.
→ Pengelogan & Pemantauan: Melaksanakan pengelogan dengan ELK atau alatan alternatif, menjejak kesihatan aplikasi dan menyediakan amaran untuk kegagalan kritikal.
→ Kontena Dengan Docker: Membina imej Docker untuk setiap perkhidmatan, mewujudkan persekitaran masa jalan yang konsisten untuk penskalaan yang lebih mudah.
→ Orkestrasi Dengan Kubernetes: Menggunakan Kubernetes untuk mengurus penempatan, penskalaan automatik, pengimbangan beban dan daya tahan.
→ Cloud Hosting: Perkhidmatan pengehosan pada platform awan (AWS, Azure, GCP), meliputi aspek seperti kecekapan kos, keselamatan dan kebolehpercayaan.
Sebagai permulaan, ia adalah kotak pasir jadi projek ini dibina untuk pembelajaran dan demonstrasi. Nota besar di sini: Ini adalah penyelesaian kejuruteraan 100% yang dibina dari awal oleh seorang lelaki yang duduk di ruang bawah tanah. Ia tidak begitu serius.
Saya akan mengemas kini dan mengusahakan projek ini setiap hari jadi harapkan kemas kini yang kerap!
Ini juga merupakan latihan tentang perkembangan dalam persekitaran pasukan, jadi kami akan berusaha dalam "pecut" untuk mencapai matlamat kami dengan retrospektif (dengan, saya rasa, saya sendiri?) untuk melihat apa yang berlaku dengan betul, apa telah tersilap, apakah penyekat yang kami temui dan bagaimana kami boleh menyelesaikannya. Saya akan mengemas kini melakukan retro pantas setiap 5 siaran atau lebih.
SATU LAGI…Saya sentiasa kemaruk untuk mendapatkan maklum balas. Jika ada sesuatu yang tidak masuk akal atau kurang jelas, beritahu saya dalam ulasan.
Jadi, sudah lewat, Sprint 1 bermula esok, berpegang pada topi anda, ia akan menjadi hari yang panjang…
Atas ialah kandungan terperinci Membina Aplikasi Perkhidmatan Mikro Boleh Skala dengan Java Spring Boot dan Angular. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!