开发订单微服务与注册调用|学习笔记(一)

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 快速学习开发订单微服务与注册调用

开发者学堂课程【5天突破 Spring Cloud开发订单微服务与注册调用】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/781/detail/13701


开发订单微服务与注册调用

 

内容介绍:

一、引入 Spring Cloud 微服务 API

二、把 Spring Cloud 微服务 API 发布到注册中心

三、结语

 

一、引入 Spring Cloud 微服务 API

image.png

1、基础知识

现已有注册中心,上图中的Eureka可以使用,但是后续的更新维护基本上停掉了,可以作为学习的一个入门点,其中很多经典的思想影响了后续类似的技术,包括concern网络、阿里出的功能实际可以认为是增强版的Eureka,它的功能更强更丰富,但在基础功能两者之间事有很多相似点的。现在有了注册中心,加入单点用于开发和测试环节,正式环境时推荐多点模式,当只有一个注入中心、一个程序的时候,以防程序挂掉,无法提供注册服务、参与服务。

2、微服务基本构架

开发一个服务程序并构建起基本架构。服务程序可以参照训练营课程中的技术去改造,回顾之前课程中提到的问题:做简单的网站开发或者简单的网站后台技术开发,实际上升到微服务架构的问题上。如果公司业务架构具有架构升级的发展需要,典型代表就是微服务架构,微服务程序主要是基于HTTP协议的具有API风格的应用程序后台接口,之前的某些概念依然适用,比如像集群的概念。

拆体现了很重要的分割思想,大型的互联网平台中的很多功能会拆分出来,比如订单、支付、快递、评论、点赞、会员、营销、用户行为数据等接口都可以拆分出来,但是有些接口在后台进行部署的时候,可能会进行数量的更改,可能早期部署两台,后期随着业务增长可能部署100台甚至1000台。

3、典型案例

典型案例就是淘宝,淘宝在创业公司阶段的时候可能只有一两台服务器,业务发展到今天,它的服务器数量达到了上万台,这和其业务规模有很大的关系。同样的,有很多游戏公司也会出现这种典型的场景,发布一款游戏,前期可能只需要几十台游戏服务器,一旦用户量暴增需要随时扩容,比如游戏的接口、游戏语音聊天的接口,接口可以随着用户量的增长而增加。像腾讯开发的一款游戏穿越火线,而腾讯的游戏部门上线了很多游戏,前期可能只有几台服务器,如果没有太多人玩这款游戏,后期就没必要为这款游戏分配服务器,根据业务的不断变化去进行集群规模的提升与伸缩,即弹性集群,可以做到张弛有度,这就是比较好的集群架构。

微服务架构同样如此,开发一个订单服务,前期没有用户的时候,几台服务器就可以满足需求,节约服务器资源,后期用户较多的时候可以进行集群数量的提升,随时需要随时加服务器也可以,如今服务器实例的启动、部署是十分便捷高效的快,这应用了一个很重要的技术doccer,互联网公司普遍使用这种模式。

客户端严格来说实际是不限制程序类型的,可以是APP,也可以是网页小程序或者是其他语言的程序,因为接口写好以后数据格式的协议都是固定的,大家按照这种模式进行交互就可以了。

 

二、把 Spring Cloud 微服务 API 发布到注册中心

1、开发 Spring Cloud 微服务 API

下面进行模拟订单服务,订单服务可以拿之前实战训练营三层架构的订单例子做实验,甚至可以把数据库连接起来,一步步将工作组合。但之前写的spring boot程序和spring cloud 有一部分的区别。

image.pngspring boot是微服务架构学习很重要的基础,如果不理解spring boot,在后面开发的话也很困难,很多功能、组件无法使用,不论三层架构还是五层架构,还是N层架构,架构的分法后期可以根据业务情况进行动态的升级改造,升级改造很重要的一点是要体现出和注册中心的联系,作为一个程序需要完成注册。

以现实生活为例,所有的居民如果实现自治,比如原始部落,大家都不登记,也不注册,通过数人数就可以知道本部落的人口,一旦人口数量增多,就需要通过登记来管理。

Eureka就是充当这种角色。大家到公司入职需要进行入职登记,像我们国家现有的制度——居住证,可以证明你在某个城市居住过,这也是类似与Eureka的模式。

服务器集群数量可以多可以少,现实生活中也是一样的,有的城市人口数量呈爆炸性增长,属于人口迁入城市,有的城市人口可能下降,属于人口迁出城市。一个普通的程序要想做到注册,比较简单的方式是可以通过添加依赖的方式扩展程序,让它具备注册功能,利用了Eureka客户端的依赖.

