nginx部署发布Vite项目

1 引言

在之前的文章《Ubuntu云服务器上部署发布Vite项目》中笔者使用了Vite提供的预览服务(npm run preview)来在云服务器上发布Web应用。这样做轻量应用是没问题的,不过遇到一些专业的问题就不行了,最好还是使用专业的HTTP服务器。除此之外,笔者还有一些其他的需求:

  1. 前后端分离的项目,需要将后端的服务转发到前端服务IP相同的端口(443端口)。
  2. 子域名的项目,需要将服务转发到主域名服务IP相同的端口(443端口)。

这个时候就需要使用nginx,毕竟nginx不仅是一款轻量、高性能的HTTP服务器,还支持转发和代理服务功能。不过上述两个问题后面在讨论,本篇就详细记录一下部署发布单个Vite项目的问题。

2 详述

2.1 操作

首先,还是需要先安装nginx:

sudo apt install nginx

然后,准备Vite项目,需要确保项目已经通过npm run build构建好,并且生成了静态文件目录(通常是dist目录下)。

接下来,在/etc/nginx/sites-available/目录下创建一个新的配置文件,例如笔者这里创建一个charlee44文件。在这个文件中填入如下内容:

server { # 定义服务器listen 80; # 监听80端口server_name charlee44.com; # 服务器域名root /path/to/your/project/dist; # 项目build后的实际路径index index.html; # 主页location / {  #位置块,定义路由try_files $uri $uri/ /index.html;}
}

sites-available目录下创建的配置是可用的配置,要真正启用这个配置需要在sites-enabled目录中,因此创建软链接:

sudo ln -s /etc/nginx/sites-available/charlee44 /etc/nginx/sites-enabled/

最后就是测试Nginx配置并重启服务,在终端输入以下命令:

sudo nginx -t
sudo systemctl restart nginx

2.2 配置

上面的配置很好理解,基本已经注释清楚了,就是位置块部分有点难理解,具体意思是:

  • $uri:先看看有没有和请求路径完全一致的文件存在,比如 /about.html
  • $uri/:如果没有,再看看是否是一个目录,比如 /about/
  • 如果都没有,就返回 /index.html

不太理解也没关系,等以后有需求了再来了解清楚。如果这个配置测试没有问题,在访问主页时页面提示:

500 Internal Server Error
nginx/1.18.0 (Ubuntu)

那么有可能是权限不够,可以检查一下文件/var/log/nginx/error.log是否有类似“Permission denied”的提示。Ubuntu中有些目录是受保护的目录(例如/root目录),可以将build项目移动到nginx可以正常访问的目录,例如/var下目录。

如果想配置HTTPS服务,那么就可以使用如下配置:

# HTTP 跳转 HTTPS
server {listen 80;server_name charlee44.com;return 301 https://$host$request_uri; # 返回301永久重定向,将请求跳转到HTTPS版本
}# HTTPS 服务
server {listen 443 ssl;server_name charlee44.com;# SSL证书ssl_certificate /etc/nginx/ssl/charlee44.com/fullchain.pem; ssl_certificate_key /etc/nginx/ssl/charlee44.com/charlee44.com.key;ssl_protocols TLSv1.2 TLSv1.3; # 启用安全的加密协议版本ssl_ciphers HIGH:!aNULL:!MD5; # 设置加密套件,禁用不安全的算法root /var/www/charlee44.com;index index.html;location / {try_files $uri $uri/ =404; # 尝试查找对应文件或目录,否则返回404页面}
}

这段配置的意思是如果用户通过HTTP访问网站,那么就将请求转发到HTTPS的443端口上。另外,HTTPS最重要的一点还有需要申请SSL证书(可以参考笔者之前的文章《在Ubuntu上使用Certbot申请Let’s Encrypt SSL证书》来进行申请)。

2.3 优化

上述HTTPS服务的配置,经过笔者的实际测试,性能比不上Vite提供的预览服务(npm run preview)。原因是因为nginx是高度可配,还有很多优化选项可以配置,具体配置如下:

# HTTP 跳转 HTTPS
server {listen 80;server_name charlee44.com;return 301 https://$host$request_uri;
}# HTTPS 服务
server {listen 443 ssl http2;  # ✅ 启用 HTTP/2server_name charlee44.com;ssl_certificate /etc/letsencrypt/live/charlee44.com/fullchain.pem;ssl_certificate_key /etc/letsencrypt/live/charlee44.com/privkey.pem;ssl_protocols TLSv1.2 TLSv1.3;ssl_ciphers HIGH:!aNULL:!MD5;root /var/www/charlee44.com;index index.html;# ✅ 静态资源缓存 + Cache-Controllocation ~* \.(js|css|png|jpg|jpeg|gif|ico|svg)$ {expires max;add_header Cache-Control "public, immutable";log_not_found off;}# ✅ HTML 文件缓存短一些(可选)location ~ \.html$ {expires 1h;}# ✅ 默认处理入口location / {try_files $uri $uri/ =404;}# ✅ 启用 Gzip 压缩gzip on;gzip_types application/javascript text/css;gzip_comp_level 6;# ✅ 提升文件传输效率sendfile on;tcp_nopush on;tcp_nodelay on;
}

