溫馨提示×

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

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

Forever+nginx部署Node站點(diǎn)的方法示例

發(fā)布時(shí)間:2020-09-06 22:26:03 來(lái)源:腳本之家 閱讀:115 作者:Mango在掘金 欄目:服務(wù)器

最近入手了一款最便宜的騰訊云服務(wù)器,主要用來(lái)部署自己的個(gè)人博客以及學(xué)習(xí)一些liunx知識(shí),從而全方面了解掌握web技術(shù)。強(qiáng)烈建議前端人員擁有一個(gè)屬于自己的服務(wù)器。在寫此文章之前,我的云服務(wù)器已經(jīng)安裝好Mysql以及node, nginx等。下面以部署node網(wǎng)站為例,講解幾個(gè)常見的場(chǎng)景

線程持久運(yùn)行

一般來(lái)說(shuō),我們?cè)趙indow cmd上通過node index.js啟動(dòng)一個(gè)服務(wù)器,只要不關(guān)閉,就可以一直訪問和調(diào)用接口。但是在linux上往往如果長(zhǎng)時(shí)間不操作或者你要執(zhí)行其他操作時(shí)候,你的node服務(wù)就會(huì)斷開,用戶也不能訪問你的網(wǎng)站了。怎么辦?我們可以安裝forever模塊來(lái)解決。

npm install forever -g // 全局安裝forever模塊

由原先的啟動(dòng)方式node index.js 改為 forever start index.js即可,下面列出幾個(gè)常見命令

forever list // 列出當(dāng)前所有運(yùn)行的服務(wù)
forever start -w index.js // 文件改動(dòng)自動(dòng)重啟
forever stopall // 停止所有服務(wù)
forever stop app.js //停止其中一個(gè)node App 
forever stop [id] // forever list 找到對(duì)應(yīng)的id,然后

當(dāng)然還有許多命令,可以查閱相關(guān)模塊。一般來(lái)說(shuō)最簡(jiǎn)單的使用方式就是:

forever start index.js

這樣即使我們切換到其他linux路徑時(shí)或者退出時(shí),node服務(wù)還是存在的,即別人還是可以訪問你的網(wǎng)站啦。

配置nginx

nginx是一個(gè)由俄羅斯人開發(fā)的反向代理服務(wù)器,如今已經(jīng)被全世界許多公司所使用。關(guān)于nginx的介紹以及安裝可以自己查閱資料或者到菜鳥教程快速學(xué)習(xí)一下。這里我的linux已經(jīng)安裝好了nginx了.

下面我要使用nginx來(lái)代理剛剛forever start index.js啟動(dòng)的http://localhost:8089了,即通過我的域名來(lái)訪問http://localhost:8089 這個(gè)網(wǎng)站了. 查看nginx配置文件路徑

find / -name nginx.conf

Forever+nginx部署Node站點(diǎn)的方法示例

切換到里面進(jìn)入修改里面配置

 server {
  listen    80; # 監(jiān)聽端口 直接配置80即可
  server_name hellocode.xyz; # 輸入域名會(huì)跳轉(zhuǎn)到 http://localhost:8089
  include /etc/nginx/default.d/*.conf;
  location / {
   proxy_pass http://118.89.33.75:8089; # 你的node網(wǎng)站應(yīng)用
  }
  error_page 404 /404.html;
    location = /40x.html {
  }
  error_page 500 502 503 504 /50x.html;
    location = /50x.html {
  }
}

退出檢查配置是否正確

nginx -t

Forever+nginx部署Node站點(diǎn)的方法示例

重新加載nginx

nginx -s reload

打開瀏覽器 輸入網(wǎng)址即可以訪問網(wǎng)站啦 !

在訪問過程之中可能會(huì)遇到跨域問題,那么就需要node端設(shè)置支持跨域,以express框架來(lái)說(shuō),index.js中自定義一個(gè)中間件

var allowCors = function(req, res, next) {
 res.header('Access-Control-Allow-Origin', req.headers.origin);
 res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS');
 res.header('Access-Control-Allow-Headers', 'Content-Type');
 res.header('Access-Control-Allow-Credentials','true');
 next();
};
app.use(allowCors);//使用跨域中間件

關(guān)于跨域問題,后面的博客會(huì)有詳細(xì)講解!

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

向AI問一下細(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