若依微服务框架ruoyi-cloud使用手册(持续更新中)-程序员宅基地

技术标签: 微服务  java  microservices  

一、项目启动事项

1.首先进行项目相关工具及环境准备,官方文档也有,不过还是贴一下。
JDK >= 1.8 (推荐1.8版本)
Mysql >= 5.5.0 (推荐5.7版本)
Redis >= 3.0
Maven >= 3.0
Node >= 10
Nacos >= 1.1.0
sentinel >= 1.6.0(启动项目非必要)
这里需要注意的是:
NodeJavaScript 是运行在服务端的 JavaScript环境,这里配合vue进行前端界面展示。
Redis进行必要的数据缓存。
Nacos在这里作为spring cloud微服务的注册中心和配置中心。
详情请自查。

2.环境配置好后,执行操作类似若依官网,用idea或eclipse都行,贴一下网址好了:

https://doc.ruoyi.vip/ruoyi-cloud/document/hjbs.html#%E8%BF%90%E8%A1%8C%E7%B3%BB%E7%BB%9F

注意事项如下:

后端运行:

注意Redis和Nacos都要启动;
可能在运行RuoYiSystemApplication (系统模块)时连接数据库失败,这里因为直接导入数据脚本ry_config.sql的话会导入默认的System模块的数据库配置,数据库密码为password,如下图:
在这里插入图片描述
可以在ry_config.sql文件中查找修改成自己的mysql密码后重新导入本地数据库(注意不止修改一处)。

前端运行(在idea或vscode的Terminal(终端)执行命令):
在通过npm命令安装依赖时可能会有以下错误:
Downloading binary from https://github.com/sass/node-sass/releases/download/v4.14.1/win32-x64-72_bin
原因是node-sass被墙掉了,下载不了,可通过以下命令下载:

npm i node-sass --sass_binary_site=https://npm.taobao.org/mirrors/node-sass/

之后基本没问题啦操作执行完毕后可自动跳转界面进行登录访问,如果存在问题可检查以上操作步骤,重启各模块查看。
在这里插入图片描述

二、新建功能模块案例

步骤如下:
1.创建新模块:ruoyi-test;
2.进行新模块代码的基础配置调整
3.在nacos进行新模块的配置管理
4.新增测试表,生成代码,并进行前后端代码的修改和使用
5.进行界面菜单配置,启动新建的模块,重启前端vue界面,登录查看新模块基础界面及功能。

具体如下:

1.创建新模块ruoyi-test:
这里在ruoyi-modules目录下新建test模块并新增界面,可参考ruoyi-system模块的目录结构及命名,类似若依原始框架的module创建,不贴图了吧;

2.进行新模块代码的基础配置调整:
修改ruoyi-test下的pom文件,参考ruoyi-system模块,可复制ruoyi-system的pom文件内容,修改system相关字段即可;
修改ruoyi-modules下的pom文件,增加 ruoyi-test 代码,参考ruoyi-system部分;
参考ruoyi-system模块修改TestApplication启动类代码,新增相关注解即可,如下:

在这里插入图片描述另外对于resources可复制ruoyi-system模块文件进行调整(注意在bootstrap.yml文件中端口号不要冲突,可全局搜索一下,避免冲突)

在这里插入图片描述

3.在nacos进行新模块的配置管理
登录nacos:http://localhost:8848/nacos/
克隆 ruoyi-system-dev.yml ,命名为 ruoyi-test-dev.yml(名称对应自己模块),
在这里插入图片描述
点击编辑,修改下方的mybatis.typeAliasesPackage,改为 自己的对应名称,发布。如下:

在这里插入图片描述修改 ruoyi-gateway-dev.yml,添加新增的模块,发布。界面如下:

在这里插入图片描述
4.新增测试表,生成代码,并进行前后端代码的修改和使用
创建测试表student,设置字段注释,在系统界面生成代码;
生成的后端代码参考其他们模块的目录结构进行复制粘贴,修改maoper等各层级的代码,消除bug,保证后端各方法到持久层的正常跳转;
修改控制层的权限标识为自己对应的模块。如下:

在这里插入图片描述前端代码包括.vue文件和.js文件,可参考system模块在ruoyi-ui的views和api文件下创建新增自己的模块代码,这里js文件包含各接口路径,需要保证是自己模块路径。界面类似如下:
在这里插入图片描述
5.进行界面菜单配置,启动新建的模块,重启前端vue界面,登录查看新模块基础界面及功能。
菜单配置可参考system模块样式进行路径及权限标识,按钮等的配置即可;
启动新建的模块,重启前端vue界面,可查看测试模块的基础功能。如下:

