搜索
首页Javajava教程使用 Java Spring Boot 和 Angular 构建可扩展的微服务应用程序

第 1 部分 - 第一次咨询


你看,虽然我和其他人一样喜欢微服务,但我是否认为它们处理和调试起来非常令人头疼?是的。但是,微服务架构在开发人员和招聘人员中是一个热门话题,如果我不将自己的大型可扩展项目放入沙箱中,该项目已准备好投入生产,同时又保持低成本或不存在成本,那么我就错了,因为嘿,我们都破产了。 


场景:

恭喜!您被 IceToMeetYou Inc. 聘为顾问,他们正在寻求将当前的运输管理软件升级为更加定制的解决方案。 IceToMeetYou Inc. 是一家初创公司,其产品刚刚获得约 30 亿美元的融资,该产品向被困在沙漠中的一个人出售进口冰块。他们当前的任务管理软件太小,功能有限,无法处理所有传入的货物,这个人(我们称他为丹尼斯)需要保持他的冰沙冷。他们想要建立一些任务管理系统,可以处理来自丹尼斯的多个传入订单直至完成,将订单分配给运送冰块的工企鹅,跟踪所述企鹅的进度并接收状态更新的实时通知。首席执行官表示,请随时提出任何有助于建设该项目的问题。当我们开始考虑项目构建时,我们将这样做......


技术堆栈:

对于这个项目,我们将使用以下技术堆栈:

后端:Java Spring Boot,因为它是构建 REST API 和微服务的强大框架,提供了广泛的工具,例如服务发现、云部署和用于事件驱动系统的 Kafka。
前端: Angular 拥有强大的前端框架和用于全局状态管理的 NgRx
数据库: MySQL/PostgreSQL(用于关系数据)、MongoDB(用于任务数据)
实时更新: Kafka(用于事件流)和 WebSockets
部署:用于编排的 Docker 和 Kubernetes
测试: JUnit、Jest 和 K6(用于负载和性能测试)


大局观:

这里的主要目的是演示 Web 应用程序时的所有可移动部分。虽然这个列表并不详尽,但目标是用简单的英语涵盖许多基础,以便这个过程是可重复的,并且在考虑企业应用程序时不费吹灰之力。对于每个部分,我将通过深入博客、代码演示、图表、思维过程展示从设计到部署到通过 V1 MVP 的每个步骤,最重要的是,始终确保我们正在解决问题。

微服务架构:

 → 设计原则: 理解和实现微服务原则,例如服务独立性、可扩展性和容错性
 → 服务隔离:如何分离成自己关注的领域,
 → 服务间通信: 选择通信策略(REST API、Kafka、WebSockets)并处理跨服务的数据一致性。

使用 Spring Boot 进行后端开发:

 → 服务开发: 使用 Spring Boot 实现各个服务,处理 RESTful 端点,并确保正确隔离关注点。
 → 身份验证和安全性: 使用 JWT、OAuth 和 Spring Security 进行安全的用户身份验证和基于角色的访问控制。
 → 数据库管理: 设置关系型 (MySQL/PostgreSQL) 和 NoSQL (MongoDB) 数据库、优化微服务的数据存储以及处理数据迁移。

使用 Angular 进行前端开发:

用户界面设计: 使用 Angular 创建无缝用户体验
 → 状态管理: 使用 NgRx 处理应用程序状态,以实现一致、反应式的用户交互。
 → API 集成: 通过 RESTful API 将 Angular 前端连接到 Spring Boot 后端服务并安全地管理数据传输。

实时数据通信和通知:

Websockets 和事件流: 实现 WebSockets 以实现即时更新,并实现 Kafka 以在服务之间实现可靠的事件流。
 → 推送通知: 向用户提供实时更新,确保高效的消息分发而不造成服务过载。

性能测试和监控:

负载测试: 使用 K6 评估负载下的系统,识别瓶颈,并优化微服务的性能。
 → 日志记录和监控: 使用 ELK 或替代工具实现日志记录,跟踪应用程序运行状况,并为严重故障设置警报。

部署和扩展:

使用 Docker 进行容器化: 为每个服务构建 Docker 镜像,建立一致的运行时环境以方便扩展。
 → 使用 Kubernetes 进行编排: 使用 Kubernetes 来管理部署、自动扩展、负载平衡和弹性。
 → 云托管:云平台(AWS、Azure、GCP)上的托管服务,涵盖成本效率、安全性和可靠性等方面。

演出前的一些最后想法......

Building a Scalable Microservices Application with Java Spring Boot and Angular

