如何将前端项目打包并部署到不同服务器环境

学习源码可以看我的个人前端学习笔记 (github.com):qdxzw/frontlearningNotes

觉得有帮助的同学,可以点心心支持一下哈(笔记是根据b站尚硅谷的前端讲师【张天禹老师】整理的,用于自己复盘,有需要学习的可以去b站学习原版视频)

本教程将详细介绍如何将前端项目进行打包并部署到不同的服务器环境,包括本地服务器、Nginx服务器和云服务器。本教程将详细介绍如何将前端项目进行打包并部署到不同的服务器环境,包括本地服务器、Nginx服务器和云服务器。

一、项目打包

我们开发用的脚手架其实就是一个微型服务器,用于:支撑开发环境、运行代理服务器等。

打包完的文件中不存在:.vue、.jsx、.less等文件,而是:html、css、js等。

打包后的文件,不再借助脚手架运行,而是需要部署到服务器上运行。

打包前,请务必梳理好前端项目的ajax封装(请求前缀、代理规则等)。

打开package.json,执行打包命令(npm run build:prod)

这里我演示的是黑马的一个项目:

账号:13800000002

密码:hm#qd@23!

后端服务器地址:https://heimahr.itheima.net/api

生产环境:http://localhost:9528/prod-api

开发环境:https://localhost:9528/api

二、部署方式

1.本地服务器部署

本次我们使用express框架在本地创建一个服务器

安装express

前提是电脑已经安装了node

新建一个文件夹,执行npm init -y命令,生成package.json,再执行npm add express命令,下载express,成功之后如下图。

每次修改代码时,都要重新启动服务器,比较麻烦,所以提出了热部署(nodemon),安装命令:npm i nodemon -g

最后完整代码如下:

const express = require('express')
const app = express()
const port = 9528// 配置静态资源
app.use(express.static(__dirname + '/public'))app.listen(port, () => {console.log(`本地服务器启动http://localhost:${port}`)
})

执行命令:nodemon .\app.js,浏览器输入http://localhost:9528会出现这个页面:

解决刷新404问题

①打包时更改路由配置,使用hash模式,缺点请求路径不美观有#,不够优雅

②使用node相关的库(connect-history-api-fallback )

官网地址:npm | Home

下载connect-history-api-fallback

npm install --save connect-history-api-fallback

完整代码

const express = require('express')
var history = require('connect-history-api-fallback')const app = express()
app.use(history())
const port = 9528// 配置静态资源
app.use(express.static(__dirname + '/public'))app.listen(port, () => {console.log(`本地服务器启动http://localhost:${port}`)
})

请求无法发送问题

使用node相关的库(http-proxy-middleware )

下载http-proxy-middleware

npm i http-proxy-middleware

完整代码

const express = require('express')
var history = require('connect-history-api-fallback')
const { createProxyMiddleware } = require('http-proxy-middleware')
const app = express()
app.use(history())
const port = 9528// 配置静态资源
app.use(express.static(__dirname + '/public'))
app.use('/prod-api',createProxyMiddleware({target: 'https://heimahr.itheima.net/api',changeOrigin: true,pathRewrite: { '^/prod-api': '' }})
)
app.listen(port, () => {console.log(`本地服务器启动http://localhost:${port}`)
})

2.nginx服务器部署

nginx简介

Nginx由俄罗斯工程师伊戈尔·赛索耶夫(Igor Sysoev)为rambler.ru(俄罗斯访问量第二大的网站)设计开发,是用于 Web 服务、反向代理、内容缓存、负载均衡、媒体流传输等场景的开源软件。自2004年发布以来,凭借开源的力量,Nginx不断完善和成熟。

nginx部署前端项目

找到nginx安装目录,修改配置文件,然后双击启动nginx.exe服务,注意每次修改后都需要重新启动nginx服务

解决刷新404问题