在这里插入图片描述

三、不同微服务系统间接口调用案例

进行微服务系统A对微服务系统B进行接口调用的操作测试,这里系统A与系统B共用同一个nacos配置中心,步骤如下:
1、在系统B中添加测试接口
2、在系统A的ruoyi-api中进行测试接口的调用配置。
3、在系统A中某功能模块调用步骤2中配置好的接口,打印获取的接口数据。
4、在测试接口的基础上添加含有对象参数的接口,这里贴一下格式

具体如下,注意这里包括两种接口调用方式,以无参和对象参数传递:
1、在系统B中添加测试接口
在系统B的功能模块的控制层中添加需要测试用的接口,可以是系统模块功能中的普通接口(比如某获取某模块的列表数据),这里简单来,直接返回字符串。界面如下:

在这里插入图片描述2、在系统A的ruoyi-api中进行测试接口的调用配置。
简单一些可直接在ruoyi-api的ruoyi-api-system中进行测试,这个项目里ruoyi替换为了ctt,不用在意。仿照RemoteUserService文件和factory / RemoteUserFallbackFactory文件创建测试用的对应文件,这里我们创建RemoteTestService(接口文件)和RemoteTestFallbackFactory(降级处理)文件,目录如下(注意最后一行的spring.factorys文件,后面有用):
在这里插入图片描述
注意在RemoteTestService接口文件中,要自己定义需要调用的服务名称,就是下图中图一的红线标识和图二的服务名称配置(这里图二的服务名称即我们调用的系统B接口所在的的module服务名称)
图一:
在这里插入图片描述图二:

在这里插入图片描述最后在spring.factorys中配置我们的RemoteUserFallbackFactory文件,保证降级处理功能正常,RemoteUserFallbackFactory文件在这里类似于异常处理的操作。
在这里插入图片描述
3、在系统A中某功能模块调用步骤2中配置好的接口,打印获取的接口数据。
在系统A的,随便某常用控制层接口中,调用我们刚刚创建的RemoteTestService接口并打印,如下:
引入:

 @Autowired
    private RemoteTestService remoteTestService;

调用及打印(第四行插入的语句打印获取的接口数据):

 @GetMapping("/list")
    public TableDataInfo list(OrderBookFx orderBookFx)
    {
        System.err.println("???" + remoteTestService.getInfo());
        startPage();
        List<OrderBookFx> list = orderBookFxService.selectOrderBookFxList(orderBookFx);
        return getDataTable(list);
    }

