Rumah Java javaTutorial Amalan mikro perkhidmatan elegan Spring Cloud

Amalan mikro perkhidmatan elegan Spring Cloud

Jun 22, 2023 pm 12:31 PM
perkhidmatan mikro spring cloud rahmat

Dengan perkembangan Internet, seni bina perkhidmatan mikro menjadi semakin popular di kalangan syarikat Internet. Spring Cloud menyediakan penyelesaian microservice yang lengkap berdasarkan Spring Boot. Artikel ini akan memperkenalkan cara menggunakan rangka kerja Awan Musim Bunga untuk mengamalkan perkhidmatan mikro.

1. Gambaran keseluruhan seni bina perkhidmatan mikro

Apa yang dipanggil seni bina perkhidmatan mikro adalah untuk memisahkan aplikasi kepada beberapa unit perkhidmatan autonomi yang lebih kecil dan menggunakan mekanisme komunikasi yang ringan antara perkhidmatan perkhidmatan boleh dibina, digunakan, diuji dan diskalakan secara bebas. Kelebihan seni bina perkhidmatan mikro ialah ia boleh meningkatkan produktiviti pasukan dan keanjalan dan kebolehskalaan sistem.

2. Rangka kerja perkhidmatan mikro Spring Cloud

Spring Cloud ialah penyelesaian perkhidmatan mikro bagi keluarga Spring. Ia menyediakan kit alat yang lengkap dan kaya berdasarkan Spring Boot. Spring Cloud menggunakan berbilang komponen (seperti Eureka, Zuul, Hystrix, dll.) untuk membina persekitaran perkhidmatan mikro yang lengkap. Berikut ialah komponen utama Spring Cloud:

1 Eureka: melaksanakan pendaftaran dan penemuan perkhidmatan, menyediakan pusat pendaftaran perkhidmatan
2: melaksanakan komunikasi antara perkhidmatan, memudahkan panggilan RESTful; >3. Hystrix: Laksanakan fungsi seperti pemutus litar dan penurunan taraf, meningkatkan kekukuhan sistem
4: Menyediakan perkhidmatan gerbang API untuk mencapai pengimbangan beban
5 menyediakan pusat konfigurasi yang diedarkan.

3. Amalan Perkhidmatan Mikro Awan Musim Bunga

Berikut ialah contoh mudah untuk menunjukkan cara menggunakan rangka kerja Awan Musim Bunga untuk membina perkhidmatan mikro. Contoh ini mengandungi dua perkhidmatan: perkhidmatan pengguna dan perkhidmatan pesanan. Perkhidmatan pengguna menyediakan operasi CRUD untuk maklumat pengguna, dan perkhidmatan pesanan perlu menghubungi perkhidmatan pengguna untuk mendapatkan maklumat pengguna.

1. Buat pusat pendaftaran perkhidmatan

Pertama, kami wujudkan pusat pendaftaran perkhidmatan untuk mendaftar dan menemui perkhidmatan. Buat projek Spring Boot untuk melaksanakan pendaftaran perkhidmatan dan penemuan melalui komponen Eureka Spring Cloud.

Tambah kebergantungan:

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

Tambah anotasi @EnableEurekaServer pada kelas permulaan.

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {

  public static void main(String[] args) {
    SpringApplication.run(EurekaServerApplication.class, args);
  }
}
Salin selepas log masuk

Dalam fail konfigurasi application.properties, konfigurasikan maklumat berkaitan Pelayan Eureka.

2. Cipta perkhidmatan pengguna

Buat perkhidmatan pengguna untuk menyediakan operasi CRUD untuk maklumat pengguna. Buat projek Spring Boot untuk melaksanakan komunikasi antara perkhidmatan melalui komponen Feign Spring Cloud.

Tambah kebergantungan:

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

Tambah anotasi @EnableFeignClients pada kelas permulaan.

@SpringBootApplication
@EnableFeignClients
public class UserServiceApplication {

