各个组件导的包:
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的统一前缀