目录
一、Eureka介绍
eureka是做什么的
为什么要使用eureka
服务治理
服务注册
服务发现
Eureka的服务端与客户端
eureka服务端
eureka客户端
二、eureka的搭建
搭建eureka服务模块
1、创建eureka-server项目
2、pom.xml
3、application.yml
4、主程序
5、修改host文件
搭建eureka服务提供者(service provider)
1、修改item-service模块
2、pom.xml
3、aplliaction.yml添加eureka注册配置
4、主程序添加服务注册发现客户端
5、启动并查看服务注册情况
三、eureka的使用
服务提供者 的“高可用”
1、配置启动参数
2、启动两个服务,并查看注册信息
eureka的高可用
1、添加两个配置yml文件
2、配置启动参数
3、启动两台服务器,查看注册信息
4、修改item-service服务的yml
以下内容来自百度百科
Eureka包含两个组件:Eureka Server和Eureka Client。
Eureka Server提供服务注册服务,各个节点启动后,会在Eureka Server中进行注册,这样EurekaServer中的服务注册表中将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观的看到。
Eureka Client是一个java客户端,用于简化与Eureka Server的交互,客户端同时也就是一个内置的、使用轮询(round-robin)负载算法的负载均衡器。
在应用启动后,将会向Eureka Server发送心跳,默认周期为30秒,如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,Eureka Server将会从服务注册表中把这个服务节点移除(默认90秒)。
Eureka Server之间通过复制的方式完成数据的同步,Eureka还提供了客户端缓存机制,即使所有的Eureka Server都挂掉,客户端依然可以利用缓存中的信息消费其他服务的API。综上,Eureka通过心跳检查、客户端缓存等机制,确保了系统的高可用性、灵活性和可伸缩性。
eureka主要负责完成微服务架构中的服务治理功能
当服务的模块越来越多,系统的功能越来越复杂,以前用到的静态配置就会变得越来越难以维护,会消耗巨大的人力,所以通过使用服务注册与发现来完成对微服务应用的自动化管理。
用来实现各个微服务实例化的自动化注册与发现。
首先会构建一个服务中心,之后的每个服务单元向这个服务中心提供主机,端口号等信息登记自己提供的服务。
而注册中心通过服务名分类组织服务清单,并对其进行维护。
服务注册中心需要以心跳的方式去监测清单中的服务是否可用,若不可用需要从服务清单中剔除。
服务之间不需要指定具体的实例地址,而是通过服务中心发起请求调用实现。所以,调用方并不需要知道服务提供方具体的位置,只需向注册中心发起请求,从而获取所有服务的实例清单,才能实现对具体服务实例的访问。
实际应用中,不会每次都向注册中心获取服务,使用了缓存和服务剔除等不同的策略。
支持高可用配置,当集群中有分片故障时,Eureka就会进入自我保护模式,允许在有分片故障期间继续提供注册与发现的功能。当分片恢复正常,集群中的其他分片会将其状态同步回来。
会向注册中心注册自身提供的服务,并周期性的发送心跳来更新它的服务租约。同时它能将服务端的注册信息查询并缓存到本地且周期性的刷新状态。
pom.xml中添加eureka Server依赖
org.springframework.cloud
spring-cloud-starter-netflix-eureka-server
编辑application.yml文件中的参数配置
spring:
application:
name: eureka-server
server:
port: 2001
eureka:
instance:
hostname: eureka1
client:
register-with-eureka: false
fetch-registry: false
server:
enable-self-preservation: false
其中,
hostname是eureka集群服务器之间的区分
不向自身注册。由于该应用为单个注册中心,所以设置为false,代表不向注册中心注册自己。
不从自身拉取注册信息。由于单个注册中心,不拉去自身信息。
eureka 的自我保护状态:心跳失败的比例,在15分钟内是否超过85%,如果出现了超过的情况,Eureka Server会将当前的实例注册信息保护起来,同时提示一个警告,一旦进入保护模式,Eureka Server将会尝试保护其服务注册表中的信息,不再删除服务注册表中的数据。也就是不会注销任何微服务。测试阶段将其关闭。
最后一次心跳后,间隔多久认定微服务不可用,默认90
编辑XxxApllication.java
添加@EnableEurekaServer
通过此注解触发自动配置
package cn.tedu.sp05;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@EnableEurekaServer //通过注解触发自动配置
@SpringBootApplication
public class Sp05EurekaApplication {
public static void main(String[] args) {
SpringApplication.run(Sp05EurekaApplication.class, args);
}
}
这里我把电脑的host文件添加配置,添加eureka域名映射
host文件位置:
C:\Windows\System32\drivers\etc\hosts
127.0.0.1 eureka1
127.0.0.1 eureka2
6、启动服务,访问测试
输入地址:
http://eureka1:2001
此模块就是正常配置的一个服务模块
其中的配置:
服务名称为item-service
端口号使用8001
spring:
application:
name: item-service
server:
port: 8001
添加Eureka Descovery Client依赖
org.springframework.cloud
spring-cloud-starter-netflix-eureka-client
#defaultZone - 默认地点
#如果使用云服务器,可以由服务商提供不同的地点的服务器
eureka:
client:
service-url:
defaultZone: http://eureka1:2001/eureka
其中还有一些属性
默认地点,可以修改为具体的地名,比如beijing,shanghai,shenzhen ,表示eureka服务器的部署位置,需要云服务器提供。
心跳间隔时间,默认为30s
拉取注册信息间隔时间,默认30s
主程序添加@EnableDiscoveryClient注解
package cn.tedu.sp02;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@EnableDiscoveryClient
@SpringBootApplication
public class Sp02ItemserviceApplication {
public static void main(String[] args) {
SpringApplication.run(Sp02ItemserviceApplication.class, args);
}
}
可以看到item-service服务已经被注册到eureka服务中
使用:
修改Name为 Sp02Item-8001
并且在Program argments中添加: --server.port=8001
使用左上角的复制按钮将Sp02Item-8001复制一个出来
将其Name修改为Sp02Item-8002
Program arguments修改为:--server.port=8002
注:使用此方法会将application.yml文件中的配置信息修改,从而使一个项目使用两个不同的端口分别启动(集群)。
application-eureka1.yml
eureka:
instance:
hostname: eureka1
client:
#向自身注册
register-with-eureka: true #profile的配置会覆盖公用配置
#向自身拉取注册信息
fetch-registry: true #profile的配置会覆盖公用配置
service-url:
defaultZone: http://eureka2:2002/eureka #eureka1启动时向eureka2注册
application-eureka2.yml
eureka:
instance:
hostname: eureka2
client:
#向自身注册
register-with-eureka: true #profile的配置会覆盖公用配置
#向自身拉取注册信息
fetch-registry: true #profile的配置会覆盖公用配置
service-url:
defaultZone: http://eureka1:2001/eureka #eureka2启动时向eureka1注册
其中,register-with-eureka 和 fetch-registry 均改为true
将自身作为服务向其他服务注册中心注册自己,这样就形成了一组相互注册的服务注册中心,实现服务清单的同步。
编辑eureka1参数
修改Name为Sp05Eureka-2001
添加Program arguments参数为:--spring.profiles.active=eureka1 --server.port=2001
编辑eureka2参数
复制eureka1修改其参数
Name为Sp05Eureka-2002
Program argments为 : --spring.profiles.active=eureka2 --server.port=2002
使item-serivce向两台eureka服务注册
中间使用逗号(,)将两台服务器分隔开
eureka:
client:
service-url:
defaultZone: http://eureka1:2001/eureka,http://eureka2:2002/eureka