亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解nginx websocket配置

 更新時間:2018年08月10日 09:45:36   作者:hexuyong  
這篇文章主要介紹了詳解nginx websocket配置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

一·什么是websocket

WebSocket協(xié)議相比較于HTTP協(xié)議成功握手后可以多次進(jìn)行通訊,直到連接被關(guān)閉。但是WebSocket中的握手和HTTP中的握手兼容,它使用HTTP中的Upgrade協(xié)議頭將連接從HTTP升級到WebSocket。這使得WebSocket程序可以更容易的使用現(xiàn)已存在的基礎(chǔ)設(shè)施。

WebSocket工作在HTTP的80和443端口并使用前綴ws://或者wss://進(jìn)行協(xié)議標(biāo)注,在建立連接時使用HTTP/1.1的101狀態(tài)碼進(jìn)行協(xié)議切換,當(dāng)前標(biāo)準(zhǔn)不支持兩個客戶端之間不借助HTTP直接建立Websocket連接。

二.創(chuàng)建基于Node的WebSocket服務(wù)

安裝node.js和npm

$ yum install nodejs npm

安裝ws和wscat模塊

ws是nodejs的WebSocket實(shí)現(xiàn),我們借助它來搭建簡單的WebSocket Echo Server。

wscat是一個可執(zhí)行的WebSocket客戶端,用來調(diào)試WebSocket服務(wù)是否正常。

npm install ws wscat

創(chuàng)建一個簡單的服務(wù)端

$ vim server.js
console.log("Server started");
var Msg = '';
var WebSocketServer = require('ws').Server
  , wss = new WebSocketServer({port: 8010});
  wss.on('connection', function(ws) {
    ws.on('message', function(message) {
    console.log('Received from client: %s', message);
    ws.send('Server received from client: ' + message);
  });
 });

運(yùn)行服務(wù)端

$ node server.js
 Server started

驗(yàn)證服務(wù)端是否正常啟動

$ netstat -tlunp|grep 8010
tcp6    0   0 :::8010         :::*          LISTEN   23864/nodejs

使用wscat做為客戶端測試

wscat命令默認(rèn)安裝當(dāng)前用戶目錄node_modules/wscat/目錄,我這里的位置是/root/node_modules/wscat/bin/wscat

輸入任意內(nèi)容進(jìn)行測試,得到相同返回則說明運(yùn)行正常。

$ cd /root/node_modules/wscat/bin/
$ ./wscat --connect ws://127.0.0.1:8010
connected (press CTRL+C to quit)
> Hello
< Server received from client: Hello
> Welcome to www.hi-linux.com
< Server received from client: Welcome to www.hi-linux.com

三.使用Nginx對WebSocket進(jìn)行反向代理

安裝Nginx

yum -y install nginx

配置Nginx Websocket

$ vim /usr/local/nginx/conf/nginx.conf
# 在http上下文中增加如下配置,確保Nginx能處理正常http請求。
http{
 map $http_upgrade $connection_upgrade {
  default upgrade;
  ''   close;
 }
 upstream websocket {
  #ip_hash;
  server localhost:8010; 
  server localhost:8011;
 }
# 以下配置是在server上下文中添加,location指用于websocket連接的path。
 server {
  listen    80;
  server_name localhost;
  access_log /var/log/nginx/yourdomain.log;
  location / {
   proxy_pass http://websocket;
   proxy_read_timeout 300s;
   proxy_set_header Host $host;
   proxy_set_header X-Real-IP $remote_addr;
   proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
   proxy_http_version 1.1;
   proxy_set_header Upgrade $http_upgrade;
   proxy_set_header Connection $connection_upgrade;
}
}
}

最重要的就是在反向代理的配置中增加了如下兩行,其它的部分和普通的HTTP反向代理沒有任何差別。

proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;

這里面的關(guān)鍵部分在于HTTP的請求中多了如下頭部:

Upgrade: websocket
Connection: Upgrade

這兩個字段表示請求服務(wù)器升級協(xié)議為WebSocket。服務(wù)器處理完請求后,響應(yīng)如下報文# 狀態(tài)碼為101 

HTTP/1.1 101 Switching Protocols
Upgrade: websocket
Connection: upgrade

告訴客戶端已成功切換協(xié)議,升級為Websocket協(xié)議。握手成功之后,服務(wù)器端和客戶端便角色對等,就像普通的Socket一樣,能夠雙向通信。不再進(jìn)行HTTP的交互,而是開始WebSocket的數(shù)據(jù)幀協(xié)議實(shí)現(xiàn)數(shù)據(jù)交換。

