0 环境

系统环境:win10
编辑器:IDEA

1 注册中心

Eureka是springcloud中的注册中心。
原因:
当是单体应用 类似一条直线
随着项目越来越大 系统拆分 类似那个藕(模块间相互协作 调用) 为了解决服务之间的耦合 注册中心有必要出现了

2 Eureka构成

Eureka分为两部分:服务端和客户端,服务端就是注册中心,接收其他服务注册,客户端则是Java客户端,用来注册。

Eureka有三个角色:
Eureka Server:注册中心
Eureka Provider:服务提供者
Eureka Consumer:服务消费者

3 基础搭建

Eureka由Java开发的,springcloud使用springboot对Eureka进行了封装,使用方便。

1 对应的版本

2 创建一个springboot项目 添加Eureka依赖

2 yml配置 启动Eureka功能

# 给当前服务取一个名字
spring:
application:
name: eureka # 设置端口号
server:
port: 1234 # 默认情况下 Eureka Server也是一个普通的微服务 即当它是一个注册中心的时候 他有2种 1:注册中心 2:普通服务(把自己注册到自己的上面去)
# 比喻不形象 Server是一个结婚登记处 1:他是一个登记员 登记其他人的结婚信息 2:同时他也是人类的一员 他也可能结婚 那么自己登记自己老 也不是不可以 # register-with-eureka为false 表示不把当前项目注册到服务中心上
# fetch-registry为false 表示不从Eureka Server上获取注册信息
eureka:
client:
register-with-eureka: false
fetch-registry: false

3 启动项目

浏览器输入http://localhost:1234/

4 Eureka后台管理界面介绍

4 Eureka集群

注册中心使用之后 所有服务都要通过服务注册中心进行信息交换 服务注册中心的稳定性很重要 一旦注册中心崩了 整个系统都会受到影响 在实际使用中 Eureka一般是以集群的形式出现的

Eureka集群 多个Eureka实例的启动 多Eureka实例之间 相互注册、同步数据 共同组成一个Eureka集群
(你中有我 我中有你 互通有无)

1 全景

2 yml配置

# 给当前服务取一个名字
spring:
application:
name: eureka # 设置端口号
server:
port: # 默认情况下 Eureka Server也是一个普通的微服务 即当它是一个注册中心的时候 他有2种 :注册中心 :普通服务(把自己注册到自己的上面去)
# 比喻不形象 Server是一个结婚登记处 :他是一个登记员 登记其他人的结婚信息 :同时他也是人类的一员 他也可能结婚 那么自己登记自己老 也不是不可以 # register-with-eureka为false 表示不把当前项目注册到服务中心上
# fetch-registry为false 表示不从Eureka Server上获取注册信息
eureka:
client:
register-with-eureka: true
fetch-registry: true
# A服务要注册到B上面
service-url:
defaultZone: http://eurekaB:1235/eureka
instance:
hostname: eurekaA
# 给当前服务取一个名字
spring:
application:
name: eureka # 设置端口号
server:
port: # 默认情况下 Eureka Server也是一个普通的微服务 即当它是一个注册中心的时候 他有2种 :注册中心 :普通服务(把自己注册到自己的上面去)
# 比喻不形象 Server是一个结婚登记处 :他是一个登记员 登记其他人的结婚信息 :同时他也是人类的一员 他也可能结婚 那么自己登记自己老 也不是不可以 # register-with-eureka为false 表示不把当前项目注册到服务中心上
# fetch-registry为false 表示不从Eureka Server上获取注册信息
eureka:
client:
register-with-eureka: true
fetch-registry: true
# A服务要注册到B上面
service-url:
defaultZone: http://eurekaA:1234/eureka
instance:
hostname: eurekaB

3 打jar包

java jar xxxx.jar --spring.profiles.active=a
java jar xxxx.jar --spring.profiles.active=b
启动2个实例时 可能会报一些错 不影响使用 页面登陆不了 排除你自己哪里写的有问题了

启动成功后 确实是相互注册了 共建了一个集群

5 Eureka细节

Eureka分为Eureka Server和Eureka Client

1 Eureka Server

对外提供的功能:
(服务端的接收 发放 同步server端)
.服务注册(接收) 所有服务都注册到server端
.提供注册表(发放) 注册表将所有注册到服务上来的整理成一个列表 Eureka调用服务时 获取这个注册表 正常情况下 注册表会缓存下来 若缓存失效 直接获取最新的注册表
.同步状态 Eureka Client通过注册、心跳等机制 和Eureka Server同步当前客户端的状态

2 Eureka Client

