【SpringCloud微服务实战】搭建企业级应用开发框架(一):架构说明

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: SpringCloud分布式应用微服务系统组件列表:• 微服务框架组件:Spring Boot2 + SpringCloud Hoxton.SR8 + SpringCloud Alibaba• Spring Boot Admin: 管理和监控SpringBoot应用程序的微服务健康状态• 数据持久化组件:MySql + Druid + MyBatis + MyBatis-Plus

SpringCloud分布式应用微服务系统架构图:

微信截图_20220518133130.png

                                springcloud微服务系统架构图


SpringCloud分布式应用微服务系统组件列表:


  • 微服务框架组件:Spring Boot2 + SpringCloud Hoxton.SR8 + SpringCloud Alibaba


  • Spring Boot Admin: 管理和监控SpringBoot应用程序的微服务健康状态


  • 数据持久化组件:MySql + Druid + MyBatis + MyBatis-Plus


  • Mycat: 中间件实现数据库读写分离


  • Seata: 分布式事务管理,跨服务的业务操作保持数据一致性


  • 高性能的key-value缓存数据库:Redis + RedissonClient + RedisTemplate


  • API接口文档:  Swagger2 + knife4j


  • 接口参数校验:spring-boot-starter-validation


  • Nacos:一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台


  • Sentinel:把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性


  • OpenFeign:  微服务架构下服务之间的调用的解决方案 + Ribbon实现负载均衡/高可用重试机制


  • Gateway:  微服务路由转发 + 聚合knife4j微服务文档 + 【Gateway+OAuth2+JWT微服务统一认证授权】


  • Oauth2:SpringSecurity单点登录功能支持多终端认证授权 + RBAC权限框架


  • 验证码:集成滑动验证码【AJ-Captcha】 + 图片验证码【EasyCaptcha】


  • 多租户:  基于Mybatis-Plus【TenantLineInnerInterceptor】插件实现多租户功能


  • 数据权限:  基于Mybatis-Plus【DataPermissionHandler】分页插件实现可配置的数据权限功能


  • 对象存储服务( OSS):MinIO + 阿里云 + 七牛云 + 腾讯云 + 百度云 + 华为云


  • 工作流:Flowable轻量级业务流程引擎


  • XXL-JOB:分布式任务调度平台,作业调度系统


  • Ant-design-vue + ElementUI (基础)优秀流行的前端开源框架整合


  • uni-app: 可发布到iOS、Android、Web(响应式)、以及各种小程序(微信/支付宝/百度/头条/QQ/钉钉/淘宝)、快应用等多个平台 (本框架中主要用于H5、小程序)


  • Flutter:  给开发者提供简单、高效的方式来构建和部署跨平台、高性能移动应用 (本框架中主要用于移动应用)


  • EKL:  Elasticsearch + Logstash + Kibana分布式日志监控平台


  • 代码生成器: 基于Mybatis-Plus代码生成插件开发的,便捷可配置的代码生成器


  • Keepalived + Nginx: 高可用 + 高性能的HTTP和反向代理web服务器


  • DevOps : kubernetes + docker + jenkins 实现持续集成(CI)和持续交付(CD)


  • 数据报表:基于Ant-design-vue + Echarts实现的自定义数据可视化报表


GitEgg-Cloud是一款基于SpringCloud整合搭建的企业级微服务应用开发框架,开源项目地址:


Gitee: https://gitee.com/wmz1930/GitEgg


GitHub: https://github.com/wmz1930/GitEgg