  public static void main(String[] args) {
    SpringApplication.run(UserServiceApplication.class, args);
  }
}
Salin selepas log masuk

Buat antara muka Perkhidmatan Pengguna dan tentukan operasi CRUD untuk maklumat pengguna. Gunakan anotasi @FeignClient untuk menentukan perkhidmatan yang akan dipanggil. Dalam antara muka ini, panggilan ke OrderService ditakrifkan.

@FeignClient(name = "order-service", fallback = OrderServiceFallback.class)
public interface OrderService {
  
  @GetMapping("/user/{userId}")
  UserDTO getUserById(@PathVariable("userId") Long userId);
  
  @PostMapping("/user")
  UserDTO createUser(@RequestBody UserDTO user);
  
  @PutMapping("/user")
  UserDTO updateUser(@RequestBody UserDTO user);
  
  @DeleteMapping("/user/{userId}")
  void deleteUser(@PathVariable("userId") Long userId);
}
Salin selepas log masuk

Dalam fail konfigurasi application.properties, konfigurasikan maklumat berkaitan Eureka dan tamat masa Feign.

3. Buat perkhidmatan pesanan

Buat perkhidmatan pesanan untuk memproses maklumat pesanan. Buat projek Spring Boot dan gunakan komponen Spring Cloud's Ribbon dan Feign untuk memanggil perkhidmatan pengguna dan mencapai pengimbangan beban antara perkhidmatan.

Tambah kebergantungan:


  org.springframework.cloud
  spring-cloud-starter-ribbon


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

Tambah anotasi @EnableFeignClients dan @EnableDiscoveryClient pada kelas permulaan.

@SpringBootApplication
@EnableFeignClients
@EnableDiscoveryClient
public class OrderServiceApplication {

  public static void main(String[] args) {
    SpringApplication.run(OrderServiceApplication.class, args);
  }
}
Salin selepas log masuk

Buat antara muka OrderService dan tentukan operasi CRUD untuk maklumat pesanan. Dalam antara muka ini, panggilan ke UserService ditakrifkan.

public interface OrderService {

  @GetMapping("/order/{orderId}")
  OrderDTO getOrderById(@PathVariable("orderId") Long orderId);

  @PostMapping("/order")
  OrderDTO createOrder(@RequestBody OrderDTO order);

  @PutMapping("/order")
  OrderDTO updateOrder(@RequestBody OrderDTO order);

  @DeleteMapping("/order/{orderId}")
  void deleteOrder(@PathVariable("orderId") Long orderId);
}
Salin selepas log masuk

Dalam kelas pelaksanaan, gunakan @Autowired untuk menyuntik antara muka UserService.

@Service
public class OrderServiceImpl implements OrderService {

  @Autowired
  private UserService userService;

  // ...
}
Salin selepas log masuk

Dalam fail konfigurasi application.properties, konfigurasikan maklumat berkaitan Eureka dan kaedah pengimbangan beban Ribbon.

4 Ringkasan

Artikel ini memperkenalkan cara membina persekitaran berdasarkan seni bina perkhidmatan mikro melalui rangka kerja Spring Cloud, dan menggunakan contoh mudah untuk menunjukkan cara melaksanakan pendaftaran dan penemuan perkhidmatan, perkhidmatan Inter. -komunikasi, pengimbangan beban dan fungsi lain. Sudah tentu, ini hanyalah titik permulaan yang mudah, dan lebih banyak senario serta isu perlu dipertimbangkan dalam aplikasi praktikal. Hanya melalui pembelajaran dan amalan yang lebih mendalam, kebolehpercayaan dan skalabiliti sistem boleh dipertingkatkan dengan lebih baik.

Atas ialah kandungan terperinci Amalan mikro perkhidmatan elegan 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
4 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)

Rangka Kerja PHP dan Perkhidmatan Mikro: Penerapan dan Pengkontenaan Asli Awan Rangka Kerja PHP dan Perkhidmatan Mikro: Penerapan dan Pengkontenaan Asli Awan Jun 04, 2024 pm 12:48 PM

