开发者学堂课程干货总结——Spring Cloud微服务架构设计与开发实战(十三)

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
简介: Spring Cloud微服务架构设计与开发实战课时2.2—微服务注册与发现Eureka 。Java Spring Cloud是全球范围内最成熟、最完善、最流行的微服务架构方案体系。被众多的互联网大公司采用,包括阿里巴巴、腾讯、支付宝、网易、IBM、谷歌、京东、百度、滴滴等。电子书+视频为同学带来最佳学习效果,文字、课程链接、图谱地址统统为大家放送了哦!

哈喽各位同学们大家好呀,今天是开发者学院中课程“Spring Cloud微服务架构设计与开发实战”的章节二的微服务注册与发现Eureka ”干货总结~是一起学习新课程吧!

课程链接以及图谱地址小编已经为大家指路了,搭配学习效果更佳👇

课程名称:服务注册与发现Eureka

课程地址https://developer.aliyun.com/learning/course/60/detail/1085

图谱名称:Alibaba Java 技术图谱

图谱地址:https://developer.aliyun.com/graph/java


服务注册与发现Eureka


各位同学大家好,我们继续学习Spring Cloud微服务架构,设计与实践开发课程。这节课的话我们讲下实战的开发工作,我们现在要做什么?我们要做一个微服务的注册中心,来解决微服务的一个注册和发现问题。 

 

一、Spring Cloud服务注册与发现 

如何解决微服务的注册和发现,对于微服务来说,我们要实地进行拆分,进行部署的时候,实例数量是不固定的,可能是2个或者200个,2000个,都有可能。微服务的实际数量是弹性伸缩的,这一点它和传统的架构不太一样。微服务弹性实际上有点像云计算原生靠拢,这点也是他的 优势。微服务本身拆分以后能够很好的进行治理,进行快速的部署。 

image.png服务注册与发现 

1. 大规模微服务集群架构 

2. 许多服务实例 

3. 客户端要找到自己调用的服务 

4. 新服务上线 

5. 某个服务宕机,下线 

6. 实时监控服务的状态 

 

 

 

 

解决大规模服务的集群的注册和发现问题主要为了方便方便客户端的一个调用,假设我们开发了一个微服微的订单服务,开始只取一台服务,客户端直接调用微服务就可以了,但是如是取两台,写2个服务IP地址或者做轮巡都不太理想,因为遇到大型促销场景,需要增加10台,或者1000台都要更改配置列,服务的实力实力全部给拿进来。 

当服务的微服务的集群的数量增加的时候,弹性增加的时候,不定增加的时候,这时候需摇有一种方案能够去解决这个问题,把客户端和服务集群能够解偶。解偶很重要就是注册中心,帮我们去管理这些服务。 

Spring Cloud Eureka服务发现与注册 

1. Netflix公司开源的项目 

2.Eureka:注册中心, 

3. 一个基于 REST 的中心服务,管理服务 

4. 实现云端的服务注册和服务发现 

5. Eureka组件组成:Eureka服务器和Eureka客户端 

6. 竞争对手ZooKeeper 

7. 服务发现模块(Eureka)是Netflix的核心 

8. Spring Cloud Netflix提供的简化开发模板 

9. 直接使用spring boot,创建项目 

10. 添加@EnableEurekaServer 开发注册服务中心 

在微服务架构体系里面,Netflix公司贡献了其中一个很重要的项目叫Eureka,主要是解决服务注册中心的问题。ZooKeeper也是同类型的产品,Spring Cloud通过扩展组件进行集成。 

咱们主要是要介绍实在开发,后面叫底层原理原码给大家留做扩展作业,后面给大家介绍。 

 

 

 

 

 

Spring Cloud 架构图 

image.png 

微服务的实体数量是动态的,有可能是一台,也有可能是两台,有可能是100台1000台,我微服务的数量是弹性的,灵活弹性根据客户端的压力我来做弹性伸缩,我客户端调微服务的话,不是直接找微服务了,是先找注册中心,有哪些好的微服务,哪有哪些匹配的,比如我找订单微服务,就是找支付微服务,每次去找搜索,如有最新的列表给到,再去调用它们。客户端也可以按照各种负载均衡的策略去调,结合一些负载均衡的算法来做一个灵活的调度。 

 

二、Eureka注册中心开发实战 

Spring Eureka注册中心 

1. 创建Eureka服务注册中心项目 

2. 添加@EnableEurekaServer 

3. 将spring boot应用改造成Eureka服务注册中心 

4. application.properties增加配置 

5. 打包项目 

6. 运行 

7. 测试页面 

8.参考https://spring.io/guides/gs/serviceregistration-and-discovery/ 

image.png 

配置文件内容 

数据中心主要复杂的就是配置,如果记不住可以在文档里面拷贝过来。 

image.png 

配置中心正常的界面 

注意事项: 

image.png 

@EnableEurekaServer,主要是让服务具备注册中心的能力 

再进行配置文件,配置文件有几个核心参数,端口一定要配对。 

 

  1. Eureka底层原理与源码分析 

