Rumah Java javaTutorial Idea dan amalan seni bina perkhidmatan mikro Spring Cloud

Idea dan amalan seni bina perkhidmatan mikro Spring Cloud

Jun 22, 2023 am 08:34 AM
spring cloud berlatih Seni bina perkhidmatan mikro

Dengan kemajuan pesat teknologi Internet, seni bina perkhidmatan mikro, sebagai model seni bina perisian baharu, telah mula menarik perhatian meluas. Spring Cloud ialah salah satu rangka kerja mikroperkhidmatan sumber terbuka yang paling banyak digunakan. Ia menggunakan ciri-ciri cemerlang Spring Boot untuk membantu pembangun dengan cepat membina aplikasi perkhidmatan mikro berskala, berprestasi tinggi, sangat tersedia dan mudah diurus. Artikel ini akan memperkenalkan idea dan amalan seni bina perkhidmatan mikro Spring Cloud.

1. Pengenalan kepada seni bina perkhidmatan mikro

Seni bina perkhidmatan mikro ialah seni bina sistem teragih yang membahagikan aplikasi tunggal yang kompleks kepada berbilang perkhidmatan kecil. Setiap perkhidmatan mikro mewakili unit berfungsi aplikasi, dan setiap perkhidmatan boleh digunakan, dinaik taraf, dikembangkan dan diselenggara secara bebas, dengan itu meningkatkan kebolehskalaan, keanjalan dan toleransi kesalahan sistem. Pada masa yang sama, seni bina perkhidmatan mikro menggunakan mekanisme komunikasi ringan untuk menjadikan komunikasi antara perkhidmatan lebih mudah, lebih pantas dan lebih dipercayai.

2. Idea seni bina perkhidmatan mikro Spring Cloud

Spring Cloud ialah rangka kerja mikro berasaskan Spring Boot Ia menyediakan pelbagai komponen perkhidmatan mikro, seperti pusat pendaftaran perkhidmatan dan pusat konfigurasi. pengimbangan beban, pemutus litar, get laluan API, dsb., boleh membantu pembangun membina aplikasi perkhidmatan mikro dengan cepat.

  1. Pendaftaran dan penemuan perkhidmatan

Spring Cloud menyediakan dua pusat pendaftaran perkhidmatan, Eureka dan Konsul. Pembekal perkhidmatan mendaftarkan maklumat perkhidmatannya ke pusat pendaftaran perkhidmatan apabila ia bermula, dan pengguna perkhidmatan boleh menanyakan contoh perkhidmatan yang tersedia melalui pusat pendaftaran perkhidmatan. Pusat pendaftaran perkhidmatan juga menyediakan mekanisme degupan jantung dan strategi pengimbangan beban.

  1. Pusat Konfigurasi

Spring Cloud Config ialah pusat konfigurasi teragih yang disediakan oleh Spring Cloud, yang boleh merealisasikan pengurusan terpusat dan kemas kini konfigurasi yang dinamik. Pembangun hanya perlu meletakkan fail konfigurasi aplikasi di pusat konfigurasi untuk mencapai konfigurasi dinamik dan kemas kini aplikasi.

  1. Pengimbangan Beban

Spring Cloud menyediakan dua komponen pengimbangan beban: Ribbon dan Feign. Ribbon ialah pengimbang beban sisi klien berdasarkan HTTP dan TCP yang mengurus pengimbangan beban dan failover secara automatik. Feign ialah klien HTTP deklaratif yang menukar permintaan HTTP kepada panggilan kaedah Java, memudahkan proses pengekodan panggilan perkhidmatan.

  1. Pemutus litar

Spring Cloud menyediakan pemutus litar Hystrix, yang boleh merealisasikan kemerosotan perkhidmatan dan pemutus litar. Apabila perkhidmatan gagal, Hystrix boleh bertukar secara automatik kepada perkhidmatan sandaran atau kembali kepada nilai lalai untuk memastikan ketersediaan dan kestabilan sistem.

  1. API Gateway

Spring Cloud menyediakan gerbang API Zuul, yang boleh menyediakan masuk dan keluar bersatu untuk perkhidmatan mikro. Zuul boleh melaksanakan penghalaan, penapisan, pengimbangan beban, pengendalian pengecualian dan fungsi lain, yang boleh meningkatkan keselamatan, kebolehselenggaraan dan kebolehskalaan sistem.