相比之前的配置,在性能上主要优化了以下几点:

2.3.1 启用HTTP/2

使用HTTP/2协议可以实现多路复用、头部压缩等特性,显著提升加载速度:

listen 443 ssl http2;  # ✅ 启用 HTTP/2

2.3.2 静态资源缓存控制

设置浏览器缓存策略,减少重复请求,加快页面加载速度:

# ✅ 静态资源缓存 + Cache-Control
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg)$ {expires max;  # 设置些资源永不过期add_header Cache-Control "public, immutable";   # 设置缓存策略:公开可缓存,内容不变log_not_found off; # 不记录不存在的文件的404日志
}# ✅ HTML 文件缓存短一些(可选)
location ~ \.html$ {expires 1h; # HTML文件可能经常更新,设置较短缓存时间
}

2.3.3 Gzip压缩

启用Gzip并指定压缩类型,以减少传输体积,加快网页加载速度(尤其对 JS/CSS):

# ✅ 启用 Gzip 压缩
gzip on;
gzip_types application/javascript text/css;
gzip_comp_level 6; # 启用 Gzip 压缩时,使用压缩级别 6(共 1 到 9 级)

2.3.4 文件传输优化

提升网络传输效率,降低延迟,提高吞吐量:

# ✅ 提升文件传输效率
sendfile on;
tcp_nopush on;  # 合并头部+正文,减少小包数量
tcp_nodelay on;   # 对动态请求或 WebSocket 立即发送数据

3 结语

其实HTTP服务器的性能优化远不止这点内容,针对本篇内容的性能优化配置,笔者就可以想到两点:

  1. 静态资源缓存控制的性能优化是通知客户端缓存文件资源,那么是否可以在服务器上缓存文件资源到内存呢?这样当客户端请求过来,就可以不经过硬盘直接传输内存中的数据,这样可以节省一次磁盘IO。
  2. 启用Gzip压缩,压缩文件也是算在客户端请求响应时间的,那么是否可以预先将文件按照最高级别进行压缩,然后需要的时候再直接传输出去呢?这样可以节省临时文件的时间,同时也最大程度的减少的文件传输体积。

其实这两个问题,甚至更多的性能优化思路,nginx都有一定程度的解决方案,就留待以后再研究吧。

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

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

相关文章

Unity文件夹标签 —— FolderTag

GitHub地址 FolderTag 下载之后解压,将FolderTag文件夹拖进Unity项目的Assets文件夹 选中文件夹,填上标签

【0基础开发油猴脚本】某漫画网站图片旋转

有朋友在用某漫画网站在线看漫画,但是那个网站会把漫画图片右旋90度,如图。于是,他就像我发起了求助,问我能不能写个脚本。我说,AI都发展到2025了,前端(脚本)这种东西还用自己写吗&a…

Vue Router 中,params参数的名称必须与路由配置中的动态路径参数名完全一致

路由配置与 params 参数的绑定关系 在路由配置中,使用 冒号(:) 定义动态路径参数: // router.js(路由配置) { path: /search/:keyword, // 这里的:keyword是动态路径参数 name: Search, component: S…

Spring Boot 应用开发实战指南:从入门到实战(内含实用技巧+项目案例)

📘 Spring Boot 应用开发实战指南:从入门到实战(内含实用技巧项目案例)🚀 你是否还在为 Spring 配置复杂、开发效率低下而苦恼?Spring Boot 早已成为 Java 后端开发的“标配”,本篇文章将带你全…

【NLP入门系列五】中文文本分类案例

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 博主简介:努力学习的22级本科生一枚 🌟​;探索AI算法,C,go语言的世界;在迷茫中寻找光芒…

【微信小程序】- 监听全局globalData数据

【微信小程序】- 监听全局globalData数据 数据劫持(Object.defineProperty)实现适用场景 数据劫持(Object.defineProperty) 实现 通过拦截 globalData 的属性读写实现自动监听,适合精确监听特定变量。 ​实现步骤​&…

高速公路闲置土地资源化利用:广西浦北互通3MW分布式光伏监控实践

摘要: 分布式光伏项目在清洁能源转型中扮演重要角色,其创新的空间利用模式有助于缓解能源开发与土地资源间的矛盾。广西大唐至浦北高速公路(浦北互通)项目,利用高速公路沿线闲置空地建设光伏电站,发挥了分布…