這里使用map指令可以將變量組合成為新的變量,會根據(jù)客戶端傳來的連接中是否帶有Upgrade頭來決定是否給源站傳遞Connection頭,這樣做的方法比直接全部傳遞upgrade更加優(yōu)雅。

默認(rèn)情況下,連接將會在無數(shù)據(jù)傳輸60秒后關(guān)閉,proxy_read_timeout參數(shù)可以延長這個時間或者源站通過定期發(fā)送ping幀以保持連接并確認(rèn)連接是否還在使用。

啟動nginx

/etc/init.d/nginx start

試通過Nginx訪問WebSocket服務(wù)

$ cd /root/node_modules/wscat/bin/
$ ./wscat --connect ws://192.168.2.210
connected (press CTRL+C to quit)
> Hello Nginx
< Server received from client: Hello Nginx
> Welcome to www.hi-linux.com
< Server received from client: Welcome to www.hi-linux.com

測試成功,ok

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • nginx 基本入門教程

    nginx 基本入門教程

    本篇文章主要介紹了詳解nginx 基本入門,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • 詳解nginx實(shí)現(xiàn)https網(wǎng)站設(shè)置

    詳解nginx實(shí)現(xiàn)https網(wǎng)站設(shè)置

    這篇文章主要介紹了詳解nginx實(shí)現(xiàn)https網(wǎng)站設(shè)置,詳細(xì)的介紹了HTTPS簡介和證書生成等,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • Nginx服務(wù)器安裝及配置文件與使用詳解

    Nginx服務(wù)器安裝及配置文件與使用詳解

    這篇文章主要介紹了Nginx服務(wù)器安裝及配置文件與使用詳解 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • 503 service unavailable錯誤解決方案講解

    503 service unavailable錯誤解決方案講解

    這篇文章主要介紹了503 service unavailable錯誤解決方案講解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • nginx配置多個前端項(xiàng)目實(shí)現(xiàn)步驟

    nginx配置多個前端項(xiàng)目實(shí)現(xiàn)步驟

    本文主要介紹了nginx配置多個前端項(xiàng)目實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • 使用AWS的ELB服務(wù)時為Nginx啟用代理協(xié)議的步驟講解

    使用AWS的ELB服務(wù)時為Nginx啟用代理協(xié)議的步驟講解

    這篇文章主要介紹了使用AWS的ELB服務(wù)時為Nginx啟用代理協(xié)議的步驟講解,ELB服務(wù)是亞馬遜服務(wù)器提供的常用的負(fù)載均衡方案,需要的朋友可以參考下
    2015-12-12
  • nginx開啟https配置之后網(wǎng)頁無法訪問的問題處理解決

    nginx開啟https配置之后網(wǎng)頁無法訪問的問題處理解決

    最近新購服務(wù)器部署nginx之后按照之前的方式部署前端項(xiàng)目并配置https之后訪問頁面無法顯示,本文主要介紹了nginx開啟https配置之后網(wǎng)頁無法訪問的問題處理解決,具有一定的參考價值,感興趣的可以了解一下
    2023-11-11
  • 阿里云國際版使用Nginx作為HTTPS轉(zhuǎn)發(fā)代理服務(wù)器的處理方法

    阿里云國際版使用Nginx作為HTTPS轉(zhuǎn)發(fā)代理服務(wù)器的處理方法

    本文介紹了使用NGINX作為HTTPS流量轉(zhuǎn)發(fā)代理的兩種方法。它總結(jié)了NGINX使用HTTP?CONNECT隧道和NGINX流充當(dāng)HTTPS轉(zhuǎn)發(fā)代理的解決方案的原則,環(huán)境構(gòu)建要求,應(yīng)用場景和關(guān)鍵問題
    2022-05-05
  • Nginx Gzip模塊啟用和配置指令詳解

    Nginx Gzip模塊啟用和配置指令詳解

    這篇文章主要介紹了Nginx Gzip模塊啟用和配置指令詳解的,需要的朋友可以參考下
    2014-04-04
  • Nginx反向代理入門實(shí)戰(zhàn)指南

    Nginx反向代理入門實(shí)戰(zhàn)指南

    反向代理:反向代理也叫reverse proxy,指的是代理外網(wǎng)用戶的請求到內(nèi)部的指定web服務(wù)器,并將數(shù)據(jù)返回給用戶的一種方式,這是用的比較多的一種方式,下面這篇文章主要給大家介紹了關(guān)于Nginx反向代理的相關(guān)資料,需要的朋友可以參考下
    2021-08-08

最新評論