都说好记性不如烂笔头,每天写一点,从量变到质变的开始!废话不多说,以下所有内容均来自本人实际操作:
Spring Cloud Netflix通过自动配置并绑定到Spring Environment和其他Spring编程模型习惯用法,为Spring Boot应用程序提供Netflix OSS集成。通过一些简单的注释,您可以快速启用和配置应用程序内部的通用模式,并使用经过实战检验的Netflix组件构建大型分布式系统。提供的模式包括服务发现(Eureka),断路器(Hystrix),智能路由(Zuul)和客户端负载平衡(Ribbon)。
1.Spring Cloud Netflix功能
-
服务发现:可以注册Eureka实例,并且客户端可以使用Spring托管的Bean发现实例
-
服务发现:可以使用声明性Java配置创建嵌入式Eureka服务器
-
断路器:Hystrix客户端可以使用简单的注释驱动的方法装饰器构建
-
断路器:具有声明性Java配置的嵌入式Hystrix仪表板
-
声明式REST客户端:Feign创建一个用JAX-RS或Spring MVC注释修饰的接口的动态实现。
-
客户端负载均衡器:功能区
-
外部配置:从Spring Environment到Archaius的桥梁(使用Spring Boot约定启用Netflix组件的本机配置)
-
路由器和过滤器:Zuul过滤器的自动注册,以及用于反向代理创建的简单配置约定
2.搭建Spring Cloud项目-注册中心
2.1 导入依赖
父项目
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.1</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
版本控制
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>2020.0.0</spring-cloud.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
项目依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
2.2 yml配置
server:
port: 8761
eureka:
server:
#防止由于Eureka的机制导致Client被错误显示在线,仅在开发环境使用,生产环境需缓存此信息,防止因网络波动导致服务频繁上下线
enable-self-preservation: false
client:
#不向注册中心注册自己
register-with-eureka: false
service-url:
#其他应用向注册中心注册的注册地址,注册中心集群直接以","分隔
defaultZone: http://localhost:8761/eureka/
spring:
application:
name: spring-cloud-register
2.3 开启服务(@EnableEurekaServer)
@SpringBootApplication
@EnableEurekaServer
public class SpringCloudRegisterApplication {
public static void main(String[] args) {
SpringApplication.run(SpringCloudRegisterApplication.class, args);
}
}
2.4 启动项目查看效果(http://localhost:8761)
可以看到目前没有实例被注册
3.搭建Spring Cloud项目-服务中心
3.1 导入依赖
父项目
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.1</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
版本控制
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>2020.0.0</spring-cloud.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
项目依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
3.2 yml配置
server:
port: 8888
eureka:
client:
service-url:
#向注册中心注册的注册地址,注册中心集群直接以","分隔
defaultZone: http://localhost:8761/eureka/
spring:
application:
name: spring-cloud-producer
3.3 添加一个服务
@RestController
public class HelloController {
@RequestMapping("/hello")
public String hello(@RequestParam String name) {
return "hello "+name+",producer is ready";
}
}
3.4 开启客户端注册(@EnableEurekaClient)
/**
* 增加@EnableEurekaClient,如果是其他注册中心可以使用注解@EnableDiscoveryClient来进行服务的注册
*/
@SpringBootApplication
@EnableEurekaClient
public class SpringCloudProducerApplication {
public static void main(String[] args) {
SpringApplication.run(SpringCloudProducerApplication.class, args);
}
}
3.5 启动项目并访问注册中心查看(http://localhost:8761)
4.搭建Spring Cloud项目-消费中心
4.1 导入依赖
父项目
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.1</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
版本控制
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>2020.0.0</spring-cloud.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
项目依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
4.2 yml配置
server:
port: 9999
eureka:
client:
service-url:
#向注册中心注册的注册地址,注册中心集群直接以","分隔
defaultZone: http://localhost:8761/eureka/
spring:
application:
name: spring-cloud-consumer
4.3 开启客户端注册和Feign客户端服务(@EnableEurekaClient@EnableFeignClients)
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class SpringBootConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(SpringBootConsumerApplication.class, args);
}
}
4.4 新建一个类调用消费中心的服务
@RestController
public class HelloController {
/**
* name:远程服务名,及spring.application.name配置的名称
* 此类中的方法和远程服务中contoller中的方法名和参数需保持一致
*/
@FeignClient(name = "spring-cloud-producer")
static interface HelloRemote {
@RequestMapping(value = "/hello")
public String hello(@RequestParam(value = "name") String name);
}
/**
* spring cloud 提供的类可以查看注册中心的服务
*/
@Autowired
public DiscoveryClient discoveryClient;
@Autowired
public HelloRemote helloRemote;
/**
* 查看服务中心信息
*/
@GetMapping("/getProducer")
public ResponseEntity<List<ServiceInstance>> getInstances() {
try {
List<ServiceInstance> instances = this.discoveryClient.getInstances("spring-cloud-producer");
return ResponseEntity.ok(instances);
} catch (Exception e) {
e.printStackTrace();
}
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(null);
}
/**
* 调用远程服务
*/
@GetMapping("/hello/{name}")
public String index(@PathVariable("name") String name) {
return helloRemote.hello(name);
}
}
4.5 启动项目查看效果