打印结果如下:在这里插入图片描述
4、在测试接口的基础上添加含有对象参数的接口,这里贴一下格式
对于常用的有对象参数的接口上面的GetMapping是不适用的,同样是上述的微服务系统A对微服务系统B进行接口调用,这里贴一下正确格式,也可以参考链接(https://blog.csdn.net/qq_42422368/article/details/109381309
系统B接口:

    @PostMapping(value = "/company/list")
    public List<CruiseCompInfo> companyList(@RequestBody CruiseCompInfo cruiseCompInfo)
    {
        return cruiseCompInfoService.selectCruiseCompInfoList(cruiseCompInfo);
    }

系统A接口:

    @RequestMapping(value = "/company/list", method = RequestMethod.POST)
    public List<CruiseCompInfo> companyList(@RequestBody CruiseCompInfo cruiseCompInfo);

有一个注意点是A系统调用接口传参时可以new一个空的对象做参数,但是不能直接拿null做参数,因为在系统B中用到的@RequestBody 的 required 默认值是true。
贴一下效果:
在这里插入图片描述

四、服务器部署

可以参考若依官网,微服务版项目部署文档:https://doc.ruoyi.vip/ruoyi-cloud/document/hjbs.html#%E9%83%A8%E7%BD%B2%E7%B3%BB%E7%BB%9F
这里在linux系统进行jar包发布,前端生成的dist文件在nginx配置展示,操作如下:

1、环境准备
2、后端部署
3、前端部署
4、项目启动

具体如下:
1、环境准备
服务器环境配置:主要是nginx配置以及常规nacos、redis配置
注意点:
nginx环境:https://www.cnblogs.com/xxoome/p/5866475.html

2、后端部署
后端需要保证nacos配置中心的配置信息正确,主要是路径方面的,比如redis及nacos配置在服务器部署后可以正常访问和连接。
运行项目一级目录下的打包文件bin/package.bat
会默认在项目下生成 target文件夹,包含jar
注意是在Terminal(终端)运行命令,生成的jar包可以先拿几个必要的比如auth、gateway、system模块的jar包部署测试。
jar包可以放服务器随便某目录进行启动,比如:
在这里插入图片描述运行一个jar包的命令举例,进入到对应的文件夹,执行:
nohup java -jar ctt-auth-2.1.0.jar > ./logs/ctt-auth.log 2>&1 &
jar包改成自己的名称,./logs/ctt-auth.log为自定义的日志目录。
也可以按自己习惯的jar包命令执行。

3、前端部署
修改相关配置,运行命令生成dist包文件。
配置修改:前端ui文件中的index.js文件、vue.config.js文件
如下图:
在这里插入图片描述在这里插入图片描述在这里插入图片描述图二下方红线未服务器ip。
修改后在前端执行 npm run build:prod 生成dist包文件,放在nginx文件下。
在这里插入图片描述这里的上级目录ctt是自己建的项目名称,改成自己的,下面的nginx配置对应上就好。

然后是nginx/sbin下的nginx文件配置,可参考若依文档的nginx配置:https://doc.ruoyi.vip/ruoyi-vue/document/hjbs.html#nginx%E9%85%8D%E7%BD%AE
可以复制链接里nginx配置的代码再进行调整,调整时注意以下红线的3个地方:
在这里插入图片描述1、服务器项目访问端口:字面意思。
2、root /home/ruoyi/projects/ruoyi-ui;
这里是配置前端文件访问路径,ruoyi-ui就相当于生成的dist文件名称,比如我们的dist在ngingx目录下,为ngingx/ctt/dist,路径就改为/ctt/dist。
3、http://localhost:8080/;
这个是对应的是后端网关,对应下图标红的路径和端口,在前端代码的vue.config.js文件:

在这里插入图片描述有时候红线部分用localhost不用服务器ip的话,生成的dist文件部署到服务器上可能会识别不了localhost,就红线部分要改成对应的服务器ip。

rhou项目启动
一般后端jar包启动,nginx启动就可以访问部署的项目了。
在这里插入图片描述

五、一些坑~

大多数人过着他人的生活,他们的思想是他人的观点,
他们的行为是对他人的模仿,他们的热情是一句引言。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_42422368/article/details/109031112

智能推荐

黑色背景下显示灰色android,深色模式还是黑色模式?微信把所有人都搞懵了-程序员宅基地

文章浏览阅读1.1k次。原标题:深色模式还是黑色模式?微信把所有人都搞懵了前一阵子,微信正式加入了对 " 深色模式 " 的支持,这也是除了 Windows Phone 版本以外微信第一次从系统层面支持深色模式。虽然这次更新离 WWDC 上的演示已经过去了 9 个月,但这也重新将 " 深色模式 " 这四个词推到了风头浪尖。除了对 " 深色模式 " 的迫切需求外,网上也有不少关于微信深色模式的讨论,比如有人" 因深色模式不是..._开了深色模式黑底变灰色

Scintilla开源库使用指南(一)-程序员宅基地

文章浏览阅读82次。Scintilla是一个免费、跨平台、支持语法高亮的编辑控件。它完整支持源代码的编辑和调试,包括语法高亮、错误指示、代码完成(codecompletion)和调用提示(calltips)。能包含标记(marker)的页边(margin)可用于标记断点、折叠和高亮当前行。Scintilla是一个免费、跨平台、支持语法高亮的编辑控件。它完整支持源代码的编辑和调试,包括语法高亮、错误指示、代..._scintilla 不知道如何生成cxx

计算机专业研究生面试英语翻译,20考研复试英语&面试最强攻略,都是干货!-程序员宅基地

文章浏览阅读1.4k次。原标题:20考研复试英语&面试最强攻略,都是干货!考研初试千辛万苦通过,成功就在眼前,可是偏偏中间还有复试英语这个拦路虎,复试中的英语环节每年让不少同学都很紧张,要想对答如流,顺利跨过这条河,充足的准备不可少。考研贴心管家爱启航给大家列几个常见问题答疑,以及复试都是什么考查方式,面试又会问哪些问题呢?知己知彼才能百战百胜!小伙伴速来取经~复试中英语的考查形式?英语考试形式主要分为笔试、听力..._考研复试英译汉

高并发高流量网站架构-程序员宅基地

文章浏览阅读3.2k次。Web2.0的兴起,掀起了互联网新一轮的网络创业大潮。以用户为导向的新网站建设概念,细分了网站功能和用户群,不仅成功的造就了一大批新生的网站,也极大的方便了上网的人们。但Web2.0以用户为导向的理念,使得新生的网站有了新的特点——高并发,高流量,数据量大,逻辑复杂等,对网站建设也提出了新的要求。 本文围绕高并发高流量的网站架构设计问题,主要研究讨论了以下内容: 首先在整个网络

主流计算机编程语言之父---集锦_计算机编程之父-程序员宅基地

文章浏览阅读1.2k次。主流计算机编程语言之父---集锦 收藏1)J. Backus的FORTRAN语言 早期电脑都直接采用机器语言,即用“0”和“1”为指令代码来编写程序,难写难读,编程效率极低。为了方便编程,随即出现了汇编语言,虽然提高了效率,但仍然不够直观简便。从1954年起,电脑界逐步开发了一批“高级语言”,采用英文词汇、符号和数字,遵照一定的规则来编写程序。高级语言诞生后,软件业得到突飞猛进的发展。1953年12月, IBM公司程序师_计算机编程之父