3. Amalan seni bina perkhidmatan mikro Spring Cloud

Berikut mengambil sistem pusat beli-belah dalam talian yang mudah sebagai contoh untuk memperkenalkan cara menggunakan Spring Cloud untuk membina aplikasi perkhidmatan mikro.

  1. Buat pusat pendaftaran perkhidmatan

Gunakan Eureka untuk mencipta pusat pendaftaran perkhidmatan. Tambahkan kebergantungan berikut pada projek:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
Salin selepas log masuk

Tambahkan anotasi @EnableEurekaServer ke kelas permulaan aplikasi untuk memulakan pusat pendaftaran perkhidmatan Eureka.

  1. Buat perkhidmatan produk

Perkhidmatan produk menyediakan fungsi pertanyaan untuk maklumat produk. Cipta aplikasi web standard menggunakan Spring MVC. Tambahkan kebergantungan berikut dalam fail pom.xml aplikasi:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
Salin selepas log masuk

Tambah anotasi @EnableDiscoveryClient dalam kelas permulaan aplikasi untuk mendaftarkan perkhidmatan ke pusat pendaftaran perkhidmatan Eureka.

  1. Buat perkhidmatan pesanan

Perkhidmatan pesanan menyediakan fungsi penciptaan pesanan dan pertanyaan. Cipta aplikasi web standard menggunakan Spring MVC. Tambahkan kebergantungan berikut dalam fail pom.xml aplikasi:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    <dependency>
Salin selepas log masuk

Tambah anotasi @EnableDiscoveryClient dalam kelas permulaan aplikasi untuk mendaftarkan perkhidmatan ke pusat pendaftaran perkhidmatan Eureka.

  1. Gunakan Ribbon untuk mencapai pengimbangan beban

Apabila memanggil perkhidmatan produk dalam perkhidmatan pesanan, anda boleh menggunakan Ribbon untuk mencapai pengimbangan beban. Tambahkan kebergantungan berikut dalam fail pom.xml aplikasi:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
Salin selepas log masuk

Buat kelas konfigurasi Ribbon dan anotasi objek RestTemplate dengan anotasi @LoadBalanced. Apabila memanggil perkhidmatan produk dalam perkhidmatan pesanan, anda hanya perlu menggunakan objek RestTemplate.

  1. Gunakan Hystrix untuk melaksanakan pemutus litar

Apabila memanggil perkhidmatan produk dalam perkhidmatan pesanan, kegagalan mungkin berlaku. Untuk memastikan ketersediaan dan kestabilan perkhidmatan pesanan, Hystrix boleh digunakan untuk melaksanakan pemutus litar. Tambahkan kebergantungan berikut dalam fail pom.xml aplikasi:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
Salin selepas log masuk

Buat kelas konfigurasi Hystrix dan gunakan anotasi @HystrixCommand untuk menganotasi kaedah perkhidmatan. Apabila kaedah perkhidmatan gagal, Hystrix akan bertukar secara automatik kepada perkhidmatan ganti atau kembali kepada nilai lalai.

  1. Gunakan Zuul untuk melaksanakan get laluan API

Gunakan Zuul untuk melaksanakan get laluan API dalam pesanan perkhidmatan dan perkhidmatan produk. Tambahkan kebergantungan berikut dalam fail pom.xml aplikasi:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
Salin selepas log masuk

Buat kelas konfigurasi Zuul dan gunakan anotasi @EnableZuulProxy untuk mendayakan proksi Zuul. Konfigurasikan peraturan penghalaan dan penapis dalam fail konfigurasi.

Di atas adalah langkah utama untuk membina aplikasi perkhidmatan mikro menggunakan Spring Cloud.

4

Spring Cloud ialah rangka kerja perkhidmatan mikro berdasarkan Spring Boot Ia menyediakan pelbagai komponen perkhidmatan mikro untuk membantu pembangun dengan cepat membina aplikasi perkhidmatan mikro berskala, berprestasi tinggi, sangat tersedia dan mudah diurus. Artikel ini memperkenalkan idea dan amalan seni bina perkhidmatan mikro Spring Cloud, dengan harapan dapat membantu pembangun. Pada masa yang sama, walaupun seni bina perkhidmatan mikro membawa banyak faedah, ia juga memerlukan pembangun untuk melaksanakan lebih banyak kerja reka bentuk dan pembangunan untuk mencapai kejayaan projek.

