都说好记性不如烂笔头,每天写一点,从量变到质变的开始!废话不多说,以下所有内容均来自本人实际操作:

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: falseclient:#不向注册中心注册自己register-with-eureka: falseservice-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 提供的类可以查看注册中心的服务*/@Autowiredpublic DiscoveryClient discoveryClient;@Autowiredpublic 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 启动项目查看效果

初探Spring Cloud-Netflix相关推荐

  1. Spring Cloud Netflix Zuul中的速率限制

    来源:SpringForAll社区 1.引言 Spring Cloud Netflix Zuul 是一个包含Netflix Zuul的开源网关.它为Spring Boot应用增加了一些特别的特性.不幸 ...

  2. Spring Cloud Netflix项目进入维护模式之我见

    这两天看到一则新闻:https://spring.io/blog/2018/12/12/spring-cloud-greenwich-rc1-available-now#spring-cloud-ne ...

  3. 《Spring Cloud Netflix官方文档》2. 服务发现:Eureka服务器

    2. 服务发现:Eureka服务器 2.1 如何创建Eureka服务器 引用org.springframework.cloud的spring-cloud-starter-eureka-server就可 ...

  4. 《Spring Cloud Netflix官方文档》1.服务发现:Eureka客户端

    1.     服务发现:Eureka客户端 服务发现是微服务架构的关键原则之一.使用手动配置或一些约定方式来处理多服务多实例的方式是非常困难,并且十分脆弱的.Eureka同时是Netflix服务发现的 ...

  5. spring cloud netflix

    spring cloud netflix,实际上就是基于netflix公司的开源组件,然后基于spring cloud的标准规范,在springboot的基础之上进行整合.

  6. SpringCloud学习笔记(1)- Spring Cloud Netflix

    文章目录 SpringCloud学习笔记(1)- Spring Cloud Netflix 单体应用存在的问题 Spring Cloud Eureka Eureka Server代码实现 Eureka ...

  7. Spring Cloud Netflix尤里卡

    本教程是关于Spring云Netflix Eureka的. 在这里,我们将创建eureka发现服务器和微服务,这些服务本身将注册到发现服务器和使用netflix客户端API的客户端中,以使用示例示例来 ...

  8. SpringCloud学习笔记(6)----Spring Cloud Netflix之负载均衡-Ribbon的使用

    1. 什么是负载均衡? 负载均衡,就是分发请求流量到不同的服务器. 负载均衡一般分为两种 1. 服务器端负载均衡(nginx) 2. 客户端负载均衡(Ribbon) 2. 服务提供者(spring-c ...

  9. SpringCloud 入门教程(十):和RabbitMQ的整合 -- 消息总线Spring Cloud Netflix Bus

    在本教程第三讲Spring Cloud 入门教程(三): 配置自动刷新中,通过POST方式向客户端发送/refresh请求, 可以让客户端获取到配置的最新变化.但试想一下, 在分布式系统中,如果存在很 ...

  10. Spring Cloud Netflix之Eureka上篇

    前言:Spring Cloud NetFlix这个项目对NetFlix中一些久经考验靠谱的服务发现,熔断,网关,智能路由,以及负载均衡等做了封装,并通过注解的或简单配置的方式提供给Spring Clo ...

最新文章

  1. 打开方式中选择默认方式无反映_Win7系统无法选择打开方式的解决方法
  2. linux大文件拷贝,Linux如何提高大文件的拷贝效率
  3. MySQL 四种事务隔离级别详解及对比--转
  4. apr_pool -- 内存池
  5. Python绘制三维散点图
  6. mysql stack is full_mysql优化之表的优化与列类型选择
  7. PHP API 框架开发的学习
  8. 网页截图和svg模版动态生成图片Java实现
  9. C++共享内存类封装
  10. 超界文字滚动 (id和类型两种实现方式)
  11. Python-Matplotlib 7 饼状图
  12. CPU瓶颈(五)--过度编译与不必要重复编译的解决方案
  13. Win10如何ping端口是否开放
  14. 关于word导出pdf时更新域出错的问题
  15. 100天精通Andriod逆向——第5天:app逆向流程简介
  16. 32位win系统,突破4G内存限制方法
  17. 读博士的方法有哪些?什么是硕博连读?专硕如何读博?
  18. Taro使用 微信小程序 副文本编辑器
  19. 我是如何赚到人生第一个100万的?
  20. debian安装无线网卡驱动

热门文章

  1. 轻量级linux桌面环境,Linux发行版最为轻量级的桌面环境之一Xfce 桌面
  2. 宝塔面板FTP存储空间无法连接的问题
  3. 核酸检测系统的潜在性能问题猜想
  4. c++使用POP协议接收以及解析邮件
  5. win7下安装python库的若干问题
  6. 乒乓球比赛赛程_乒乓球赛程_如何组织一场乒乓球赛
  7. 【PDF处理】java将全图片的pdf压缩,输出新的pdf
  8. 制作u盘winpe启动盘_u盘ghost,教你如何制作运行u盘ghost启动盘
  9. 计算几何:记录求两球体相交部分体积(球缺)模板
  10. cass等距离等分线段的命令键_CAD等分线段指令是什么?