91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

M2實現Nodejs項目自動部署的方法步驟

發布時間:2020-08-24 08:54:00 來源:腳本之家 閱讀:137 作者:leason57 欄目:web開發

PM2實現Nodejs項目自動部署

首先簡單說下思路:本地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;
    }
    h2,h3 {
      color: #fff;
    }
    nav {
      margin-top: 20px;
    }
    a {
      color: #ccc;
      cursor: pointer;
    }
    a:hover {
      text-decoration: underline;
    }
  </style>
</head>

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

把本地項目放到遠程倉庫,可選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做好端口轉發配置

執行部署

把本地項目所有的更新push到遠程倉庫,然后執行

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

如果沒有問題的話,本地打開瀏覽器訪問對應ip:port就可以看到內容了。

后面每次項目做了個更新之后, 同步到遠程倉庫,然后執行pm2 deploy ecosystem.json production即可。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阳原县| 富民县| 长武县| 浮梁县| 祁东县| 平定县| 漯河市| 那坡县| 望奎县| 酉阳| 台山市| 通山县| 武邑县| 红原县| 隆化县| 项城市| 九龙县| 平谷区| 石首市| 平江县| 十堰市| 浦县| 大方县| 叶城县| 延安市| 白河县| 晴隆县| 资阳市| 郎溪县| 固安县| 卓尼县| 江口县| 眉山市| 韶关市| 宜城市| 宁波市| 新闻| 新密市| 开鲁县| 凤翔县| 鄄城县|