PM2實現(xiàn)Nodejs項目自動部署
首先簡單說下思路:本地git倉庫與遠(yuǎn)程倉庫關(guān)聯(lián)(github、碼云等平臺)汹粤,然后pm2按照指定配置登錄服務(wù)器,拉取遠(yuǎn)程倉庫的代碼更新,再執(zhí)行一些指定的命令(如打包等)湘纵。
創(chuàng)建本地項目并關(guān)聯(lián)到遠(yuǎn)程倉庫
- 本地新建名為web的項目,進(jìn)入項目并創(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:');
})
- 把本地項目放到遠(yuǎn)程倉庫脖咐,可選Github或者碼云等平臺铺敌。首先查看本地是否生成過
.ssh
目錄及目錄下是否有私鑰及公鑰文件
ls ~/.ssh
- 如果存在,跳到下一步屁擅。如果不存在
id_rsa
偿凭、id_rsa.pub
文件,需要先生成一下:
"youemail"填寫你的郵箱
ssh-keygen -t rsa -C "youremail"
- 查看本地公鑰的內(nèi)容并復(fù)制內(nèi)容添加到遠(yuǎn)程倉庫
cat ~/.ssh/id_rsa.pub
- 本地倉庫關(guān)聯(lián)遠(yuǎn)程倉庫的其他操作這里就不贅述派歌。
服務(wù)器從遠(yuǎn)程倉庫拉取項目
服務(wù)器環(huán)境:阿里云的ecs弯囊,系統(tǒng)是Ubuntu 14.06
這一步后面是不需要手動操作的,但我們要做好配置胶果,這里可以先手動拉取遠(yuǎn)程代碼測試一下是否配置成功匾嘱。
- 確保服務(wù)器已安裝NodeJs、git早抠、pm2,未安裝的話自行百度霎烙。
- 復(fù)制服務(wù)器的公鑰并添加到遠(yuǎn)程倉庫,操作步驟同本地的2、3悬垃、4步游昼。
- 定位到用戶目錄,拉取遠(yuǎn)程倉庫確钡脸溃可以拉取成功,若成功的話這個項目目錄刪除即可酱床。
xxxx為你遠(yuǎn)程倉庫的項目地址
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",
// 遠(yuǎn)程倉庫地址
"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
- 進(jìn)入用戶目錄,并編輯
.bashrc
文件簸淀,下面幾行都注釋掉
這步是為了防止部署的時候服務(wù)器報錯找不到pm2命令
# If not running interactively, don't do anything
#case $- in
# *i*) ;;
# *) return;;
#esac
- nginx做好端口轉(zhuǎn)發(fā)配置
執(zhí)行部署
- 把本地項目所有的更新push到遠(yuǎn)程倉庫瓶蝴,然后執(zhí)行
pm2 deploy ecosystem.json production setup
pm2 deploy ecosystem.json production
如果沒有問題的話,本地打開瀏覽器訪問對應(yīng)ip:port就可以看到內(nèi)容了租幕。
后面每次項目做了個更新之后舷手, 同步到遠(yuǎn)程倉庫,然后執(zhí)行pm2 deploy ecosystem.json production
即可劲绪。