1、介绍Eureka
1、为什么需要注册中心Eureka?
讲Eureka之前我们先说说使用SpringCloud构建项目
1.从分布式/微服务的角度而言:就是把我们一大的项目,分解成多个小的模块。这些小的模块组合起来,完成功能
2.那会出现什么问题呢?
首当其冲的就是子系统之间的通讯问题。子系统与子系统之间不是在同一个环境下,那就需要远程调用。
3.既然是远程调用,就必须知道ip地址,而ip地址经常变动的话,那我们手动维护这些静态资源会非常麻烦,
所以就有了今天的主角Eureka
4.当服务器启动后,就会将ip交给注册中心Eureka管理,然后注册中心时刻监控着ip的存活情况
2、Eureka是什么?
Eureka专门用于给其他服务注册的称为Eureka Server(服务注册中心),其余注册到Eureka Server的服务称为Eureka Client
1.服务注册:服务启动之后,自动将ip跟端口注册到注册中心
2.服务治理:服务管理,通过心跳方式,保证注册中心每个服务ip可用
3.Eureka Client分为服务提供者和服务消费者。
Eureka就是一个统一管理整个微服务系统ip列表管理中心
3、Eureka治理机制
1、服务提供者(Provider Server)
服务注册:启动的时候会通过发送REST请求的方式将自己注册到Eureka Server上,同时带上了自身服务的一些元数据信息。
服务续约:在注册完服务之后,其他的服务(如服务提供者)会维护一个心跳用来持续告诉EurekaServer:"我还活着”。
服务下线:当服务实例进行正常的关闭操作时,它会触发一个服务下线的REST请求给EurekaServer,告诉服务注册中心:“我要下线了”。
2、服务消费者(Consumer Server)
获取服务:当我们启动服务消费者的时候,它会发送一个REST请求给服务注册中心,来获取上面注册的服务清单
服务调用:服务消费者在获取服务清单后,通过服务名可以获得具体提供服务的实例名和该实例的元数据信息,在进行服务调用的时候,优先访问同处一个Zone中的服务提供方。
3、服务注册中心(Eureka Server)
失效剔除:默认每隔一段时间(默认为60秒) 将当前清单中超时(默认为90秒)没有续约的服务剔除出去。
自我保护:Eureka Server 在运行期间,会统计心跳失败的比例在15分钟之内是否低于85%(通常是网络不稳定),
Eureka Server会将当前的实例注册信息保护起来,让这些实例不会过期,尽可能保护这些注册信息。
REST请求是什么
广义地说,就是客户端向服务端请求访问指定数据或者在服务端保存数据、服务端响应客户端请求的过程。从编程角度来说,服务端提供了一个端点(URL)等待接收客户端的请求,客户端连接这个端点并发送数据(记住,REST 是无状态的,请求中携带的数据不会被存储)、服务端返回正确的响应。
2、安装与配置Eureka
1、在项目上右击-new-创建Moudle
还是maven项目不要换,直接下一步
2、确认目录是否正确
3、检查父pom依赖这时你会发现自动出现modules块配置
4、进入Eureka-pom.xml配置依赖
<!-- 必备依赖-->
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</dependency>
<!--spring cloud eureka的依赖(server)-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<!--eureka自我安全管理-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
<!--web项目并版本号随父项目-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
5、在Eureka(module)-src-main-resources中创建application.yml(固定名称的配置文件)并配置以下配置
#因为SpringBoot自带TomCat服务器所以需要自定义端口号,目的是为了接下来的启动项目端口配置
server:
port: 5010
#Eureka配置
eureka:
instance:
hostname: localhost #将Eureka服务端口配置在本机
client:
register-with-eureka: false #禁止自己当作服务注册自己
fetch-registry: false #屏蔽当前注册信息
serviceUrl: #当前eureka服务地址
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
server:
enable-self-preservation: true #开启自我保护机制,保护不可用服务被删除
#Spring配置
spring:
application:
name: EUREKA-ONE #设定当前服务应用程序名称
#安全机制配置
security:
user:
name: root #登录账户
password: root #登录密码
6、创建Eureka主启动类(注意:主启动类一定要在com.eureka.start包的第一级下,如果com.eureka.start创建任何文件,都要保持此Eureka主启动类与它们同级,切勿不可在其他包下级,否则很容易出现启动出错,寻找问题很麻烦)
//为SpringBoot核心注解,目的是开启自动配置
@SpringBootApplication
//引入下方注解可以将项目作为SpringCloud中的注册中心
@EnableEurekaServer
public class EurekaServiceStart {
public static void main(String[] args) {
//创建SpringApplication对象,在初始化对象是保存事件监听器
//容器在初始化判断是否为web应用,并保存main方法的主配置类
//调用run方法,准备spring上下文,完成初始化,创建,加载。会在不同时机触发监听器不同事件
SpringApplication.run(EurekaServiceStart.class,args);
}
}
7、启动
启动成功
8、进入浏览器查看并输入账号密码
成功!