欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

為Node.js程序配置使用Nginx服務器的簡明教程

 更新時間:2016年01月12日 09:46:30   作者:soasme  
這篇文章主要介紹了為Node.js程序配置使用Nginx服務器的簡明教程,Nginx與Node自帶的服務器一樣都擁有非阻塞的高性能,需要的朋友可以參考下

Node.js是一個基于Chrome JavaScript運行時建立的平臺, 用于方便地搭建響應速度快、易于擴展的網(wǎng)絡應用。Node.js 使用事件驅(qū)動, 非阻塞I/O 模型而得以輕量和高效,非常適合在分布式設備上運行的數(shù)據(jù)密集型的實時應用,如實時聊天等等。然而對于gzip編碼,靜態(tài)文件,HTTP緩存,SSL處理,負載平衡和反向代理等,都可以通過nginx來完成,從而減小node.js的負載,并通過nginx強大的緩存來節(jié)省網(wǎng)站的流量從而提高網(wǎng)站的加載速度。
流程圖

201611294252934.png (528×274)

nginx配置如下:

 http {
  proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=one:8m max_size=3000m inactive=600m;
  proxy_temp_path /var/tmp;
  include    mime.types;
  default_type application/octet-stream;
  sendfile    on;
  keepalive_timeout 65;
 
  gzip on;
  gzip_comp_level 6;
  gzip_vary on;
  gzip_min_length 1000;
  gzip_proxied any;
  gzip_types text/plain text/html text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
  gzip_buffers 16 8k;
 
  ssl_certificate /some/location/sillyfacesociety.com.bundle.crt;
  ssl_certificate_key /some/location/sillyfacesociety.com.key;
  ssl_protocols    SSLv3 TLSv1;
  ssl_ciphers HIGH:!aNULL:!MD5;
 
  upstream silly_face_society_upstream {
   server 127.0.0.1:61337;
   server 127.0.0.1:61338;
   keepalive 64;
  }
 
  server {
   listen 80;
   listen 443 ssl;
 
   server_name sillyfacesociety.com;
   return 301 $scheme://www.sillyfacesociety.com$request_uri;
  }
 
  server {
    listen 80;
    listen 443 ssl;
 
    server_name www.sillyfacesociety.com;
 
    error_page 502 /errors/502.html;
 
    location ~ ^/(images/|img/|javascript/|js/|css/|stylesheets/|flash/|media/|static/|robots.txt|humans.txt|favicon.ico) {
     root /usr/local/silly_face_society/node/public;
     access_log off;
     expires max;
    }
 
    location /errors {
     internal;
     alias /usr/local/silly_face_society/node/public/errors;
    }
 
    location / {
     proxy_redirect off;
     proxy_set_header  X-Real-IP      $remote_addr;
     proxy_set_header  X-Forwarded-For $proxy_add_x_forwarded_for;
     proxy_set_header  X-Forwarded-Proto $scheme;
     proxy_set_header  Host          $http_host;
     proxy_set_header  X-NginX-Proxy  true;
     proxy_set_header  Connection "";
     proxy_http_version 1.1;
     proxy_cache one;
     proxy_cache_key sfs$request_uri$scheme;
     proxy_pass     http://silly_face_society_upstream;
    }
  }
}

配置段說明

http {
  ...
  upstream silly_face_society_upstream {
   server 127.0.0.1:61337;
   server 127.0.0.1:61338;
   keepalive 64;
  }
  ...
}

nginx負載均衡多個nodo.js實例。keepalive 64 指示nginx在任何時候保持最少64個HTTP/ 1.1連接到代理服務器。如果有更多的流量nginx將打開更多的連接。

http {
  ...
  server {
    ...
    location / {
     proxy_redirect off;
     proxy_set_header  X-Real-IP      $remote_addr;
     proxy_set_header  X-Forwarded-For $proxy_add_x_forwarded_for;
     proxy_set_header  Host          $http_host;
     proxy_set_header  X-NginX-Proxy  true;
     ...
     proxy_set_header  Connection "";
     proxy_http_version 1.1;
     proxy_pass     http://silly_face_society_upstream;
    }
    ...
  }
}

將符合哪些的請求發(fā)送到代理上。nginx的匹配規(guī)則可以取看看前面的文章。
nginx處理靜態(tài)內(nèi)容

http {
  ...
  server {
    ...
    location ~ ^/(images/|img/|javascript/|js/|css/|stylesheets/|flash/|media/|static/|robots.txt|humans.txt|favicon.ico) {
     root /usr/local/silly_face_society/node/public;
     access_log off;
     expires max;
    }
    ...
  }
}

設置緩存

