將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.pswp.cn/news/251443.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/251443.shtml
英文地址,請注明出處:http://en.pswp.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;…

遲遲發布的軟工實踐兩月感想

第七周&#xff0c;第八周了。 寫幾點反省。 嚴謹。工作的時候&#xff0c;說話行文風格要注意&#xff0c;因為這影響溝通的質量&#xff0c;影響別人對你的評價。會間接影響對方的響應&#xff0c;影響合作。學會主動承擔責任&#xff0c;做受關注的那個人。主動鍛煉自己。開…

構建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) 方法... //…

對象的克隆

對象的克隆 1、克隆即復制的意思&#xff0c;對象的克隆&#xff0c;意味著生成一個對象&#xff0c;這個對象和某個對象的屬性和行為是一致的&#xff0c;但是這個對象和源對象是兩個不同的對象。實現對象的克隆&#xff0c;方法是實現Cloneable接口&#xff0c;否則會報異常C…

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 …

es6 --- set實現并集(Union)、交集(Intersect)和差集(Difference)

Set:類似于數組,但是成員的值都是唯一的 let a new Set([1, 2, 3]); let b new Set([4, 3, 2]);// 并集 let union new Set([...a, ...b]);// 交集 let intersect new Set([...a].filter(x > b.has(x)));// 差級 let difference new Set( [...a].filter(x > !b.has…