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.
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka-server</artifactId> </dependency>
@SpringBootApplication @EnableEurekaServer public class EurekaServerApplication { public static void main(String[] args) { SpringApplication.run(EurekaServerApplication.class, args); } }
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
@SpringBootApplication @EnableFeignClients public class UserServiceApplication { public static void main(String[] args) { SpringApplication.run(UserServiceApplication.class, args); } }
@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); }
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> org.springframework.cloud spring-cloud-starter-ribbon
@SpringBootApplication @EnableFeignClients @EnableDiscoveryClient public class OrderServiceApplication { public static void main(String[] args) { SpringApplication.run(OrderServiceApplication.class, args); } }
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); }
@Service public class OrderServiceImpl implements OrderService { @Autowired private UserService userService; // ... }
Atas ialah kandungan terperinci Amalan mikro perkhidmatan elegan Spring Cloud. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!