【项目技术介绍篇】若依开源项目RuoYi-Cloud后端技术介绍

作者介绍:本人笔名姑苏老陈,从事JAVA开发工作十多年了,带过大学刚毕业的实习生,也带过技术团队。最近有个朋友的表弟,马上要大学毕业了,想从事JAVA开发工作,但不知道从何处入手。于是,产生了写一个博客专栏想法,介绍当前互联网企业JAVA项目开发如何快速入门。

本文收录于《30天企业JAVA项目开发实战入门》专栏,该专栏内容以当前互联网软件企业中的项目实战为线索,介绍企业JAVA项目开发中涉及到的开发流程、技术、工具、规范要求等等。帮助想从事JAVA开发的大学生或新人,更快的、更好的入门JAVA后端开发工作。

文章目录

    • 一、前言
    • 二、技术介绍
      • 2.1 工程结构介绍
      • 2.2 技术架构介绍
        • 2.2.1 核心组件
        • 2.2.2 数据存储中间件
        • 2.2.3 其他中间件组件
    • 三、总结

一、前言

由于本专栏项目实战学习,是以若依开源项目RuoYi-Cloud为示例。所以,本文介绍一下若依开源项目RuoYi-Cloud后端技术;

  • 若依项目RuoYi-Cloud简介

    若依项目RuoYi-Cloud 是一个 Java EE 企业级的开源免费的快速开发平台,是一个基于Spring Boot、Spring Cloud & Alibaba的微服务的权限管理系统。如果想快速的开发一个Java EE 企业级项目,可以在若依项目的基础上,开发定制自己的项目。尤其是如果要开发一个后台管理系统,由于若依开源项目中已经内置完整的权限管理模块,所以能够更加快速的完成项目的开发工作;

  • 若依项目RuoYi-Cloud技术选型

采用前后端分离的模式,微服务版本前端基于 Vue/Element UI ;
后端采用Spring Boot、Spring Cloud & Alibaba微服务架构;
注册中心、配置中心选型Nacos,权限认证使用Redis;
流量控制框架选型Sentinel,分布式事务选型Seata;

  • 若依项目官方网站和文档地址

若依官网地址:https://www.ruoyi.vip/

若依演示地址:https://vue.ruoyi.vip/login

技术文档地址:https://doc.ruoyi.vip/ruoyi-cloud/

代码下载地址:https://gitee.com/y_project/RuoYi-Cloud

二、技术介绍

2.1 工程结构介绍

如下是若依项目RuoYi-Cloud工程的目录结构:

com.ruoyi     
├── ruoyi-ui              // 前端框架 [80]
├── ruoyi-gateway         // 网关模块 [8080]
├── ruoyi-auth            // 认证中心 [9200]
├── ruoyi-api             // 接口模块
│       └── ruoyi-api-system                          // 系统接口
├── ruoyi-common          // 通用模块
│       └── ruoyi-common-core                         // 核心模块
│       └── ruoyi-common-datascope                    // 权限范围
│       └── ruoyi-common-datasource                   // 多数据源
│       └── ruoyi-common-log                          // 日志记录
│       └── ruoyi-common-redis                        // 缓存服务
│       └── ruoyi-common-seata                        // 分布式事务
│       └── ruoyi-common-security                     // 安全模块
│       └── ruoyi-common-swagger                      // 系统接口
├── ruoyi-modules         // 业务模块
│       └── ruoyi-system                              // 系统模块 [9201]
│       └── ruoyi-gen                                 // 代码生成 [9202]
│       └── ruoyi-job                                 // 定时任务 [9203]
│       └── ruoyi-file                                // 文件服务 [9300]
├── ruoyi-visual          // 图形化管理模块
│       └── ruoyi-visual-monitor                      // 监控中心 [9100]
├──pom.xml   

