首先簡單說下思路:本地git倉庫與遠程倉庫關聯(github、碼雲等平台),然后pm2按照指定配置登錄服務器,拉取遠程倉庫的代碼更新,再執行一些指定的命令(如打包等)。
創建本地項目並關聯到遠程倉庫
本地新建名為web的項目,進入項目並創建一個簡單的Nodejs文件app.js,
mkdir web && cd web vi app.js
文件內容編輯如下,完成后保存退出: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"
- 查看本地公鑰的內容並復制內容添加到遠程倉庫
cat ~/.ssh/id_rsa.pub
本地倉庫關聯遠程倉庫的其他操作這里就不贅述。
服務器從遠程倉庫拉取項目
服務器環境:阿里雲的ecs,系統是Ubuntu 14.06
這一步后面是不需要手動操作的,但我們要做好配置,這里可以先手動拉取遠程代碼測試一下是否配置成功。
- 確保服務器已安裝NodeJs、git、pm2,未安裝的話自行百度。
- 復制服務器的公鑰並添加到遠程倉庫,操作步驟同本地的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" // 環境變量 } } ], // 環境部署的配置,此處只以production為例 "deploy": { "production": { // 登錄服務器的用戶名 "user":"slevin", // 服務器ip "host": ["47.75.191.199"], // 服務器ssh登錄端口,未修改的話一般默認為22 "port": "22", // 指定拉取的分支 "ref": "origin/master", // 遠程倉庫地址 "repo": "git@gitee.com:mslevin/website.git", // 指定代碼拉取到服務器的目錄 "path": "/www/website/production", "ssh_options": "StrictHostKeyChecking=no", "env": { "NODE_ENV": "production" } } } }
服務器相關配置
配置文件中指定了存放項目的目錄/www/website/production,但可能並不存在,需要手動新建:
mkdir /www && cd www mkdir website
由於pm2需要在website目錄中創建productions目錄,需要更改website的讀寫權限
cd /www sudo chmod 777 website
進入用戶目錄,並編輯.bashrc文件,下面幾行都注釋掉
這步是為了防止部署的時候服務器報錯找不到pm2命令
# If not running interactively, don't do anything #case $- in # *i*) ;; # *) return;; #esac
nginx做好端口轉發配置
廣州品牌設計公司https://www.houdianzi.com PPT模板下載大全https://redbox.wode007.com
執行部署
把本地項目所有的更新push到遠程倉庫,然后執行
pm2 deploy ecosystem.json production setup pm2 deploy ecosystem.json production
如果沒有問題的話,本地打開瀏覽器訪問對應ip:port就可以看到內容了。后面每次項目做了個更新之后, 同步到遠程倉庫,然后執行pm2 deploy ecosystem.json production即可。