本文將介紹在叢集環境下,如何配置 WebSocket 埠。
注:5.1.20 及之後版本的BI工程,新增了一個容器Websocket方案。推薦優先查看是否可使用該方案:容器Websocket方案
無需任何使用者操作,無需任何手動配置,無需額外開啟埠,系統可自動使用Web容器自帶的WebSocket進行連結,埠複用http埠。
超級管理者可透過「fine_conf_entity視覺化配置插件」修改 WebSocket 埠。重啟伺服器後設定生效。
注:修改 FineDB 資料庫表欄位值的方法請參考 FineDB 常用表欄位修改 。
是否支援
設定多個值
參數值為埠陣列["port1","port2"]
port均屬於區間(1024,65535]
設定埠號時有一些注意事項:
1)埠號可設定範圍:1024~65535,若為多個值,設定格式為:[埠號1,埠號2,埠號3]。
2)建議「WebSocket轉發埠」的值要多於叢集節點數,保證每個節點都會選擇當前可用的埠,不會因為埠占用而導致伺服器無法啟動。
3)建議「WebSocket埠」設定多個值,作為備用,防止一臺伺服器部署了多個工程,埠被佔用。
4)不要設定埠號為伺服器遠端連結埠 3389。
5)如果工程和 nginx 負載均衡在一個環境下,不要重複設定某個埠號既是 WebSocket 埠,又是 WebSocket 轉發埠。
6)若 WebSocketConfig.port、WebSocketConfig.requestPort、WebSocketConfig.requestPorts 欄位後面有空格,配置不生效。
7)若 WebSocketConfig.port、WebSocketConfig.requestPort、WebSocketConfig.requestPorts 大小寫錯誤,配置不生效。
8)WebSocketConfig.requestPort 和 WebSocketConfig.requestPorts 不能同時存在於 fine_conf_entity 表中,否則會出錯。
在負載均衡層面配置 Websocket 的轉發策略為粘滯,詳情請參見:負載均衡配置指導
nginx.conf 檔案中,server 的 listen 埠需要與「WebSocket 轉發埠」配置一致,詳情請參見:Linux 系統安裝配置 Nginx 4.1 節
例如用設定的 Websocket 轉發埠(WebSocketConfig.requestPort預設48889)轉發 Websocket 埠(WebSocketConfig.port預設 48888 )
以下範例為工程伺服器 IP 為 192.168.6.171,Nginx 伺服器 IP 為 192.168.6.181,如下圖所示:
#使用者或者使用者組 預設為nobody#user root;#允許進程數量,建議設定為cpu核心數或者auto自動檢查,注意Windows伺服器上雖然可以啟動多個processes,但是實際只會用其中一個worker_processes auto;#自動根據CPU數目綁定CPU親緣性,nginx1.9.10及以上版本才能用#worker_cpu_affinity auto;#error日誌存放位置error_log logs/error.log;#error_log logs/error.log notice;#error_log logs/error.log info;#PID存放位置#pid logs/nginx.pid;#工作模式及連結數上限events { #每個worker_processes的最大連結數,Windows伺服器無論這裏設定多大實際都只有1024 #併發數是 worker_processes 和 worker_connections 的乘積 worker_connections 1024;}http { #設定mime類型,類型由mime.type檔案定義 include mime.types; #預設檔案類型,預設為text/plain default_type application/octet-stream; #日誌格式 log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for" $upstream_addr'; #access_log確定了Nginx是否儲存存取日誌,將這個設定為關閉可以降低磁碟IO而提升速度 access_log off; #access_log logs/access.log main; #sendfile 指令指定 nginx 是否呼叫 sendfile 函式(zero copy 方式)來匯出檔案, #對於普通應用,必須設為 on, #如果用來進行下載等應用磁碟IO重負載應用,可設定為 off, #以平衡磁碟與網路I/O處理速度,降低系統的uptime. sendfile on; #tcp_nopush on; #http長連結(client <-> nginx)逾時時間,請求完成之後連結保持的時間 keepalive_timeout 65s; #types_hash_max_size越小,消耗的記憶體就越小,但散列key的衝突率可能上升 types_hash_max_size 2048; #開啟gzip壓縮 #gzip on; #gzip_disable "MSIE [1-6]."; #設定請求緩衝 client_header_buffer_size 512k; large_client_header_buffers 4 512k; #允許使用者最大上傳資料大小,根據業務需求調整上傳檔案大小限制 client_max_body_size 100M; upstream FR.com { #max_fails=n fail_timeout=m 表示m時間內逾時n次失敗嘗試,將會在接下來m時間內標記此節點不可用(m時間過後無論此節點是否啟動都會被重新標記為可用狀態) #其中fails為“失敗嘗試”,失敗嘗試由下面server配置中,proxy_next_upstream指令定義 server 192.168.6.171:8080 max_fails=15 fail_timeout=300s; keepalive 300; #其它server參數說明: #down 標記伺服器掛掉 #backup 備份伺服器,當主伺服器(例如上面的95和96)不可用時才加入伺服器; #weight=number 權重,預設為1 #內建負載均衡策略有ip hash、輪詢、加權輪詢(設定server的weight值) #ip_hash; #↓====================主動健康檢查模組配置====================↓# ## interval:向後端傳送的健康檢查包的間隔,單位ms。 ## fall(fall_count): 如果連續失敗次數達到fall_count,伺服器就被認為是down ## rise(rise_count): 如果連續成功次數達到rise_count,伺服器就被認為是up。 ## timeout: 後端健康請求的逾時時間,單位ms。 ## type:健康檢查包的類型,現在支援tcp、udp、http類型 #check interval=2000 rise=5 fall=10 timeout=10000 type=http; # 檢查請求, 7-16之前的persist版本,只能使用 /webroot/decision/system/info HTTP; #check_http_send "GET /webroot/decision/system/health HTTP/1.0\r\n\r\n"; # 檢查請求 #check_http_expect_alive http_2xx http_3xx; #該指令指定HTTP答覆的成功狀態,預設認為2XX和3XX的狀態是健康的。 #↑====================主動健康檢查模組配置====================↑# } upstream WBS.com { server 192.168.6.171:48888 max_fails=15 fail_timeout=300s; #這裏必須使用ip_hash ip_hash; } server { listen 8123; server_name 192.168.6.181; #nginx預設不轉發帶底線的header,比如請求的header中有_device_這個header,轉發到負載伺服器時預設會丟棄 #可以在http或者http -> server這兩個上下文中加入一條屬性 underscores_in_headers on; #charset koi8-r; #access_log logs/host.access.log main; #↓====================主動健康檢查模組監測頁面====================↓# #location /status { # healthcheck_status html; #} #↑====================主動健康檢查模組監測頁面====================↑# #根/下的請求預設轉發到的位置,即埠後面跟的請求全部轉發到如下反向代理 location / { #對於HTTP代理,proxy_http_version指令應該設定為“1.1”,同時“Connection”頭的值也應被清空(如下proxy_set_header Connection "") proxy_http_version 1.1; #定義轉發到的伺服器(組) proxy_pass http://FR.com; #設定nginx轉發時轉發到下一個伺服器的條件,此處設定將未成功請求(proxy_next_upstream定義的40x, 50x等)傳遞到下一步進行處理 # 失敗嘗試說明:50x和429在此配置會被當作fail,error,timeout並 invalid_header無論配置與否都被認為fail,http_403 and http_404配置與否都不是fail。 # error:與後端伺服器建立連結、傳遞請求、讀取請求頭髮生的錯誤 # timeout:與後端伺服器建立連結、傳遞請求、讀取請求頭逾時,設定在proxy_next_upstream_timeout和proxy_next_upstream_tries(預設值都是0) # invalid_header:伺服器傳回非法或者為空 proxy_next_upstream http_500 http_502 http_503 http_504 http_403 http_404 http_429 error timeout invalid_header non_idempotent; #proxy_next_upstream_timeout 0; #proxy_next_upstream_tries 0; #重定向,參數off將在這個欄位中禁止所有的proxy_redirect指令 proxy_redirect off; #請求頭的一些設定,文法proxy_set_header [field] [value]; #$host為請求的主機名稱(即nginx代理伺服器), $server_port為主機埠(即nginx埠),如果有外網映射,這裏應改寫 外網地址:外網埠 形式(不要帶協定) proxy_set_header Host $host:$server_port; #這裏$remote_addr用戶端ip地址 proxy_set_header X-Real-IP $remote_addr; #這裏$proxy_add_x_forwarded_for是代理層級,如果由多層代理,這裏就寫client,proxy1,proxy2,這裏應該是client即用戶端ip proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #與後端伺服器的連結不需要保持 proxy_set_header Connection ""; #NGINX會緩衝來自代理伺服器的回应。回应儲存在內部緩衝區中,並且在收到整個回应之前不會傳送到用戶端。 #緩衝有助於優化慢用戶端的效能,如果回应從NGINX同步傳遞到用戶端,則會浪費代理伺服器時間。 #但是,當啟動緩衝時,NGINX允許代理伺服器快速處理回应,而NGINX將回应儲存的時間與用戶端下載它們所需的時間相同 #是否開啟緩衝,預設開啟 #proxy_buffering off; #設定緩衝區的大小為size #proxy_buffer_size 64k; #每個連結設定緩衝區的數量和大小,proxy_buffers [number] [size]; #proxy_buffers 32 64k; #當開啟緩衝回应的功能以後,在沒有讀到全部回应的情況下,寫緩衝到達一定大小時,nginx一定會向用戶端傳送回应,直到緩衝小於此值 #proxy_busy_buffers_size 64k; #連結到代理伺服器逾時時間,預設60s,不能超過75s #不宜太長或者太短,配合max_fails和fail_timeout設定 #併發量高的情況下,伺服器壓力過大時容易出現逾時,可以考慮max_fails和fail_timeout設定大一點,減少nginx錯誤踢出節點的機率 proxy_connect_timeout 75; #讀取逾時,預設60s,如果在逾時時間內伺服器未傳回任何資料,視為逾時。如果沒有大數據量計算或匯出的範本,則建議配置不超過100s,如果有大數據量計算或匯出的範本,則根據最長耗時的範本時間進行配置。 proxy_read_timeout 400; #寫入逾時,預設60s,如果在逾時時間內伺服器未收到資料表示逾時,視為逾時。如果沒有大數據量計算或匯出的範本,則建議配置不超過100s,如果有大數據量計算或匯出的範本,則根據最長耗時的範本時間進行配置。 proxy_send_timeout 400; } #定義404頁面 #error_page 404 /404.html; # redirect server error pages to the static page /50x.html #定義50x頁面 error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } server { #此處為websocket埠,如果是叢集部署,FineReport工程為38889,FineBI工程為48889 listen 48889; server_name 192.168.6.181; location / { proxy_http_version 1.1; proxy_pass http://WBS.com; proxy_connect_timeout 75; proxy_read_timeout 400; proxy_send_timeout 400; #升級目標為$http_upgrade 值實際為websocket proxy_set_header Upgrade $http_upgrade; #Connection設定升級 proxy_set_header Connection "upgrade"; } }
若防火牆開啟,可關閉防火牆,或者單獨開放埠。
若雲伺服器有安全組或者類似的內容,需要設定埠對外開放。
重啟 nginx 和 FineBI 工程。
重啟工程時,需要殺死工程下運作的進程,等待 2 分鐘埠釋放後,再重啟工程,否則有可能重啟失敗。
按照WebSocket轉發埠>>WebSocket埠的順序,即如果使用預設值埠,按照「48889,48888,49888」的順序依次嘗試監聽。
如果有一個埠建立監聽成功,則不再嘗試其他埠。
如果所有埠都無法與系統伺服器建立監聽,會進入部署精靈頁面,引導修改監聽埠列表,相關功能會受到影響。
滑鼠選中內容,快速回饋問題
滑鼠選中存在疑惑的內容,即可快速回饋問題,我們將會跟進處理。
不再提示
10s後關閉
反馈已提交
网络繁忙