Eureka Client很多事情帮你做了(自动拉取 更新以及缓存server信息 哪怕所有server节点凉了 client依旧能获取到想要的地址(但是地址可能不太准确)) 简化每个服务和server之间的交互

2.1 服务注册

服务提供者将自己注册到服务注册中心(server) 提示->服务提供者(业务划分上的划分) 本质上是Eureka Client 当Eureka Client向Eureka Server注册时 需要提供必要的元信息 比如IP地址 名称 运行状态 端口等。。。

2.2 服务续约

Eureka Client注册到Eureka Server上之后 注册成功后 Eureka Client每隔30s向Eureka发送一条心跳信息(告诉它我还活着)  若连续90s(连续3次没法送)有没有收到Eureka Client的续约消息 它会认为Client挂了 赶紧把client从服务列表撤销
eureka:
instance:
# 服务续约时间 默认为30s
lease-renewal-interval-in-seconds:
# 服务失效时间 默认为90s
lease-expiration-duration-in-seconds:

2.3 服务下线

当client下线时 发消息通知server我下线了

2.4 获取注册表信息

Eureka Client从Eureka Server上获取服务的注册信息 将其缓存在本地 本地客户端调用服务器  会从该信息中查找远程服务所对应的IP地址等信息 Eureka Client上缓存服务定期30s更新 若本地缓存注册表的信息与server传过来的信息有变化的话 Client会自动处理
eureka:
client
# 是否运行获取注册表信息
fetch-registry: true
# Client上缓存的服务注册信息 定期30s更新
registry-fetch-interval-seconds:

6 Eureka集群原理

在这个图上 Eureka通过Replicate进行数据同步 不同Eureka Server之间的节点地位均等 节点间集群的形成 通过置顶的serviceUrl相互注册 高可用节点的可用性得到提高 

若集群中某个节点失效 client自动切换到其他server上(每个server节点相互同步) Eureka连接方式 不建议单线连接(->-> 此时1也会和3互相同步) 可以指定多个注册地址(这样配置serviceUrl -> ->) 

Eureka分区:
.region->地理上的不同区域
.zone->具体的机房

7 小结

.注册中心的出现解决了服务间的耦合

.Eureka三种角色 server(注册中心) client(provider(提供者) consumer(服务消费者) )

.Eureka搭建 引入依赖 在application上开启server服务 在yml中配置服务名 端口号。。。启动成功后 会显示系统状态 副本 注册上来的服务信息 系统运行环境 以及该的一些ip等基本信息

