最近入手了一款最便宜的騰訊云服務(wù)器,主要用來部署自己的個(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)行
一般來說,我們?cè)趙indow cmd上通過node index.js啟動(dòng)一個(gè)服務(wù)器,只要不關(guān)閉,就可以一直訪問和調(diào)用接口。但是在linux上往往如果長時(shí)間不操作或者你要執(zhí)行其他操作時(shí)候,你的node服務(wù)就會(huì)斷開,用戶也不能訪問你的網(wǎng)站了。怎么辦?我們可以安裝forever模塊來解決。
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)模塊。一般來說最簡(jiǎn)單的使用方式就是:
這樣即使我們切換到其他linux路徑時(shí)或者退出時(shí),node服務(wù)還是存在的,即別人還是可以訪問你的網(wǎng)站啦。
配置nginx
nginx是一個(gè)由俄羅斯人開發(fā)的反向代理服務(wù)器,如今已經(jīng)被全世界許多公司所使用。關(guān)于nginx的介紹以及安裝可以自己查閱資料或者到菜鳥教程快速學(xué)習(xí)一下。這里我的linux已經(jīng)安裝好了nginx了.
下面我要使用nginx來代理剛剛forever start index.js啟動(dòng)的http://localhost:8089了,即通過我的域名來訪問http://localhost:8089 這個(gè)網(wǎng)站了. 查看nginx配置文件路徑
切換到里面進(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
打開瀏覽器 輸入網(wǎng)址即可以訪問網(wǎng)站啦 !
在訪問過程之中可能會(huì)遇到跨域問題,那么就需要node端設(shè)置支持跨域,以express框架來說,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ì)講解!
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。