image.png 

image.png

相关文章
|
9天前
|
JSON Java API
利用Spring Cloud Gateway Predicate优化微服务路由策略
Spring Cloud Gateway 的路由配置中,`predicates`​(断言)用于定义哪些请求应该匹配特定的路由规则。 断言是Gateway在进行路由时,根据具体的请求信息如请求路径、请求方法、请求参数等进行匹配的规则。当一个请求的信息符合断言设置的条件时,Gateway就会将该请求路由到对应的服务上。
109 69
利用Spring Cloud Gateway Predicate优化微服务路由策略
|
28天前
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
154 69
从单体到微服务:如何借助 Spring Cloud 实现架构转型
|
25天前
|
Java Nacos Sentinel
Spring Cloud Alibaba:一站式微服务解决方案
Spring Cloud Alibaba(简称SCA) 是一个基于 Spring Cloud 构建的开源微服务框架,专为解决分布式系统中的服务治理、配置管理、服务发现、消息总线等问题而设计。
203 13
Spring Cloud Alibaba:一站式微服务解决方案
|
11天前
|
运维 监控 Java
为何内存不够用?微服务改造启动多个Spring Boot的陷阱与解决方案
本文记录并复盘了生产环境中Spring Boot应用内存占用过高的问题及解决过程。系统上线初期运行正常,但随着业务量上升,多个Spring Boot应用共占用了64G内存中的大部分,导致应用假死。通过jps和jmap工具排查发现,原因是运维人员未设置JVM参数,导致默认配置下每个应用占用近12G内存。最终通过调整JVM参数、优化堆内存大小等措施解决了问题。建议在生产环境中合理设置JVM参数,避免资源浪费和性能问题。
36 3
|
16天前
|
机器学习/深度学习 前端开发 算法
婚恋交友系统平台 相亲交友平台系统 婚恋交友系统APP 婚恋系统源码 婚恋交友平台开发流程 婚恋交友系统架构设计 婚恋交友系统前端/后端开发 婚恋交友系统匹配推荐算法优化
婚恋交友系统平台通过线上互动帮助单身男女找到合适伴侣,提供用户注册、个人资料填写、匹配推荐、实时聊天、社区互动等功能。开发流程包括需求分析、技术选型、系统架构设计、功能实现、测试优化和上线运维。匹配推荐算法优化是核心,通过用户行为数据分析和机器学习提高匹配准确性。
51 3
|
14天前
|
前端开发 搜索推荐 安全
陪玩系统架构设计陪玩系统前后端开发,陪玩前端设计是如何让人眼前一亮的?
陪玩系统的架构设计、前后端开发及前端设计是构建吸引用户、功能完善的平台关键。架构需考虑用户需求、技术选型、安全性等,确保稳定性和扩展性。前端可选用React、Vue或Uniapp,后端用Spring Boot或Django,数据库结合MySQL和MongoDB。功能涵盖用户管理、陪玩者管理、订单处理、智能匹配与通讯。安全性方面采用SSL加密和定期漏洞扫描。前端设计注重美观、易用及个性化推荐,提升用户体验和平台粘性。
44 0
|
29天前
|
消息中间件 运维 安全
后端开发中的微服务架构实践与挑战####
在数字化转型的浪潮中,微服务架构凭借其高度的灵活性和可扩展性,成为众多企业重构后端系统的首选方案。本文将深入探讨微服务的核心概念、设计原则、关键技术选型及在实际项目实施过程中面临的挑战与解决方案,旨在为开发者提供一套实用的微服务架构落地指南。我们将从理论框架出发,逐步深入至技术细节,最终通过案例分析,揭示如何在复杂业务场景下有效应用微服务,提升系统的整体性能与稳定性。 ####
39 1
|
30天前
|
消息中间件 运维 API
后端开发中的微服务架构实践####
本文深入探讨了微服务架构在后端开发中的应用,从其定义、优势到实际案例分析,全面解析了如何有效实施微服务以提升系统的可维护性、扩展性和灵活性。不同于传统摘要的概述性质,本摘要旨在激发读者对微服务架构深度探索的兴趣,通过提出问题而非直接给出答案的方式,引导读者深入
45 1
|
Dubbo Java 应用服务中间件
深入了解Spring Cloud Alibaba Dubbo
在现代分布式系统开发中,构建高性能、可伸缩性和弹性的微服务架构变得越来越重要。Spring Cloud Alibaba Dubbo(简称Dubbo)是一个开源的分布式服务框架,可以帮助开发者构建强大的微服务架构,具备负载均衡、服务治理、远程调用等强大功能。本文将深入介绍Spring Cloud Alibaba Dubbo,帮助你理解它的核心概念、工作原理以及如何在你的项目中使用它。
|
Kubernetes Java 微服务
Spring Boot 单体应用一键升级成 Spring Cloud Alibaba(1)
Spring Boot 单体应用一键升级成 Spring Cloud Alibaba(1)
152 0
Spring Boot 单体应用一键升级成 Spring Cloud Alibaba(1)