【Linux网络编程】网络基础

目录 计算机网络背景 初识协议 网络协议 协议分层 OSI七层模型 TCP/IP五层(或四层)模型 再识协议 为什么要有TCP/IP协议? 什么是TCP/IP协议? 重谈协议 网络传输基本流程 局域网传输流程 跨网络传输流程 Socket编程预备 理解源IP地址与目的…

BlenderBot对话机器人大模型Facebook开发

文章目录 🚀 BlenderBot 的关键特性🧪 版本与改进📊 应用实例 Blender是搅拌机,果汁机,混合机的意思。 BlenderBot 是由 Facebook AI Research (FAIR) 开发的一种先进的对话生成模型。它旨在通过融合多种对话技能&…

60天python训练计划----day59

在之前的学习中,我们层层递进的介绍了时序模型的发展,从AR到MA到ARMA,再到ARIMA。本质就是把数据处理的操作和模型结合在一起了,实际上昨天提到的季节性差分也可以合并到模型中,让流程变得更加统一。 季节性差分用S来…

学习日志05 python

我相信事在人为,人定胜天,现在还是在基础语法上面打转,还是会提出一些很低级的很基础的问题,不要着急,波浪式前进、螺旋式上升的过程吧,虽然现在的确是很绝望吧...... 今天要做一个练习:编写猜…

LiteHub中间件之gzip算法

gzip算法理论部分LZ777算法霍夫曼编码算法改进型的LZ777算法代码实现压缩对象gzip实现运行分析日志查看wireshark抓包查看后台管理界面查看理论部分 gzip是一种无损压缩算法,其基础为Deflate,Deflate是LZ77与哈弗曼编码的一个组合体。它的基本原理是&…

java+vue+SpringBoo校园失物招领网站(程序+数据库+报告+部署教程+答辩指导)

源代码数据库LW文档(1万字以上)开题报告答辩稿ppt部署教程代码讲解代码时间修改工具 技术实现 开发语言:后端:Java 前端:vue框架:springboot数据库:mysql 开发工具 JDK版本:JDK1.…

Qt Quick 与 QML(五)qml中的布局

QML布局系统主要分为三大类:锚布局、定位器布局、布局管理器。一、锚布局(Anchors)通过定义元素与其他元素或父容器的锚点关系实现精确定位,支持动态调整。核心特性属性‌‌作用‌‌示例‌anchors.left左边缘对齐目标元素anchors.…

【Java|集合类】list遍历的6种方式

本文主要是总结一下Java集合类中List接口的遍历方式&#xff0c;以下面的list为例&#xff0c;为大家讲解遍历list的6种方式。 List<Integer> list new ArrayList<>();list.add(1);list.add(2);list.add(3);list.add(4);list.add(5);文章目录1.直接输出2.for循环遍…

博弈论基础-笔记

取石子1 性质一&#xff1a;12345可以确定先手赢&#xff0c;6不论取那个质数都输&#xff0c;789 10 11可以分别取12345变成6 性质二&#xff1a;6的倍数一定不能取出之后还是6的倍数&#xff08;不能转换输态&#xff09; #include <bits/stdc.h> using namespace st…

多任务学习-ESMM

简介 ESMM&#xff08;Entire Space Multi-task Model&#xff09;是2018年阿里巴巴提出的多任务学习模型。基于共享的特征表达和在用户整个行为序列空间上的特征提取实现对CTR、CVR的联合训练 解决的问题 SSB&#xff08;sample selection bias&#xff09; 如下图1所示&am…

K8S 集群配置踩坑记录

系统版本&#xff1a;Ubuntu 22.04.5-live-server-amd64 K8S 版本&#xff1a;v1.28.2 Containerd 版本&#xff1a; 1.7.27 kubelet logs kuberuntime_sandbox.go:72] "Failed to create sandbox for pod" err"rpc error: code Unknown desc failed to cre…

超滤管使用与操作流程-实验操作013

超滤管使用与操作流程 超滤管&#xff08;或蛋白浓缩管&#xff09;是一种重要的实验设备&#xff0c;广泛应用于分离与纯化大分子物质&#xff0c;尤其是蛋白质、多糖和核酸等。其工作原理依赖于超滤技术&#xff0c;通过半透膜对分子进行筛分&#xff0c;精准地将大分子物质…

GitHub已破4.5w star,从“零样本”到“少样本”TTS,5秒克隆声音,冲击传统录音棚!

嗨&#xff0c;我是小华同学&#xff0c;专注解锁高效工作与前沿AI工具&#xff01;每日精选开源技术、实战技巧&#xff0c;助你省时50%、领先他人一步。&#x1f449;免费订阅&#xff0c;与10万技术人共享升级秘籍&#xff01;你是否为录音成本高、声音不灵活、又想为多语言…