Eureka 介绍
整体介绍
- 背景:在传统应用中,组件之间的调用,通过有规范的约束的接口来实现,从而实现不同模块间良好的协作。但是被拆分成微服务后,每个微服务实例的网络地址都可能动态变化,数量也会变化,使得原来硬编码的地址失去了作用。需要一个中心化的组件来进行服务的登记和管理。
- 概念:实现服务治理,即管理所有的服务信息和状态。
注册中心相当于买票乘车,只看有没有票(有没有服务),有就去买票(获取注册列表),然后乘车(调用)。不必关心有多少火车在运行。
-
注册中心好处:不用关心有多少提供方。
-
注册中心有哪些:Eureka,Nacos,Consul,Zookeeper等。
-
服务注册与发现包括两部分,一个是服务器端,另一个是客户端。
Server是一个公共服务,为Client提供服务注册和发现的功能,维护注册到自身的Client的相关信息,同时提供接口给Client获取注册表中其他服务的信息,使得动态变化的Client能够进行服务间的相互调用。
Client将自己的服务信息通过一定的方式登记到Server上,并在正常范围内维护自己信息一致性,方便其他服务发现自己,同时可以通过Server获取到自己依赖的其他服务信息,完成服务调用,还内置了负载均衡器,用来进行基本的负载均衡。
-
Eureka:是一个RESTful风格的服务,是一个用于服务发现和注册的基础组件,是搭建Spring Cloud微服务的前提之一,它屏蔽了Server和client的交互细节,使得开发者将精力放到业务上。
-
Netflix开源的组件。包括server和client两部分。
https://github.com/Netflix/Eureka
SpringCloud官网是https://docs.spring.io/spring-cloud-netflix/docs/3.1.4/reference/html/#spring-cloud-eureka-server。要包含Eureka Server只需添加spring-cloud-starter-netflix-eureka-server依赖。
例子:
新建名为EurekaServer 的SpringBoot项目,添加spring-cloud-starter-netflix-eureka-server依赖,使用Gradle构建工具,build.gradle文件如下:
plugins {
id 'java'
id 'org.springframework.boot' version '2.7.9'
id 'io.spring.dependency-management' version '1.0.15.RELEASE'
}
group = 'com.example'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '17'
repositories {
mavenCentral()
}
ext {
set('springCloudVersion', "2021.0.6")
}
dependencies {
// implementation 'org.springframework.cloud:spring-cloud-starter'
implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-server'
testImplementation 'org.springframework.boot:spring-boot-starter-test'
}
dependencyManagement {
imports {
mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
}
}
tasks.named('test') {
useJUnitPlatform()
}
SpringCloud版本是2021.0.6,SpringBoot版本是2.7.9,java版本是jdk17.
导入依赖后,在application.yml文件配置:
server:
port: 8761
eureka:
instance:
hostname: localhost
client:
registerWithEureka: false
fetchRegistry: false
serviceUrl:
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
其中server.port指定项目的端口,eureka.instance.hostname指定eureka的主机名,eureka.client.registerWithEureka为false表示不将自己注册到eurekaServer中,eureka.client.fetchRegistry表示此eurekaServer是否从其他eurekaServer中拉取注册的服务列表。eureka.client.serviceUrl.defaultZone指定服务注册中心的URL。
在启动类上加@EnableEurekaServer注解:
@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
启动后,访问http://localhost:8761/: