Nginx 部署 Vue 项目

在 Nginx 上部署 Vue 项目是一个常见的任务,以下是经过优化的操作指南,帮助你顺利完成项目部署。

---

使用 Nginx 部署 Vue 项目

本指南将详细介绍如何使用 Nginx 部署基于 Vue.js 构建的静态网站应用。我们将从项目打包开始,直到最终通过 Nginx 服务器进行项目托管,确保你能顺利完成部署过程。

 1. 打包 Vue 项目

首先,我们需要将 Vue 项目打包成可用于生产环境的静态文件。确保项目依赖已安装:


npm install
 

然后,运行以下命令进行构建:


npm run build

该命令会生成一个 `dist` 目录,包含了项目的所有静态资源(HTML、CSS、JavaScript 文件)。这个 `dist` 文件夹将用于部署。

2. 安装 Nginx

接下来,确保 Nginx 已安装。如果 Nginx 尚未安装,可以使用以下命令进行安装:

- 对于 Ubuntu/Debian 系统:


  sudo apt update
  sudo apt install nginx
 

- 对于 CentOS 系统:


  sudo yum install nginx
 

安装完成后,启动 Nginx 服务:


sudo systemctl start nginx
 

你可以通过访问服务器的 IP 地址或域名来验证 Nginx 是否正常运行,默认情况下,它会显示 Nginx 的欢迎页。

 3. 配置 Nginx 以托管 Vue 项目

现在需要配置 Nginx 来托管我们刚才生成的 `dist` 目录。我们将修改 Nginx 的配置文件,指向这个目录。

1. 打开 Nginx 配置文件进行编辑。通常,默认配置文件位于 `/etc/nginx/sites-available/default`(Ubuntu/Debian)或 `/etc/nginx/nginx.conf`(CentOS)。

   使用以下命令编辑配置文件:


   sudo nano /etc/nginx/sites-available/default
 

2. 修改 `server` 块,使其指向 Vue 项目的 `dist` 文件夹。添加或替换以下内容:

nginx
   server {
       listen 80;
       server_name your_domain_or_IP;  # 替换为你的域名或服务器 IP

       location / {
           root /path_to_your_vue_project/dist;  # 指向 Vue 项目的 dist 文件夹
           try_files $uri $uri/ /index.html;    # 处理 Vue 的 SPA 路由
       }

       error_page 500 502 503 504 /50x.html;
       location = /50x.html {
           root /usr/share/nginx/html;
       }
   }
 

   - `server_name`:替换为你的域名或服务器 IP 地址。
   - `root`:将 `/path_to_your_vue_project/dist` 替换为项目的 `dist` 目录的绝对路径。
   - `try_files`:用于处理 Vue.js 的单页应用程序 (SPA) 路由问题,确保所有请求都指向 `index.html`。

3. 保存并退出文件。

4. 测试和重启 Nginx

在保存 Nginx 配置文件后,运行以下命令来测试配置的有效性:


sudo nginx -t
 

如果没有错误,重启 Nginx 服务使配置生效:


sudo systemctl restart nginx
 

5. 访问你的 Vue 应用

完成上述步骤后,打开浏览器并访问 `http://your_domain_or_IP`,即可看到你部署的 Vue 项目。若你使用了本地服务器进行测试,请使用服务器的 IP 地址来访问。

6. 可选步骤:为站点启用 HTTPS

