Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性简化了分布式系统的开发,通过Spring Cloud的配置模块可以实现服务注册和发现,并进行集中化的配置管理。
服务注册与发现的核心组件是Eureka Server和Eureka Client。Eureka Server提供服务注册服务,它是服务注册中心,不断地接收服务信息,同步服务列表。Eureka Client是一个Java客户端,用于注册服务,同时也可以发现和调用服务。
配置中心的核心组件是Spring Cloud Config Server。Config Server用于存储配置信息,客户端可以通过指定的API来获取配置信息。
以下是一个简单的例子,展示如何使用Spring Cloud的服务注册和配置中心功能。
- 引入依赖(pom.xml):
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
</dependencies>
- 配置Eureka Server(application.properties):
spring.application.name=eureka-server
server.port=8761
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false
eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/
- 启动Eureka Server:
@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
- 配置Config Server(application.properties):
spring.application.name=config-server
server.port=8888
spring.cloud.config.server.git.uri=https://github.com/your-repo/config-repo.git
spring.cloud.config.server.git.searchPaths=config-repo
spring.cloud.config.label=master
spring.cloud.config.server.git.username=your-username
spring.cloud.config.server.git.password=your-password
- 启动Config Server:
@EnableConfigServer
@SpringBootApplication
public class ConfigServerApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigServerApplication.class, args);
}
}
- 服务注册与发现的使用:
@EnableDiscoveryClient
@SpringBootApplication
public class ServiceApplication {
public static void main(String[] args) {
SpringApplication.run(ServiceApplication.class, args);
}
}
- 配置中心的使用:
@Configuration
public class ConfigClient {
@Value("${my.message}")
private String message;
@Bean
public CommandLineRunner run(ApplicationContext ctx) {
return args ->