首頁 >運維 >Nginx >Nginx基本功能實例分析

Nginx基本功能實例分析

王林
王林轉載
2023-05-11 23:31:041486瀏覽

1、靜態http伺服器

首先,nginx是一個http伺服器,可以將伺服器上的靜態檔案(如html、圖片)透過http協定展現給客戶端。設定:

server {

  listen 80; # 端口号

  location / {

    root /usr/share/nginx/html; # 静态文件路径

  }

}

2、反向代理伺服器

什麼是反向代理?

客戶端本來可以直接透過http協定存取某網站應用程式伺服器,網站管理員可以在中間加上一個nginx,客戶端請求nginx,nginx請求應用程式伺服器,然後將結果傳回給客戶端,此時nginx就是反向代理伺服器。

 Nginx基本功能實例分析

設定:

server {

  listen 80;

  location / {

    proxy_pass http://192.168.20.1:8080; # 应用服务器http地址

  }

}

既然伺服器可以直接http訪問,為什麼要在中間加上一個反向代理,不是多此一舉嗎?反向代理有什麼作用?

繼續往下看,下面的負載平衡、虛擬主機等,都基於反向代理實現,當然反向代理的功能也不僅僅是這些。

3、負載平衡

當網站訪問量非常大,網站站長開心賺錢的同時,也攤上事兒了。因為網站越來越慢,一台伺服器已經不夠用了。

於是將同一個應用程式部署在多台伺服器上,將大量使用者的請求指派給多台機器處理。同時帶來的好處是,其中一台伺服器萬一掛了,只要還有其他伺服器正常運行,就不會影響用戶使用。 nginx可以透過反向代理來實現負載平衡。

Nginx基本功能實例分析

設定: 

upstream myapp {

  server 192.168.20.1:8080; # 应用服务器1

  server 192.168.20.2:8080; # 应用服务器2

}

server {

  listen 80;

  location / {

    proxy_pass http://myapp;

  }

}

 以上設定會將請求輪詢指派到應用程式伺服器,也就是一個客戶端的多次請求,有可能會由多台不同的伺服器處理。可以透過ip-hash的方式,根據客戶端ip位址的hash值將請求分配給固定的某一個伺服器處理。

配置:

upstream myapp {

  ip_hash; # 根据客户端ip地址hash值将请求分配给固定的一个服务器处理

  server 192.168.20.1:8080;

  server 192.168.20.2:8080;

}

server {

  listen 80;

  location / {

    proxy_pass http://myapp;

  }

}

另外,伺服器的硬體配置可能有好有差,想把大部分請求分配給好的伺服器,把少量請求分配給差的伺服器,可以透過weight來控制。

配置:

upstream myapp {

  server 192.168.20.1:8080 weight=3; # 该服务器处理3/4请求

  server 192.168.20.2:8080; # weight默认为1,该服务器处理1/4请求

}

server {

  listen 80;

  location / {

    proxy_pass http://myapp;

  }

}

4、虛擬主機

有的網站訪問量大,需要負載平衡。然而並不是所有網站都如此出色,有的網站,由於訪問量太小,需要節省成本,將多個網站部署在同一台伺服器上。

例如將www.aaa.com和www.bbb.com兩個網站部署在同一台伺服器上,兩個網域解析到同一個ip位址,但使用者可以透過兩個網域開啟兩個完全不同的網站,互相不影響,就像訪問兩個伺服器一樣,所以叫兩個虛擬主機。

配置:

server {

  listen 80 default_server;

  server_name _;

  return 444; # 过滤其他域名的请求,返回444状态码

}

server {

  listen 80;

  server_name www.aaa.com; # www.aaa.com域名

  location / {

    proxy_pass http://localhost:8080; # 对应端口号8080

  }

}

server {

  listen 80;

  server_name www.bbb.com; # www.bbb.com域名

  location / {

    proxy_pass http://localhost:8081; # 对应端口号8081

  }

}

在伺服器8080和8081分別開了一個應用,客戶端透過不同的網域名稱訪問,根據server_name可以反向代理到對應的應用伺服器。

虛擬主機的原理是透過http請求頭中的host是否符合server_name來實現的,有興趣的同學可以研究一下http協定。

另外,server_name配置還可以過濾有人惡意將某些網域指向你的主機伺服器。

5、fastcgi

nginx本身不支援php等語言,但它可以透過fastcgi來將請求丟給某些語言或框架處理(例如php、python 、perl)。

server {

  listen 80;

  location ~ \.php$ {

    include fastcgi_params;

    fastcgi_param script_filename /php文件路径$fastcgi_script_name; # php文件路径

    fastcgi_pass 127.0.0.1:9000; # php-fpm地址和端口号

    # 另一种方式:fastcgi_pass unix:/var/run/php5-fpm.sock;

  }

}

設定中將.php結尾的請求透過fashcgi交給php-fpm處理,php-fpm是php的一個fastcgi管理員。有關fashcgi可以查閱其他資料,本文不再介紹。

fastcgi_pass和proxy_pass有什麼差別?下面一張圖帶你看明白:

Nginx基本功能實例分析

#

以上是Nginx基本功能實例分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除