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

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 上文简述了新建一个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服务提供者

目录
相关文章
|
1月前
|
SpringCloudAlibaba Java 持续交付
【构建一套Spring Cloud项目的大概步骤】&【Springcloud Alibaba微服务分布式架构学习资料】
【构建一套Spring Cloud项目的大概步骤】&【Springcloud Alibaba微服务分布式架构学习资料】
141 0
|
6天前
|
负载均衡 Java 开发者
细解微服务架构实践:如何使用Spring Cloud进行Java微服务治理
【4月更文挑战第17天】Spring Cloud是Java微服务治理的首选框架,整合了Eureka(服务发现)、Ribbon(客户端负载均衡)、Hystrix(熔断器)、Zuul(API网关)和Config Server(配置中心)。通过Eureka实现服务注册与发现,Ribbon提供负载均衡,Hystrix实现熔断保护,Zuul作为API网关,Config Server集中管理配置。理解并运用Spring Cloud进行微服务治理是现代Java开发者的关键技能。
|
15天前
|
SpringCloudAlibaba 监控 Java
SpringCloud Alibaba微服务-- Sentinel的使用(保姆级)
SpringCloud Alibaba微服务-- Sentinel的使用(保姆级)
|
15天前
|
SpringCloudAlibaba Java API
SpringCloud Alibaba微服务工程搭建(保姆级)
SpringCloud Alibaba微服务工程搭建(保姆级)
|
15天前
|
SpringCloudAlibaba Java Nacos
SpringCloud Alibaba微服务 -- Nacos使用以及注册中心和配置中心的应用(保姆级)
SpringCloud Alibaba微服务 -- Nacos使用以及注册中心和配置中心的应用(保姆级)
|
21天前
|
负载均衡 网络协议 Java
构建高效可扩展的微服务架构:利用Spring Cloud实现服务发现与负载均衡
本文将探讨如何利用Spring Cloud技术实现微服务架构中的服务发现与负载均衡,通过注册中心来管理服务的注册与发现,并通过负载均衡策略实现请求的分发,从而构建高效可扩展的微服务系统。
|
1月前
|
SpringCloudAlibaba 负载均衡 Java
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(目录大纲)
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(目录大纲)
63 1
|
1月前
|
Java Nacos Sentinel
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(九)Nacos+Sentinel+Seata
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(九)Nacos+Sentinel+Seata
194 0
|
1月前
|
SpringCloudAlibaba Java 网络架构
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(二)Rest微服务工程搭建
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(二)Rest微服务工程搭建
49 0
|
1月前
|
Java Nacos Sentinel
Spring Cloud Alibaba 面试题及答案整理,最新面试题
Spring Cloud Alibaba 面试题及答案整理,最新面试题
197 0