M2實現(xiàn)Nodejs項目自動部署的方法步驟
PM2實現(xiàn)Nodejs項目自動部署
首先簡單說下思路:本地git倉庫與遠程倉庫關(guān)聯(lián)(github、碼云等平臺),然后pm2按照指定配置登錄服務(wù)器,拉取遠程倉庫的代碼更新,再執(zhí)行一些指定的命令(如打包等)。
創(chuàng)建本地項目并關(guān)聯(lián)到遠程倉庫
本地新建名為web的項目,進入項目并創(chuàng)建一個簡單的Nodejs文件app.js,
mkdir web && cd web vi app.js
文件內(nèi)容編輯如下,完成后保存退出:wq!。
// app.s const http = require('http'); const homePage = ` <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style type="text/css"> * { padding: 0; margin: 0; } body { padding: 30px 0; text-align: center; font-size: 16px; background-color: #333; } h1,h2 { color: #fff; } nav { margin-top: 20px; } a { color: #ccc; cursor: pointer; } a:hover { text-decoration: underline; } </style> </head> <body> <h1>Nodejs部署示例項目</h1> <h2>項目部署上線示例</h2> <nav> <ul> <li><a>列表</a></li> </ul> </nav> </body> </html> ` http.createServer((req,res) => { res.statusCode = 200; res.setHeader('Content-Type','text/html'); res.end(homePage); }).listen(3000, () => { console.log('Sever Running On 3000:'); })
把本地項目放到遠程倉庫,可選Github或者碼云等平臺。首先查看本地是否生成過.ssh目錄及目錄下是否有私鑰及公鑰文件
ls ~/.ssh
如果存在,跳到下一步。如果不存在id_rsa、id_rsa.pub文件,需要先生成一下:
"youemail"填寫你的郵箱
ssh-keygen -t rsa -C "youremail"
查看本地公鑰的內(nèi)容并復(fù)制內(nèi)容添加到遠程倉庫
cat ~/.ssh/id_rsa.pub
本地倉庫關(guān)聯(lián)遠程倉庫的其他操作這里就不贅述。
服務(wù)器從遠程倉庫拉取項目
服務(wù)器環(huán)境:阿里云的ecs,系統(tǒng)是Ubuntu 14.06
這一步后面是不需要手動操作的,但我們要做好配置,這里可以先手動拉取遠程代碼測試一下是否配置成功。
確保服務(wù)器已安裝NodeJs、git、pm2,未安裝的話自行百度。
復(fù)制服務(wù)器的公鑰并添加到遠程倉庫,操作步驟同本地的2、3、4步。
定位到用戶目錄,拉取遠程倉庫確??梢岳〕晒?若成功的話這個項目目錄刪除即可。
xxxx為你遠程倉庫的項目地址
cd ~ git clone xxxx
項目中配置pm2自動部署文件
在本地項目中新建配置文件ecosystem.json,這里為了方便理解添加了注釋,但json文件不能有注釋,記得去掉。
{ "apps":[ { "name": "website", // 項目名稱 "script": "app.js", // 入口文件 "env": { "COMMON_VARIABLE": "true" }, "env_production": { "NODE_ENV": "production" // 環(huán)境變量 } } ], // 環(huán)境部署的配置,此處只以production為例 "deploy": { "production": { // 登錄服務(wù)器的用戶名 "user":"slevin", // 服務(wù)器ip "host": ["47.75.191.199"], // 服務(wù)器ssh登錄端口,未修改的話一般默認(rèn)為22 "port": "22", // 指定拉取的分支 "ref": "origin/master", // 遠程倉庫地址 "repo": "git@gitee.com:mslevin/website.git", // 指定代碼拉取到服務(wù)器的目錄 "path": "/www/website/production", "ssh_options": "StrictHostKeyChecking=no", "env": { "NODE_ENV": "production" } } } }
服務(wù)器相關(guān)配置
配置文件中指定了存放項目的目錄/www/website/production,但可能并不存在,需要手動新建:
mkdir /www && cd www mkdir website
由于pm2需要在website目錄中創(chuàng)建productions目錄,需要更改website的讀寫權(quán)限
cd /www sudo chmod 777 website
進入用戶目錄,并編輯.bashrc文件,下面幾行都注釋掉
這步是為了防止部署的時候服務(wù)器報錯找不到pm2命令
# If not running interactively, don't do anything #case $- in # *i*) ;; # *) return;; #esac
nginx做好端口轉(zhuǎn)發(fā)配置
執(zhí)行部署
把本地項目所有的更新push到遠程倉庫,然后執(zhí)行
pm2 deploy ecosystem.json production setup pm2 deploy ecosystem.json production
如果沒有問題的話,本地打開瀏覽器訪問對應(yīng)ip:port就可以看到內(nèi)容了。
后面每次項目做了個更新之后, 同步到遠程倉庫,然后執(zhí)行pm2 deploy ecosystem.json production
即可。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
實現(xiàn)一個完整的Node.js RESTful API的示例
本篇文章主要介紹了實現(xiàn)一個完整的Node.js RESTful API的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09npm報錯:npm?WARN?config?global?'--global',?&apo
這篇文章主要給大家介紹了關(guān)于npm報錯:npm?WARN?config?global?'--global',?'--local'?are?deprecated.?Use?`--location=global`?instead.的解決方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-08-08配置node服務(wù)器并且鏈接微信公眾號接口配置步驟詳解
這篇文章主要介紹了配置node服務(wù)器并且鏈接微信公眾號接口配置步驟詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,,需要的朋友可以參考下2019-06-06Node.js中開發(fā)樹形結(jié)構(gòu)接口的實現(xiàn)
本文介紹了Node.js中開發(fā)樹形結(jié)構(gòu)接口的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-12-12詳解nodejs操作mongodb數(shù)據(jù)庫封裝DB類
這篇文章主要介紹了詳解nodejs操作mongodb數(shù)據(jù)庫封裝DB類,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04如何使用axios庫在Node.js中進行代理請求(實踐案例)
axios是一個強大的基于Promise的HTTP客戶端,它在瀏覽器和Node.js環(huán)境中均可使用,本文將介紹如何充分利用axios庫,在Node.js中進行代理請求的最佳實踐,并通過一個實際案例來展示其應(yīng)用,感興趣的朋友一起看看吧2024-03-03Node如何實現(xiàn)在瀏覽器預(yù)覽項目的所有圖片詳解
最近項目遇到了個需求,需要將存放圖片進行預(yù)覽,所以這篇文章主要給大家介紹了關(guān)于Node如何實現(xiàn)在瀏覽器預(yù)覽項目的所有圖片的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-01-01