image.png在spring boot基础上稍作改造就成为了订单微服务,spring boot属于微服务的垫脚石,也是十分重要的,大家需要系统地了解学习。

相关文章
|
10天前
|
Java 持续交付 微服务
后端开发中的微服务架构实践与挑战####
本文深入探讨了微服务架构在现代后端开发中的应用,通过具体案例分析,揭示了其如何助力企业应对业务复杂性、提升系统可维护性和可扩展性。文章首先概述了微服务的核心概念及其优势,随后详细阐述了实施微服务过程中的关键技术选型、服务拆分策略、容错机制以及持续集成/持续部署(CI/CD)的最佳实践。最后,通过一个真实世界的应用实例,展示了微服务架构在实际项目中的成功应用及其带来的显著成效。 ####
|
3天前
|
缓存 运维 监控
后端开发中的微服务架构实践与挑战#### 一、
【10月更文挑战第22天】 本文探讨了微服务架构在后端开发中的应用实践,深入剖析了其核心优势、常见挑战及应对策略。传统后端架构难以满足快速迭代与高可用性需求,而微服务通过服务拆分与独立部署,显著提升了系统的灵活性和可维护性。文章指出,实施微服务需关注服务划分的合理性、通信机制的选择及数据一致性等问题。以电商系统为例,详细阐述了微服务改造过程,包括用户、订单、商品等服务的拆分与交互。最终强调,微服务虽优势明显,但落地需谨慎规划,持续优化。 #### 二、
|
9天前
|
监控 API 开发者
后端开发中的微服务架构实践与优化
【10月更文挑战第17天】 本文深入探讨了微服务架构在后端开发中的应用及其优化策略。通过分析微服务的核心理念、设计原则及实际案例,揭示了如何构建高效、可扩展的微服务系统。文章强调了微服务架构对于提升系统灵活性、降低耦合度的重要性,并提供了实用的优化建议,帮助开发者更好地应对复杂业务场景下的挑战。
15 7
|
7天前
|
运维 监控 API
后端开发中的微服务架构实践与挑战####
【10月更文挑战第19天】 本文将深入浅出地探讨微服务架构在后端开发中的应用,通过实例解析其核心理念、优势所在,以及实施过程中可能遭遇的挑战与应对策略。不同于传统单体应用,微服务以其轻量级、灵活性和可扩展性受到青睐,但同时也带来了服务间的通信复杂性、数据一致性等问题。通过本篇文章,读者将对微服务架构有一个全面而深入的理解,为实际项目中的选型与实施提供参考。 ####
|
11天前
|
负载均衡 监控 API
后端开发中的微服务架构实践
【10月更文挑战第15天】 在当今的软件开发领域,微服务架构已成为一种流行的技术趋势。本文将探讨微服务架构的基本概念、优势以及在实际后端开发中的应用。我们将通过具体案例分析,了解如何设计和实现一个高效的微服务系统,以及如何应对在实施过程中可能遇到的挑战。
26 1
|
2月前
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
2月前
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1
|
3月前
|
Kubernetes Cloud Native Docker
云原生之旅:从容器到微服务的架构演变
【8月更文挑战第29天】在数字化时代的浪潮下,云原生技术以其灵活性、可扩展性和弹性管理成为企业数字化转型的关键。本文将通过浅显易懂的语言和生动的比喻,带领读者了解云原生的基本概念,探索容器化技术的奥秘,并深入微服务架构的世界。我们将一起见证代码如何转化为现实中的服务,实现快速迭代和高效部署。无论你是初学者还是有经验的开发者,这篇文章都会为你打开一扇通往云原生世界的大门。
|
3月前
|
负载均衡 应用服务中间件 持续交付
微服务架构下的Web服务器部署
【8月更文第28天】随着互联网应用的不断发展,传统的单体应用架构逐渐显露出其局限性,特别是在可扩展性和维护性方面。为了解决这些问题,微服务架构应运而生。微服务架构通过将应用程序分解成一系列小型、独立的服务来提高系统的灵活性和可维护性。本文将探讨如何在微服务架构中有效部署和管理Web服务器实例,并提供一些实际的代码示例。
100 0
|
23天前
|
Kubernetes 安全 微服务
使用 Istio 缓解电信 5G IoT 微服务 Pod 架构的安全挑战
使用 Istio 缓解电信 5G IoT 微服务 Pod 架构的安全挑战
43 8