4.WebSocket 配置与Nginx 的完美结合

序言

在现代 web 应用中,WebSocket 作为一种全双工通信协议,为实时数据传输提供了强大的支持。若要确保 WebSocket 在生产环境中的稳定性和性能,使用 Nginx 作为反向代理服务器是一个明智的选择。本篇文章将带你了解如何在 Nginx 中配置 WebSocket,并验证其是否正常工作。

1. Nginx 中的 WebSocket 配置

1.1 安装 Nginx

在进行配置之前,确保你的系统上已安装 Nginx。你可以使用以下命令来安装:

  • Ubuntu/Debian:
sudo apt update
sudo apt install nginx
  • CentOS/RHEL:
sudo yum install nginx

1.2 基本 Nginx 配置

打开 Nginx 配置文件(通常位于 /etc/nginx/nginx.conf 或 /etc/nginx/sites-available/default)并添加以下内容,以支持 WebSocket 连接。

server {listen 80;server_name yourdomain.com;  # 替换为你的域名location /ws {  # WebSocket 路径proxy_pass http://localhost:8080;  # 你的 WebSocket 服务器地址proxy_http_version 1.1;  # 确保使用 HTTP/1.1proxy_set_header Upgrade $http_upgrade;  # 必须的配置proxy_set_header Connection "Upgrade";  # 必须的配置proxy_set_header Host $host;  # 保留主机头部proxy_set_header X-Real-IP $remote_addr;  # 客户端真实 IPproxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  # 转发 IPproxy_set_header X-Forwarded-Proto $scheme;  # 转发协议}location / {  # 其他请求proxy_pass http://localhost:8080;  # 可以根据实际情况修改}
}

1.3 重启 Nginx

配置完成后,需要重启 Nginx 以应用更改:

sudo systemctl restart nginx
或者
nginx - s reload

2. 验证 WebSocket 配置的正确性

确保 WebSocket 正常工作的方式有很多,以下是几种简单有效的方法:

2.1 使用浏览器的开发者工具

  1. 打开你的网页应用并使用浏览器的开发者工具(通常按 F12)。
  2. 切换到 Network 标签。
  3. 刷新页面,并查看 WebSocket 连接。
  4. 查找以 ws:// 或 wss:// 开头的请求,确认其状态为 101 Switching Protocols。这表示 WebSocket 连接已成功建立。

2.2 使用 wscat 测试工具

wscat 是一个非常实用的命令行工具,可以帮助你测试 WebSocket 连接。你可以通过 npm 安装:

npm install -g wscat

然后使用以下命令连接到 WebSocket 服务器:

wscat -c ws://yourdomain.com/ws

输入一些消息并确认能正常发送和接收。如果一切正常,说明 WebSocket 配置成功。

2.3 编写简单的客户端代码

你可以使用以下 JavaScript 代码在客户端验证 WebSocket 是否正常工作:

const ws = new WebSocket('ws://yourdomain.com/ws');ws.onopen = () => {console.log('Connected to the WebSocket server!');ws.send('Hello, server!');  // 发送测试消息
};ws.onmessage = (event) => {console.log('Received message from server:', event.data);
};ws.onclose = () => {console.log('Disconnected from WebSocket server.');
};ws.onerror = (error) => {console.error('WebSocket error:', error);
};

3. 常见问题及解决方法

3.1 WebSocket 连接状态为 404 或 403

  • 原因:此错误通常表明 WebSocket 请求的路径不正确,或者 Nginx 配置中的 location 块未能正确匹配 WebSocket 请求。
  • 解决方法
    • 确保 WebSocket 的 URL 与 Nginx 配置中的路径一致。例如,如果在 Nginx 中配置的是 /ws,确保你的 WebSocket 客户端也使用 ws://yourdomain.com/ws。
    • 示例:如果客户端使用 ws://yourdomain.com/socket 而服务器在 /ws 下监听,会导致 404 错误。

3.2 浏览器控制台显示“Connection Refused”

  • 原因:这种情况通常表明 WebSocket 服务器未在指定的地址和端口上运行,或者 Nginx 没有正确地将请求转发到 WebSocket 服务器。

  • 解决方法

    • 确认 WebSocket 服务器是否正在运行,使用如下命令检查端口:

      netstat -tuln | grep 8080
      
    • 确保 Nginx 配置中的 proxy_pass 地址与 WebSocket 服务器的地址匹配。

