SpringCloud组件配置方法

各个组件导的包
在这里插入图片描述

Eureka:

定义eurekaServer(7001)的配置:
先导包:
在这里插入图片描述
在这里插入图片描述

服务提供者(生产者)(8001)的配置:
先导包:
在这里插入图片描述
配置文件:
在这里插入图片描述
在这里插入图片描述
启动类:
在这里插入图片描述
配置完启动后可以看到8001注册到7001:
在这里插入图片描述

SPRINGCLOUD-PROVIDER-DEPT是application-name
可以在配置文件里面修改eureka的默认描述信息:
在这里插入图片描述
在这里插入图片描述

如果8001停掉,再打开7001,会报错:
在这里插入图片描述
在这里插入图片描述

获取注册进eureka的服务的信息:
在这里插入图片描述
在这里插入图片描述

如果注册中心只有一个,那么这个注册中心如果崩了那就所有服务都会停掉,这样很危险,所以要做注册中心的集群。

注册中心互相依赖,如果一个崩了可以通知消费者去找其他的注册中心。
在这里插入图片描述
在配置文件里面配置其他注册中心的host,例如7001关联7002和7003。
在这里插入图片描述
7002和7003
在这里插入图片描述
在这里插入图片描述

然后服务(生产者)需要注册到集群,也就是需要注册到3个注册中心。
在这里插入图片描述
Eureka和Zookeeper的区别
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Ribbon:

在这里插入图片描述
在这里插入图片描述

消费者(80):
在这里插入图片描述
配置Ribbon和eureka:
在这里插入图片描述

在配置文件里面配置eureka:
在这里插入图片描述

servuce-url里面配置的是从哪个路径获取服务

然后在启动类加上注解,消费者的eureka就配置完了:
在这里插入图片描述

配置Ribbon负载均衡算法:
在这里插入图片描述
图中是生产者的名称
在这里插入图片描述

配置好了启动之后,消费者会通过轮询算法从不同的eurekaServer去调用生产者的服务

实现负载均衡
在Spring Cloud中,当Ribbon与Eureka配合使用时,Ribbon可自动从Eureka Server获取服务提供者地址列表,并基于负载均衡算法,请求其中一个服务提供者实例。展示了Ribbon与Eureka配合使用时的架构。
在这里插入图片描述
在这里插入图片描述

创建3个生产者,这3个生产者都是一样的服务。消费者会从注册中心去获取服务的列表,然后通过负载均衡算法去请求服务。

Feign:

在这里插入图片描述
编写一个api接口,然后定义服务名
在这里插入图片描述

然后在消费者(feign,跟80是一样的只是controller不一样)里面自动装配这个api接口,然后直接调用
在这里插入图片描述

在消费者的启动类添加注解去扫描包:
在这里插入图片描述
原本的80是这样的:
在这里插入图片描述

@FeignClient注解:
FeignClient注解被@Target(ElementType.TYPE)修饰,表示FeignClient注解的作用目标在接口上
@FeignClient(name = “github-client”, url = “https://api.github.com”, configuration = GitHubExampleConfig.class)
public interface GitHubClient {
@RequestMapping(value = “/search/repositories”, method = RequestMethod.GET)
String searchRepo(@RequestParam(“q”) String queryStr);
}
 声明接口之后,在代码中通过@Resource注入之后即可使用。@FeignClient标签的常用属性如下:
name:指定FeignClient的名称,如果项目使用了Ribbon,name属性会作为微服务的名称,用于服务发现
url: url一般用于调试,可以手动指定@FeignClient调用的地址
decode404:当发生http 404错误时,如果该字段位true,会调用decoder进行解码,否则抛出FeignException
configuration: Feign配置类,可以自定义Feign的Encoder、Decoder、LogLevel、Contract
fallback: 定义容错的处理类,当调用远程接口失败或超时时,会调用对应接口的容错逻辑,fallback指定的类必须实现@FeignClient标记的接口
fallbackFactory: 工厂类,用于生成fallback类示例,通过这个属性我们可以实现每个接口通用的容错逻辑,减少重复的代码
path: 定义当前FeignClient的统一前缀

SpringCloud配置生产者和消费者:

https://blog.csdn.net/qq_39298872/article/details/114279989

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值