Faedah menggabungkan rangka kerja PHP dengan perkhidmatan mikro: Kebolehskalaan: Memanjangkan aplikasi dengan mudah, menambah ciri baharu atau mengendalikan lebih banyak beban. Fleksibiliti: Perkhidmatan mikro digunakan dan diselenggara secara bebas, menjadikannya lebih mudah untuk membuat perubahan dan kemas kini. Ketersediaan tinggi: Kegagalan satu perkhidmatan mikro tidak menjejaskan bahagian lain, memastikan ketersediaan yang lebih tinggi. Kes praktikal: Menggunakan perkhidmatan mikro menggunakan Laravel dan Kubernetes Langkah: Buat projek Laravel. Tentukan pengawal perkhidmatan mikro. Buat fail Docker. Buat manifes Kubernetes. Sebarkan perkhidmatan mikro. Uji perkhidmatan mikro.

Bagaimanakah rangka kerja Java menyokong penskalaan mendatar perkhidmatan mikro? Bagaimanakah rangka kerja Java menyokong penskalaan mendatar perkhidmatan mikro? Jun 04, 2024 pm 04:34 PM

Rangka kerja Java menyokong pengembangan mendatar perkhidmatan mikro Kaedah khusus termasuk: Spring Cloud menyediakan Ribbon dan Feign untuk pengimbangan beban sisi pelayan dan klien. NetflixOSS menyediakan Eureka dan Zuul untuk melaksanakan penemuan perkhidmatan, pengimbangan beban dan failover. Kubernetes memudahkan penskalaan mendatar dengan penskalaan automatik, pemeriksaan kesihatan dan mulakan semula automatik.

Cipta sistem teragih menggunakan rangka kerja perkhidmatan mikro Golang Cipta sistem teragih menggunakan rangka kerja perkhidmatan mikro Golang Jun 05, 2024 pm 06:36 PM

Cipta sistem teragih menggunakan rangka kerja mikro perkhidmatan Golang: Pasang Golang, pilih rangka kerja mikroperkhidmatan (seperti Gin), cipta perkhidmatan mikro Gin, tambah titik akhir untuk menggunakan perkhidmatan mikro, bina dan jalankan aplikasi, buat pesanan dan inventori perkhidmatan mikro, gunakan titik akhir untuk memproses pesanan dan inventori Gunakan sistem pemesejan seperti Kafka untuk menyambung perkhidmatan mikro Gunakan perpustakaan sarama untuk menghasilkan dan menggunakan maklumat pesanan

Apakah cabaran dalam membina seni bina perkhidmatan mikro menggunakan rangka kerja Java? Apakah cabaran dalam membina seni bina perkhidmatan mikro menggunakan rangka kerja Java? Jun 02, 2024 pm 03:22 PM

Membina seni bina perkhidmatan mikro menggunakan rangka kerja Java melibatkan cabaran berikut: Komunikasi antara perkhidmatan: Pilih mekanisme komunikasi yang sesuai seperti REST API, HTTP, gRPC atau baris gilir mesej. Pengurusan data teragih: Kekalkan konsistensi data dan elakkan transaksi teragih. Penemuan dan pendaftaran perkhidmatan: Sepadukan mekanisme seperti SpringCloudEureka atau HashiCorpConsul. Pengurusan konfigurasi: Gunakan SpringCloudConfigServer atau HashiCorpVault untuk mengurus konfigurasi secara berpusat. Pemantauan dan pemerhatian: Integrasikan Prometheus dan Grafana untuk pemantauan penunjuk, dan gunakan SpringBootActuator untuk menyediakan penunjuk operasi.

Pemantauan seni bina perkhidmatan mikro dan membimbangkan dalam rangka kerja Java Pemantauan seni bina perkhidmatan mikro dan membimbangkan dalam rangka kerja Java Jun 02, 2024 pm 12:39 PM

