前言
Nginx 是一款輕量級的Web 服務器 、反向代理服務器及電子郵件(IMAP/POP3)代理服務器。
常用用途:
✓ 1. 反向代理
✓ 2. 正向代理
這里我給來2張圖,對正向代理與反響代理做個詮釋,具體細節,大家可以翻閱下資料。
✓ 3. 負載均衡
Nginx提供的負載均衡策略有2種:內置策略和擴展策略。內置策略為輪詢,加權輪詢,Ip hash。擴展策略,就天馬行空,只有你想不到的沒有他做不到的啦,你可以參照所有的負載均衡算法,給他一一找出來做下實現。
上3個圖,理解這三種負載均衡算法的實現
✓ 4. HTTP服務器(包含動靜分離)
優勢:
Nginx 的編寫有一個明確目標就是超越 Apache Web 服務器的性能。Nginx 提供開箱即用的靜態文件,使用的內存比 Apache 少得多,每秒可以處理大約四倍於 Apache 的請求。 在低並發下 Nginx 的性能與 Apache 相當(有時候還低於),但是在高並發下 Nginx 能保持低資源低消耗高性能。Nginx 的優點還包括:高度模塊化的設計,模塊編寫簡單,以及配置文件簡潔。
安裝
yum install -y gcc-c++pcre pcre-develzlib zlib-developenssl openssl-devel
wget http://nginx.org/download/nginx-1.18.0.tar.gz
tar zxvf nginx-1.18.0.tar.gz
cd nginx-1.18.0
./configure --prefix=/usr/local/nginx
make&&make install
啟動
cd /usr/local/nginx/sbin
./nginx
查看啟動狀態
- 通過端口查詢: lsof -i:80 #nginx默認是80端口
- 通過進程查詢: ps -ef | grep nginx
- 訪問網頁查詢 curl 127.0.0.1
如果查詢結果與圖片不一致請檢查操作是否有誤
常用的命令:
⚫ nginx -s stop :快速關閉Nginx,可能不保存相關信息,並迅速終止web服務。
⚫ nginx -s quit :平穩關閉Nginx,保存相關信息,有安排的結束web服務。
⚫ nginx -s reload :因改變了Nginx相關配置,需要重新加載配置而重載。
⚫ nginx -s reopen :重新打開日志文件。
⚫ nginx -c filename :為 Nginx 指定一個配置文件,來代替缺省的。
⚫ nginx -t :不運行,而僅僅測試配置文件。nginx將檢查配置文件的語法的正確性,並嘗試打開配置文件中所引用到的 文件。
⚫ nginx -v:顯示 nginx 的版本。
⚫ nginx -V:顯示 nginx 的版本,編譯器版本和配置參數
配置文件詳解
如果你下載好啦,你的安裝文件,不妨打開conf文件夾的nginx.conf文件,Nginx服務器的基礎配置,默認的配置也存放在此。
在 nginx.conf 的注釋符號為: #
... #全局塊
events { #events塊
...
}
http #http塊
{
... #http全局塊
server #server塊
{
... #server全局塊
location [PATTERN] #location塊
{
...
}
location [PATTERN]
{
...
}
}
server
{
...
}
... #http全局塊
}
1、全局塊:配置影響nginx全局的指令。一般有運行nginx服務器的用戶組,nginx進程pid存放路徑,日志存放路徑,配置文件引入,允許生成worker process數等。
2、events塊:配置影響nginx服務器或與用戶的網絡連接。有每個進程的最大連接數,選取哪種事件驅動模型處理連接請求,是否允許同時接受多個網路連接,開啟多個網絡連接序列化等。
3、http塊:可以嵌套多個server,配置代理,緩存,日志定義等絕大多數功能和第三方模塊的配置。如文件引入,mime-type定義,日志自定義,是否使用sendfile傳輸文件,連接超時時間,單連接請求數等。
4、server塊:配置虛擬主機的相關參數,一個http中可以有多個server。
5、location塊:配置請求的路由,以及各種頁面的處理情況。
########### 每個指令必須有分號結束。#################
#user administrator administrators; #配置用戶或者組,默認為nobody nobody。
#worker_processes 2; #允許生成的進程數,默認為1
#pid /nginx/pid/nginx.pid; #指定nginx進程運行文件存放地址
error_log log/error.log debug; #制定日志路徑,級別。這個設置可以放入全局塊,http塊,server塊,級別以此為:debug|info|notice|warn|error|crit|alert|emerg
events {
accept_mutex on; #設置網路連接序列化,防止驚群現象發生,默認為on
multi_accept on; #設置一個進程是否同時接受多個網絡連接,默認為off
#use epoll; #事件驅動模型,select|poll|kqueue|epoll|resig|/dev/poll|eventport
worker_connections 1024; #最大連接數,默認為512
}
http {
include mime.types; #文件擴展名與文件類型映射表
default_type application/octet-stream; #默認文件類型,默認為text/plain
#access_log off; #取消服務日志
log_format myFormat '$remote_addr–$remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $http_x_forwarded_for'; #自定義格式
access_log log/access.log myFormat; #combined為日志格式的默認值
sendfile on; #允許sendfile方式傳輸文件,默認為off,可以在http塊,server塊,location塊。
sendfile_max_chunk 100k; #每個進程每次調用傳輸數量不能大於設定的值,默認為0,即不設上限。
keepalive_timeout 65; #連接超時時間,默認為75s,可以在http,server,location塊。
upstream mysvr {
server 127.0.0.1:7878;
server 192.168.10.121:3333 backup; #熱備
}
error_page 404 https://www.baidu.com; #錯誤頁
server {
keepalive_requests 120; #單連接請求上限次數。
listen 4545; #監聽端口
server_name 127.0.0.1; #監聽地址
location ~*^.+$ { #請求的url過濾,正則匹配,~為區分大小寫,~*為不區分大小寫。
#root path; #根目錄
#index vv.txt; #設置默認頁
proxy_pass http://mysvr; #請求轉向mysvr 定義的服務器列表
deny 127.0.0.1; #拒絕的ip
allow 172.18.5.54; #允許的ip
}
}
}
上面是nginx的基本配置,需要注意:
幾個常見配置項:
- $args #請求中的參數值
- \(uri #請求中的當前URI 不帶請求參數,參數位於\)args
- $host #HTTP請求行的主機名
- $hostname #主機名
- $content_length #"Content-Length" 請求頭字段
- $content_type #"Content-Type" 請求頭字段
- $pid #工作進程的PID ◆ $remote_addr #客戶端地址
- $remote_port #客戶端端口
- $remote_user #用於HTTP基礎認證服務的用戶名
- $request #代表客戶端的請求地址
- $request_body #客戶端的請求主體:此變量可在location中使用,將請求主體通過proxy_pass
- $request_length #請求的長度
- $request_method #HTTP請求方法,通常為"GET"或"POST"
- $request_time #處理客戶端請求使用的時間; 從讀取客戶端的第一個字節開始計時
- $request_uri #包含客戶端請求參數的原始URI ◆ $server_addr #服務器端地址
- $server_name #服務器名
- $server_port #服務器端口
- $status #HTTP響應代碼