一、概念和定义

1、服务治理:服务注册与服务发现

服务注册中心,提供服务治理功能,用来实现各个微服务实例的自动注册与发现.

服务注册与发现对于微服务系统来说非常重要。有了服务发现与注册,维护人员就不需要天天修改服务调用配置了,只需要使用服务标识符就可以访问到服务,功能类似于dubbo的注册中心(register)。

1.1、服务注册:维护服务清单,使用心跳检测清单中的服务是否可用,剔除不可用的节点

1.2、服务发现:支持调用方通过服务名发起请求调用(咨询得到发起调用),支持负载均衡

2、Eureka的服务治理实现

Eureka Server是服务注册中心,可以被高可用性的配置和部署,并且在注册的服务当中,每个服务状态可以互相复制给彼此。

Eureka Client是服务注册客户端,注册自己到Eureka Server, 提供自己的元数据(主机和端口,健康指标URL,首页等)

Eureka Server通过一个服务从各个实例接收Eureka Client发送的心跳信息。如果心跳接收失败超过配置时间,实例将会正常从注册里面移除。

Eureka Client通过HTTP(或者TCP,UDP)去Eureka Server注册和获取服务列表缓存到本地, 并周期性的刷新服务状态。

客户端端负载均衡Ribbon、智能路由Zuul,都是服务注册中心的访问者。

2.1、EurekaServer

注解: @EnableEurekaServer

配置: 

server.port=1111

eureka.instance.hostname=localhost

eureka.client.register-with-eureka=false  # 本应用为注册中心,设置为false,表示不向注册中心注册自己

eureka.client.fetch-registry=false # 本应用为注册中心,职责是维护服务实例,不需要检索服务,所以设置为false

eureka.client.serviceUrl.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka

2.2、EurekaClient

注解: @EnableDiscoveryClient

配置: 

server.port=8080

eureka.client.serviceUrl.defaultZone=http://locahost:1111/eureka # 指定服务注册中心的地址

二、开发案例:演示EurekaClient如何注册到EurekaServer

这里的EurekaClient即业务应用Application,采用配置项spring.application.name标识

1、开发一个EurekaServer注册中心

2、开发微服务ServiceHelloA和ServiceHelloB,并各自部署两个实例

我直接开发了四个Eclipse Project,

ServiceHelloA和ServiceHelloA2是微服务ServiceHelloA

ServiceHelloB和ServiceHelloB2是微服务ServiceHelloB

三、案例说明

1、控制台:EurekaServer:  http://localhost:8101/

在这个例子里,有四个EurekaClient实例注册上来,其中,ServiceHelloA两个实例,分别是8201,8202端口,ServiceHelloB两个实例,分别是8221,8222端口。

2、服务实例

ServiceHelloA: 注册两个实例到EurekaService,每个实例注册一个
http://localhost:8201/HelloA?name=Lexiaofei-8201

http://localhost:8202/HelloA?name=Lexiaofei-8202

ServiceHelloB:
http://localhost:8221/HelloB?name=Liangshengqi-8221

http://localhost:8222/HelloB?name=Liangshengqi-8222

四、代码下载

https://github.com/lexiaofei/workspace_SpringEureka.git