Atas ialah kandungan terperinci Idea dan amalan seni bina perkhidmatan mikro Spring Cloud. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menghentikan Outlook daripada menambah acara secara automatik pada kalendar saya Bagaimana untuk menghentikan Outlook daripada menambah acara secara automatik pada kalendar saya Feb 26, 2024 am 09:49 AM

Sebagai aplikasi pengurus e-mel, Microsoft Outlook membenarkan kami menjadualkan acara dan janji temu. Ia membolehkan kami kekal teratur dengan menyediakan alatan untuk mencipta, mengurus dan menjejaki aktiviti ini (juga dipanggil acara) dalam aplikasi Outlook. Walau bagaimanapun, kadangkala acara yang tidak diingini ditambahkan pada kalendar dalam Outlook, yang menimbulkan kekeliruan untuk pengguna dan menghantar spam pada kalendar. Dalam artikel ini, kami akan meneroka pelbagai senario dan langkah yang boleh membantu kami menghalang Outlook daripada menambahkan acara secara automatik pada kalendar saya. Acara Outlook – Gambaran keseluruhan ringkas acara Outlook adalah serba boleh dan mempunyai banyak ciri berguna seperti berikut: Penyepaduan Kalendar: Dalam Outlook

Perkongsian amalan kumpulan stesen CMS Dreamweaver Perkongsian amalan kumpulan stesen CMS Dreamweaver Mar 18, 2024 am 10:18 AM

Perkongsian Amalan Kumpulan Dream Weaver CMS Station Dalam beberapa tahun kebelakangan ini, dengan perkembangan pesat Internet, pembinaan laman web menjadi semakin penting. Apabila membina berbilang tapak web, teknologi kumpulan tapak telah menjadi kaedah yang sangat berkesan. Di antara banyak alat pembinaan laman web, Dreamweaver CMS telah menjadi pilihan pertama ramai peminat laman web kerana fleksibiliti dan kemudahan penggunaannya. Artikel ini akan berkongsi beberapa pengalaman praktikal tentang kumpulan stesen CMS Dreamweaver, serta beberapa contoh kod khusus, dengan harapan dapat memberikan sedikit bantuan kepada pembaca yang meneroka teknologi kumpulan stesen. 1. Apakah kumpulan stesen Dreamweaver CMS? CMS Penenun Impian

Amalan Pengekodan PHP: Menolak Alternatif kepada Penyata Goto Amalan Pengekodan PHP: Menolak Alternatif kepada Penyata Goto Mar 28, 2024 pm 09:24 PM

Amalan Pengekodan PHP: Keengganan Menggunakan Alternatif untuk Mendapatkan Pernyataan Dalam beberapa tahun kebelakangan ini, dengan pengemaskinian dan lelaran berterusan bahasa pengaturcaraan, pengaturcara telah mula memberi lebih perhatian kepada spesifikasi pengekodan dan amalan terbaik. Dalam pengaturcaraan PHP, pernyataan goto telah wujud sebagai pernyataan aliran kawalan untuk masa yang lama, tetapi dalam aplikasi praktikal ia sering membawa kepada penurunan kebolehbacaan dan kebolehselenggaraan kod. Artikel ini akan berkongsi beberapa alternatif untuk membantu pembangun enggan menggunakan pernyataan goto dan meningkatkan kualiti kod. 1. Mengapa enggan menggunakan pernyataan goto? Pertama, mari kita fikirkan mengapa

Perbincangan mendalam tentang prinsip dan amalan rangka kerja Struts Perbincangan mendalam tentang prinsip dan amalan rangka kerja Struts Feb 18, 2024 pm 06:10 PM