为了提高安全性,建议使用 HTTPS 保护你的站点。我们可以通过 [Let’s Encrypt](https://letsencrypt.org/) 免费获取 SSL 证书,并使用 Certbot 自动配置。

1. 安装 Certbot:

   - 对于 Ubuntu:


     sudo apt install certbot python3-certbot-nginx
 

   2. 生成并配置 SSL 证书:


   sudo certbot --nginx -d your_domain
 

   Certbot 会自动修改 Nginx 配置文件,添加 SSL 支持,并更新为 HTTPS 协议。

3. 验证 HTTPS 是否启用。你可以在浏览器中通过 `https://your_domain` 访问站点,确保连接是安全的。

现在,你已经成功使用 Nginx 部署了一个 Vue 项目!通过上述步骤,你可以轻松配置服务器并确保你的应用能够在生产环境中稳定运行。如果你需要进一步调整配置或优化性能,请参考 Nginx 官方文档。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

视频智能分析平台LntonAIServer视频质量诊断功能花屏、抖动、遮挡等检测

LntonAIServer新增了视频质量诊断功能,该功能专注于提升视频监控系统的稳定性和可用性,主要通过自动化检测来识别视频流中常见的质量问题,比如花屏、抖动、遮挡等问题。这些问题是影响视频监控效果的主要因素之一,而自动化的检测能…

解决el-table中使用el-input无法聚焦问题

在el-table中点击单元格时使用el-input或其他表单组件编辑单条数据。会出现聚焦不上的问题&#xff0c;需要手动点击才能够聚焦。究其原因是因为点击单元格时页面已自动聚焦到单元格&#xff0c;此时无法自动聚焦到对应的表单&#xff0c;需要手动设置。 <template><e…

操作系统八股总结

操作系统八股总结 操作系统的四大功能&#xff1a;进程控制&#xff0c;内存管理&#xff0c;设备管理&#xff0c;文件管理进程的定义:并发程序的执行&#xff0c;进程的同步与互斥进程的状态&#xff1a;创建&#xff0c;终止&#xff0c;就绪&#xff0c;运行&#xff0c;阻…

图论(2)

一、度 度统计的是一个节点上又多少条边 度出度入度 出度&#xff1a;统计以该节点为起始点箭头指向外面的边的条数 入度&#xff1a;统计箭头指向该节点的边数 度为1的节点为悬挂节点&#xff0c;边为悬挂边 用矩阵计算节点的度 二、握手定理 比如这里第一个集合里面有三…

blender图像如何分层导出?blender动画云渲染

在blender渲染时产品会被其他物体影响&#xff0c;这时候就可以用到blender中的阻隔&#xff1b;分层导出图像到PS中进行校色等后期处理。 在分层前&#xff0c;我们需要先打开渲染属性-胶片-透明&#xff0c;这样导出的图像才是透明背景的&#xff0c;反之会变成黑色底。 第一…

传统CV算法——边缘算子与图像金字塔算法介绍

边缘算子 图像梯度算子 - Sobel Sobel算子是一种用于边缘检测的图像梯度算子&#xff0c;它通过计算图像亮度的空间梯度来突出显示图像中的边缘。Sobel算子主要识别图像中亮度变化快的区域&#xff0c;这些区域通常对应于边缘。它是通过对图像进行水平和垂直方向的差分运算来…

VMware Fusion Pro 13 for Mac虚拟机软件

Mac分享吧 文章目录 效果一、下载软件二、开始安装安装完成&#xff01;&#xff01;&#xff01; 效果 一、下载软件 下载软件 地址&#xff1a;www.macfxb.cn 二、开始安装 安装完成&#xff01;&#xff01;&#xff01;

【HarmonyOS NEXT】实现截图功能

【HarmonyOS NEXT】实现截图功能 【需求】 实现&#xff1a;实现点击截图按钮&#xff0c;实现对页面/组件的截图 【步骤】 编写页面UI Entry Component struct Screenshot {BuildergetSnapContent() {Column() {Image().width(100%).objectFit(ImageFit.Auto).borderRadi…

Webpack详解与配置环境

webpack&#xff1a;webpack网址 1、工作原理&#xff1a; Webpack是一个非常强大的静态模块的打包工具。从文件入口开始&#xff0c;递归解析以来关系&#xff0c;然后将所有模块打包成一个或多个budle文件。 2、webpack核心概念&#xff1a; Entry&#xff1a;入口起点(en…

基于IMX6ULL的Cortex-A中断原理讲解,以及编写其中断向量表

首先借助STM32我们需要了解中断系统是如何构成的 会有一个中断源&#xff0c;也就是能够向CPU发出中断请求的设备或事件。中断源不分硬件和软件&#xff0c;也就是产生中断信号&#xff0c;就会执行中断服务函数 但是CPU是如何知道中断源产生后就找到对应的中断…

软件工程知识点总结(1):软件工程概述

1 什么是软件&#xff1f; 定义&#xff1a;计算机系统中的程序及其文档。 ——程序是计算机任务的处理对象和处理规模的描述&#xff1b; ——文档是为了便于了解程序所需要的阐明性资料。 2 软件的特点&#xff1f; 软件是无形的&#xff0c;不可见的逻辑实体 ——它的正确与…

828华为云征文|华为云服务器Flexus X搭建悟空crm管理系统——助力企业云上管理(解决APP Referer校验失败问题)

1、为什么我们企业会选择Flexus云服务器X实例来部署自己的CRM管理系统&#xff1f; 因为基于华为云Flexus X实例搭建CRM管理平台&#xff0c;可以从容面对企业内部瞬息万变的业务压力变化 2、华为云服务器Flexus X方案及优势&#xff1a; 灵活伸缩 搭配弹性伸缩服务AS及负载均…

Selenium 实现图片验证码识别

前言 在测试过程中&#xff0c;有的时候登录需要输入图片验证码。这时候使用Selenium进行自动化测试&#xff0c;怎么做图片验证码识别&#xff1f;本篇内容主要介绍使用Selenium、BufferedImage、Tesseract进行图片 验证码识别。 环境准备 jdk&#xff1a;1.8 tessdata&…

2024国赛数学建模B题完整分析参考论文38页(含模型和可运行代码)

2024 高教社杯全国大学生数学建模完整分析参考论文 B 题 生产过程中的决策问题 目录 摘要 一、问题重述 二、问题分析 三、 模型假设 四、 模型建立与求解 4.1问题1 4.1.1问题1思路分析 4.1.2问题1模型建立 4.1.3问题1样例代码&#xff08;仅供参考&#xff09; 4.…

复数随机变量(信号)的方差和协方差矩阵的计算

怎么计算复数随机变量的方差和协方差矩阵&#xff1f; 使得其与MATLAB中var函数和cov函数的结果一致。 前言 复信号在信号处理中随处可见&#xff0c;关于复信号&#xff08;复随机变量&#xff09;的方差和协方差矩阵该如何计算呢&#xff1f;本文给出了复信号的方差和协方差矩…

MarkdownEditor 配置以及使用

MarkdownEditor 配置以及使用 MarkdownEditor是一款基于浏览器的 Markdown 编辑器&#xff0c;虽然他是独立软件&#xff0c;但该软件内嵌一个浏览器。功能非常简单实用、反应速度很快&#xff0c;号称是Markdown领域的NotePad&#xff08;记事本&#xff09;。 MarkdownEdit…

自动驾驶---Motion Planning之轨迹拼接

1 背景 笔者在之前的专栏中已经详细讲解了自动驾驶Planning模块的内容&#xff1a;包括行车的Behavior Planning和Motion Planning&#xff0c;以及低速记忆泊车的Planning。 本篇博客主要聊一聊Motion Planning中轨迹拼接的相关内容。从网络上各大品牌的车主拍摄的智驾视频来看…

B端产品经理的流程设计思维

回首入行产品经理也已多年&#xff0c;做的项目也由C到B&#xff0c;由前到后都已涉及&#xff0c;辗转跨行仍觉互联网学海无涯&#xff0c;还是需要保持输出。思前想后还是决定聊一聊在过往服务多家大型集团的工作经历中十分重要&#xff0c;但却普遍不被视为产品经理必备能力…

Rhinoceros 8 for Mac/Win:重塑三维建模边界的革新之作

Rhinoceros 8&#xff08;简称Rhino 8&#xff09;&#xff0c;作为一款由Robert McNeel & Assoc公司开发的顶尖三维建模软件&#xff0c;无论是对于Mac还是Windows用户而言&#xff0c;都是一款不可多得的高效工具。Rhino 8以其强大的功能、广泛的应用领域以及卓越的性能&…

linux dlopen手册翻译

名称 dlclose, dlopen, dlmopen 打开和关闭一个共享对象 简介 #include <dlfcn.h> void *dlopen(const char*filename, int flags); int dlclose(void *handle);#define _GNU_SOURCE #include <dlfcn.h> void *dlmoopen(Lmid_t lmid, const char *filename, int…