从零搭建微服务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服务提供者

目录
相关文章
|
29天前
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo:微服务通信的高效解决方案
【10月更文挑战第15天】随着信息技术的发展,微服务架构成为企业应用开发的主流。Spring Cloud Dubbo结合了Dubbo的高性能RPC和Spring Cloud的生态系统,提供高效、稳定的微服务通信解决方案。它支持多种通信协议,具备服务注册与发现、负载均衡及容错机制,简化了服务调用的复杂性,使开发者能更专注于业务逻辑的实现。
53 2
|
1月前
|
Dubbo Java 应用服务中间件
Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
尼恩团队的15大技术圣经,旨在帮助开发者系统化、体系化地掌握核心技术,提升技术实力,从而在面试和工作中脱颖而出。本文介绍了如何使用Dubbo3.0与Spring Cloud Gateway进行整合,解决传统Dubbo架构缺乏HTTP入口的问题,实现高性能的微服务网关。
|
29天前
|
JSON Java 数据格式
【微服务】SpringCloud之Feign远程调用
本文介绍了使用Feign作为HTTP客户端替代RestTemplate进行远程调用的优势及具体使用方法。Feign通过声明式接口简化了HTTP请求的发送,提高了代码的可读性和维护性。文章详细描述了Feign的搭建步骤,包括引入依赖、添加注解、编写FeignClient接口和调用代码,并提供了自定义配置的示例,如修改日志级别等。
76 1
|
1月前
|
人工智能 文字识别 Java
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
尼恩,一位拥有20年架构经验的老架构师,通过其深厚的架构功力,成功指导了一位9年经验的网易工程师转型为大模型架构师,薪资逆涨50%,年薪近80W。尼恩的指导不仅帮助这位工程师在一年内成为大模型架构师,还让他管理起了10人团队,产品成功应用于多家大中型企业。尼恩因此决定编写《LLM大模型学习圣经》系列,帮助更多人掌握大模型架构,实现职业跃迁。该系列包括《从0到1吃透Transformer技术底座》、《从0到1精通RAG架构》等,旨在系统化、体系化地讲解大模型技术,助力读者实现“offer直提”。此外,尼恩还分享了多个技术圣经,如《NIO圣经》、《Docker圣经》等,帮助读者深入理解核心技术。
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
|
1月前
|
监控 Java 对象存储
监控与追踪:如何利用Spring Cloud Sleuth和Netflix OSS工具进行微服务调试
监控与追踪:如何利用Spring Cloud Sleuth和Netflix OSS工具进行微服务调试
43 1
|
1月前
|
负载均衡 算法 Nacos
SpringCloud 微服务nacos和eureka
SpringCloud 微服务nacos和eureka
61 0
|
10天前
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
50 6
|
10天前
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
26 1
|
2月前
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
2月前
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1