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

Nginx部署前端Vue项目的深度解析

目录

一、准备工作

1.1 开发环境

1.2 服务器环境

1.3 Nginx安装

二、构建Vue项目

三、上传静态文件到服务器

四、配置Nginx

五、测试并重新加载Nginx

六、访问Vue应用

七、高级配置

7.1 启用HTTPS

7.2 启用Gzip压缩

7.3 缓存控制

八、常见问题与解决方案

8.1 404错误

8.2 权限问题

8.3 跨域问题

九、总结


在现代Web开发中,Vue.js因其组件化、响应式数据绑定和易于上手的特点,成为了前端开发者构建单页应用(SPA)的首选框架之一。而Nginx,作为一个高性能的HTTP和反向代理服务器,以其稳定性、丰富的功能集和低资源消耗,成为了部署前端Vue项目的理想选择。

一、准备工作

1.1 开发环境

首先,确保你的Vue项目已经在本地开发完成,并且能够通过npm run serve命令正常运行。Vue CLI工具会在本地启动一个开发服务器,通常监听在http://localhost:8080。然而,这个开发服务器并不适合用于生产环境,因为它没有提供足够的性能优化和安全性保障。

1.2 服务器环境

你需要一台安装了Linux(如Ubuntu或CentOS)的服务器,并确保Node.js和npm已经安装。虽然Node.js和npm在部署Vue项目到Nginx时不是必需的(因为Vue项目已经被打包成了静态文件),但它们对于在本地构建Vue项目是必要的。

1.3 Nginx安装

如果服务器上还没有安装Nginx,你可以通过操作系统的包管理器进行安装。以Ubuntu为例,可以使用以下命令:

sudo apt update  
sudo apt install nginx

安装完成后,你可以通过sudo systemctl status nginx命令检查Nginx是否成功启动。

二、构建Vue项目

在将Vue项目部署到Nginx之前,你需要先将其构建成静态文件。这通常通过运行Vue CLI提供的npm run build命令来完成。

npm run build

构建完成后,Vue CLI会在项目的根目录下生成一个dist文件夹,里面包含了所有用于生产环境的静态文件,如index.html、JavaScript、CSS和图像资源等。

三、上传静态文件到服务器

dist文件夹中的所有文件上传到服务器的指定目录。你可以使用SCP、FTP或其他文件传输工具来完成这一步骤。假设我们将这些文件上传到/var/www/vue-app目录:

