Spring Cloud是一系列框架的有序集合,它提供了一些简单的模式来构建大型的、分布式的微服务系统。Spring Cloud构建于Spring Boot之上,使得开发者可以快速的创建、部署、和管理微服务。
Spring Cloud的核心组件包括:
- Eureka:服务发现与负载均衡。
- Feign:服务调用。
- Ribbon:客户端负载均衡。
- Hystrix:服务容错管理,防止系统雪崩。
- Zuul:API网关,提供路由转发、请求过滤等功能。
以下是一个简单的Spring Cloud示例,使用Eureka作为服务注册中心,Feign作为服务调用方式。
- 创建Eureka Server:
@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
application.properties:
spring.application.name=eureka-server
server.port=8761
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false
- 创建服务提供者(Eureka Client):
@SpringBootApplication
@EnableEurekaClient
@RestController
public class ServiceProviderApplication {
@Value("${server.port}")
private String port;
@GetMapping("/hello")
public String hello() {
return "Hello from port: " + port;
}
public static void main(String[] args) {
SpringApplication.run(ServiceProviderApplication.class, args);
}
}
application.properties:
spring.application.name=service-provider
server.port=8081
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
- 创建服务消费者(Feign Client):
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class ServiceConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(ServiceConsumerApplication.class, args);
}
}
Feign接口:
@FeignClient("service-provider")
public interface HelloClient {
@GetMapping("/hello")
String hello();
}
application.properties:
spring.application.name=service-consumer
server.port=8082
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
在这个例子中,我们创建了一个Eureka Server和一个服务提供者。服务提供者将它的服务注册到Eureka Server。然后我们创建了一个Feign客户端,用来调用服务提供者的服务。这个例子展示了Spring Cloud如何使用Eureka进行服务注册与发现,以及如何使用Feign进行服务间的远程调用。