将Vue+Nodejs项目部署到阿里云服务器

上传文件至云服务器

一、打包文件

在项目根目录下运行

npm run build

等待命令运行结束后,会发现目录下多了 dist 文件夹,这个文件夹就是我们等下要放到服务器中的。

二、文件传输

  1. 打开 Xftp与实例建立连接
  2. 云服务器Apache默认的根目录是/var/www/html,因此我们在这个目录下新建music文件夹(这里以我的项目文件名为例)
  3. 将项目本地的dist文件夹的内容移到云服务器music文件夹下(准备好前端资源)
  4. 将项目本地的server文件夹也移到云服务器dist文件夹下(这里注意不要复制node_modules文件夹
  5. 补充当时后台代码路径:C:\try\Vue-mmPlayer-master\dist
    上传代码到云服务器
    这里再补充一个项目:
    电商后台管理项目:http://arwin521.top/vue/
    在这里插入图片描述

这里将本地dist文件夹中的内容,放在了vue文件夹内,若直接将dist文件夹拖到vue路径下,则会报错
愚蠢的错误
报这样的错实在是太愚蠢了 😦

三、初始化项目

① 输入以下两行代码进入项目

进入项目目录
ls指令后下面会显示该目录下的文件夹

② 上传 package.json到服务器目录

上传 package.json

③ 在Xshell中安装"dependencies"中项目运行需要的所有依赖

 npm install

全部安装完成后,项目目录下便会有node_modules文件夹了。

④ 启动服务

这里默认已经云服务器已经安装了Nodejs,3000端口也添加到了安全组,且已经为Nodejs创建软链接(使node和npm命令全局有效,若未完成这一步请参考上一篇博文)

node app.js

运行app.js文件,在浏览器打开 服务器公网IP:80(如:263.182.35.68:80),就可以正常运行访问了。这里我使用的是网易云音乐提供的开源的api。
3000端口

四、安装pm2

上面我们以 node app.js 启动了项目,当我们退出 Xshell 时,进程就会关闭,无法再访问到项目,而 pm2 就是解决这种问题的,以 pm2 启动项目后,退出 Xshell 后依然可以正常访问。

① 安装pm2

npm install -g pm2

注:以 -g 全局安装的插件都在 node 安装目录 bin 文件下

② pm2配置全局变量

我们为了可以在任何目录都可以使用pm2命令,我们将此文件夹加入环境变量

whereis pm2

查询pm2的安装路径 显示是: /opt/node/bin/pm2

ln  -s /opt/node/bin/pm2 /usr/local/bin
pm2

这一步为pm2配置全局变量
注意这里如果重复操作有可能会出现以下错误:
failed to create symbolic link ‘/usr/local/bin/pm2’: File exists
这里只需要删除并重新创建软链,再执行pm2

mv /usr/local/bin/pm2 /tmp/
ln  -s /opt/node/bin/pm2 /usr/local/bin
pm2

failed to create symbolic link ‘/usr/local/bin/pm2’: File exists

③ 启动项目

 cd /var/www/html/music/dist/serverpm2 start app.js

pm2启动
这样以 pm2 启动项目后,退出 Xshell 后,就依然可以正常访问了。
贴上项目跑起来以后的地址:http://arwin521.top/music/arwin/#/music/toplist

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

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

相关文章

javascript --- 函数的优化(尾调用优化)

从一个熟悉的Fibonacci数列的实现开始: function Fibonacci (n) {if ( n < 1) { return 1};return Fibonacci(n -1) Fibonacci(n-2); }以上代码很简单… 但执行以下代码 console.log(Fibonacci(100));会发现编译工具,卡住不动. 原因在于:递归调用(函数调用自身),每次都会…

第5课 - 线性表的本质

第5课 - 线性表的本质 数据结构是为了解决生活中的实际问题而存在的&#xff0c;那生活中与线性表相对应的例子有什么呢&#xff1f; 幼儿园中就有一个例子&#xff0c;在老师安排小朋友活动时&#xff0c;会将小朋友组织成下面的站队形式&#xff0c;这个就是线性表。 1. 线性…

Django--网页管理实例解析

此篇为代码流程的注释以及自己写的小项目的思路&#xff1a; 首先是项目的路由配置&#xff1a; 1 urlpatterns [2 # url(r^admin/, admin.site.urls),3 url(r^yemian/,yemian),4 url(r^zuoye/,zuoye),5 url(r^class/,views.class_list),6 url(r^class_ad…

阿里云ecs实例中创建数据库

阿里云ecs实例中创建数据库安装mysql创建数据库1.登录2.新建数据库3.执行.sql文件4.查询表&#xff0c;验证是否创建成功4.退出数据库安装mysql 参考https://blog.csdn.net/qq_36350532/article/details/79496049 创建数据库 1.登录 mysql -u root -p&#xff08;这里写密码…

javascript --- 尾递归优化的实现

考虑一个正常的递归函数 function sum(x, y) {if (y > 0) {return sum (x 1, y - 1);} else {return x;} } sum(1, 100000000);超出调用栈的最大次数… 下面使用尾递归优化实现: function tco(f) {var value ;var active false;var accumulated [];return function acc…

《对不队》团队项目用户验收评审

任务1&#xff1a;团队作业Beta冲刺 Beta冲刺第一天&#xff1a;https://www.cnblogs.com/bingoF6/p/9221744.htmlBeta冲刺第二天&#xff1a;https://www.cnblogs.com/bingoF6/p/9226305.htmlBeta冲刺第三天&#xff1a;https://www.cnblogs.com/bingoF6/p/9230815.htmlBeta冲…

部署项目的问题(一)—— vue工程打包上线样式错乱问题

1、 打开index.html一片空白 参考&#xff1a;链接: link. 修改build对象里的assetsPublicPath为’./’ assetsPublicPath: ./2、ElementUI样式丢失 参考&#xff1a;链接: link. 这里尝试完前三种&#xff1a; 1.main.js样式引入顺序问题 调整了import的顺序&#xff08;…

构建SpringBoot第一个Demo

使用官方地址生成项目 https://start.spring.io Generate&#xff1a;可以选择Maven或者Gradle构建项目 语言&#xff1a;我想一般都是Java 接下来选择SpringBoot的版本&#xff0c;目前比较稳定的1.5.10 GroupID&#xff1a;自定义 Artifact&#xff1a;自定义 Dependencies&…

部署项目的问题(二)—— 阿里云服务器 ECS升级node版本

在运行服务端代码时报错&#xff0c;当时报错的代码没copy下来&#xff0c;大概就是如下形式 mbp:hybrid-statistic wfp$ node app.js /Users/wfp/Work/hybrid-statistic/app.js:28 async function responseTime(ctx, next) {^^^^^^^^ SyntaxError: Unexpected token function…

javascript --- Object.assign()浅复制解决方法

Object.assign()是浅复制(即:只复制对象得引用而,而不是新实例).它无法正确复制get属性和set属性. 看下面得例子: // 定义一个source对象,含set方法 const source {set foo(value) {console.log(value);} };// 使用Object.assign进行赋值 const target1 {}; Object.assign(t…

微信小程序与Java后台的通信

一、写在前面 最近接触了小程序的开发&#xff0c;后端选择Java&#xff0c;因为小程序的代码运行在腾讯的服务器上&#xff0c;而我们自己编写的Java代码运行在我们自己部署的服务器上&#xff0c;所以一开始不是很明白小程序如何与后台进行通信的&#xff0c;然后查找资料发现…

面向对象初识④

抽象类与接口类 接口类 继承有两种用途&#xff1a; 一&#xff1a;继承基类的方法&#xff0c;并且做出自己的改变或者扩展&#xff08;代码重用&#xff09; 二&#xff1a;声明某个子类兼容于某基类&#xff0c;定义一个接口类Interface&#xff0c;接口类中定义了一些接口…

部署项目的问题(三)—— node启动服务时listen监听的端口被占用

Error: listen EADDRINUSE :::8888表示的就是listen监听的端口被占用 查询什么进程占用了8888端口 sudo fuser -n tcp 8888 &#xff08;指令一&#xff09; 或者 netstat -tln | grep 8888 &#xff08;指令二&#xff09;反复执行指令一&#xff0c;总得到不同结果&#x…

es6 --- 内置的Symbol值

Symbol.hasInstance // Symbol.hasInstance class MyClass {[Symbol.hasInstance] (foo) {return foo instanceof Array;} } [1, 2, 3] instanceof new MyClass() // true// symbol.hasInstance:会在[1, 2, 3] instanceof 时 自动调用 [Symbol.hasInstance] (foo) 方法... //…

15 调试

1. pdb pdb是基于命令行的调试工具&#xff0c;非常类似gnu的gdb&#xff08;调试c/c&#xff09;。 def getAverage(a,b):result abprint("result is %s"%result)return resulta 10 b 20 c ab ret getAverage(a,b) print(ret) 2.执行时调试 程序启动&#xff0…

html5播放视频只有声音不出现画面?

一开始网上大神们都是要把MP4的编码格式转换成AVC&#xff08;H264&#xff09;&#xff0c;然后赶紧用格式工厂把它给换了&#xff0c;结果&#xff01;&#xff01; 没用&#xff01;&#xff01;还是黑屏&#xff1f;&#xff1f;&#xff1f;咋回事啊&#xff0c;然后自己又…

vue项目代码改进(一)login组件

Login登录组件 1. 新增登录头像&#xff08;css样式回顾&#xff09; 1&#xff09;div.avatar 2&#xff09;子绝父相定位&#xff0c;left…top… 3&#xff09;border 4&#xff09;placeholder 5&#xff09;box-shadow box-shadow: offset-x offset-y blur spread color …

解析DBF文件

上周&#xff0c;公司给了许多DBF后缀的数据文件让我进行解析。 因为是DBF文件我发现mysql&#xff0c;和Oracle都能直接对DBF文件进行导入。在导入过程中发现这些数据库并不能识别这些文件。 通过百度找到了打开这种文件的软件Visual FoxPro、Access&#xff0c;用它们打开后出…

Scrum 冲刺 第一日

Scrum 冲刺 第一日 站立式会议燃尽图Alpha 阶段认领任务明日任务安排项目预期任务量成员贡献值计算规则今日贡献量参考资料站立式会议 返回目录 燃尽图 返回目录 Alpha 阶段认领任务 学号组员分工用时20162309邢天岳补充说明书&部分测试18h20162311张之睿编写代码20h201623…

浅析 NodeJs 的几种文件路径

Node 中的文件路径大概有 __dirname, __filename, process.cwd(), ./ 或者 ../&#xff0c;前三个都是绝对路径&#xff0c;为了便于比较&#xff0c;./ 和 ../ 我们通过 path.resolve(./)来转换为绝对路径。 先看一个简单的栗子&#xff1a; 假如我们有这样的文件结构&#xf…