SpringCloud的服务注册中心(一)的更多相关文章

  1. springcloud 笔记-服务注册中心

    1.搭建springcloud服务注册中心需要添加eureka的依赖: <?xml version="1.0" encoding="UTF-8"?> ...

  2. SpringCloud + Consul服务注册中心 + gateway网关

    1  启动Consul 2  创建springcloud-consul项目及三个子模块 2.1 数据模块consul-producer 2.2 数据消费模块consul-consumer 2.3 ga ...

  3. SpringCloud之服务注册中心

    1.Eureka 1.1RestTemplate 它提供了多种访问远程http服务的方法,是一种简单便捷的访问restful服务模板类,是spring提供的用于访问Rest服务的客户端模板工具集. 1 ...

  4. SpringCloud的服务注册中心(三) - 进一步了解 Eureka

    一.服务治理参与者 服务注册中心: eureka-server 服务提供者:HELLO-SERVICE 服务消费者 :HELLO-CONSUMER 很多时候,客户端既是服务提供者又是服务消费者,-&g ...

  5. SpringCloud的服务注册中心(四)- 高可用服务注册中心的搭建

    一.双 服务注册注册中心 1.服务注册中心的服务端 - EurekaServer 1.1.EurekaServer1 String.application.name=eureka-server ser ...

  6. springcloud搭建服务注册中心与服务发现

    1.创建服务注册中心 创建一个普通的Spring Boot工程 首先我们需要创建一个普通的Spring Boot工程,命名为eureka-server,普通到什么程度呢?就是一个starter都不需要 ...

  7. SpringCloud(四):服务注册中心Eureka Eureka高可用集群搭建 Eureka自我保护机制

    第四章:服务注册中心 Eureka 4-1. Eureka 注册中心高可用集群概述在微服务架构的这种分布式系统中,我们要充分考虑各个微服务组件的高可用性 问题,不能有单点故障,由于注册中心 eurek ...

  8. SpringCloud的服务注册中心(二)注册中心服务端和两个微服务应用客户端

    一.构建EurekaServer工程 1.pom.xml 2.application.yml 3. EurekaServerApp.java 4.启动EurekaServer 二.构建部署 Eurek ...

  9. SpringCloud之服务注册-eureka

    类似于DUBBO 的zookeeper, SpringCloud本身提供一套服务注册中心--eureka 与zookeeper的区别在于 1:zookeeper本身就是一个应用,安装即可用:eurek ...

随机推荐

  1. Bond UVA - 11354(LCA应用题)

    Once again, James Bond is on his way to saving the world. Bond's latest mission requires him to trav ...

  2. Problem : 1012 ( u Calculate e )

    /*tips:本题只有输入,没有输出,在线测试只检测结果,所以将前面几个结果罗列出来就OK了.为了格式输出问题纠结了半天,最后答案竟然还是错的....所以啊,做题还是得灵活变通.*/ #include ...

  3. IO查找文件复制到指定路径

    public class IOTest { // 存储获取的文件绝对路径 private static List<String> list = new ArrayList<Strin ...

  4. 功能性AI术语表

    算法:一套计算机要遵循的指令.一个算法可以是一个简单的单步程序也可以是一个复杂的神经网络,但是通常被用来指一个模型. 人工智能:这是一个统称.广义上说,软件意味着模仿或取代人类智能的各个方面.人工智能 ...

  5. 利用github协作开发步骤

    项目使用IDEA开发,IDEA上可以加载很多的插件(而且下载很快),安装github插件,安装git 首先一个成员需要创建好代码库,这个代码库存放项目,所有的开发提交代码都是向这个库提交,在githu ...

  6. flex布局之兼容

    Android 2.3 开始就支持旧版本 display:-webkit-box; 4.4 开始支持标准版本 display: flex; IOS  6.1 开始支持旧版本 display:-webk ...

  7. java常用集合总结

    1.线程安全 线程安全就是说多线程访问同一代码,不会产生不确定的结果. 2.List类和Set类List类和Set类是Collection集合接口的子接口.Set子接口:无序,不允许重复.List子接 ...

  8. java基础笔记(8)----接口

    接口 是特殊的抽象类,纯抽象类---所有方法都是抽象方法 接口和抽象类的区别: 相同点: 编译后,会分别生成对应的.class文件 都不能创建对象(实例化),但是可以生成引用(使用多态) 不同点: 抽 ...

  9. [Java] JDK 环境配置(图文)

    Windows10 上的安装配置 1.前往 JDK 官网下载对应 jdk 版本安装包: http://www.oracle.com/technetwork/java/javase/downloads/ ...

  10. [Java反射机制]用反射改进简单工厂模式设计

    如果做开发的工作,工厂设计模式大概都已经深入人心了,比较常见的例子就是在代码中实现数据库操作类,考虑到后期可能会有数据库类型变换或者迁移,一般都会对一个数据库的操作类抽象出来一个接口,然后用工厂去获取 ...