服务注册中心 Eureka

Eureka,是 Spring Cloud Netflix 组件之一。 包含服务治理(Eureka)包括服务注册、服务发现和服务检测监控等。

在Spring Cloud Netflix 整合技术栈中,Eureka既可以作为服务注册中心也可以用于服务发现对整个微服务架构起着最核心的整合作用。

那啥是服务注册中心?

举个例子:某某洗浴中心则作为服务注册中心。

那啥是服务注册?

举个例子:某某洗浴中心有N个PLMM来上班将信息登记到上面去

那啥是服务发现?

举个例子:某男子来到了洗浴中心翻了翻了人员信息找到了某项洗浴服务选了一位对应的PLMM,然后就干了些该干的事情然后就走了。

在微服务架构中,由于每一个服务的粒度相对传统SOA来说要小的多,所以服务的数量会成倍增加。这时如果有效管理服务的注册信息就尤为重要。

在分布式系统中,我们不仅仅是需要在注册中心找到服务和服务地址的映射关系这么简单,我们还需要考虑更多更复杂的问题:

  1. 服务注册后,如何被及时发现
  2. 服务宕机后,如何及时下线
  3. 服务如何有效的水平扩展
  4. 服务发现时,如何进行路由
  5. 服务异常时,如何进行降级
  6. 注册中心如何实现自身的高可用

    这些问题解决都依赖服务注册中心。

    注册中心是微服务架构非常重要的一个组件,管理各种服务功能包括服务的注册、发现、熔断、负载、降级等。可以说是微服务架构中的”通讯录“,它记录了服务和服务地址的映射关系。在分布式架构中,服务会注册到这里,当服务需要调用其它服务时,就到这里找到服务的地址,进行调用。
工程版本信息
  1. SpringCloud Hoxton.SR3
  2. SpringBoot 2.2.1.RELEASE
  3. java1.8
父工程依赖管理
 <dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR3</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.2.1.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
SpringCloud Eureka 服务注册中心搭建

创建名称为eureka-server的子工程pom信息如下:

<dependencies>
<!-- Web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- Test -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!-- eureka服务端依赖jar包 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>

创建SpringBoot启动类EurekaServerApplication内容如下:


/**
* Eureka服务端
* author: SimpleWu
*/
@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}

创建application.properties内容如下:

spring.application.name=eureka-server
server.port=23001
#是否向服务注册中心注册自己
eureka.client.register-with-eureka=false
#是否检索服务
eureka.client.fetch-registry=false
#eureka.client.service-url.defaultZone= http://${spring.security.user.name}:${spring.security.user.password}@localhost:${server.port}/eureka
eureka.client.service-url.defaultZone= http://localhost:${server.port}/eureka

到了这里直接启动EurekaServerApplication main方法。

启动成功后可以访问:http://localhost:23001/ 就能够查看到Eureka Web界面。

Eureka增加安全认证

增加依赖:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>

增加properties配置:

#spring security 用户密码
spring.security.user.name=root
spring.security.user.password=123456

关闭csrf:

/**
* 关闭 csrf
* @author SimpleWu
*/
@EnableWebSecurity
@Configuration
public class WebSecurityConfig extends WebSecurityConfigurerAdapter{ @Override
protected void configure(HttpSecurity http) throws Exception {
http.csrf().disable();
//http.authorizeRequests().anyRequest().permitAll().and().logout().permitAll();
super.configure(http);
} }

然后我们重新访问的时候就需要输入账号与密码才能够放文档Eureka服务。

客户端连接Eureka需要携带账号密码properties配置可以使用

eureka.client.service-url.defaultZone= http://${spring.security.user.name}:${spring.security.user.password}@localhost:${server.port}/eureka
Eureka集群模式

3个服务组成一组通用的高可用服务分别为23001端口,23002端口,23003端口

配置Host三个实例服务映射:

127.0.0.1 eureka001

127.0.0.1 eureka002

127.0.0.1 eureka003

然后分别启动3个Eureka服务,配置分别如下:

eureka001:

server.port=23001
eureka.instance.hostname=eureka001
eureka.client.service-url.defaultZone= http://eureka002:23002/eureka,http://eureka003:23003/eureka

eureka002:

server.port=23002
eureka.instance.hostname=eureka002
eureka.client.service-url.defaultZone= http://eureka001:23001/eureka,http://eureka003:23003/eureka

eureka003:

server.port=23003
eureka.instance.hostname=eureka003
eureka.client.service-url.defaultZone= http://eureka001:23001/eureka,http://eureka003:23003/eureka

客户端(服务提供方配置):

eureka.client.service-url.defaultZone= http://eureka001:23001/eureka,http://eureka002:23002/eureka,http://eureka003:23003/eureka

到这里我们Eureka高可用集群就搭建成功了,可以客户端只向Eureka001注册服务,euereka002,eureka003中也会同步到euerka001的服务节点数据。

Eureka监听事件
  1. EurekaInstanceCanceledEvent 服务下线事件
  2. EurekaInstanceRegisteredEvent 服务注册事件
  3. EurekaInstanceRenewedEvent 服务续约事件
  4. EurekaRegistryAvailableEvent Eureka注册中心启动事件
  5. EurekaServerStartedEvent Eureka Server启动事件

    只需要在方法上标注@EventListener注解就可以监听到以上事件案例如下:
