hyperf/docs/zh-tw/tutorial/nginx.md

2.1 KiB
Raw Blame History

Nginx 反向代理

Nginx 是一個高效能的 HTTP 和反向代理伺服器,程式碼完全用 C 實現,基於它的高效能以及諸多優點,我們可以把它設定為 hyperf 的前置伺服器,實現負載均衡或 HTTPS 前置伺服器等。

配置 Http 代理

# 至少需要一個 Hyperf 節點,多個配置多行
upstream hyperf {
    # Hyperf HTTP Server 的 IP 及 埠
    server 127.0.0.1:9501;
    server 127.0.0.1:9502;
}

server {
    # 監聽埠
    listen 80; 
    # 繫結的域名,填寫您的域名
    server_name proxy.hyperf.io;

    location / {
        # 將客戶端的 Host 和 IP 資訊一併轉發到對應節點  
        proxy_set_header Host $http_host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        
        # 轉發Cookie設定 SameSite
        proxy_cookie_path / "/; secure; HttpOnly; SameSite=strict";
        
        # 執行代理訪問真實伺服器
        proxy_pass http://hyperf;
    }
}

配置 Websocket 代理

# 至少需要一個 Hyperf 節點,多個配置多行
upstream hyperf_websocket {
    # 設定負載均衡模式為 IP Hash 演算法模式,這樣不同的客戶端每次請求都會與同一節點進行互動
    ip_hash;
    # Hyperf WebSocket Server 的 IP 及 埠
    server 127.0.0.1:9503;
    server 127.0.0.1:9504;
}

server {
    listen 80;
    server_name websocket.hyperf.io;
    
    location / {
        # WebSocket Header
        proxy_http_version 1.1;
        proxy_set_header Upgrade websocket;
        proxy_set_header Connection "Upgrade";
        
        # 將客戶端的 Host 和 IP 資訊一併轉發到對應節點  
        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;
    
        # 客戶端與服務端無互動 60s 後自動斷開連線,請根據實際業務場景設定
        proxy_read_timeout 60s ;
        
        # 執行代理訪問真實伺服器
        proxy_pass http://hyperf_websocket;
    }
}