基于若依框架前后端分离的项目部署

news2025/4/20 20:45:54

文章目录

  • 单项目的部署
    • 项目目录
    • 后端打包上传
    • 前端打包上传
    • 配置nginx
    • 服务器打开防火墙
    • 完成
  • 两个项目的部署
    • 两个项目介绍
    • 后端打包并上传
    • 前端打包并上传
    • nginx配置
    • 服务器端口开放
    • 完成

腾讯云服务器 之 环境搭建

单项目的部署

项目目录

在这里插入图片描述

后端打包上传

  • 查看端口号

    在ruoyi-admin的application.yml文件中

    在这里插入图片描述

  • 停止本地的运行,然后clean下,这样可以规避很多报错问题
    在这里插入图片描述

  • 找到ruoyi-admin,打包
    在这里插入图片描述

  • 打包完成后,打开ruoyi-admin所在的文件夹,进入target目录找到jar包
    在这里插入图片描述

  • 上传到服务器

    • 路径自己选,我是在data目录下创建了一个java文件夹,专门用来存放jar包的
      在这里插入图片描述

    • 启动jar包 戳这里 → 项目部署笔记 之 jar包启动方式

      第一次启动还好,后续启动的时候建议先ps -ef查看是否已经启动,启动后需要杀掉之前的进程

      // 命令意思就不解释了,不明白的可以看jar包启动方式的博客
      nohup java -jar ruoyi-admin.jar >> info.log
      

前端打包上传

  • 进入目录“employment-vue3”
    cd employment-vue3
    
  • 打包
    npm run build:prod
    
  • 注意在执行上边命令时,整个过程可以出现warn,但是不可以出现error
  • 打包完毕
    在这里插入图片描述
  • 上传到 nginx目录下的html中
    • 进入html目录

      cd /usr/src/nginx/html
      
    • 上传(命令自行百度吧,我这边使用的是final shell可以直接上传)

    • 上传成功,记住该dist所在的位置

      /usr/src/nginx/html/dist

      在这里插入图片描述

配置nginx

  • 找到nginx.conf文件

    一般在你安装的nginx目录下的conf文件夹下

    在这里插入图片描述

  • 编辑conf文件

    worker_processes  1;
    
    events {
        worker_connections  1024;
    }
    
    http {
        include       mime.types;
        default_type  application/octet-stream;
        sendfile        on;
        keepalive_timeout  65;
    
        server {
        	# 此为前端访问的端口,默认是80,如果有多个项目,这里需要更改
            listen       80;  
            server_name  你的服务器ip地址;
    		charset utf-8r;
    
    		location / {
    			# 这里是前端的dist上传的地址,需要具体到dist目录下
                root   /usr/src/nginx/html/dist;
                index  index.html index.htm;
    			try_files $uri $uri/ /index.html;
            }
    		error_page   500 502 503 504  /50x.html;
    		location /prod-api/ {
    			proxy_set_header Host $http_host;
    			proxy_set_header X-Real-IP $remote_addr;
    			proxy_set_header REMOTE-HOST $remote_addr;
    			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    			# 这里是后端设置的端口号
    			proxy_pass http://localhost:8088/;
    		}
            location = /50x.html {
                root   html;
            }
        }
    }
    
  • 编辑完成后,重启配置文件

    • 进入sbin目录(即nginx安装目录下)
      在这里插入图片描述
  • 执行重新加载命令

    ./nginx -s reload
    

服务器打开防火墙

在这里插入图片描述

完成

在这里插入图片描述

两个项目的部署

两个项目介绍

  • 一个是ruoyi-admin(我们上边已经部署完成了)
  • 一个是info-manage

后端打包并上传

在这里插入图片描述

单项目部署后端打包一样,记录下端口号8081:
1、打包
2、上传到data/java/目录下
3、启动jar包:nohup java -jar infomanage-admin.jar >> info.log &
(日志文件记得改一下)

前端打包并上传

单项目上传中我给dist文件存放的位置其实是有点不规范的,但是项目已经运行暂时不改,我们第二次上传的时候可以在html中创建一个以项目命名的文件夹,然后在文件夹中上传dist文件
在这里插入图片描述