对于初学者来说,它是一个沙箱,因此该项目是为了学习和演示而构建的。这里需要注意的是:这是一个 100% 过度设计的解决方案,由一个坐在地下室的人从头开始构建。事情没那么严重。 

我每天都会更新并致力于这个项目,所以期待频繁的更新! 

这也是对团队环境中开发的一种练习,因此我们将在“冲刺”中工作,通过回顾(我猜是我自己?)来实现我们的目标,看看哪些是正确的,哪些是正确的出了问题,我们遇到了哪些阻碍以及我们如何解决它们。 我将每 5 个帖子左右更新一次快速回顾。

还有一件事……我总是渴望得到反馈。如果有些事情没有意义或不够清楚,请在评论中告诉我。 

所以,时间不早了,Sprint 1 明天就要开始了,坚持住,这将是漫长的一天……

以上是使用 Java Spring Boot 和 Angular 构建可扩展的微服务应用程序的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
JVM如何促进Java的'写作一次,在任何地方运行”(WORA)功能?JVM如何促进Java的'写作一次,在任何地方运行”(WORA)功能?May 02, 2025 am 12:25 AM

JVM通过字节码解释、平台无关的API和动态类加载实现Java的WORA特性:1.字节码被解释为机器码,确保跨平台运行;2.标准API抽象操作系统差异;3.类在运行时动态加载,保证一致性。

Java的较新版本如何解决平台特定问题?Java的较新版本如何解决平台特定问题?May 02, 2025 am 12:18 AM

Java的最新版本通过JVM优化、标准库改进和第三方库支持有效解决平台特定问题。1)JVM优化,如Java11的ZGC提升了垃圾回收性能。2)标准库改进,如Java9的模块系统减少平台相关问题。3)第三方库提供平台优化版本,如OpenCV。

说明JVM执行的字节码验证的过程。说明JVM执行的字节码验证的过程。May 02, 2025 am 12:18 AM

JVM的字节码验证过程包括四个关键步骤:1)检查类文件格式是否符合规范,2)验证字节码指令的有效性和正确性,3)进行数据流分析确保类型安全,4)平衡验证的彻底性与性能。通过这些步骤,JVM确保只有安全、正确的字节码被执行,从而保护程序的完整性和安全性。

平台独立性如何简化Java应用程序的部署?平台独立性如何简化Java应用程序的部署?May 02, 2025 am 12:15 AM

Java'splatFormIndepentEncealLowsApplicationStorunonAnyOperatingsystemwithajvm.1)singleCodeBase:writeandeandcompileonceforallplatforms.2)easileupdates:updatebybytecodeforsimultaneDeployment.3)testOnOneOnePlatForforuluniverSalpeforuluniverSaliver.4444.4444

Java的平台独立性如何随着时间的流逝而发展?Java的平台独立性如何随着时间的流逝而发展?May 02, 2025 am 12:12 AM

Java的平台独立性通过JVM、JIT编译、标准化、泛型、lambda表达式和ProjectPanama等技术不断增强。自1990年代以来,Java从基本的JVM演进到高性能的现代JVM,确保了代码在不同平台的一致性和高效性。

在Java应用程序中缓解平台特定问题的策略是什么?在Java应用程序中缓解平台特定问题的策略是什么?May 01, 2025 am 12:20 AM

Java如何缓解平台特定的问题?Java通过JVM和标准库来实现平台无关性。1)使用字节码和JVM抽象操作系统差异;2)标准库提供跨平台API,如Paths类处理文件路径,Charset类处理字符编码;3)实际项目中使用配置文件和多平台测试来优化和调试。

Java的平台独立性与微服务体系结构之间有什么关系?Java的平台独立性与微服务体系结构之间有什么关系?May 01, 2025 am 12:16 AM

java'splatformentenceenhancesenhancesmicroservicesharchitecture byferingDeploymentFlexible,一致性,可伸缩性和便携性。1)DeploymentFlexibilityAllowsibilityAllowsOllowsOllowSorlowsOllowsOllowsOllowSeStorunonAnyPlatformwithajvM.2)penterencyCrossServAccAcrossServAcrossServiCessImplifififiesDeevelopmentandeDe

GRAALVM与Java的平台独立目标有何关系?GRAALVM与Java的平台独立目标有何关系?May 01, 2025 am 12:14 AM

GraalVM通过三种方式增强了Java的平台独立性:1.跨语言互操作,允许Java与其他语言无缝互操作;2.独立的运行时环境,通过GraalVMNativeImage将Java程序编译成本地可执行文件;3.性能优化,Graal编译器生成高效的机器码,提升Java程序的性能和一致性。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。