溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

M2實(shí)現(xiàn)Nodejs項(xiàng)目自動(dòng)部署的方法步驟

發(fā)布時(shí)間:2020-08-24 08:54:00 來(lái)源:腳本之家 閱讀:133 作者:leason57 欄目:web開(kāi)發(fā)

PM2實(shí)現(xiàn)Nodejs項(xiàng)目自動(dòng)部署

首先簡(jiǎn)單說(shuō)下思路:本地git倉(cāng)庫(kù)與遠(yuǎn)程倉(cāng)庫(kù)關(guān)聯(lián)(github、碼云等平臺(tái)),然后pm2按照指定配置登錄服務(wù)器,拉取遠(yuǎn)程倉(cāng)庫(kù)的代碼更新,再執(zhí)行一些指定的命令(如打包等)。

創(chuàng)建本地項(xiàng)目并關(guān)聯(lián)到遠(yuǎn)程倉(cāng)庫(kù)

本地新建名為web的項(xiàng)目,進(jìn)入項(xiàng)目并創(chuàng)建一個(gè)簡(jiǎn)單的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;
    }
    h2,h3 {
      color: #fff;
    }
    nav {
      margin-top: 20px;
    }
    a {
      color: #ccc;
      cursor: pointer;
    }
    a:hover {
      text-decoration: underline;
    }
  </style>
</head>

<body>
  <h2>Nodejs部署示例項(xiàng)目</h2>
  <h3>項(xiàng)目部署上線示例</h3>
  <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:');
})

把本地項(xiàng)目放到遠(yuǎn)程倉(cāng)庫(kù),可選Github或者碼云等平臺(tái)。首先查看本地是否生成過(guò).ssh目錄及目錄下是否有私鑰及公鑰文件

ls ~/.ssh

如果存在,跳到下一步。如果不存在id_rsa、id_rsa.pub文件,需要先生成一下:

"youemail"填寫你的郵箱

ssh-keygen -t rsa -C "youremail"

查看本地公鑰的內(nèi)容并復(fù)制內(nèi)容添加到遠(yuǎn)程倉(cāng)庫(kù)

cat ~/.ssh/id_rsa.pub

本地倉(cāng)庫(kù)關(guān)聯(lián)遠(yuǎn)程倉(cāng)庫(kù)的其他操作這里就不贅述。

服務(wù)器從遠(yuǎn)程倉(cāng)庫(kù)拉取項(xiàng)目

服務(wù)器環(huán)境:阿里云的ecs,系統(tǒng)是Ubuntu 14.06

這一步后面是不需要手動(dòng)操作的,但我們要做好配置,這里可以先手動(dòng)拉取遠(yuǎn)程代碼測(cè)試一下是否配置成功。

確保服務(wù)器已安裝NodeJs、git、pm2,未安裝的話自行百度。

復(fù)制服務(wù)器的公鑰并添加到遠(yuǎn)程倉(cāng)庫(kù),操作步驟同本地的2、3、4步。

定位到用戶目錄,拉取遠(yuǎn)程倉(cāng)庫(kù)確??梢岳〕晒?若成功的話這個(gè)項(xiàng)目目錄刪除即可。

xxxx為你遠(yuǎn)程倉(cāng)庫(kù)的項(xiàng)目地址

cd ~
git clone xxxx

項(xiàng)目中配置pm2自動(dòng)部署文件

在本地項(xiàng)目中新建配置文件ecosystem.json,這里為了方便理解添加了注釋,但json文件不能有注釋,記得去掉。

{
  "apps":[
    {
      "name": "website", // 項(xiàng)目名稱
      "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)程倉(cāng)庫(kù)地址
      "repo": "git@gitee.com:mslevin/website.git",
      // 指定代碼拉取到服務(wù)器的目錄
      "path": "/www/website/production",
      "ssh_options": "StrictHostKeyChecking=no",
      "env": {
        "NODE_ENV": "production"
      }
    }
  }
}

服務(wù)器相關(guān)配置

配置文件中指定了存放項(xiàng)目的目錄/www/website/production,但可能并不存在,需要手動(dòng)新建:

mkdir /www && cd www
mkdir website

由于pm2需要在website目錄中創(chuàng)建productions目錄,需要更改website的讀寫權(quán)限

cd /www
sudo chmod 777 website

進(jìn)入用戶目錄,并編輯.bashrc文件,下面幾行都注釋掉

這步是為了防止部署的時(shí)候服務(wù)器報(bào)錯(cuò)找不到pm2命令

# If not running interactively, don't do anything
#case $- in
#  *i*) ;;
#   *) return;;
#esac

nginx做好端口轉(zhuǎn)發(fā)配置

執(zhí)行部署

把本地項(xiàng)目所有的更新push到遠(yuǎn)程倉(cāng)庫(kù),然后執(zhí)行

pm2 deploy ecosystem.json production setup
pm2 deploy ecosystem.json production

如果沒(méi)有問(wèn)題的話,本地打開(kāi)瀏覽器訪問(wèn)對(duì)應(yīng)ip:port就可以看到內(nèi)容了。

后面每次項(xiàng)目做了個(gè)更新之后, 同步到遠(yuǎn)程倉(cāng)庫(kù),然后執(zhí)行pm2 deploy ecosystem.json production即可。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI