首頁 運維 Nginx Nginx Proxy Manager與WebSocket的高效通訊實現

Nginx Proxy Manager與WebSocket的高效通訊實現

Sep 26, 2023 pm 02:46 PM
nginx websocket proxy

Nginx Proxy Manager与WebSocket的高效通信实现

Nginx Proxy Manager(以下簡稱NPM)是一個基於Nginx的代理管理工具,它提供了一種簡單而強大的方式來管理多個反向代理伺服器。最近,我在使用NPM時遇到了一個問題:如何實現NPM與WebSocket的高效通訊。在本文中,我將分享我在實現這一目標時所獲得的經驗和教訓,並提供具體的程式碼範例。

在開始之前,讓我們先簡單了解一下WebSocket。 WebSocket是一種在單一TCP連線上進行全雙工通訊的協定。與HTTP不同,WebSocket允許伺服器主動向客戶端發送數據,而不需要客戶端發出請求。由於其低延遲和高效性,WebSocket在即時應用程式中非常受歡迎,例如聊天應用程式、即時資料傳輸等。

NPM使用Nginx來處理HTTP和HTTPS請求,並提供反向代理功能。為了實現與WebSocket的高效通信,我們需要將NPM配置為可以轉發WebSocket請求並正確處理相關頭部資訊。下面是一個簡單的Nginx設定範例:

server {
    listen 80;
    server_name example.com;
    
    location / {
        proxy_pass http://backend;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "Upgrade";
    }
    
    location /ws/ {
        proxy_pass http://backend;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "Upgrade";
    }
    
    location /api/ {
        ...
    }
    
    location /admin/ {
        ...
    }
    
    ...

    upstream backend {
        server backend.example.com;
    }
}
登入後複製

在上述設定中,我們使用了兩個location區塊來處理WebSocket請求。第一個location區塊用於處理根路徑下的WebSocket請求,而第二個location區塊用於處理以/ws/開頭的WebSocket請求。在這兩個location區塊中,我們使用了proxy_pass指令將請求轉發給後端伺服器,並設定了相關HTTP頭部訊息,以確保WebSocket請求能夠正確地傳遞到後端伺服器。

除了設定Nginx,我們還需要在後端伺服器上實作WebSocket的相關邏輯。以下是使用Node.js和WebSocket函式庫實作的簡單範例:

const WebSocket = require('ws');

const wss = new WebSocket.Server({ port: 8080 });

wss.on('connection', (ws) => {
    console.log('Client connected');

    ws.on('message', (message) => {
        console.log(`Received: ${message}`);
    });

    ws.send('Hello, client!');
});
登入後複製

在上述程式碼中,我們建立了一個WebSocket伺服器,並在connection事件中處理新的連線。在connection事件處理程序中,我們可以處理來自客戶端的訊息,並發送回應。

使用上述Nginx設定和WebSocket伺服器程式碼,我們可以實現NPM與WebSocket的高效通訊。例如,我們可以使用NPM來處理HTTP請求,並將特定URL上的WebSocket請求轉送到後端WebSocket伺服器。這樣,我們就可以在同一個網域下同時使用HTTP和WebSocket,而WebSocket請求可以與其他HTTP請求一樣被NPM管理。

綜上所述,透過適當配置NPM和實現後端WebSocket伺服器的程式碼,我們可以實現NPM與WebSocket的高效通訊。這使得我們能夠在使用NPM的同時,輕鬆處理WebSocket請求,並實現即時應用程式所需的即時通訊功能。希望本文的程式碼範例和解釋對您有所幫助!

以上是Nginx Proxy Manager與WebSocket的高效通訊實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

怎麼查看nginx是否啟動 怎麼查看nginx是否啟動 Apr 14, 2025 pm 01:03 PM

確認 Nginx 是否啟動的方法:1. 使用命令行:systemctl status nginx(Linux/Unix)、netstat -ano | findstr 80(Windows);2. 檢查端口 80 是否開放;3. 查看系統日誌中 Nginx 啟動消息;4. 使用第三方工具,如 Nagios、Zabbix、Icinga。

linux怎麼查看nginx是否啟動 linux怎麼查看nginx是否啟動 Apr 14, 2025 pm 12:48 PM

在 Linux 中,使用以下命令檢查 Nginx 是否已啟動:systemctl status nginx根據命令輸出進行判斷:如果顯示 "Active: active (running)",則 Nginx 已啟動。如果顯示 "Active: inactive (dead)",則 Nginx 已停止。

linux怎麼啟動nginx linux怎麼啟動nginx Apr 14, 2025 pm 12:51 PM

在 Linux 中啟動 Nginx 的步驟:檢查 Nginx 是否已安裝。使用 systemctl start nginx 啟動 Nginx 服務。使用 systemctl enable nginx 啟用在系統啟動時自動啟動 Nginx。使用 systemctl status nginx 驗證啟動是否成功。在 Web 瀏覽器中訪問 http://localhost 查看默認歡迎頁面。

nginx在windows中怎麼配置 nginx在windows中怎麼配置 Apr 14, 2025 pm 12:57 PM

如何在 Windows 中配置 Nginx?安裝 Nginx 並創建虛擬主機配置。修改主配置文件並包含虛擬主機配置。啟動或重新加載 Nginx。測試配置並查看網站。選擇性啟用 SSL 並配置 SSL 證書。選擇性設置防火牆允許 80 和 443 端口流量。

怎麼啟動nginx服務器 怎麼啟動nginx服務器 Apr 14, 2025 pm 12:27 PM

啟動 Nginx 服務器需要按照不同操作系統採取不同的步驟:Linux/Unix 系統:安裝 Nginx 軟件包(例如使用 apt-get 或 yum)。使用 systemctl 啟動 Nginx 服務(例如 sudo systemctl start nginx)。 Windows 系統:下載並安裝 Windows 二進製文件。使用 nginx.exe 可執行文件啟動 Nginx(例如 nginx.exe -c conf\nginx.conf)。無論使用哪種操作系統,您都可以通過訪問服務器 IP

怎麼解決nginx跨域問題 怎麼解決nginx跨域問題 Apr 14, 2025 am 10:15 AM

解決 Nginx 跨域問題有兩種方法:修改跨域響應頭:添加指令以允許跨域請求,指定允許的方法和頭,以及設置緩存時間。使用 CORS 模塊:啟用模塊並配置 CORS 規則,允許跨域請求、方法、頭和設置緩存時間。

nginx403怎麼解決 nginx403怎麼解決 Apr 14, 2025 am 10:33 AM

如何解決 Nginx 403 Forbidden 錯誤?檢查文件或目錄權限;2. 檢查 .htaccess 文件;3. 檢查 Nginx 配置文件;4. 重啟 Nginx。其他可能原因還包括防火牆規則、SELinux 設置或應用程序問題。

怎麼把nginx訪問地址設置成服務器ip 怎麼把nginx訪問地址設置成服務器ip Apr 14, 2025 am 11:36 AM

要在 Nginx 中將訪問地址設置為服務器 IP,請:配置服務器塊,設置監聽地址(如:listen 192.168.1.10:80)設置服務器名稱(如:server_name example.com www.example.com),或將其留空以訪問服務器 IP保存並重新加載 Nginx 以應用更改

See all articles