【超详细!】vue+koa+nginx前后端分离开发项目上线部署到云服务器

本文涉及的产品
.cn 域名,1个 12个月
简介: 1、项目介绍本项目是vue+koa前后端分离开发的手机商城项目,先贴一下项目的目录,我们主要就是要部署dist和server这两个文件夹

1、项目介绍


本项目是vue+koa前后端分离开发的手机商城项目,先贴一下项目的目录,我们主要就是要部署dist和server这两个文件夹


image.png


2、部署前文件的处理


(1)修改config/index.js文件


将build里面的assetsPublicPath路径改成./,不然生成的dist文件加载不到js、css、img等静态文件


build: {
    //需要修改的地方
    assetsPublicPath: './',


(2)修改请求后端的url


在本地进行项目开发,后端的url一般都用http://localhost:3000。部署上线后就需要将这个url换成真正的域名了,我是统一定义在src/config.js文件里面


后面跟的端口要跟后端server/app.js里面的监听端口app.listen(3000)一致

//需要修改的部分
const host = 'http://yourdomain.com:3000'
const config = {
  host
}
export default config


(3)在项目文件夹下面运行npm run build,生成dist文件夹


~/xbapp$ npm run build


生成的dist文件夹目录,我们在本地打开dist/index.html文件,测试一下样式是否能正常显示


image.png


(4)修改数据库信息


后端有操作数据库的话,也需要更改数据库名、数据库密码等信息


3、将项目上传到云服务器


用git或者scp上传都可以,我上传到了/mnt/xbapp目录下面


git上传有个需要注意的地方,项目根目录下面的.gitigonre文件可能会将dist文件夹忽略上传,我们需要在.gitigonre文件中删掉dist/


.DS_Store
dist/     //需要删掉
npm-debug.log*
yarn-debug.log*
yarn-error.log*


git程序员都会,就不展开讲了,之前写过git部署项目的文章,大家可以借鉴一下

项目上线–git部署项目


下面我们就开始在云服务器上操作了


4、koa配置并测试


(1)安装koa插件


koa需要node环境的支持,云服务器如果没有node环境需要先安装node

node环境安装参考文章


接下来我们开始安装koa插件


#打开server文件夹
cd /mnt/xbapp/server
#删掉node_modules文件夹和package-lock.json文件
rm -r node_modules
rm package-lock.json
#安装插件
npm install
#开启项目
npm run dev


npm install的时候,可能会报错,比如let notifier = require('update-notifier')({pkg})这个错误,大部分的错误是因为node版本过低引起的,可以更新一下node版本,参考文章:linux环境升级node版本


(2)测试


成功运行npm run dev之后,不代表koa已经配置成功了,在浏览器上面输入域名+koa开启的端口,顺利返回koa2就说明后端已经部署OK了


image.png


(3)可能遇到的错误


当然啦,在顺利见到上面的效果之前,可能会碰倒许许多多的错误,如果npm run dev成功之后,域名+端口请求还是显示连接超时

告诉大家几个解题思路:


  • ping一下域名检查是不是域名的问题


ping yourdomain.com


  • 不是域名问题 在用telnet检查一下端口,域名没有问题的话,一般问题就出在端口身上


telnet yourdomain.com 3000


端口出问题原因有很多,大家只能根据自己的情况来解决了,我用的是阿里云服务器,


端口请求超时的原因是安全组中没有开启3000端口,添加上就可以了。


添加端口参考文章:在安全组中添加授权端口


5、配置nginx


nginx是web代理服务器,由他将浏览器的请求转发到服务器项目上面


一般安装好的nginx都在/etc/nginx文件夹中,我们先来看一下这里面的nginx.conf文件,里面能找到这么两条语句,意思是nginx的配置会引用/etc/nginx/conf.d/文件夹下面以.conf结尾的文件和/etc/nginx/sites-enabled/文件夹下面的所有文件



 include /etc/nginx/conf.d/*.conf;
 include /etc/nginx/sites-enabled/*;


所以,我们在这两个文件夹下面进行配置都可以,我比较习惯在conf.d文件夹里面


#打开conf.d文件夹
cd /etc/nginx/conf.d
#创建一个.conf文件
touch xbapp.conf
#打开刚刚创建的文件
vim xbapp.conf


在xbapp.conf文件中粘贴下面的代码,


upstream koa.server{
  server localhost:3000;
}
server {
  listen   80;
  server_name yourdomain.com;    #这里修改成自己的域名
  root /mnt/xbapp/dist;  #修改成自己的文件夹路径,index页面在dist文件夹下,所以指向dist文件夹
  location / {
    index  index.html index.htm;
  }
}


配置好了之后,输入nginx -t检查一下nginx配置是否成功,成功的话,会显示下面这两条语句


$ nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful


重新启动nginx


service nginx restart


现在打开域名应该就可以正常显示项目页面了,最后我们来安装pm2这个进程管理器,帮助koa后端进程长期开启


6、安装pm2并启动项目


//安装pm2
~$ npm install pm2 --global
//检查是否安装成功
~$ pm2 -v
//进入项目目录
~$ cd /mnt/xbapp/server/
//启动项目
/mnt/xbapp/server/$ pm2 start app.js
//启动成功返回的信息
[PM2] Starting /mnt/truth_hold/server/app.js in fork_mode (1 instance)
[PM2] Done.
┌────┬────────────────────┬──────────┬──────┬──────────┬──────────┬──────────┐
│ id │ name               │ mode     │ ↺    │ status   │ cpu      │ memory   │
├────┼────────────────────┼──────────┼──────┼──────────┼──────────┼──────────┤
│ 0  │ app                │ fork     │ 0    │ online   │ 0%       │ 25.8mb   │
└────┴────────────────────┴──────────┴──────┴──────────┴──────────┴──────────┘


这样vue项目就算是部署成功了~~


相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
7天前
|
存储 人工智能 自然语言处理
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
ChatMCP 是一款基于模型上下文协议(MCP)的 AI 聊天客户端,支持多语言和自动化安装。它能够与多种大型语言模型(LLM)如 OpenAI、Claude 和 OLLama 等进行交互,具备自动化安装 MCP 服务器、SSE 传输支持、自动选择服务器、聊天记录管理等功能。
68 14
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
|
28天前
|
安全 开发工具 Swift
Swift 是苹果公司开发的现代编程语言,具备高效、安全、简洁的特点,支持类型推断、闭包、泛型等特性,广泛应用于苹果各平台及服务器端开发
Swift 是苹果公司开发的现代编程语言,具备高效、安全、简洁的特点,支持类型推断、闭包、泛型等特性,广泛应用于苹果各平台及服务器端开发。基础语法涵盖变量、常量、数据类型、运算符、控制流等,高级特性包括函数、闭包、类、结构体、协议和泛型。
29 2
|
1月前
|
关系型数据库 API 数据库
后端开发的艺术:从零到一构建高效服务器
在数字化时代,后端开发是支撑现代互联网应用的基石。本文旨在探讨后端开发的核心概念、关键技术以及如何构建一个高效的服务器。我们将从基础的编程语言选择开始,逐步深入到数据库设计、API开发和性能优化等关键领域。通过实际案例分析,我们将揭示后端开发的复杂性和挑战性,同时提供实用的解决方案和最佳实践。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的见解和启发。
|
2月前
|
前端开发 JavaScript Java
第6章:Vue中的ajax(包含:回顾发送ajax请求方式、vue-cli脚手架配置代理服务器)
第6章:Vue中的ajax(包含:回顾发送ajax请求方式、vue-cli脚手架配置代理服务器)
83 4
|
2月前
|
网络安全 Docker 容器
VScode远程服务器之远程 远程容器 进行开发(五)
VScode远程服务器之远程 远程容器 进行开发(五)
46 1
|
2月前
|
Java PHP
PHP作为广受青睐的服务器端脚本语言,在Web开发中占据重要地位。理解其垃圾回收机制有助于开发高效稳定的PHP应用。
【10月更文挑战第1天】PHP作为广受青睐的服务器端脚本语言,在Web开发中占据重要地位。其垃圾回收机制包括引用计数与循环垃圾回收,对提升应用性能和稳定性至关重要。本文通过具体案例分析,详细探讨PHP垃圾回收机制的工作原理,特别是如何解决循环引用问题。在PHP 8中,垃圾回收机制得到进一步优化,提高了效率和准确性。理解这些机制有助于开发高效稳定的PHP应用。
53 3
|
2月前
|
NoSQL PHP Redis
布谷语音app源码服务器环境配置及技术开发语言
布谷语音app源码服务器环境配置及技术语言研发。。
|
2月前
|
Kubernetes 网络安全 容器
VScode远程服务器进行开发(三)
VScode远程服务器进行开发(三)
47 0
|
3月前
|
JavaScript 前端开发
vue配合axios连接express搭建的node服务器接口_简单案例
文章介绍了如何使用Express框架搭建一个简单的Node服务器,并使用Vue结合Axios进行前端开发和接口调用,同时讨论了开发过程中遇到的跨域问题及其解决方案。
66 0
vue配合axios连接express搭建的node服务器接口_简单案例
|
数据采集 SQL 弹性计算
使用云服务器ECS部署了自己的第一个爬虫
云服务器部署爬虫爬取网站最新通告并推送
使用云服务器ECS部署了自己的第一个爬虫