3.3 收到的消息为空或格式不正确

  • 原因:这可能是由于服务器未能正确解析发送的消息,或未能以预期格式发送消息。

  • 解决方法

    • 检查服务器代码以确保正确接收和处理消息。例如,在 Node.js 的 WebSocket 服务器中,可以使用以下代码确保将消息以字符串格式发送:
    ws.on('message', (message) => {const response = JSON.stringify({ message: message });clients.forEach(client => client.send(response));
    });
    
    • 在客户端确认处理消息的代码逻辑是否正确,例如:
    ws.onmessage = (event) => {const data = JSON.parse(event.data);console.log('Received message:', data.message);
    };
    

3.4 连接经常断开

  • 原因**:可能是由于服务器的资源(如 CPU、内存)不足,或者 Nginx 的超时设置过低。

  • 解决方法

    1. 检查服务器的资源使用情况,确保能处理所有 WebSocket 连接。

    2. 在 Nginx 配置中增加 proxy_read_timeout 和 proxy_send_timeout 的值,例如:

      location /ws {proxy_read_timeout 86400;  # 24 小时proxy_send_timeout 86400;...
      }
      
    3. 监控 WebSocket 连接的状态,以发现是否有客户端异常断开。

3.5 使用 SSL(wss://)时出现证书错误

  • 原因:SSL 证书未正确配置,或者证书与请求的域名不匹配。

  • 解决方法

    • 确保在 Nginx 配置中正确加载了 SSL 证书和私钥:

      server {listen 443 ssl;server_name yourdomain.com;ssl_certificate /path/to/fullchain.pem;ssl_certificate_key /path/to/privkey.pem;...
      }
      
    • 使用 Let’s Encrypt 获取有效的 SSL 证书并确保证书与访问的域名一致。可以使用 certbot 工具自动化这一过程。

3.6 在负载均衡环境中,WebSocket 连接断开

  • 原因:如果 Nginx 配置了负载均衡而没有保持会话(Sticky Sessions),可能导致 WebSocket 连接在请求转发时断开。

  • 解决方法

    • 在 Nginx 配置中使用 ip_hash 来确保同一客户端总是连接到同一后端服务器:

      upstream websocket {ip_hash;server backend1:8080;server backend2:8080;
      }server {location /ws {proxy_pass http://websocket;...}
      }
      

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/3499.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Linux命令 - 关于命令及其使用

文章目录 1 什么是命令?2 识别命令3 命令帮助文档4 命令别名 1 什么是命令? 命令可以是以下四种形式之一: 可执行程序:就像我们所看到的位于/usr/bin目录中的文件一样,这一类程序可以是用诸如C和C语言编写的程序编译…

【万字详文介绍】:迭代扩张卷积神经网络(IDCNN)

💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢…

220V变5V300mA非隔离芯片WT5104

220V变5V300mA非隔离芯片WT5104 WT5104特点包括: - 宽输入电压:85VAC~265VAC,适应全球电网电压波动。 - 输出规格:稳定5V直流电,最大电流500mA,适用于轻功率电子设备。 - 工作模式灵活:支持CCM…

WonderWorld: Interactive 3D Scene Generation from a Single Image 论文解读

目录 一、概述 二、相关工作 1、新视图生成 2、单视图3D场景生成 3、视频生成 4、快速的3D场景表示 三、WonderWorld 1、FLAGS表示 2、引导深度扩散模块 3、单视角层次生成 4、基于几何的初始化 surfel表示 5、阶段一——生成3D场景部分 6、阶段二——用户交互控…

kkfileview4.2.1 LibreOffice_7.1.4_Linux_x86-64_rpm.tar.gz

问题 java.lang.IllegalStateException: officeHome doesnt exist or is not a directory: optlibreoffice7.1 安装 kkfileview4.2.1 LibreOffice_7.1.4_Linux_x86-64_rpm.tar.gz 测试 全过程脚本 [zengwenfenglocalhost Desktop]$ pwd /home/zengwenfeng/Desktop [zengwe…

可编辑71页PPT | 企业架构及典型设计方案

荐言分享:企业架构(Enterprise Architecture, EA)是战略与技术之间的桥梁,旨在确保企业的信息系统、业务流程、组织结构和技术基础设施能够协同工作,以支持企业的整体战略目标。它通过定义一套标准化的框架、原则、模型…

python代码获取zabbix上机器磁盘使用率

1.需要先给机器打上标记os_type: Linux或者os_type: Windows 2.代码请求获取数据: 先装一下相关的数据包 pip install pyzabbix from pyzabbix import ZabbixAPI import requests import urllib3 import concurrent.futuresclass ZabbixInfo():def __init__(self…

一个完整的crm系统都应该具备哪些功能?CRM系统功能盘点

前段时间我们去拜访一位企业老板,正好他们在开会,团队正在讨论如何与一位潜在的大客户达成交易。 客户对产品表现出浓厚的兴趣,也提出了一些具体的问题,例如上一次交易的详细信息、服务响应时间以及可能的折扣方案,但…

导师双选系统开发:Spring Boot技术详解

第一章 绪论 1.1 选题背景 如今的信息时代,对信息的共享性,信息的流通性有着较高要求,尽管身边每时每刻都在产生大量信息,这些信息也都会在短时间内得到处理,并迅速传播。因为很多时候,管理层决策需要大量信…

CTF顶级工具与资源

《Web安全》http://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247484238&idx1&snca66551c31e37b8d726f151265fc9211&chksmc0e47a12f793f3049fefde6e9ebe9ec4e2c7626b8594511bd314783719c216bd9929962a71e6&scene21#wechat_redirect 《网安面试指南》h…

数列分块入门

本期是数列分块入门。其中的大部分题目来自hzwer在LOJ上提供的数列分块入门系列。 Blog:here (其实是对之前分块的 blog 的整理补充) sto hzwer orz %%% [转载] ---------------------------------------------------------------------------------…

模型自动绑骨,在线生成动画,神奇的网站《Mixamo》

英文名mixamo 网站地址:Mixamohttps://www.mixamo.com/#/首先进入需要注册,国内的手机号就可以,但是会有一些慢,多试几次 1、进入界面如下 2、载入自己的模型 2、绑定骨骼 拖动这几个有颜色的圈圈分别对应右图位置,点…

2024 CSS保姆级教程四

CSS中的动画 CSS动画(CSS Animations)是为层叠样式表建议的允许可扩展标记语言(XML)元素使用CSS的动画的模块​ 即指元素从一种样式逐渐过渡为另一种样式的过程​ 常见的动画效果有很多,如平移、旋转、缩放等等&#…

Docker安装anythingllm

拉镜像 docker pull mintplexlabs/anythingllm 启动 anythingllm docker run -d --name anythingllm --add-hosthost.docker.internal:host-gateway --env STORAGE_DIR/app/server/storage --health-cmd "/bin/bash/usr/local/bin/docker-healthcheck.sh || exit 1"…

格行:从新晋网红到国货之光,它究竟做对了什么?

作为一家迅速崛起的新消费品牌,近两年来,格行饱受质疑。 无论是商家还是消费者,都有人对其爱之恨之,喜欢它的人,认为它是正义的化身,价格的屠夫,国货的骄傲,原本需要花几百才能买到…

小菜家教平台(二):基于SpringBoot+Vue打造一站式学习管理系统

目录 前言 今日进度 详细过程 一、数据库重构 二、编写登录接口 相关知识点 前言 昨天我们重启了小菜家教平台的开发,创建了新项目并初步进行了配置,今天我们继续。大家要是有需要源码的话可以在评论区跟我说,博客中就不添加源码了~ 今…

数学期望和联合概率密度

数学期望的定义 数学期望是描述随机变量平均趋势的一个重要统计量。根据随机变量的类型(离散或连续),数学期望的定义有所不同。 离散型随机变量的数学期望: 若离散型随机变量 X X X取值为 x 1 , x 2 , … , x n , … x_1,x_2,\do…

MRCTF2020:你传你ma呢

文件上传题先判断黑白名单过滤,先传个最简单的木马 这里上传不了php文件,猜测可能是对php文件进行了过滤,将文件改为任意后缀这里改为.abc 还是上传不成功,猜测可能对MIME也做了过滤,将Content-Type更改为image/jpeg再…

Harmony项目基础

项目基础 开发环境 DevEco Stuio下载和安装 DevEco Studio下载 下载链接:https://developer.huawei.com/consumer/cn/deveco-studio/ 安装IDE 直接运行安装文件即可 配置SDK及工具链 DevEco Studio 提供 SDK Manager 统一管理 SDK 及工具组件,包括如下组件包&…

《使用Gin框架构建分布式应用》阅读笔记:p307-p392

《用Gin框架构建分布式应用》学习第16天,p307-p392总结,总86页。 一、技术总结 1.AWS chapter 08讲使用AWS进行部署,可以根据需要选择是否阅读。因为使用到的概率很小,且还要绑卡,本人选择跳过。 2.CI/CD (1)什么…