从零搭建微服务SpringCloud(三)创建SpringCloud注册中心-Eureka

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 上文简述了新建一个SpringCloud第一步需要的一些pom依赖配置。那么这篇文章来看一下SpringCloud注册中心应该如何创建以及配置。

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

image.png
还是maven项目不要换,直接下一步
image.png
image.png

2、确认目录是否正确

image.png

3、检查父pom依赖这时你会发现自动出现modules块配置

image.png

4、进入Eureka-pom.xml配置依赖

image.png

<!--    必备依赖-->
<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(固定名称的配置文件)并配置以下配置

image.png

#因为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主启动类与它们同级,切勿不可在其他包下级,否则很容易出现启动出错,寻找问题很麻烦)

image.png

//为SpringBoot核心注解,目的是开启自动配置
@SpringBootApplication
//引入下方注解可以将项目作为SpringCloud中的注册中心
@EnableEurekaServer
public class EurekaServiceStart {
    public static void main(String[] args) {
        //创建SpringApplication对象,在初始化对象是保存事件监听器
        //容器在初始化判断是否为web应用,并保存main方法的主配置类
        //调用run方法,准备spring上下文,完成初始化,创建,加载。会在不同时机触发监听器不同事件
        SpringApplication.run(EurekaServiceStart.class,args);
    }
}

7、启动

image.png
启动成功
image.png

8、进入浏览器查看并输入账号密码

image.png
成功!
image.png


上一篇:从零搭建微服务SpringCloud(二)新建一个SpringCloud项目

下一篇:从零搭建微服务SpringCloud(四)设计SpringCloud服务提供者

目录
相关文章
|
19天前
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
138 68
从单体到微服务:如何借助 Spring Cloud 实现架构转型
|
2月前
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo:微服务通信的高效解决方案
【10月更文挑战第15天】随着信息技术的发展,微服务架构成为企业应用开发的主流。Spring Cloud Dubbo结合了Dubbo的高性能RPC和Spring Cloud的生态系统,提供高效、稳定的微服务通信解决方案。它支持多种通信协议,具备服务注册与发现、负载均衡及容错机制,简化了服务调用的复杂性,使开发者能更专注于业务逻辑的实现。
74 2
|
17天前
|
Java Nacos Sentinel
Spring Cloud Alibaba:一站式微服务解决方案
Spring Cloud Alibaba(简称SCA) 是一个基于 Spring Cloud 构建的开源微服务框架,专为解决分布式系统中的服务治理、配置管理、服务发现、消息总线等问题而设计。
159 13
Spring Cloud Alibaba:一站式微服务解决方案
|
3天前
|
Java 关系型数据库 Nacos
微服务SpringCloud链路追踪之Micrometer+Zipkin
SpringCloud+Openfeign远程调用,并用Mircrometer+Zipkin进行链路追踪
46 20
|
24天前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
78 5
|
29天前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评。然而,“客户端不发送心跳检测”是使用中常见的问题之一。本文详细探讨了该问题的原因及解决方法,包括检查客户端配置、网络连接、日志、版本兼容性、心跳检测策略、服务实例注册状态、重启应用及环境变量等步骤,旨在帮助开发者快速定位并解决问题,确保服务正常运行。
44 5
|
1月前
|
网络安全 Nacos 开发者
Nacos作为流行的微服务注册与配置中心,“节点提示暂时不可用”是常见的问题之一
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,“节点提示暂时不可用”是常见的问题之一。本文将探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务的正常运行。通过检查服务实例状态、网络连接、Nacos配置、调整健康检查策略等步骤,可以有效解决这一问题。
37 4
|
1月前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,实际使用中常遇到“客户端不发送心跳检测”的问题。本文深入探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务正常运行。通过检查客户端配置、网络连接、日志、版本兼容性、心跳策略、注册状态、重启应用和环境变量等步骤,系统地排查和解决这一问题。
51 3
|
1月前
|
安全 Nacos 数据库
Nacos是一款流行的微服务注册与配置中心,但直接暴露在公网中可能导致非法访问和数据库篡改
Nacos是一款流行的微服务注册与配置中心,但直接暴露在公网中可能导致非法访问和数据库篡改。本文详细探讨了这一问题的原因及解决方案,包括限制公网访问、使用HTTPS、强化数据库安全、启用访问控制、监控和审计等步骤,帮助开发者确保服务的安全运行。
47 3
|
2月前
|
JSON Java 数据格式
【微服务】SpringCloud之Feign远程调用
本文介绍了使用Feign作为HTTP客户端替代RestTemplate进行远程调用的优势及具体使用方法。Feign通过声明式接口简化了HTTP请求的发送,提高了代码的可读性和维护性。文章详细描述了Feign的搭建步骤,包括引入依赖、添加注解、编写FeignClient接口和调用代码,并提供了自定义配置的示例,如修改日志级别等。
137 1