location / {root   E:\dist;index  index.html index.htm;try_files $uri $uri/ /index.html;#解决刷新404}

请求无法发送问题

location /prod-api/ {# 设置代理目标proxy_pass https://heimahr.itheima.net/api/;}

3.云服务器部署

  • 前提要有一个属于自己的云服务器,并下载好liunx系统
  • 本地电脑安装Xftp、Xshell软件

Xftp用于传输文件

Xshell用于编写命令

本地资源上传

将打包好的文件上传到远程服务器,我们这里可以使用Xftp,比较简单

首先打开Xftp,点击新建,然后输入主机地址,点击连接,接着根据提示输入用户(默认是root)、密码,如下图。

连接成功后,如下图,左边是你的本地文件,右边是远程服务器的文件

接下来把你需要上传的文件直接拖入到远程目录下就可以上传。

这里我把我的打包文件放在了/www/server/hr这个目录下,大家可以自己选择(建议不要放在root文件下面,会有权限的问题)

远程服务器下传nginx

使用Xshell软件连接远程服务器,和Xftp类似,点击新建,然后输入主机地址,点击连接,接着根据提示输入用户(默认是root)、密码,如下图。

连接成功后,如下图,接着可以这这里敲命令~

下载nginx

yum install nginx

查看nginx的版本

查看nginx的安装位置

ps -aux|grep nginx

nginx配置

找到nginx目录下的conf/nginx.conf文件,之前在本地怎么配置的,远程也是一样的~

server {listen 8110;server_name 主机ip地址;location / {root   /www/server/hr;index  index.html index.htm;try_files $uri $uri/ /index.html;#解决刷新404}location /prod-api/ {# 设置代理目标proxy_pass https://heimahr.itheima.net/api/;}error_page   500 502 503 504  /50x.html;location = /50x.html {root   html;}}

我这里用的8110端口,因为默认的端口跑了其他的项目,大家如果使用的是默认的80端口,接下的配置可以不用看,直接跳到启动nginx那里~

nginx新增对外开放端口方法

需要添加防火墙对外开放端口

firewall-cmd --list-all 查看开放的端口号

sudo firewall-cmd --add-port=8110/tcp --permanent 开放8110端

重启防火墙firewall-cmd --reload

此时再去通过浏览器访问
注意!!!如果这时还是不能访问就需要去自己的云服务器官网打开相关端口。

这里我以阿里云服务器为例,进入首页后打开控制台,找到服务器实例,点击安全组,如下图。

点击管理规则,在入方向这里进行端口的配置

此时再去通过浏览器访问,就可以正常访问了

启动nginx

service nginx start 

常见命令:

检查nginx配置文件是否正常: nginx -t

重启nginx: nginx -s reload

成功运行截图:

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

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

相关文章

AI-driven Robotics专栏目录

本文是机器人学和人工智能相关专题文章的目录,记录了作者在AI和Robotics方面的学习心得,欢迎参与互动讨论,一起学习进步。作者很懒,但文章持续更新中… ROS相关 建议按顺序阅读下列文章 基于Docker的ROS开发 ROS2基础编程 ROS…

wxPython Demo大全系列:ActivityIndicator控件分析

一、ActivityIndicator介绍 wx.ActivityIndicator 控件是 wxPython 中用于显示活动指示器的控件,通常用于指示程序正在执行某些后台任务或操作。它在用户界面中以动画的形式表现出活动状态,让用户知道应用程序正在进行处理而不是被挂起。 主要特点 可视…

数据源不同?奥威BI软件是这么做的

面对数据源不同的情况,BI(商业智能)软件如奥威BI软件通常通过一系列技术和方法来实现数据的整理。以下以奥威BI软件为例,详细解释其如何整理不同数据源的数据: 数据收集: 爬虫技术:奥威BI软件…

eNSP学习——理解OSPF的Router-ID

目录 相关命令 原理概述 实验内容 实验目的 实验步骤 实验拓扑 实验编址 具体步骤 1、验证Router-ID选举机制 2、基本配置 3、理解OSPF的Router-ID 加深理解 相关命令 [R1]router id 1.1.1.1 //手动强制指定Router-ID[R1]int g0/0/0 [R1-GigabitEthernet0/0/0]…

透视AI技术:探索折射技术在去衣应用中的奥秘

引言: 随着人工智能技术的飞速发展,其在图像处理和计算机视觉领域的应用日益广泛。其中,AI去衣技术作为一种颇具争议的应用,引发了广泛的讨论和关注。本文将深入探讨折射技术在AI去衣中的应用及其背后的原理。 一、AI去衣技术简介…

Java进阶指南:高级面试问题与精辟解答(二)

Java 面试问题及答案 1. 什么是Java中的多线程?请简述Java中实现多线程的两种方式。 答案: Java中的多线程指的是程序能够同时执行多个任务的能力。Java提供了两种主要的方式来实现多线程: 继承Thread类:创建一个继承自Thread类…

精通Java异常机制,写出高质量代码

作为一名Java开发人员,异常处理是一个无法回避的话题。无论你是初学者还是老手,精通异常处理对于写出高质量、可维护的代码至关重要。今天,我将与大家分享关于Java异常处理的一切,助你在代码质量的道路上突飞猛进! 一、什么是异常…

java小技能: 数字和字母组合的验证码图片(生成验证码字符并加上噪点,干扰线)

文章目录 引言I 验证码的作用1.1 验证使用计算机的是一个人,而非计算机程序。1.2 提供一个很短的时间窗的一次性密码。II 数字和字母组合的验证码图片2.1 获取验证码图片2.2 生成验证码字符并加上噪点,干扰线see also引言 世界上没有绝对的信息安全,但是有防范得好和坏的分…

打造云计算时代的仿真软件

2024年5月25日,北京云道智造科技有限公司(下称“云道智造”)在深圳成功举办了2024新品发布会暨用户大会。来自全国各地的近500位客户和合作伙伴代表齐聚一堂,共同见证了云道智造新产品的隆重发布,交流分享了仿真领域的…

C++到底是如何从代码到游戏的?

很难用一篇回答说明怎样从C代码一路写出游戏,中间涉及的知识和技术太多了。 但是换一个角度看,从基本的C代码开始写出任何东西都不至于难到无法理解的程度,任何复杂的软件都是有迹可循的。刚好我有一些资料,是我根据网友给的问题…

ehcache3的使用

springboot使用 启动类EnableCaching 方法使用 Cacheable(cacheNames “empCache”,key “#id”) 钩子实现: EnableCaching Configuration public class CacheConfig {/*** 配置缓存 */Beanpublic CustomerCache redisCache(){CustomerCache cache new Custo…

一文带你搞懂Java-final关键字

引言 阅读《Java并发编程实战》的基础知识篇发现java中的final作用实在是太大了,故结合实例深入剖析final关键字。 基础 修饰类 final修饰类时意味着该类不能被继承,所有方法都将为final,所有在final类中给任何方法添加final是没有任何意义的。 修饰方法 priv…

Java SE 深入总结:核心概念与实践

Java SE(Standard Edition)是Java平台的核心,为开发者提供了丰富的API和工具来构建各种桌面和移动应用。本文将深入探讨Java SE的核心概念,并通过代码示例来展示这些概念的应用。 1. 面向对象编程(OOP) J…

2024-05-29 blue-VH-driver-对外接口的并行调用-设计与思考

摘要: VH的driver的对外接口, 要做到可以并行,也就是两个不同的线程,分别调用,不能互相阻塞。 本文记录对其的思考和设计。 上下文: 2024-05-28 blue-VH-driver-需求分析及问题分析-CSDN博客 2024-05-27 blue-vh-问题点-CSDN博客 2024-05…

Wpf 使用 Prism 实战开发Day28

首页汇总方块点击导航功能 点击首页汇总方块的时候,跳转到对应的数据页面 step1: 在IndexViewModel 中,给TaskBar 里面Target 属性,赋上要跳转的页面 step2: 创建导航事件命令和方法实现 step3: 实现导航的逻辑。通过取到 IRegionManager 的…

免费,Python蓝桥杯等级考试真题--第17级(含答案解析和代码)

Python蓝桥杯等级考试真题–第17级 一、 选择题 答案:B 解析:(x-y)%25%21,故答案为B。 答案:B 解析:x16,所以i的值为range(1,16),取值为1-15&…

OpenMV学习笔记2——颜色识别

目录 一、打开单颜色识别实例代码 二、代码基础部分 三、阈值选择 四、给识别到的颜色画框 五、多颜色识别 一、打开单颜色识别实例代码 如图,双击打开对应文件即可进入实例代码。 二、代码基础部分 # Single Color RGB565 Blob Tracking Example # # This e…

手机拍照扫描成电子版,这三款软件助你轻松搞定!

在数字化时代,将手机拍照的内容快速转换为电子版已经成为许多人日常生活和工作中不可或缺的技能。无论是快速记录文档、合同,还是将纸质照片、笔记转化为电子格式,手机拍照扫描功能都为我们提供了极大的便利。今天,就为大家介绍三…

11.任务状态查询API函数总结

一、任务相关 API 函数预览 二、任务相关 API 函数详解 1. 函数 uxTaskPriorityGet() 此函数用于获取指定任务的任务优先级,若使用此函数,需在 FreeRTOSConfig.h 文件中设 置配置项 INCLUDE_uxTaskPriorityGet 为 1,此函数的函数原型如下所示…

mybatis异常:Invalid bound statement (not found): com.lm.mapper.ArticleMapper.list

现象: 原因: 无效绑定,应该是mybatis最常见的一个异常了,接口与XML文件没绑定。首先,mapper接口并没有实现类,所以框架会通过JDK动态代理代理模式获取接口的代理实现类,进而根据接口全限定类名…