nginx配置

  • 在部署了单个服务后,我们可以看到server的内容为
    在这里插入图片描述

  • 我们可以仿照上边的server再复制一个

    修改前端访问的接口为18088,同步项目的后端接口为8081
    (18088这个数字是根据自己爱好来哈,不是强制的)
    (具体的配置信息看下方)

  • 配置内容

    nginx的配置文件,删除掉了其他的注释信息,这里只粘贴了必要的内容

    // 
    worker_processes  auto;
    events {
        worker_connections  1024;
    }
    
    http {
        include       mime.types;
        default_type  application/octet-stream;
        sendfile        on;
        keepalive_timeout  65;
        server {
            listen       80;
            server_name  你的服务器地址;
            charset utf-8r;
            location / {
                root   /usr/src/nginx/html/dist;
                index  index.html index.htm;
                try_files $uri $uri/ /index.html;
            }
            error_page   500 502 503 504  /50x.html;
            location /prod-api/ {
    			proxy_set_header Host $http_host;
    			proxy_set_header X-Real-IP $remote_addr;
    			proxy_set_header REMOTE-HOST $remote_addr;
    			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_pass http://localhost:8088/;
            }
        }
    
        server{
        	#第二个项目的访问端口号
            listen       18088;
            server_name  你的服务器地址;
            charset utf-8r;
            location / {
            	# 第二个项目的前端文件的路径
                root   /usr/src/nginx/html/info/dist;
                index  index.html index.htm;
                try_files $uri $uri/ /index.html;
            }
            error_page   500 502 503 504  /50x.html;
            location /prod-api/ {
    			proxy_set_header Host $http_host;
    			proxy_set_header X-Real-IP $remote_addr;
    			proxy_set_header REMOTE-HOST $remote_addr;
    			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    			# 第二个项目的后端端口
    	        proxy_pass http://localhost:8081/;
            }
       }
    }
    
  • 重新加载配置文件 在这里插入图片描述

服务器端口开放

在这里插入图片描述

完成

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

黑马Java基础笔记-1

JVM,JDK和JRE JDK是java的开发环境 JVM虚拟机:Java程序运行的地方 核心类库:Java已经写好的东西,我们可以直接用。 System.out.print中的这些方法就是核心库中的所包含的 开发工具: javac(编译工具)、java&…

面向新一代扩展现实(XR)应用的物联网框架

中文标题: 面向新一代扩展现实(XR)应用的物联网框架 英文标题: Towards an IoT Framework for the New Generation of XR Applications 作者信息 Joo A. Dias,UNIDCOM - IADE,欧洲大学,里斯本&…

pcl各模块

参考资料: https://github.com/Ewenwan/MVision/blob/master/PCL_APP/1_%E7%82%B9%E4%BA%91%E6%BB%A4%E6%B3%A2filter.md 点云库PCL各模块学习 语雀 各模块依赖关系: 模块: common pcl_common中主要是包含了PCL库常用的公共数据结构和方…

Oracle Recovery Tools修复ORA-600 6101/kdxlin:psno out of range故障

