Rumah >Java >javaTutorial >Amalan mikro perkhidmatan elegan Spring Cloud

Amalan mikro perkhidmatan elegan Spring Cloud

PHPz
PHPzasal
2023-06-22 12:31:441253semak imbas

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>

Tambah anotasi @EnableEurekaServer pada kelas permulaan.

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {

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

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>

Tambah anotasi @EnableFeignClients pada kelas permulaan.

@SpringBootApplication
@EnableFeignClients
public class UserServiceApplication {

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

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);
}

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>

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);
  }
}

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);
}

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

@Service
public class OrderServiceImpl implements OrderService {

  @Autowired
  private UserService userService;

  // ...
}

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:
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