当前位置: 首页 > article >正文

若依前后端分离版部署实战:Nginx反向代理+生产环境优化配置

若依前后端分离版生产环境部署全攻略Nginx调优与安全实践第一次将若依框架部署到生产环境时我遇到了前端资源加载缓慢、后端接口频繁超时的问题。经过多次实战调优终于总结出一套兼顾性能与安全的部署方案。本文将分享从基础部署到深度优化的完整路径特别适合已经完成本地开发但缺乏生产环境经验的团队。1. 生产环境基础架构设计若依前后端分离架构的核心在于解耦前端资源与后端服务。典型的生产环境部署采用三层结构前端静态资源由Nginx直接托管后端Java服务独立运行Nginx同时承担反向代理和负载均衡的角色。这种架构的优势在于资源隔离静态资源与动态API分离部署避免相互干扰弹性扩展前后端可独立横向扩展安全增强通过Nginx实现请求过滤和流量控制在硬件资源配置上建议2核4G及以上配置的云服务器单独的数据盘用于存放日志和备份至少10Mbps的公网带宽2. Nginx核心配置实战2.1 反向代理基础配置修改nginx.conf中的server块实现基础路由分离server { listen 80; server_name yourdomain.com; # 前端静态资源 location / { root /opt/project/ruoyi-ui; index index.html; try_files $uri $uri/ /index.html; } # 后端API代理 location /prod-api/ { proxy_pass http://127.0.0.1:8080/; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }关键参数说明try_files确保前端路由正常跳转proxy_set_header传递真实客户端IP路径中的/prod-api/需与前端请求基地址一致2.2 性能优化配置在http上下文中添加以下优化参数http { # 文件传输优化 sendfile on; tcp_nopush on; tcp_nodelay on; # 连接超时控制 keepalive_timeout 65; client_header_timeout 15; client_body_timeout 15; send_timeout 25; # 缓冲控制 client_body_buffer_size 128k; client_max_body_size 10m; # 压缩配置 gzip on; gzip_min_length 1k; gzip_comp_level 4; gzip_types text/plain application/javascript application/x-javascript text/css; }优化效果对比配置项默认值优化值提升效果keepalive_timeout75s65s减少连接占用时间gzip_comp_level14压缩率提升30%tcp_nodelayoffon减少小包延迟3. HTTPS安全部署方案3.1 证书申请与配置使用Lets Encrypt免费证书# 安装certbot sudo apt install certbot python3-certbot-nginx # 获取证书需提前解析域名 sudo certbot --nginx -d yourdomain.com # 设置自动续期 sudo certbot renew --dry-runNginx的SSL配置示例server { listen 443 ssl; server_name yourdomain.com; ssl_certificate /etc/letsencrypt/live/yourdomain.com/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/yourdomain.com/privkey.pem; # 安全协议配置 ssl_protocols TLSv1.2 TLSv1.3; ssl_ciphers ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384; ssl_prefer_server_ciphers on; ssl_session_timeout 1d; ssl_session_cache shared:SSL:50m; # HSTS增强安全 add_header Strict-Transport-Security max-age63072000 always; }3.2 安全防护配置在server块中添加安全头add_header X-Frame-Options SAMEORIGIN; add_header X-Content-Type-Options nosniff; add_header X-XSS-Protection 1; modeblock; add_header Content-Security-Policy default-src self;常见攻击防护策略DDoS防护限制单个IP的请求频率limit_req_zone $binary_remote_addr zoneone:10m rate30r/m;SQL注入防护过滤特殊字符set $block_sql_injections 0; if ($query_string ~ union.*select.*\() { set $block_sql_injections 1; } if ($block_sql_injections 1) { return 403; }4. 高级性能调优技巧4.1 静态资源优化配置独立的静态资源服务server { listen 80; server_name static.yourdomain.com; location / { root /opt/project/ruoyi-ui/static; expires 365d; access_log off; add_header Cache-Control public; } }前端构建优化建议配置webpack的chunk splitting开启资源hash命名使用CDN加速静态资源4.2 后端服务优化若依Java服务启动参数nohup java -server \ -Xms2048m -Xmx2048m \ -XX:UseG1GC \ -XX:MaxGCPauseMillis200 \ -XX:ParallelGCThreads4 \ -XX:ConcGCThreads2 \ -jar ruoyi-admin.jar /dev/null 21 JVM参数对比测试参数组合平均响应时间GC停顿时间内存占用默认参数320ms450ms1.2GBG1GC优化280ms210ms1.5GB并行GC堆调优260ms180ms1.8GB4.3 监控与日志方案Nginx日志格式化log_format main $remote_addr - $remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $request_time $upstream_response_time;日志分析工具推荐GoAccess实时流量分析goaccess /var/log/nginx/access.log -o report.html --log-formatCOMBINEDELK Stack分布式日志系统PrometheusGrafana性能监控看板5. 常见问题排查指南问题1前端页面刷新后404检查Nginx的try_files配置确认Vue路由模式是否为history验证静态资源路径是否正确问题2接口请求跨域确保Nginx代理路径配置一致检查后端CORS配置验证HTTPS环境下协议一致性问题3上传文件大小限制# Nginx配置调整 client_max_body_size 50m; # Spring Boot配置调整 spring.servlet.multipart.max-file-size50MB spring.servlet.multipart.max-request-size50MB问题4Redis连接超时检查requirepass配置一致性验证bind地址是否为0.0.0.0确认防火墙规则放行6379端口在最近一次客户现场部署中我们发现当并发用户超过500时默认的Nginx worker配置会出现请求堆积。通过调整以下参数解决了问题worker_processes auto; worker_connections 4096; multi_accept on;

相关文章:

若依前后端分离版部署实战:Nginx反向代理+生产环境优化配置

若依前后端分离版生产环境部署全攻略:Nginx调优与安全实践 第一次将若依框架部署到生产环境时,我遇到了前端资源加载缓慢、后端接口频繁超时的问题。经过多次实战调优,终于总结出一套兼顾性能与安全的部署方案。本文将分享从基础部署到深度优…...

实战指南:5个技巧高效使用计算机视觉特征匹配基准数据集

实战指南:5个技巧高效使用计算机视觉特征匹配基准数据集 【免费下载链接】hpatches-dataset HPatches: Homography-patches dataset. 项目地址: https://gitcode.com/gh_mirrors/hp/hpatches-dataset 在计算机视觉和图像处理研究领域,特征匹配算法…...

Apex压枪宏终极指南:如何快速提升射击精度与稳定性

Apex压枪宏终极指南:如何快速提升射击精度与稳定性 【免费下载链接】Apex-NoRecoil-2021 Scripts to reduce recoil for Apex Legends. (auto weapon detection, support multiple resolutions) 项目地址: https://gitcode.com/gh_mirrors/ap/Apex-NoRecoil-2021 …...

别光看模型列表!Spring AI和LangChain4j在向量数据库支持上的真实体验对比

别光看模型列表!Spring AI和LangChain4j在向量数据库支持上的真实体验对比 当开发者选择Java生态的AI框架时,往往被琳琅满目的模型支持列表吸引注意力。但在实际构建RAG系统或知识库应用时,向量数据库的集成体验才是决定开发效率的关键因素。…...

ComfyUI Segment Anything:零基础也能掌握的智能图像分割神器

ComfyUI Segment Anything:零基础也能掌握的智能图像分割神器 【免费下载链接】comfyui_segment_anything Based on GroundingDino and SAM, use semantic strings to segment any element in an image. The comfyui version of sd-webui-segment-anything. 项目地…...

Obsidian科研知识管理架构:构建高效学术工作流的本地化解决方案

Obsidian科研知识管理架构:构建高效学术工作流的本地化解决方案 【免费下载链接】obsidian_vault_template_for_researcher This is an vault template for researchers using obsidian. 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian_vault_template_fo…...

yz-bijini-cosplay性能优化指南:GPU资源高效利用

yz-bijini-cosplay性能优化指南:GPU资源高效利用 1. 为什么需要GPU优化 当你运行yz-bijini-cosplay这类图像生成模型时,可能会遇到这样的情况:生成速度慢、图片分辨率上不去,甚至有时候程序直接崩溃报"显存不足"。这些…...

从MCAS系统缺陷看软件安全:一个传感器故障如何导致波音737MAX两次空难?

从MCAS系统缺陷看航空软件安全设计的致命盲区 当一架现代客机以每小时800公里的速度巡航在万米高空时,它的每一个飞行动作背后都有数百万行代码在实时运算。2018年至2019年发生的两起波音737MAX空难,将航空电子系统中一个名为MCAS的软件模块推上了风口浪…...

EPLAN项目标准化实战:如何用结构标识符打造高效电气设计模板

EPLAN项目标准化实战:如何用结构标识符打造高效电气设计模板 电气设计领域正经历着从传统绘图向智能化管理的转型。在这个背景下,EPLAN作为行业领先的电气工程设计软件,其结构标识符功能已成为实现项目标准化的核心工具。我曾参与过多个大型工…...

MicroBlue:Arduino轻量级BLE消息通信框架

1. MicroBlue库概述:面向Arduino的BLE消息通信框架 MicroBlue是一个专为Arduino平台设计的轻量级蓝牙低功耗(BLE)通信库,核心目标是建立Arduino硬件与MicroBlue移动应用之间的可靠、结构化消息通道。该库并非直接操作BLE协议栈&am…...

深入解析 | 萤火虫算法在Matlab中的高效实现与优化技巧

1. 萤火虫算法基础与Matlab环境搭建 第一次接触萤火虫算法时,我被它优雅的生物灵感所吸引。想象夏夜里的萤火虫,它们通过发光相互吸引,最终形成有序的群体行为——这正是算法名称的由来。2008年由剑桥学者Yang提出的这个算法,如今…...

5分钟掌握Warframe自动演奏:ShawzinBot终极免费指南 [特殊字符]

5分钟掌握Warframe自动演奏:ShawzinBot终极免费指南 🎮 【免费下载链接】ShawzinBot Convert a MIDI input to a series of key presses for the Shawzin 项目地址: https://gitcode.com/gh_mirrors/sh/ShawzinBot 想让你的Warframe角色在游戏中演…...

如何快速掌握抗体序列分析:ANARCI完整入门指南

如何快速掌握抗体序列分析:ANARCI完整入门指南 【免费下载链接】ANARCI Antibody Numbering and Antigen Receptor ClassIfication 项目地址: https://gitcode.com/gh_mirrors/an/ANARCI 抗体序列编号是抗体研究和药物开发中的关键环节,而ANARCI&…...

如何快速上手w64devkit:面向开发者的轻量级跨平台编译指南

如何快速上手w64devkit:面向开发者的轻量级跨平台编译指南 【免费下载链接】w64devkit Portable C and C Development Kit for x64 (and x86) Windows 项目地址: https://gitcode.com/gh_mirrors/w6/w64devkit w64devkit是一个专为Windows平台设计的轻量级C和…...

GreaterWMS开源仓库管理系统:从传统仓储到智能供应链的三大技术突破

GreaterWMS开源仓库管理系统:从传统仓储到智能供应链的三大技术突破 【免费下载链接】GreaterWMS This Inventory management system is the currently Ford Asia Pacific after-sales logistics warehousing supply chain process . After I leave Ford , I start …...

3分钟快速上手:ESM蛋白质语言模型完全指南

3分钟快速上手:ESM蛋白质语言模型完全指南 【免费下载链接】esm Evolutionary Scale Modeling (esm): Pretrained language models for proteins 项目地址: https://gitcode.com/gh_mirrors/esm/esm ESM(Evolutionary Scale Modeling)…...

GIMP Resynthesizer终极指南:5步掌握智能纹理合成与图像修复

GIMP Resynthesizer终极指南:5步掌握智能纹理合成与图像修复 【免费下载链接】resynthesizer Suite of gimp plugins for texture synthesis 项目地址: https://gitcode.com/gh_mirrors/re/resynthesizer GIMP Resynthesizer是一套功能强大的GIMP纹理合成插件…...

APA第7版Microsoft Word样式文件:3分钟搞定学术论文引用格式

APA第7版Microsoft Word样式文件:3分钟搞定学术论文引用格式 【免费下载链接】APA-7th-Edition Microsoft Word XSD for generating APA 7th edition references 项目地址: https://gitcode.com/gh_mirrors/ap/APA-7th-Edition 还在为学术论文的APA第7版引用…...

Web Scraper完整指南:零代码网页数据抓取终极解决方案

Web Scraper完整指南:零代码网页数据抓取终极解决方案 【免费下载链接】web-scraper-chrome-extension Web data extraction tool implemented as chrome extension 项目地址: https://gitcode.com/gh_mirrors/we/web-scraper-chrome-extension Web Scraper是…...

别再手动算反射率了!用Python一键搞定大疆P4M多光谱影像辐射定标(附完整代码)

用Python自动化处理大疆P4M多光谱影像:从DN值到反射率的一站式解决方案 多光谱影像分析在精准农业、环境监测等领域发挥着越来越重要的作用。大疆精灵4多光谱无人机(P4M)凭借其便携性和专业级的多光谱数据采集能力,已成为众多研究机构和企业的首选设备。…...

UTM虚拟机架构解析与iOS/macOS跨平台虚拟化技术实现深度指南

UTM虚拟机架构解析与iOS/macOS跨平台虚拟化技术实现深度指南 【免费下载链接】UTM Virtual machines for iOS and macOS 项目地址: https://gitcode.com/gh_mirrors/ut/UTM UTM是一款基于QEMU技术的开源虚拟化解决方案,专为iOS和macOS平台设计,实…...

为什么要做 GeoPipeAgent每

指令替换 项目需求:将加法指令替换为减法 项目目录如下 /MyProject ├── CMakeLists.txt # CMake 配置文件 ├── build/ #构建目录 │ └── test.c #测试编译代码 └── mypass2.cpp # pass 项目代码 一,测试代码示例 test.c // test.c #includ…...

Vivado IP核的Modelsim仿真库管理:一次配置,多个工程复用指南

Vivado IP核的Modelsim仿真库管理:一次配置,多个工程复用指南 在FPGA开发中,Vivado IP核与Modelsim的协同仿真一直是工程师们绕不开的痛点。每次新建工程都要重复导出IP库、配置路径、添加文件的繁琐流程,不仅浪费时间&#xff0c…...

Maxwell磁场仿真实战:无线传能线圈建模与优化

1. 无线传能线圈建模基础 第一次用Maxwell做无线传能线圈仿真时,我对着空白的建模界面发呆了半小时——到底该从哪下手?后来发现,把复杂问题拆解成小步骤才是关键。我们先从最简单的单匝圆环线圈开始,就像学画画先从画圆圈开始一…...

告别繁琐!WinRAR在Win11右键菜单的两种高效配置方案全解析

Win11右键菜单的WinRAR终极优化指南:极简派与功能派的完美平衡术 每次在Windows 11的资源管理器里右键点击压缩文件时,那个冗长的WinRAR子菜单是否让你感到效率受阻?作为一款装机量超过5亿的压缩工具,WinRAR在Windows 11上的右键菜…...

Qwen3.5-9B助力VSCode高效开发:CodeX风格智能编码实战

Qwen3.5-9B助力VSCode高效开发:CodeX风格智能编码实战 1. 为什么需要本地化智能编码助手 在软件开发过程中,代码补全和智能提示已经成为提升效率的刚需。但主流云端方案如GitHub Copilot存在几个痛点:网络延迟影响响应速度、企业代码安全顾…...

006、轻量化改进(四):神经架构搜索(NAS)与自动设计

一、从一次调试说起 上周在 Jetson Nano 上部署 YOLO 时遇到一个典型问题:模型推理时间达标了,但功耗始终压不下去。客户要求边缘设备连续工作 8 小时以上,现有的轻量化模型在功耗上还是“奢侈”了点。手动调整了通道数、改了两次激活函数&am…...

lingbot-depth-pretrain-vitl-14惊艳效果:室内走廊长距离(8m+)深度连续性展示

lingbot-depth-pretrain-vitl-14惊艳效果:室内走廊长距离(8m)深度连续性展示 1. 引言:当AI“看见”深度 想象一下,你站在一条长长的走廊里,一眼望不到头。你能大概判断出走廊有多长,远处的门离…...

G-Helper:拯救华硕笔记本性能的轻量级控制神器

G-Helper:拯救华硕笔记本性能的轻量级控制神器 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, Strix, Scar, and…...

Windows11下VSCode配置C/C++开发环境避坑指南(附完整配置文件)

Windows 11下VSCode配置C/C开发环境全流程解析 最近在帮几位刚接触编程的朋友配置Windows 11下的C/C开发环境时,发现即便是照着教程一步步操作,也总会遇到各种"坑"。作为一个从Visual Studio转战VSCode的老码农,我深知配置过程中的…...