目录结构使用说明如下:

  • ruoyi-ui ,前端工程目录,在实际项目开发中,由于是采用前后端分离模式的,该目录会单独剥离出来,成为一个独立的前端工程,由专门的前端开发人员进行管理维护;

  • ruoyi-gateway,网关模块,包括路由转发、异常处理、限流、降级、接口、鉴权等等,是系统对外提供接口服务的唯一入口;

  • ruoyi-auth,认证模块,包括登录认证,系统退出,刷新令牌等等,用于判断一个用户是否为合法用户的处理过程;

  • ruoyi-api,接口模块,即内部的微服务模块之间,需要提供接口给对方调用,需要在接口模块中进行定义;如ruoyi-api-system中提供系统接口;

  • ruoyi-common,通用模块,即在这里封装各个模块公用的方法,包括核心模块、权限范围、多数据源、日志记录、系统接口等等;

  • ruoyi-modules,业务模块,即在这里定义项目中的业务模块(也叫微服务),比如用户模块、订单模块、商品模块等等跟项目实际业务相关的模块;

  • ruoyi-visual,微服务状态监控模块,一个图形化管理工具,用来对系统中的所有微服务的状态进行监控;

2.2 技术架构介绍

若依项目RuoYi-Cloud后端技术架构采用了阿里巴巴开源的Spring Cloud Alibaba微服务开发解决方案。(PS:官方地址:https://sca.aliyun.com/zh-cn/)

在这里插入图片描述

2.2.1 核心组件
  • Gateway:服务网关,基于Spring生态系统之上构建的API网关,包括:Spring 5.x,Spring Boot 2.x和Project Reactor,是系统对外提供接口访问的唯一入口。

  • Nacos:配置管理、服务注册和发现,是阿里巴巴开源的一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

  • Robbin :负载均衡,是 Netflix 发布的一个负载均衡器,提供一系列完善的配置项如连接超时,重试等;

  • Feign :一个声明式Http端调用,集成了Robbin的负载均衡功能,使得Eureka和Ribbon的使用更加简单。

  • Sleuth - 服务追踪,将一次分布式请求还原成调用链路,进行日志记录,性能监控并将一次分布式请求的调用情况集中展示出来。

  • Sentinel:服务流量治理,是阿里巴巴开源的一款微服务流量治理组件,主要以流量为切入点,从流量限流、熔断降级、系统负载保护等多个维度来帮助开发者保障微服务的稳定性,类似于Springcloud Hystrix组件;

2.2.2 数据存储中间件
  • Minio/FastDFS/OSS:分布式文件存储服务,即将数据存储在多个存储服务器上,并使用这些分布式存储资源形成一个虚拟存储设备。

  • ElasticSearch:数据检索服务,是一个开源的分布式搜索和分析引擎,它被广泛用于构建实时的、可扩展的搜索和分析应用程序,主要作用是存储、搜索和分析大量的数据。

  • Redlis:缓存服务,是一个开源的内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理。

  • Mysql :是最流行的关系型数据库管理系统之一,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,大部分项目开发都会选择 MySQL作为数据库。

2.2.3 其他中间件组件
  • SpringBootAdmin Server:服务监控中心,可以用来监控服务是否健康、是否在线、以及一些jvm数据等等;

  • Ruoyi-auth:认证中心,包括登录认证,系统退出,刷新令牌等等,用于判断一个用户是否为合法用户的处理过程;

  • Quartz /XXL-Job:分布式任务调度系统,用于在分布式环境下,定时任务的管理与执行;

  • Zipkin/sky Walking:链路监控服务中心,用于对微服务系统调用链监控,记录服务之间的请求过程;Zipkin是 Twitter 开源的调用链分析工具,目前基于 SpringCloud Sleuth 得到了广泛的使用,特点是轻量,使用部署简单;是本土开源的基于字节码注入的调用链分析,以及应用监控分析工具。特点是支持多种插件,UI 功能较强,接入端无代码侵入。目前已加入 Apache 孵化器。

  • ELK:日志聚合系统,ELK是Elasticsearch(ES) , Logstash, Kibana的结合,是一个开源日志收集软件。

  • RabbitMQ/KAFKA:消息队列,是一种在应用间或应用内不同组件间传递消息的通信模式,它允许消息在发送者和接收者之间异步地传递。在实际应用中,消息队列常用于处理大量请求、异步任务、事件驱动等场景。

三、总结

以上,本文介绍了若依开源项目RuoYi-Cloud中后端工程结构。另外,对技术框架做了简单的介绍。

如果您对文章中内容有疑问,欢迎在评论区进行留言,我会尽量抽时间给您回复。如果文章对您有帮助,欢迎点赞、收藏。您的点赞,是对我最大的支持和鼓励,谢谢 :-)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/577444.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用友BI告诉你,分析指标计算也可以很简单