JDK1.8 HashMap ----resize源码解读_hashmap 1.8 源码解析 resize-程序员宅基地

文章浏览阅读170次。/** * Initializes or doubles table size. If null, allocates in * accord with initial capacity target held in field threshold. * Otherwise, because we are using power-of-two expansion, the * elements from each bin must either stay at sa_hashmap 1.8 源码解析 resize

随便推点

计算机丢失logmanager dll,修复logmanager.dll-程序员宅基地

文章浏览阅读9.3k次。logmanager.dll是电脑系统必备的一个DLL组件修复程序。系统重要文件logmanager.dll。Logmanager.dll文件是一个为大家找到的DLL文件,如果你丢失了计算机上的logmanager.dll,你可以去e-net看文件,在这个站点下载文件,按照教程安装注册文件正常运行。现在!软件介绍:什么是logmanager.dll?它是计算机应用程序中的重要组成部分。如果您的系统..._logmanager.dll

EDZML导入MySQL数据库时出现{EZDML for win64默认自带了一个libmysql.dll,但是它 需要Visual C++ Redistributable Packages for}-程序员宅基地

文章浏览阅读812次。EZDML for win64默认自带了一个libmysql.dll,但是它需要Visual C++ Redistributable Packages for Visual Studio 2013的支持,你可能需要装一下这个支持库才能加载成功.1.最近在做大数据项目的时候用到了EDZML软件,但是连接MySQL时出现该问题,一直没有解决,如下图:2.我已经发邮件给EDZML开发者,问题解决之后我回来更新的。1.最近在做大数据项目的时候用到了EDZML软件,但是连接MySQL时出现该问题,一直没有解决,如下_ezdml for win64默认自带了一个libmysql.dll

数据结构-3.2.6综合应用题1-附带tag标志域的循环队列_循环队列tag标志算法-程序员宅基地

文章浏览阅读676次。# 1 题目描述 若希望循环队列中的元素都能够得到利用,则需设置一个标志域tag,并以tag的值为0还是1,来区分队头指针front和队尾指针rear相同时的队列的状态是“空”,还是“满”,试编写与此结构相应的入队和出队算法。 # 2 基本思路 主要是队列为空、队列为满时的判断条件, [1]队空条件:Q->front==Q->rear&._循环队列tag标志算法

python_判断列表中是否有相同元素_python循环比较相邻元素是否一样-程序员宅基地

文章浏览阅读1w次,点赞4次,收藏13次。判断列表中的相同元素思想:将第一位元素,与后面元素进行比较,发现相同则打印结论二三如果所有元素比较后,也没有发现相同,则打印结论。list01 = [34, 8, 56, 9, 8, 9]result = False # 假设结论是没有重复# 取数据for r in range(len(list01) - 1): # 作比较 for c in range(r ..._python循环比较相邻元素是否一样

特征筛选利器:详解T-test(T检验)原理、参数分析、单\双尾检验选择-程序员宅基地

文章浏览阅读1.8w次,点赞5次,收藏56次。当笔者使用SPSS,或者调用很多sk-learn函数包时,常常会用并不是最难的,**会选择包,会阅读结果,会得出统计学答案**才是最难的。_t-test

如何删除linux系统下的非空目录_linux删除非空目录的命令-程序员宅基地

文章浏览阅读1.1w次,点赞7次,收藏43次。标题: 如何删除linux系统下的非空目录删除目录的常用shell命令为: rmrm 是一个用于删除文件和目录的命令行实用程序。与命令不同 rmdir, rm 可以删除空目录和非空目录。默认情况下,在没有任何选项的情况下使用时 rm 不会删除目录如下图所示:首先,先查看一下我们有几个目录:有两个=>分别是:First_linux_progarm 与 test1尝试使用rm删除test1如何删除linux系统下的空目录? =>如果要删除空目录,请使用 -d(–dir) 选项_linux删除非空目录的命令

推荐文章

热门文章

相关标签