1.微服务架构
分布式架构就是将一个项目拆分成n个子项目,每个子项目使用rpc远程调用技术
一个基于 REST 服务的,服务注册与发现的组件
它主要包括两个组件:Eureka Server 和 Eureka Client
Eureka Client:一个Java客户端,用于简化与 Eureka Server 的交互(通常就是微服务中的客户端和服务端)
Eureka Server:提供服务注册和发现的能力(通常就是微服务中的注册中心)
各个微服务启动,会通过 Eureka Client 向 Eureka Server 注册自己,Eureka Server 会存储该服务的信息
也就是说,每个微服务的客户端和服务端,都会注册到 Eureka Server,这就衍生出了微服务相互识别的话题
同步:每个 Eureka Server 同时也是 Eureka Client(逻辑上的)
多个 Eureka Server 之间通过复制的方式完成服务注册表的同步,形成 Eureka 的高可用
识别:Eureka Client 会缓存 Eureka Server 中的信息
即使所有 Eureka Server 节点都宕掉,服务消费者仍可使用缓存中的信息找到服务提供者
续约:微服务会周期性(默认30s)地向 Eureka Server 发送心跳以Renew(续约)信息(类似于heartbeat)
续期:Eureka Server 会定期(默认60s)执行一次失效服务检测功能
它会检查超过一定时间(默认90s)没有Renew的微服务,发现则会注销该微服务节点
代码如下:
1.Eureka server
pom文件:
org.springframework.cloud
spring-cloud-starter-eureka-server
org.springframework.boot
spring-boot-starter-test
test
启动类:
加入@EnableEurekaServer服务注册
@SpringBootApplication
@EnableEurekaServer
public class EurekaApp {
public static void main(String[] args) {
SpringApplication.run(EurekaApp.class, args);
}
}
application.yml配置:
server:
port: 8080 端口号
eureka:
instance:
hostname: localhost
client:
#(查看@EnableEurekaServer注解的源码,会发现它间接用到了@EnableDiscoveryClient)
registerWithEureka: false
因为这是一个单点的EurekaServer,不需要同步其它EurekaServer节点的数据,故设为false
fetchRegistry: false
serviceUrl:
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
2.Eureka Client配置
pom配置文件:
org.springframework.cloud
spring-cloud-starter-eureka
org.springframework.cloud
spring-cloud-starter-ribbon
启动类:需要增加 @EnableEurekaClient
@EnableEurekaClient
@SpringBootApplication
public class LiulfApp {
public static void main(String[] args) {
SpringApplication.run(LiulfApp.class, args);
}
application.yml配置文件
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8080/eureka/
server:
port: 8980
spring:
application:
name: service-liulf