数据库异常断电,然后启动异常,我接手该库,尝试recover恢复 SQL> recover database; ORA-10562: Error occurred while applying redo to data block (file# 2, block# 63710) ORA-10564: tablespace SYSAUX ORA-01110: ???????? 2: H:\TEMP\GDLISNET\SYSAUX01.DBF O…

2025MathorcupC题 音频文件的高质量读写与去噪优化 保姆级教程讲解|模型讲解

2025Mathorcup数学建模挑战赛(妈妈杯)C题保姆级分析完整思路代码数据教学 C题:音频文件的高质量读写与去噪优化 随着数字媒体技术的迅速发展,音频处理成为信息时代的关键技术之一。在日常生活中,从录音设备捕捉的原始…

.net core web api 数据验证(DataAnnotations)

目录 一、什么是 DataAnnotations? 二、扩展验证逻辑(自定义验证器) 一、什么是 DataAnnotations? DataAnnotations 是一组特性(Attributes),用于在模型类上定义验证规则。主要用于属性级别的…

【工具-Krillin AI】视频翻译、配音、语音克隆于一体的一站式视频多语言转换工具~

Krillin AI 是全能型音视频本地化与增强解决工具。这款简约而强大的工具,集音视频翻译、配音、语音克隆于一身,支持横竖屏格式输出,确保在所有主流平台(哔哩哔哩,小红书,抖音,视频号&#xff0c…

ICPR-2025 | 让机器人在未知环境中 “听懂” 指令精准导航!VLTNet:基于视觉语言推理的零样本目标导航

作者:Congcong Wen, Yisiyuan Huang, Hao Huang ,Yanjia Huang, Shuaihang Yuan, YuHao, HuiLin and Yi Fang 单位:纽约大学阿布扎比分校具身人工智能与机器人实验室,纽约大学阿布扎比分校人工智能与机器人中心,纽约大学坦登工程…

Shiro-550 动调分析与密钥正确性判断

一、Shiro 简介 Apache Shiro是一个开源安全框架,用于构建 Java 应用程序,提供身份验证、授权、加密和会话管理等功能。 二、Shiro-550(CVE-2016-4437) 1、漏洞原理 Shiro 在用户登陆时提供可选项 RememberMe,若勾选…

Python制作简易PDF查看工具PDFViewerV1.0查找功能优化

原文说明 为不破坏原文结构,因此功能优化不在原文中维护了。关于这款工具原文请通过下面链接访问。Python制作简易PDF查看工具PDFViewerV1.0 这款小工具基本功能已经可以作为一款文档浏览器使用,但还有一些美中不足的地方,本文将介绍对文本查…

20250419将405的机芯由4LANE的LVDS OUT配置为8LANE的步骤

20250419将405的机芯由4LANE的LVDS OUT配置为8LANE的步骤 2025/4/19 15:38 查询格式YUV/RGB 81 09 04 24 60 FF 90 50 00 00 FF 查询辨率帧率 81 09 04 24 72 FF 90 50 01 03 FF 查询LVDS mode : Singel output/Dual output 81 09 04 24 74 FF 90 50 00 00 FF 配置405的机…

从0开发一个unibest+vue3项目,使用vscode编辑器开发,总结vue2升vue3项目开始,小白前期遇到的问题

开头运行可看官网 链接: unibest官网 一:vscode中vue3代码显示报错标红波浪线 去查看扩展商店发现一些插件都弃用了,例如h5的插件以及vue老插件 解决办法:下载Vue - Official插件(注意:横杠两边是要加空格的&#xff…

HTML5好看的水果蔬菜在线商城网站源码系列模板4

文章目录 1.设计来源1.1 主界面1.2 关于我们1.3 商品信息1.4 新闻资讯1.5 联系我们1.5 登录注册 2.效果和源码2.1 动态效果2.2 源代码 源码下载 作者:xcLeigh 文章地址:https://blog.csdn.net/weixin_43151418/article/details/147264262 HTML5好看的水果…

多人五子棋联机对战平台 测试报告

目录 项目介绍 测试用例设计 部分功能测试示例 自动化测试 测试范围 排除范围 自动化测试目录​编辑 执行全部自动化测试用例 性能说明 总结 性能测试 结果分析 测试总结 项目介绍 该项目基于WebSocket实现实时通信,采用SSM框架构建在线五子棋多人联机…

欣佰特携数十款机器人相关前沿产品,亮相第二届人形机器人和具身智能行业盛会

2025年4月15日至16日,备受关注的第二届中国人形机器人与具身智能产业大会已在北京成功举行。作为国内前沿科技及产品服务领域的重要参与者,欣佰特科技携众多前沿产品精彩亮相,全方位展示了其在人形机器人与具身智能领域的创新产品。 在本次大…

windows安装hadoop-3.3.5(图文教程)

本章教程,记录在Windows操作系统上安装hadoop-3.3.5的整个过程。 一、基础环境准备 JDK版本:java version “1.8.0_431” ,并且配置JAVA_HOME系统环境变量 hadoop版本:3.3.5,配置HADOOP_HOME系统环境变量。 下载地址:https://archive.apache.org/dist/hadoop/common/hado…

【eNSP实验】OSPF单区域配置

简介 OSPF(开放最短路径优先)是一种基于链路状态算法的内部网关协议(IGP),用于自治系统内部动态路由。其核心机制为:各路由器通过泛洪链路状态通告(LSA)同步网络拓扑,构…

【技术派后端篇】ElasticSearch 实战指南:环境搭建、API 操作与集成实践

1 ES介绍及基本概念 ElasticSearch是一个基于Lucene 的分布式、高扩展、高实时的基于RESTful 风格API的搜索与数据分析引擎。 RESTful 风格API的特点: 接受HTTP协议的请求,返回HTTP响应;请求的参数是JSON,返回响应的内容也是JSON…

鸿蒙语言基础

准备工作 去鸿蒙官网下载开发环境 点击右侧预浏览,刷新和插销按钮,插销表示热更新,常用按钮。 基础语法 string number boolean const常量 数组 let s : string "1111"; console.log("string", s);let n : number …

在 Amazon Graviton 上运行大语言模型:CPU 推理性能实测与调优指南

引言 在生成式 AI 浪潮中,GPU 常被视为大模型推理的唯一选择。然而,随着 ARM 架构的崛起和量化技术的成熟,CPU 推理的性价比逐渐凸显。本文基于 Amazon Graviton 系列实例与 llama.cpp 工具链,实测了 Llama 3、DeepSeek 等模型的…