.eureka集群(类似互联网 离了你照转) 比如需要2个eureka yml配置 注 register-with-eureka: true fetch-registry: true 配置一个hostname serviceUrl->其他yml的(http://hostname:port/application name)
为了省事 打包运行 即可看到相互注册了 .eureka细节 server -> 对外提供3个功能:给予服务注册(接收) 提供注册表 便于client的调用 同步 判断client是否活着 活着才能同步 否则就被杀掉(无情)
client -> 特色:自动拉取 更新 缓存信息
服务注册:服务提供者将自己注册上去(业务划分出2个角色 本质是一个人) 注册时需要提供一些元信息 ip啥的(类似身份证 手机号啥的 证明你是你开玩笑的 好认识你和你交朋友)
服务续约:注册上来 噩梦刚开始 client向server30s续约(费)一次 告诉server别杀我 我还活着 server连续3次90s未接收到client消息 掉线了(类似在黑吧 当你时间到了 给你3次机会 你还没有付费 你个穷鬼 别站在茅坑不拉屎 赶紧下来) 就这样被server从服务列表中剔除了
服务下线:告诉server我下线了(老板 我下线了 我结一下帐)
获取注册表信息(消费者):从server上获取信息 缓存本地 更新操作 -> 根据信息比对是否进行更新处理
提供者:向server注册 提供自身的信息 以及与server心跳时间(存活)的约定 以及服务下线的功能
消费者:从server获取服务注册信息 并缓存 定期对比该服务信息进行更新处理 .集群
server每个节点地位平等 通过Replicate数据同步 serverUrl相当于拨号 节点相互之间的连接方式(某个节点崩溃怎么办) 脚踏"两"只船

springcloud之Eureka上的更多相关文章

  1. SpringCloud Netflix Eureka(服务注册/发现)

    ⒈Eureka是什么? Eureka是Netflix的一个子模块,也是核心模块之一,Eureka是一个基于REST的服务,用于定位服务以实现云端中间层服务发现和故障转移,服务注册与发现对于微服务架构来 ...

  2. SpringCloud中eureka配置心跳和剔除下线的服务的时间

    在默认的springCloud中eureka注册中心在服务下线时表现的非常不灵敏,用惯了dubbo的zk注册中心表示很不习惯,eureka设计的本意是在服务不会频繁上下线和网络稳定的内网,这种设计在生 ...

  3. springcloud(二) eureka的使用

    上一节讲到order微服务是通过rest调用user微服务的地址.但是,user微服务的地址是写死的, 如果user微服务集群的话,那么order微服务该如何调用呢?这个时候注册中心该上场了 演示eu ...

  4. SpringCloud学习笔记(三、SpringCloud Netflix Eureka)

    目录: 服务发现简介 SpringCloud Netflix Eureka应用 Eureka高可用 Eureka源码分析 >>> Eureka Client初始化(客户端定时获取服务 ...

  5. SpringCloud之Eureka注册中心原理及其搭建

    一.Eureka简介 Eureka是Netflix开发的服务发现框架,本身是一个基于REST的服务,主要用于定位运行在AWS域中的中间层服务,以达到负载均衡和中间层服务故障转移的目的.SpringCl ...

  6. springCloud 之 Eureka注册中心高可用配置

    springCloud的eureka高可用配置方案思路是:几个服务中心之间相互注册,比如两个注册中心,A注册到B上,B注册到A上,如果是三个注册中心则是:A注册到BC上,B注册到AC上,C注册到AB上 ...

  7. 【分布式】SpringCloud(3)--Eureka服务注册与发现

    1.Eureka概述 1.1.什么是Eureka Eureka是Netflix的一个子模块.基于REST的服务,用于定位服务,以实现云端中间层服务发现和故障转移. 只需要使用服务的标识符,就可以访问到 ...

  8. springcloud优雅停止上下线与熔断

    SpringCloud 服务优雅上下线 Spring Boot 框架使用"约定大于配置"的特性,优雅流畅的开发过程,应用部署启动方式也很优雅.但是我们通常使用的停止应用的方式是 k ...

  9. SpringCloud创建Eureka模块集群

    1.说明 本文详细介绍Spring Cloud创建Eureka模块集群的方法, 基于已经创建好的Spring Cloud Eureka Server模块, 请参考SpringCloud创建Eureka ...

随机推荐

  1. 《YouTube 网站的架构演进》阅读笔记

    概述 YouTube 在国内是个404网站,需要翻墙得见,这是有用的废话,先铺垫一下. 从全球网站来看,它仅次于母公司 Google,全球排名位列第2.每天超过5亿以上视频播放量,平均每个用户点击10 ...

  2. 《ES6标准入门》(阮一峰)--7.数值的扩展

    1.二进制和八进制表示法 ES6 提供了二进制和八进制数值的新的写法,分别用前缀0b(或0B)和0o(或0O)表示. 0b111110111 === 503 // true 0o767 === 503 ...

  3. duilib之重写BUTTON按钮

    在使用BUTTON过程中,有时候发现一些属性不够用,或要从新绘制BUTTON按钮,那该如何操作?其实很简单,只需要继承CButtonUI类就行. 创建类CMyButtonUI,继承CButtonUI, ...

  4. dede:list 与 dede:arclist 的区别

    1.{dede:list}是用于列表页的文章列表调用,通常是用于list_article.htm页面,这个文章列表是可以分页的. 功能说明:表示列表模板里的分页内容列表适用范围:仅列表模板 list_ ...

  5. java se

    集群 数据库集群.服务器集群.内存 java特性 封装:封装细节和封装变化(可能发生需求变更的代码必须要封装,set方法除了完成赋值功能外,还能处理额外的任务,记录访问的人) 继承 多态 访问限定符 ...

  6. 虚拟 DOM 到底是什么?

    虚拟 DOM 到底是什么? 作者:wangshengliang 注意:由于文章太长,对文章有删减,但是不会影响整体阅读 是什么? 虚拟 DOM (Virtual DOM )这个概念相信大家都不陌生,从 ...

  7. Swift 协议protocol

    // associatedtype 关键字 用来声明一个类型的占位符作为协议定义的一部分 protocol LXFViewModelType { associatedtype Input associ ...

  8. Node.js NPM 作用

    章节 Node.js NPM 介绍 Node.js NPM 作用 Node.js NPM 包(Package) Node.js NPM 管理包 Node.js NPM Package.json NPM ...

  9. yagmail四行代码发送邮件

    yagmail四行代码发送邮件 import yagmail # 链接邮箱服务器 yag = yagmail.SMTP(user="xxxx@163.com", password= ...

  10. 文件的概念、标准IO其一

    1.文件的概念 文件是一种存储在磁盘(掉电不丢失存储设备)上,掉电不丢失的一种存储数据的方式,文件在系统中有以下层次的结构来实现. 系统调用.文件IO.标准IO的关系如下: 2.linux系统的文件分 ...