## upstream
1. 默認已被編譯進nginx;
2. 禁用須通過--without-http_upstream_module;
## upstream語法結構
語法:
```
upstream name {...}
```
上下文:
```
http
```
## server
語法:
```
server address [parameters]
```
上下文:
```
upstream
```
parameters可選值:
| 可選參數 | 含義 |
| --- | --- |
| weight=number | 權重值,默認為1 |
| max_conns=number | 上游服務器的最大并發連接數 |
| fail_timeout=time | 服務器不可用的判定時間 |
| max_files=number | 服務器不可用的檢查次數,在fail_timeout時間范圍內檢查的次數,不是永遠不將請求轉發給它了.當確認它不可用之后就會標記 |
| backup | 備份服務器,僅當其他服務器都不可用時 |
| backup | 備份服務器,僅當其他服務器都不可用時 |
| down | 標記服務器長期不可用,離線服務 |
## keepalive
限制每個worker子進程與上游服務器**空閑**長連接的最大數量;
語法:
```
keepalive connections;
```
上下文:
```
upstream
```
示例:
```
keepalive 16;
```
## keepalive_requests
單個長連接可以處理的最多HTTP請求個數;當達到這個請求個數后,關閉這個鏈接,等客戶端再請求的時候再創建一個新的連接;
語法:
```
keepalive_requests number;
```
默認值:
```
keepalive_requests 100;
```
上下文:
```
upstream
```
## keepalive_timeout
空閑長連接的最長保持時間;每個長連接可以允許的最長時間;
語法:
```
keepalive_timeout time;
```
默認值:
```
keepalive_timeout 60s;
```
上下文:
```
upstream
```
## queue(商業版才可使用)
所有上游服務器不可用時,請求會被放到隊列中等待;
語法:
```
queue number [timeout=time];
```
上下文:
```
upstream
```
示例:
```
queue 100 timeout=30s; //定義100個連接放入內存中,可以放置30s秒
```
## 示例
```
upstream back_end{ //back_end是名稱
server 127.0.0.1:8080 weight=3 max_conns=1000 fail_timeout=10s max_fails=2;
keepalive 32;
keepalive_requests 50;
keepalive_timeout 30s;
}
```
- NginX簡述
- 什么是中間件
- NginX概述
- 選擇NginX的理由
- NginX環境安裝
- 四項確認
- NginX安裝
- 安裝
- 安裝目錄詳解
- 編譯參數詳解
- Nginx主目錄
- 基于NginX的中間件架構
- Nginx日志類型
- Nginx變量
- 常見NginX中間架構
- 靜態資源web服務
- 概述
- 靜態資源服務場景-CDN
- 瀏覽器緩存原理
- 跨站訪問
- 防盜鏈
- 代理服務
- 概述
- 配置語法
- 其他配置語法
- 負載均衡調度器SLB
- 概述
- 配置
- 動態緩存
- ====分割線====
- Nginx初體驗
- nginx簡介
- 請求全流程
- nginx核心優勢
- 安裝第一個rpm包nginx
- Nginx進程結構與熱部署
- 進程結構
- 信號量管理nginx
- 配置文件重載原理真相
- nginx熱部署
- nginx模塊化管理機制
- nginx編譯安裝的配置參數
- nginx配置文件結構
- 虛擬主機的分類
- Nginx核心指令基礎應用
- main段核心參數用法
- events段核心參數用法
- HTTP段核心參數用法
- server_name
- server_name指令用法優先級
- root和alias的區別
- location的基礎用法
- location指令中匹配規則的優先級
- 深入理解location中URL結尾的反斜線
- stub_status模塊用法
- Nginx應用進階
- connection和request
- 對connection做限制的limit_conn模塊
- 對request處理速率做限制的limit_req模塊
- 限制特定IP或網段訪問的access模塊
- 限制特定用戶訪問的auth_basic模塊
- 基于HTTP響應狀態碼做權限控制的auth_request模塊
- rewrite模塊
- return指令
- rewrite指令
- return和rewrite指令執行順序
- if指令
- autoindex模塊用法
- Nginx的變量
- 變量分類
- TCP連接相關變量
- 發送HTTP請求變量
- 處理HTTP請求變量
- 反向代理
- 基礎原理
- 動靜分離
- nginx作為反向代理支持的協議
- 用于定義上游服務的upstream模塊
- upstream模塊指令用法詳解
- 配置一個可用的上游應用服務器
- proxy_pass常見誤區
- 代理場景下nginx接受用戶請求包體的處理方式
- 代理場景下Nginx更改發往上游的用戶請求
- 代理場景下Nginx與上游服務建立連接細節
- 基于fastcgi的反向代理
- 負載均衡
- 負載均衡基礎
- 實現nginx對上游服務負載均衡
- 負載均衡hash算法
- 負載均衡ip_hash算法
- 負載均衡最少連接數算法
- 針對上游服務器返回異常時的容錯機制
- Nginx緩存
- 緩存基礎
- 緩存相關指令
- 緩存用法配置示例
- 配置nginx不緩存上游服務特定內容
- 緩存失效降低上游壓力機制1-合并源請求
- 緩存失效降低上游壓力機制2-啟用陳舊緩存
- 第三方清除模塊ngx_cache_purge介紹
- ngx_cache_purge用法配置示例
- Nginx和HTTPS
- https原理基礎
- https如何解決信息被竊聽的問題
- https如何解決報文被篡改以及身份偽裝問題
- 配置私有CA服務器
- 組織機構向CA申請證書及CA簽發證書
- 深入Nginx架構
- Nginx性能優化