@EventListener
public void listen(EurekaInstanceCanceledEvent event) {
logger.info("服务{}已下线", event.getAppName());
logger.info("server地址信息{}", event.getServerId());
//邮箱通知给管理员发送警告
}

孰能巧用 Spring Cloud 服务注册中心Eureka的更多相关文章

  1. spring cloud 服务注册中心eureka高可用集群搭建

    spring cloud 服务注册中心eureka高可用集群搭建 一,准备工作 eureka可以类比zookeeper,本文用三台机器搭建集群,也就是说要启动三个eureka注册中心 1 本文三台eu ...

  2. spring Cloud服务注册中心Eureka集群

    spring Cloud服务注册中心Eureka集群配置: 在application.yml文件加以下配置: server: port: 8761 tomcat: uri-encoding: UTF- ...

  3. spring Cloud服务注册中心eureka

    Eureka是什么? 1.Eureka是SpringCloud Netflix的核心子模块. 2.Eureka包含Eureka Server和Eureka Client. 3.Server提供注册服务 ...

  4. Spring Cloud服务注册中心交付至kubernetes

    前言 服务发现原则: 各个微服务在启动时,会将自己的网络地址等信息注册到服务发现组件中,服务发现组件会存储这些信息 服务消费者可以从服务发现组件中查询到服务提供者的网络地址,并使用该地址来远程调用服务 ...

  5. 二、Spring Cloud之注册中心 Eureka

    前言 算是正式开始学习 spring cloud 的项目知识了,大概的知道Springcloud 是由众多的微服务组成的,所以我们现在一个一个的来学习吧. 注册中心,在微服务中算是核心了.所有的服务都 ...

  6. Spring Cloud 中注册中心Eureka客户端配置

    注册中心配置客户端(注册一个虚拟的商品服务) 一.新建项目:     1.创建一个SpirngBoot应用,增加服务注册和发现依赖     2.模拟商品信息,存储在内存中     3.开发商品列表接口 ...

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

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

  8. spring cloud(二)服务(注册)中心Eureka

    Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的Service Registry和Service Discovery实现.也是springcloud体系中最重要最核心的组 ...

  9. Spring Cloud ---- 服务注册与发现(Eureka 找到了!找到了! 嘻嘻)

    记录一下吧,为什么接触分布式.因为裸辞之后没有找到工作,好的公司都要求有分布式经验,但是我完全没有.在一次面试的时候,面试官说如果你会分布式架构的话,我可以把工资给你开高2.5,我就考虑着给我点时间, ...

随机推荐

  1. jquery动态创建元素

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...

  2. 如果你说最近在看《诛仙》,平时喜欢玩LOL,你就是在把自己往悬崖上推

    面试官可能会问你一些和技术看上去没有任何关系的问题,比如问你最近在看什么书,学习之余喜欢做什么,常去哪些网站之类的.如果你说最近在看<诛仙>,平时喜欢玩LOL,你就是在把自己往悬崖上推.实 ...

  3. SQLServer2008-2012开启远程连接的配置方法

    一.远程连接端口设置(很关键的一步)1.在服务器上打开SQL Server Configuration Manager.选择SQL Server配置管理器->SQL Server 网络配置-&g ...

  4. delphi 获取大于2G的物理内存大小

    一般情况下,我们是用GlobalMemoryStatus 来获取物理内存大小的 但该API在物理内存大小超过2G的时候,返回值均为2GB.因此,没有办法获取真实的物理内存大小,所以需要对此进行改进. ...

  5. Win8 Metro(C#)数字图像处理--2.38Hough变换直线检测

    原文:Win8 Metro(C#)数字图像处理--2.38Hough变换直线检测  [函数名称] Hough 变换直线检测         HoughLineDetect(WriteableBit ...

  6. LoadLibrary方法加载运行DLL库

    最近和另一家公司对接,要求用对方提供的测试程序测试我们做的DLL. 接到对方的测试程序,发现和我们以前调用DLL的方式不太一样.但我稍微看了一会代码也看懂其意思了,一天搞定了. 但其中也遇到些小困惑, ...

  7. ASP.NET MVC控制器Controller中参数

    前述文章参见:ASP.NET MVC控制器Controller 绪论 之前的控制器返回的均为常量字符串,接下来展示如何获取请求传来的参数,而返回"动态"的字符串. 可以在操作方法B ...

  8. Delphi6/7 中XML 文档的应用

    XML文档是新一代的Web数据格式.它可以用树的形式储存一切数据.下面介绍一下TXMLDocument控件的一些用法:已定义:XMLDoc: TXMLDocument;EncoderMIME: TId ...

  9. IIS上.net注册

    如果先安装了.Net平台,后再安装IIS,那么在IIS中可能就没有出现ASP.NET版本的下拉菜单,这是我们可手动注册.Net 一般.Net版本都存放在:C:\WINDOWS\Microsoft.NE ...

  10. Codility---Dominator

    Task description A zero-indexed array A consisting of N integers is given. The dominator of array A ...