scp -r dist/* user@your-server-ip:/var/www/vue-app

四、配置Nginx

接下来,你需要编辑Nginx的配置文件,以便它能够正确地服务于你的Vue项目。Nginx的配置文件通常位于/etc/nginx/sites-available/目录下,你可以在该目录下创建一个新的配置文件,或者编辑默认的default文件。

以下是一个基本的Nginx配置示例,用于部署Vue项目:

server {  listen 80;  server_name your-vue-app.com;  root /var/www/vue-app;  index index.html;  location / {  try_files $uri $uri/ /index.html;  }  # 其他配置,如SSL证书配置、Gzip压缩等  
}

在这个配置中:

  • listen 80; 表示Nginx监听80端口,这是HTTP协议的默认端口。
  • server_name your-vue-app.com; 表示你的网站域名,你需要将其替换为你的实际域名。
  • root /var/www/vue-app; 指定Vue项目静态文件所在的目录。
  • index index.html; 指定默认的首页文件。
  • location / { try_files $uri $uri/ /index.html; } 是一个关键配置,它确保了Vue的路由能够正确地映射到index.html文件。这是单页应用(SPA)的常见需求,因为SPA的路由是在前端通过JavaScript动态生成的,而不是通过服务器上的实际文件路径。

如果你将配置放在/etc/nginx/sites-available/目录下,你可能需要将其链接到/etc/nginx/sites-enabled/目录来启用它。你可以使用ln -s命令来创建这个链接。

五、测试并重新加载Nginx

在修改完配置文件后,你需要测试Nginx配置是否正确,并重新加载Nginx以使更改生效。

使用以下命令测试Nginx配置:

sudo nginx -t

如果显示syntax is ok,则表示配置文件没有语法错误。接下来,你可以使用以下命令重新加载Nginx:

sudo systemctl reload nginx

或者,如果你的系统不使用systemd,你可以使用:

sudo service nginx reload

六、访问Vue应用

现在,你可以通过浏览器访问你的域名或服务器IP地址,来查看部署好的Vue应用是否运行正常。例如,打开http://your-vue-app.com,你应该能够看到Vue应用的首页。

七、高级配置

7.1 启用HTTPS

为了保障数据传输的安全性,你可能需要为你的Vue应用启用HTTPS。这通常涉及配置SSL证书。你可以使用Let's Encrypt等免费证书颁发机构来生成SSL证书,并将其配置在Nginx中。

7.2 启用Gzip压缩

为了优化网站加载速度,你可以在Nginx中启用Gzip压缩。这可以通过在Nginx配置文件中添加相应的指令来实现。

gzip on;  
gzip_types text/plain application/json application/javascript text/css;

7.3 缓存控制

为了更好地控制浏览器缓存,你可以在Nginx配置中加入Cache-Control头部信息。这有助于减少对后端服务器的请求,加快页面加载速度。

location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {  expires 1y;  add_header Cache-Control "public, must-revalidate";  
}

八、常见问题与解决方案

8.1 404错误

如果你在访问某些路由时遇到404错误,通常是因为Nginx没有正确配置try_files指令。确保你的配置文件中包含了try_files $uri $uri/ /index.html;,这样Nginx就能将所有未找到的资源重定向到index.html文件。

8.2 权限问题

确保Nginx用户对Vue项目静态文件所在的目录具有读取权限。你可以通过修改目录的权限或使用chown命令来改变目录的所有者。

8.3 跨域问题

如果你的Vue项目需要调用后端API,并且遇到了跨域问题,你可以在Nginx中配置反向代理来解决这个问题。通过在Nginx配置文件中添加相应的location块,并将请求转发到后端服务的真实地址,你可以绕过浏览器的同源策略限制。

九、总结

通过本文,我们深入探讨了如何使用Nginx部署前端Vue项目。从准备工作、构建Vue项目、上传静态文件到服务器、配置Nginx,到测试并重新加载Nginx,再到高级配置和常见问题与解决方案,我们一步步地完成了整个部署过程。希望这些内容能够帮助你顺利地将Vue项目部署到Nginx服务器上,并在实际工作中进一步优化部署方案。

相关文章:

Nginx部署前端Vue项目的深度解析

目录 一、准备工作 1.1 开发环境 1.2 服务器环境 1.3 Nginx安装 二、构建Vue项目 三、上传静态文件到服务器 四、配置Nginx 五、测试并重新加载Nginx 六、访问Vue应用 七、高级配置 7.1 启用HTTPS 7.2 启用Gzip压缩 7.3 缓存控制 八、常见问题与解决方案 8.1 40…...

PHP一站式解决方案高级房产系统小程序源码

一站式解决方案,高级房产系统让房产管理更轻松 🏠【开篇:告别繁琐,迎接高效房产管理新时代】🏠 你是否还在为房产管理的繁琐流程而头疼?从房源录入、客户咨询到合同签订、售后服务,每一个环节…...

轻量级模型解读——EfficientNet系列

EfficientNet自2019年谷歌提出以来,经历了三个版本,2019EfficientNet ——> 2020EfficientNet-Lite——> 2021EfficientNetv2 文章目录 1、EfficientNet2、EfficientNetv23、EfficientNet-Lite 对于EfficientNet和EfficientNetv2的解读可见另外两篇…...

深入浅出SRS—RTMP实现

RTMP 直播是 SRS 最典型的使用场景,客户端使用 RTMP 协议向 SRS 推流,使用 RTMP 协议从 SRS 拉流,SRS 作为一个 RTMP 直播服务器实现媒体的转发。同时,RTMP 是 SRS 的中转协议,其他协议之间的互通需要先转为 RTMP&…...

睿赛德科技携手先楫共创RISC-V生态|RT-Thread EtherCAT主从站方案大放异彩

日前,在先楫HPM6E00技术日上,睿赛德科技(RT-Thread)向广大工业用户展示了多年来双方在RISC-V生态领域的合作历程和成果,同时睿赛德科技携手先楫半导体首次推出了基于HPM6800处理器的EtherCAT主站解决方案,吸…...

【Cesium实体创建】

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 Cesium目录 前言一、Cesium二、点 线 实体1.点实体2.线实体 总结 前言 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不…...

为何一些包的Priority在apt-cache和deb文件当中的不一样

最近遇到一些问题,调查的时候发现是一些包的Priority在apt-cache和deb文件当中的不一样导致的,复现步骤如下: $ apt update $ apt download whiptail $ dpkg-deb -e whiptail_0.52.23-1b1_amd64.deb $ cat control | grep Prio Priority: op…...

CRUD的最佳实践,联动前后端,包含微信小程序,API,HTML等(三)

关说不练假把式,在上一,二篇中介绍了我心目中的CRUD的样子 基于之前的理念,我开发了一个命名为PasteTemplate的项目,这个项目呢后续会转化成项目模板,转化成项目模板后,后续需要开发新的项目就可以基于这…...

nvidia-cuda-tensorrt-cudnn下载网站

tensorrt:https://developer.nvidia.com/tensorrt/download cudnn:https://developer.nvidia.com/rdp/cudnn-archive cuda:https://developer.nvidia.com/cuda-toolkit-archive...

GitLab 是什么?GitLab使用常见问题解答

GitLab 是什么 GitLab是由GitLab Inc.开发,使用MIT许可证的基于网络的Git仓库管理工具开源项目,且具有wiki和issue跟踪功能,使用Git作为代码管理工具,并在此基础上搭建起来的web服务。 ​GitLab 是由 GitLab Inc.开发&#xff0c…...

数字时代,寻找新的生意增长点之前要做什么准备?

要做好最基础也最繁复的数据管理。 在竞争日益激烈的快消市场中,企业面临前所未有的挑战与压力。在这种高压环境下,数字化转型不再仅仅是选择,而是企业探索新的业务增长点、保持竞争优势的关键战略。然而,随着企业数字化进程的加…...

使用Python本地搭建http.server文件共享服务并实现公网环境远程访问——“cpolar内网穿透”

前言 本文主要介绍如何在Windows系统电脑上使用python这样的简单程序语言,在自己的电脑上搭建一个共享文件服务器,并通过cpolar创建的公网地址,打造一个可以随时随地远程访问的私人云盘。 数据共享作为和连接作为互联网的基础应用&#xff…...

STM32——Flash闪存

以上部分,主存储器:程序存储器; 启动程序代码:系统存储器; 用户选择字节:选项字节 以下是闪存的管理员,用于擦除和读写的地址 C8T6一共64K,主存储器为64页 以下是整体框图&#x…...

python科学计算:NumPy 数组的高级操作

1 数组的形状变换 NumPy 提供了多种方法来改变数组的形状。这些方法不会改变数组的内容,而是重新组织数据的排列方式。 1.1 reshape() 函数 reshape() 是最常用的形状变换函数,它可以改变数组的形状,前提是变换后的总元素数量与原数组一致…...

【补-网络安全】日常运维(二)终端端口占用排查

文章目录 一、利用ipconfig、netstat 命令行统计二 、策略封禁IP 引言:检查频繁,第一步我们梳理完资产,第二步应该对资产终端进行一个排查,诊断把脉,了解清楚系统的端口占用及开放情况 一、利用ipconfig、netstat 命令行统计 1.先用ipconfig定位该终端的IP地址 2.明确IP地址后…...

设计模式之适配器模式:软件世界的桥梁建筑师

一、什么是适配器模式 适配器模式(Adapter Pattern)是一种结构型设计模式(Structural Pattern),通过将类的接口转换为客户期望的另一个接口,适配器可以让不兼容的两个类一起协同工作。其核心思想是通过一个…...

Java 入门指南:Java 并发编程 —— Fork/Join 框架 实现任务的拆分与合并

Fork/Join Fork/Join 是Java并发编程中的一个框架,用于解决大型任务的并行执行问题。它于 Java 7中引入,旨在简化对多核处理器上可并行执行任务的开发。 Fork/Join 框架基于分治(divide and conquer)的设计思想。它将大型任务划…...

token过期时间分平台(web和app)设置方法

token分平台设置方法 本文介绍了Spring下的登录和鉴权机制的主要方法以及 token认证的主要流程,并介绍在spring中web端和APP端设置不同token过期时间的实现方法。主要基于SpringBootspringSecurityJWT框架实现。 一、应用场景 同一系统的跨平台操作,基于…...

[000-01-008].Seata案例应用

业务说明:这里我们创建三个服务,一个订单服务,一个库存服务,一个账户服务。当用户下单时,会在订单服务中创建一个订单,然后通过远程调用库存服务来扣减下单商品的库存;再通过远程调用账户服务来…...

超详细!!!electron-vite-vue开发桌面应用之创建新窗口以及主进程和子进程的通信监听(十二)

云风网 云风笔记 云风知识库 一、新建打开窗口 1、在electron/main.ts中加入主进程打开窗口逻辑代码 import { ipcMain } from "electron"; ipcMain.handle("open-win", (_, arg) > {const childWindow new BrowserWindow({webPreferences: {preloa…...

国防科技大学计算机基础课程笔记02信息编码

1.机内码和国标码 国标码就是我们非常熟悉的这个GB2312,但是因为都是16进制,因此这个了16进制的数据既可以翻译成为这个机器码,也可以翻译成为这个国标码,所以这个时候很容易会出现这个歧义的情况; 因此,我们的这个国…...

HTML 语义化

目录 HTML 语义化HTML5 新特性HTML 语义化的好处语义化标签的使用场景最佳实践 HTML 语义化 HTML5 新特性 标准答案&#xff1a; 语义化标签&#xff1a; <header>&#xff1a;页头<nav>&#xff1a;导航<main>&#xff1a;主要内容<article>&#x…...

零门槛NAS搭建:WinNAS如何让普通电脑秒变私有云?

一、核心优势&#xff1a;专为Windows用户设计的极简NAS WinNAS由深圳耘想存储科技开发&#xff0c;是一款收费低廉但功能全面的Windows NAS工具&#xff0c;主打“无学习成本部署” 。与其他NAS软件相比&#xff0c;其优势在于&#xff1a; 无需硬件改造&#xff1a;将任意W…...

linux之kylin系统nginx的安装

一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源&#xff08;HTML/CSS/图片等&#xff09;&#xff0c;响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址&#xff0c;提高安全性 3.负载均衡服务器 支持多种策略分发流量…...

模型参数、模型存储精度、参数与显存

模型参数量衡量单位 M&#xff1a;百万&#xff08;Million&#xff09; B&#xff1a;十亿&#xff08;Billion&#xff09; 1 B 1000 M 1B 1000M 1B1000M 参数存储精度 模型参数是固定的&#xff0c;但是一个参数所表示多少字节不一定&#xff0c;需要看这个参数以什么…...

YSYX学习记录(八)

C语言&#xff0c;练习0&#xff1a; 先创建一个文件夹&#xff0c;我用的是物理机&#xff1a; 安装build-essential 练习1&#xff1a; 我注释掉了 #include <stdio.h> 出现下面错误 在你的文本编辑器中打开ex1文件&#xff0c;随机修改或删除一部分&#xff0c;之后…...

测试markdown--肇兴

day1&#xff1a; 1、去程&#xff1a;7:04 --11:32高铁 高铁右转上售票大厅2楼&#xff0c;穿过候车厅下一楼&#xff0c;上大巴车 &#xffe5;10/人 **2、到达&#xff1a;**12点多到达寨子&#xff0c;买门票&#xff0c;美团/抖音&#xff1a;&#xffe5;78人 3、中饭&a…...

06 Deep learning神经网络编程基础 激活函数 --吴恩达

深度学习激活函数详解 一、核心作用 引入非线性:使神经网络可学习复杂模式控制输出范围:如Sigmoid将输出限制在(0,1)梯度传递:影响反向传播的稳定性二、常见类型及数学表达 Sigmoid σ ( x ) = 1 1 +...

智能分布式爬虫的数据处理流水线优化:基于深度强化学习的数据质量控制

在数字化浪潮席卷全球的今天&#xff0c;数据已成为企业和研究机构的核心资产。智能分布式爬虫作为高效的数据采集工具&#xff0c;在大规模数据获取中发挥着关键作用。然而&#xff0c;传统的数据处理流水线在面对复杂多变的网络环境和海量异构数据时&#xff0c;常出现数据质…...

【Android】Android 开发 ADB 常用指令

查看当前连接的设备 adb devices 连接设备 adb connect 设备IP 断开已连接的设备 adb disconnect 设备IP 安装应用 adb install 安装包的路径 卸载应用 adb uninstall 应用包名 查看已安装的应用包名 adb shell pm list packages 查看已安装的第三方应用包名 adb shell pm list…...