分析数据,特别是分析财务数据,要计算得分析指标都非常多,涉及的数据来源也是各有不同,一旦哪个环节出了错就一切都得重来。难道分析指标的计算就没有更快更简单的办法了?奥威-用友BI告诉你,分析指标计算有别…

项目模块—实现抑郁测评(小程序)

script <script setup> import { ref } from "vue";//控制轮播图页码 let current ref(0);//答题逻辑 const add (value) > {if (current.value < 9) {current.value current.value 1;} else {uni.switchTab({url: "/pages/my/my",});} }…

学习【Redis实战篇】这一篇就够了

目录 1. 短信登录1-1. 技术点redis存储token拦截器刷新token有效期 1-2. 业务登录注册 2. 商户查询缓存1-1. 技术点缓存更新策略缓存穿透缓存雪崩缓存击穿 1-2. 业务查询缓存的商铺信息 3. 优惠卷秒杀3-1. 技术点全局唯一ID乐观锁基于Redis实现分布式锁基于Redisson实现分布式锁…

JSes6语法和Json快速入门

对象操作 对象的crud 创建对象&#xff1a;let obj{} 新增属性&#xff1a;ojb.a1 修改属性&#xff1a;ojb.a2 查询属性&#xff1a;obj.a 删除属性&#xff1a;delete obj.a 其他操作 obj[a]1 Object.assign() //深拷贝&#xff1f;浅拷贝 let{ name} user &#x…

常用类(日期时间)

目录 一、JDK 8之前的日期时间API1.1、System类中获取时间戳的方法1.2、Java中两个Date类的使用1.3、SimpleDateFormat的使用1.4、Calendar日历类的使用 二、JDK8中日期时间API的介绍2.1、LocalDate、LocalTime、LocalDateTime的使用2.2、Instant类的使用2.3、DateTimeFormatte…

数据结构——lesson11排序之快速排序

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…

数据结构刷题篇 之 【力扣二叉树基础OJ】详细讲解(含每道题链接及递归图解)

有没有一起拼用银行卡的&#xff0c;取钱的时候我用&#xff0c;存钱的时候你用 1、相同的树 难度等级&#xff1a;⭐ 直达链接&#xff1a;相同的树 2、单值二叉树 难度等级&#xff1a;⭐ 直达链接&#xff1a;单值二叉树 3、对称二叉树 难度等级&#xff1a;⭐⭐ 直达…

原来这就是线程安全(一)

TOC 一:什么是线程不安全?? 先看一段代码: public class Demo1 {public static int count 0;public static void main(String[] args) throws InterruptedException {Thread t1new Thread(()->{for (int i 0; i < 50000; i) {count;}});Thread t2new Thread(()-&g…

【C语言】——指针六:冒泡排序与qsort函数的实现

【C语言】——指针六&#xff1a;冒泡排序与qsort函数 一、冒泡排序1.1、冒泡排序的原理1.2、用代码实现冒泡排序 二、qsort函数2.1、qsort函数的定义2.2、 qosrt函数的使用&#xff08;1&#xff09;比较函数的写法&#xff08;2&#xff09;使用 q s o r t qsort qsort 函数…

C语言编译与链接

前言 我们想一个问题&#xff0c;我们写的C语言代码都是文本信息&#xff0c;电脑能直接执行c语言代码吗&#xff1f;肯定不能啊&#xff0c;计算机能执行的是二进制指令&#xff0c;所以将C语言转化为二进制指令需要一段过程&#xff0c;这篇博客讲一下编译与链接&#xff0c;…

基于AI网关的光伏电站在线监测方案

光伏电站作为利用太阳能的重要方式&#xff0c;凭借其环保、高效和可持续性的优势&#xff0c;在全球范围内得到广泛应用。然而&#xff0c;光伏电站的运营和维护也面临着诸多难点和痛点。在这一背景下&#xff0c;AI智能网关的应用为光伏电站的运营和维护带来了新的突破。 光伏…

数据结构进阶篇 之 【二叉树链序存储】的整体实现讲解

封建迷信我嗤之以鼻&#xff0c;财神殿前我长跪不起 一、二叉树链式结构的实现 1.二叉树的创建 1.1 手动创建 1.2 前序递归创建 2.二叉树的遍历 2.1 前序&#xff0c;中序以及后序遍历概念 2.2 层序遍历概念 2.3 前序打印实现 2.4 中序打印实现 2.4 后序打印实现 2.…