首頁 > web前端 > js教程 > 使用pm2部署node.js專案全過程分享

使用pm2部署node.js專案全過程分享

小云云
發布: 2018-03-09 09:10:04
原創
2574 人瀏覽過

一、買域名和伺服器

要部署專案肯定要買域名,這點是必不可少的,發現騰訊雲上邊有免費的伺服器可用(只免費7天),於是就到騰訊雲買了域名,又在騰訊雲領了免費的伺服器,當然這段期間會讓你實名認證。

買網域

#採用伺服器

在騰訊雲選擇了CentOS伺服器,接下來進行網域解析,然後設定伺服器(帳號密碼之類的)

網域解析

二、部署Node.js環境

(一)登入伺服器,先更新一下(第一次使用伺服器先更新)

yum update -y
登入後複製

(二)安裝node 和pm2

wget指令下載Node.js安裝套件。安裝套件是編譯好的文件,解壓縮之後,在bin資料夾中就已存在node和npm,無需重複編譯。

wget https://nodejs.org/dist/v8.9.3/node-v8.9.3-linux-x64.tar.xz
登入後複製

解壓縮檔案。

tar xvf node-v8.9.3-linux-x64.tar.xz
登入後複製

建立軟鏈接,使node和npm指令全域有效。透過建立軟體連結的方法,使得在任意目錄下都可以直接使用node和npm指令:

ln -s /root/node-v8.9.3-linux-x64/bin/node /usr/local/bin/node
ln -s /root/node-v8.9.3-linux-x64/bin/npm /usr/local/bin/npm
登入後複製

查看node、npm版本。

node -v
npm -v
登入後複製

至此,Node.js環境已安裝完畢。軟體預設安裝在/root/node-v8.9.3-linux-x64/目錄下。如果需要將軟體安裝到其他目錄(如:/opt/node/)下,請進行以下操作:

mkdir -p /opt/node/
mv /root/node-v8.9.3-linux-x64/* /opt/node/
rm -f /usr/local/bin/node
rm -f /usr/local/bin/npm
ln -s /opt/node/bin/node /usr/local/bin/node
ln -s /opt/node/bin/npm /usr/local/bin/npm
登入後複製

安裝pm2

npm install pm2@latest -g
登入後複製

建立軟鏈接,使pm2指令全域有效

ln -s /root/node-v8.9.3-linux-x64/bin/pm2 /usr/local/bin/pm2
登入後複製

三、將專案用git部署到伺服器上

#首先進入到伺服器根目錄,顯示根目錄資料夾內容,然後進入var目錄下邊,在var目錄下邊新建一個www的資料夾,顯示var資料夾下邊內容,再進入www資料夾下邊,依序指令為

cd /
ls
cd var
ls
mkdir www
cd www
登入後複製

上個圖片

然後將你的倉庫裡面的項目git clone 下來

首先要安裝git,使用下邊指令

yum install git
y
登入後複製

進入到你的專案中

上圖中可以看到有一個不是express專案的文件,它是pm2的設定檔pm2的設定方法為http://pm2.keymetrics.io/docs/usage/ cluster-mode/

下邊是我專案裡面的配置(新手,有問題大神可以指點下)

{
 "apps": [
  {
   "name": "app1",
   "script": "bin/www",
   "log_date_format": "YYYY-MM-DD HH:mm:SS",
   "log_file": "logs/app1.log",
   "error_file": "logs/app1-err.log",
   "out_file": "logs/app1-out.log",
   "pid_file": "pids/app1.pid",
   "instances": 1,
   "min_uptime": "200s",
   "max_restarts": 10,
   "max_memory_restart": "1M",
   "cron_restart": "1 0 * * *",
   "watch": false,
   "merge_logs": true,
   "exec_interpreter": "node",
   "exec_mode": "cluster_mode",
   "autorestart": true,
   "vizion": false
  }
 ]
}
登入後複製

四、啟動項目

pm2 start processes.json
登入後複製

#關閉項目

先查找ID
pm2 status
然后,停止相应项目的id
pm2 stop id
登入後複製

再啟動對應項目

先查找ID
pm2 status
然后,开启相应项目的id
pm2 start id
登入後複製

設定pm2開機自動啟動

pm2 startup
pm2 save
登入後複製

之所以使用pm2啟動項目,是因為這樣退出伺服器鏈接,node專案依舊可以運作。

這樣專案已經部署完成,但是專案中的連接埠只能是80埠。後台大神告訴可以用nginx做代理伺服器。並告訴了安裝方法。

五、安裝nginx 並設定nginx

安裝nginx

yum install nginx
登入後複製

設定nginx

進入設定的資料夾目錄,編輯nginx.conf 文件,也可以在conf.d資料夾下新建後綴名為.conf的文件

cd /
cd etc/nginx
vim nginx.conf
登入後複製

來張圖

##這裡用到了vim編輯器的使用方法,可在網上搜使用方法


簡單提幾個使用方法,直接按鍵盤

i  编辑
Esc 退出编辑
:q  退出vim编辑器
:wq 保存并退出vim编辑器
登入後複製
下邊是我的nginx配置(新手,有問題大神可以指點下)

啟動nginx


service nginx start
登入後複製
這樣nginx就運行了。


每次修改完nginx設定都要重新啟動下,用下邊的指令

service nginx reload
登入後複製
設定nginx開機自動啟動

ln -s /bin/systemctl /usr/local/bin/systemcel
systemcel enable nginx
登入後複製
至此,node專案在伺服器部署結束,直接存取網址即可。

相關推薦:

pm2部署多個node.js專案教學分享

#教你在heroku雲端平台上部署Node. js應用程式_node.js

nodejs安裝設定並部署一個網站實例教學分享

以上是使用pm2部署node.js專案全過程分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板