Analisis prinsip dan penerokaan praktikal rangka kerja Struts Sebagai rangka kerja MVC yang biasa digunakan dalam pembangunan JavaWeb, rangka kerja Struts mempunyai corak reka bentuk dan skalabiliti yang baik dan digunakan secara meluas dalam pembangunan aplikasi peringkat perusahaan. Artikel ini akan menganalisis prinsip rangka kerja Struts dan menerokanya dengan contoh kod sebenar untuk membantu pembaca memahami dan menggunakan rangka kerja itu dengan lebih baik. 1. Analisis prinsip rangka kerja Struts 1. Seni bina MVC Rangka kerja Struts adalah berdasarkan MVC (Model-View-Con

Amalan Terbaik untuk Pengurusan Trafik dengan Golang Amalan Terbaik untuk Pengurusan Trafik dengan Golang Mar 07, 2024 am 08:27 AM

Golang ialah bahasa pengaturcaraan yang berkuasa dan cekap yang digunakan secara meluas untuk membina perkhidmatan dan aplikasi web. Dalam perkhidmatan rangkaian, pengurusan trafik adalah bahagian penting Ia boleh membantu kami mengawal dan mengoptimumkan penghantaran data pada rangkaian dan memastikan kestabilan dan prestasi perkhidmatan. Artikel ini akan memperkenalkan amalan terbaik untuk pengurusan trafik menggunakan Golang dan memberikan contoh kod khusus. 1. Gunakan pakej bersih Golang untuk pengurusan trafik asas Pakej bersih Golang menyediakan cara untuk mengendalikan data rangkaian.

Cabaran dan Peluang Seni Bina Perkhidmatan Mikro PHP: Meneroka Wilayah Belum Dipetakan Cabaran dan Peluang Seni Bina Perkhidmatan Mikro PHP: Meneroka Wilayah Belum Dipetakan Feb 19, 2024 pm 07:12 PM

Seni bina perkhidmatan mikro PHP telah menjadi cara yang popular untuk membina aplikasi yang kompleks dan mencapai kebolehskalaan dan ketersediaan yang tinggi. Walau bagaimanapun, penggunaan perkhidmatan mikro juga membawa cabaran dan peluang yang unik. Artikel ini akan menyelidiki aspek seni bina perkhidmatan mikro PHP ini untuk membantu pembangun membuat keputusan termaklum apabila meneroka wilayah yang belum dipetakan. Kerumitan sistem teragih yang mencabar: Seni bina Microservices menguraikan aplikasi kepada perkhidmatan yang digandingkan secara longgar, yang meningkatkan kerumitan sedia ada sistem teragih. Contohnya, komunikasi antara perkhidmatan, pengendalian kegagalan dan kependaman rangkaian semuanya menjadi faktor yang perlu dipertimbangkan. Tadbir urus perkhidmatan: Menguruskan sejumlah besar perkhidmatan mikro memerlukan mekanisme untuk menemui, mendaftar, menghalakan dan mengurus perkhidmatan ini. Ini melibatkan membina dan mengekalkan rangka kerja tadbir urus perkhidmatan, yang boleh intensif sumber. Penyelesaian masalah: dalam perkhidmatan mikro

Panduan praktikal untuk pembangunan jauh menggunakan PyCharm Panduan praktikal untuk pembangunan jauh menggunakan PyCharm Feb 25, 2024 pm 07:18 PM

Menggunakan PyCharm untuk pembangunan jauh ialah cara yang cekap yang membolehkan pembangun mengedit, nyahpepijat dan menjalankan kod dengan mudah pada pelayan jauh dalam persekitaran setempat. Artikel ini akan memperkenalkan cara menggunakan PyCharm untuk amalan pembangunan jauh, dan menggabungkannya dengan contoh kod khusus untuk membantu pembaca memahami dan menggunakan teknologi ini dengan lebih baik. Apakah PyCharmPyCharm ialah persekitaran pembangunan bersepadu (IDE) Python yang dibangunkan oleh JetBrains, yang menyediakan pelbagai fungsi dan alatan untuk membantu

Rangka kerja PHP terbaik untuk seni bina perkhidmatan mikro: prestasi dan kecekapan Rangka kerja PHP terbaik untuk seni bina perkhidmatan mikro: prestasi dan kecekapan Jun 03, 2024 pm 08:27 PM

Rangka Kerja Mikroperkhidmatan PHP Terbaik: Symfony: Fleksibiliti, prestasi dan kebolehskalaan, menyediakan set komponen untuk membina perkhidmatan mikro. Laravel: menumpukan pada kecekapan dan kebolehujian, menyediakan antara muka API yang bersih dan menyokong perkhidmatan tanpa kewarganegaraan. Slim: minimalis, pantas, menyediakan sistem penghalaan mudah dan pembina bahagian tengah pilihan, sesuai untuk membina API berprestasi tinggi.

See all articles