欢迎感兴趣的小伙伴Star支持一下。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1天前
|
运维 负载均衡 Cloud Native
云原生架构技术之云原生微服务
微服务模式将后端单体应用拆分为松耦合的多个子应用,每个子应用负责一组子功能。这些子应用称为“微服务”,多个“微服务”共同形成了一个物理独立但逻辑完整的分布式微服务体系。这些微服务相对独立,通过解耦研发、测试与部署流程,提高整体迭代效率。此外,微服务模式通过分布式架构将应用水平扩展和冗余部署,从根本上解决了单体应用在拓展性和稳定性上存在的先天架构缺陷。但也要注意到微服务模型也面临着分布式系统的典型挑战:如何高效调用远程方法、如何实现可靠的系统容量预估、如何建立负载均衡体系、如何面向松耦合系统进行集成测试、如何面向大规模复杂关联应用的部署与运维。
12 4
|
2天前
|
消息中间件 数据库 网络架构
构建高效后端:微服务架构的优化策略
【5月更文挑战第31天】在这篇文章中,我们将深入探讨如何通过采用微服务架构来提升后端开发的效率和性能。我们将分析微服务架构的关键优势,并讨论如何克服实施过程中的挑战。通过具体的案例研究,我们将展示如何优化微服务架构以实现最佳的性能和可维护性。无论你是后端开发的新手还是经验丰富的专业人士,这篇文章都将为你提供有价值的见解和实用的技巧。
|
2天前
|
敏捷开发 负载均衡 监控
探索微服务架构下的API网关设计与实践
【5月更文挑战第31天】本文将深入剖析微服务架构中的关键组件——API网关,探讨其设计理念、核心功能以及在实际项目中的应用。我们将从API网关的基本概念出发,逐步展开对其路由、负载均衡、认证授权、监控日志等方面的详细讨论,并结合实际案例,分析如何高效地实现和管理一个稳定的API网关。
|
2天前
|
监控 应用服务中间件 API
探索微服务架构中的API网关模式
【5月更文挑战第31天】在这篇文章中,我们将深入探讨微服务架构中的关键组件——API网关。我们将了解API网关的定义、功能以及它如何优化微服务的通信流程,提高安全性和性能。此外,我们还将讨论一些常见的API网关实现技术,并分析它们的优势和局限性。
|
2天前
|
缓存 监控 安全
微服务架构下的API网关设计与实践
【5月更文挑战第31天】本文深入探讨了在微服务架构中,API网关的核心作用与设计策略。通过分析网关的职责、选型标准及实现细节,文章为读者提供了一套完整的API网关解决方案。同时,结合具体案例,展示了如何在实际应用中有效部署和优化API网关,确保系统的高可用性和可扩展性。
|
2天前
|
监控 安全 API
微服务架构下的API网关设计原则
【5月更文挑战第31天】在本文中,我们将深入探讨微服务架构下API网关的设计原则。API网关作为微服务架构的入口点,其设计至关重要。我们将从性能、安全性、可扩展性等方面进行分析,并提出一些实用的设计建议。
|
2天前
|
负载均衡 测试技术 API
探索微服务架构中的API网关
【5月更文挑战第31天】在这篇文章中,我们将深入探讨微服务架构中的一个关键组件——API网关。我们将了解它的定义、作用以及如何有效地实现它。此外,我们还将讨论一些最佳实践和可能遇到的挑战。
|
2天前
|
运维 负载均衡 安全
探索微服务架构下的API网关设计与实现
【5月更文挑战第31天】在这篇文章中,我们将深入探讨微服务架构的关键组成部分——API网关。通过分析API网关的核心功能、设计原则以及实现技术,本文旨在为读者提供一个关于如何构建和维护高效、可靠的API网关的全面视角。我们将从API网关的基本概念出发,逐步深入到其在微服务架构中的作用,以及如何选择合适的技术栈来实现这一目标。最后,我们将通过一个具体的案例分析,展示API网关在实际项目中的应用和优化策略。
|
2天前
|
存储 数据库 微服务
探索微服务架构下的数据一致性挑战
【5月更文挑战第31天】在微服务架构的浪潮中,数据一致性问题如同潜藏的礁石,随时可能让航船触礁。本文将深入探讨微服务架构下数据一致性的挑战,揭示分布式事务的复杂性,并分享实现最终一致性的策略与实践。通过案例分析,我们将一探究竟如何在保证系统高可用的同时,确保数据的完整性和准确性。
|
2天前
|
监控 持续交付 API
探索微服务架构的高效之路
【5月更文挑战第31天】在数字化浪潮下,企业后端架构正面临前所未有的挑战与机遇。本文将深入探讨微服务架构的核心优势,揭示其如何提升开发效率、促进敏捷迭代,并确保系统的高可用性与扩展性。我们将从理论到实践,一步步剖析微服务设计的关键要素,并通过实际案例分析,展示如何在复杂业务场景中灵活运用微服务原则,以应对快速变化的市场需求。