Pemantauan dan amaran seni bina mikroperkhidmatan dalam rangka kerja Java Dalam seni bina perkhidmatan mikro, pemantauan dan amaran adalah penting untuk memastikan kesihatan sistem dan operasi yang boleh dipercayai. Artikel ini akan memperkenalkan cara menggunakan rangka kerja Java untuk melaksanakan pemantauan dan membimbangkan seni bina perkhidmatan mikro. Kes praktikal: Gunakan SpringBoot+Prometheus+Alertmanager1. Integrasikan Prometheus@ConfigurationpublicclassPrometheusConfig{@BeanpublicSpringBootMetricsCollectorsspringBootMetric.

Rangka kerja PHP dan perkhidmatan mikro: ketekalan data dan pengurusan transaksi Rangka kerja PHP dan perkhidmatan mikro: ketekalan data dan pengurusan transaksi Jun 02, 2024 pm 04:59 PM

Dalam seni bina perkhidmatan mikro PHP, ketekalan data dan pengurusan transaksi adalah penting. Rangka kerja PHP menyediakan mekanisme untuk melaksanakan keperluan ini: gunakan kelas transaksi, seperti DB::transaction dalam Laravel, untuk menentukan sempadan transaksi. Gunakan rangka kerja ORM, seperti Doktrin, untuk menyediakan operasi atom seperti kaedah lock() untuk mengelakkan ralat konkurensi. Untuk urus niaga teragih, pertimbangkan untuk menggunakan pengurus transaksi teragih seperti Saga atau 2PC. Sebagai contoh, urus niaga digunakan dalam senario kedai dalam talian untuk memastikan konsistensi data apabila menambah pada troli beli-belah. Melalui mekanisme ini, rangka kerja PHP mengurus urus niaga dan konsistensi data dengan berkesan, meningkatkan keteguhan aplikasi.

Amalan Terbaik untuk Seni Bina Perkhidmatan Mikro Java Amalan Terbaik untuk Seni Bina Perkhidmatan Mikro Java Jun 01, 2024 pm 06:58 PM

Amalan seni bina perkhidmatan mikro Java terbaik: Gunakan rangka kerja perkhidmatan mikro: Sediakan struktur dan alatan, seperti SpringBoot, Quarkus, Micronaut. Gunakan RESTfulAPI: Menyediakan antara muka yang konsisten dan standard untuk komunikasi silang perkhidmatan. Laksanakan mekanisme pemutus litar: menangani kegagalan perkhidmatan dengan anggun dan mencegah ralat berlatarkan. Gunakan pengesanan teragih: Pantau permintaan dan kebergantungan merentas perkhidmatan untuk memudahkan penyahpepijatan dan penyelesaian masalah. Ujian automatik: memastikan keteguhan dan kebolehpercayaan sistem, seperti menggunakan JUnit. Pengkontenaan dan orkestrasi: Gunakan alatan seperti Docker dan Kubernetes untuk memudahkan penggunaan dan pengurusan.

Apakah peranan yang dimainkan Spring Boot dalam seni bina perkhidmatan mikro? Apakah peranan yang dimainkan Spring Boot dalam seni bina perkhidmatan mikro? Jun 04, 2024 pm 02:34 PM

SpringBoot memainkan peranan penting dalam memudahkan pembangunan dan penggunaan dalam seni bina perkhidmatan mikro: menyediakan konfigurasi automatik berasaskan anotasi dan mengendalikan tugas konfigurasi biasa, seperti sambungan pangkalan data. Menyokong pengesahan kontrak API melalui ujian kontrak, mengurangkan perubahan yang merosakkan antara perkhidmatan. Mempunyai ciri sedia pengeluaran seperti pengumpulan metrik, pemantauan dan pemeriksaan kesihatan untuk memudahkan pengurusan perkhidmatan mikro dalam persekitaran pengeluaran.

See all articles