http {
  ...
  proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=one:8m max_size=3000m inactive=600m;
  proxy_temp_path /var/tmp;
  ...
}


http {
 server {
   ...
   location / {
     ...
     proxy_cache one;
     proxy_cache_key sfs$request_uri$scheme;
     ...
   }
   ...
 }
}

緩存是通過HTTP頭部來控制的。

helloworld
試驗一下,我們來寫個helloworld.js

var http = require('http'); 
 
 
http.createServer(function (request, response) { 
  
 response.writeHead(200, {'Content-Type': 'text/plain'}); 
 response.end('hello world\n'); 
}).listen(61337); 
 
 
console.log('Server running at http://127.0.0.1:61337/'); 

然后用node helloworld.js指令開啟,這樣跑在本地的機子的nodejs的程序就算開起來了,占用的是8000端口,可自己修改。

此時確定在nginx的vhost.conf里面的設置應有:

server { 
  listen 80; 
  server_name jb51.net.jb51.net; 
  location / { 
  proxy_pass http://127.0.0.1:61337; 
  } 
} 

將網(wǎng)站域名設置好,然后端口設置為80,最后proxy_pass設置為http://127.0.0.1:61337,將所有從jb51.net:80的請求傳遞到nodejs程序去。
重啟nginx、訪問域名,就可以了看到helloworld了。
雖然node.js本身就可以做服務器是沒錯啦,比如welcome.js里面設置為80端口就可以了。
但是一個機子跑多個網(wǎng)站,其他網(wǎng)站又是用別的服務器,在80端口已經(jīng)被占用的情況下,是可以用代理到別的端口來處理的。

相關(guān)文章

  • Nginx+Tomcat+Https 服務器負載均衡配置實踐方案詳解

    Nginx+Tomcat+Https 服務器負載均衡配置實踐方案詳解

    這篇文章主要介紹了Nginx+Tomcat+Https 服務器負載均衡配置實踐方案的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • 詳解基于centos7搭建Nginx網(wǎng)站服務器(包含虛擬web主機的配置)

    詳解基于centos7搭建Nginx網(wǎng)站服務器(包含虛擬web主機的配置)

    這篇文章主要介紹了詳解基于centos7搭建Nginx網(wǎng)站服務器(包含虛擬web主機的配置),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • nginx部署.net core站點的方法

    nginx部署.net core站點的方法

    這篇文章主要介紹了nginx部署.net core站點的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • 詳解如何基于Nginx搭建流媒體服務器

    詳解如何基于Nginx搭建流媒體服務器

    Nginx RTMP是一個Nginx插件,支持將RTMP和HLS流添加到媒體服務器,本文將以ubuntu為例為大家介紹一下如何安裝使用nginx Rtmp 插件的步驟,需要的可以參考下
    2023-10-10
  • 前端項目中Nginx配置指南詳解

    前端項目中Nginx配置指南詳解

    這篇文章主要為大家詳細介紹了在前端項目開發(fā)中如何配置Nginx,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的小伙伴可以了解一下
    2023-09-09
  • Nginx與安全相關(guān)的幾個配置小結(jié)

    Nginx與安全相關(guān)的幾個配置小結(jié)

    Nginx提供了一系列的安全相關(guān)參數(shù),可以幫助加固網(wǎng)站安全性,本文主要介紹了Nginx與安全相關(guān)的幾個配置小結(jié),具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • Nginx學習之靜態(tài)文件服務器配置方法

    Nginx學習之靜態(tài)文件服務器配置方法

    本篇文章主要介紹了Nginx學習之靜態(tài)文件服務器配置方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • Nginx 設置域名轉(zhuǎn)發(fā)到指定端口的實現(xiàn)方法

    Nginx 設置域名轉(zhuǎn)發(fā)到指定端口的實現(xiàn)方法

    這篇文章主要介紹了Nginx 設置域名轉(zhuǎn)發(fā)到指定端口的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-08-08
  • nginx worker進程循環(huán)的實現(xiàn)

    nginx worker進程循環(huán)的實現(xiàn)

    這篇文章主要介紹了nginx worker進程循環(huán)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-02-02
  • nginx實現(xiàn)動靜分離的案例詳解

    nginx實現(xiàn)動靜分離的案例詳解

    nginx 和 Tomcat 是兩個不同的服務器軟件,在分離部署方面有著各自的優(yōu)勢和適用場景,一般來說,Nginx 適合作為反向代理和負載均衡服務器,用于處理靜態(tài)文件和高并發(fā)請求,本文將大家介紹一下nginx實現(xiàn)動靜分離的案例,需要的朋友可以參考下
    2023-08-08

最新評論