非洲外贸网站,学网站开发难吗,北京网站设计精选刻,莱芜大集SpringCloud微服务全家桶学习笔记
内容#xff1a;SpringCloud SpringCloud alibaba
技术栈#xff1a;Java8mavengit#xff0c;githubNginxRabbitMQSpringBoot2.0
仓库#xff1a;链接
服务调用Ribbon
是什么#xff1f;
Ribbon是Netflix发布的开源项目#xff…SpringCloud微服务全家桶学习笔记
内容SpringCloud SpringCloud alibaba
技术栈Java8mavengitgithubNginxRabbitMQSpringBoot2.0
仓库链接
服务调用Ribbon
是什么
Ribbon是Netflix发布的开源项目主要功能是提供客户端的软件负载均衡算法和服务调用。Ribbon客户端组件提供一系列完善的配置项如连接超时重试等。简单的说就是在配置文件中列出Load Balancer简称LB后面所有的机器Ribbon会自动的帮助你基于某种规则如简单轮询随机连接等去连接这些机器。我们很容易使用Ribbon实现自定义的负载均衡算法。
做什么
Ribbon本地负载均衡客户端 VS Nginx服务端负载均衡区别 Nginx是服务器负载均衡客户端所有请求都会交给nginx然后由nginx实现转发请求。即负载均衡是由服务端实现的。
Ribbon本地负载均衡在调用微服务接口时候会在注册中心上获取注册信息服务列表之后缓存到JVM本地从而在本地实现RPC远程服务调用技术。
架构说明 Ribbon在工作时分成两步 第一步先选择 EurekaServer ,它优先选择在同一个区域内负载较少的server. 第二步再根据用户指定的策略在从server取到的服务注册列表中选择一个地址。 其中Ribbon提供了多种策略比如轮询、随机和根据响应时间加权。
Ribbon核心组件IRule,负载均衡算法 默认为轮询如何切换负载均衡算法呢
需要在著启动类添加注释**RibbonClient** 这个自定义配置类不能放在ComponentScan所扫描的当前包下以及子包下否则我们自定义的这个配置类就会被所有的Ribbon客户端所共享达不到特殊化定制的目的了。 所以在创建配置类如MySelfRule时不能建在主启动类所在包及其子包下 openFeign服务调用
Feign是一个声明式WebService客户端。使用Feign能让编写Web Service客户端更加简单。 它的使用方法是定义一个服务接口然后在上面添加注解。Feign也支持可拔插式的编码器和解码器。Spring Cloud对Feign进行了封装使其支持了Spring MVC标准注解和HttpMessageConverters。Feign可以与Eureka和Ribbon组合使用以支持负载均衡
能干吗
前面在使用RibbonRestTemplate时利用RestTemplate对http请求的封装处理形成了一套模版化的调用方法。但是在实际开发中由于对服务依赖的调用可能不止一处往往一个接口会被多处调用所以通常都会针对每个微服务自行封装一些客户端类来包装这些依赖服务的调用。所以Feign在此基础上做了进一步封装由他来帮助我们定义和实现依赖服务接口的定义。在Feign的实现下我们只需创建一个接口并使用注解的方式来配置它(以前是Dao接口上面标注Mapper注解,现在是一个微服务接口上面标注一个Feign注解即可)即可完成对服务提供方的接口绑定简化了使用Spring cloud Ribbon时自动封装服务调用客户端的开发量。
Feign集成了Ribbon 利用Ribbon维护了Payment的服务列表信息并且通过轮询实现了客户端的负载均衡。而与Ribbon不同的是通过feign只需要定义服务绑定接口且以声明式的方法优雅而简单的实现了服务调用 只需要一个接口微服务调用接口一个注解FeignClient **注**默认Feign客户端只等待一秒钟但是服务端处理需要超过1秒钟导致Feign客户端不想等待了直接返回报错。 为了避免这样的情况有时候我们需要设置Feign客户端的超时控制。
日志打印
Feign 提供了日志打印功能我们可以通过配置来调整日志级别从而了解 Feign 中 Http 请求的细节。 说白了就是对Feign接口的调用情况进行监控和输出
四种日志级别
NONE默认的不显示任何日志
BASIC仅记录请求方法、URL、响应状态码及执行时间
HEADERS除了 BASIC 中定义的信息之外还有请求和响应的头信息
FULL除了 HEADERS 中定义的信息之外还有请求和响应的正文及元数据。
服务配置文件配置 配置类配置 服务启动运行结果可查看到服务的详细运行过程