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.rhkb.cn/news/466889.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

canal1.1.7使用canal-adapter进行mysql同步数据

重要的事情说前面,canal1.1.8需要jdk11以上,大家自行选择,我这由于项目原因只能使用1.1.7兼容版的 文章参考地址: canal 使用详解_canal使用-CSDN博客 使用canal.deployer-1.1.7和canal.adapter-1.1.7实现mysql数据同步_mysql更…

SpringBoot之定时任务

1. 前言 本篇博客是个人的经验之谈,不是普适的解决方案。阅读本篇博客的朋友,可以参考这里的写法,如有不同的见解和想法,欢迎评论区交流。如果此篇博客对你有帮助,感谢点个赞~ 2. 场景 我们讨论在单体项目&#xff0c…

绿色能源发展关键:优化风电运维体系

根据QYResearch调研团队最新发布的《全球风电运维市场报告2023-2029》显示,预计到2029年,全球风电运维市场的规模将攀升至307.8亿美元,并且在接下来的几年里,其年复合增长率(CAGR)将达到12.5%。 上述图表及…

前端 Canvas 绘画 总结

目录 一、使用案例 1、基础使用案例 2、基本案例改为直接JS实现 二、相关资料 1、API教程文档 2、炫酷案例 一、使用案例 1、基础使用案例 使用Canvas的基本步骤&#xff1a; 1、需要一个canvas标签 2、需要获取 画笔 对象 3、使用canvas提供的api进行绘图 <!--…

力扣排序455题(分发饼干)

假设你是一位很棒的家长&#xff0c;想要给你的孩子们一些小饼干。 但是&#xff0c;每个孩子最多只能给一块饼干。 对每个孩子 i&#xff0c;都有一个胃口值 g[i],这是能 让孩子们满足胃口的饼干的最小尺寸;并且每块饼 干j&#xff0c;都有一个尺寸 s[j]。如果 s[j]> g[i]&…

C语言 | Leetcode C语言题解之第537题复数乘法

题目&#xff1a; 题解&#xff1a; bool parseComplexNumber(const char * num, int * real, int * image) {char *token strtok(num, "");*real atoi(token);token strtok(NULL, "i");*image atoi(token);return true; };char * complexNumberMulti…

Android使用scheme方式唤醒处于后台时的App场景

场景&#xff1a;甲App唤醒处于后台时的乙App的目标界面Activity&#xff0c;且乙App的目标界面Activity处于最上层&#xff0c;即已经打开状态&#xff0c;要求甲App使用scheme唤醒乙App时&#xff0c;达到跟从桌面icon拉起App效果一致&#xff0c;不能出现只拉起了乙App的目标…

如何对接低价折扣相对稳定电影票渠道?

对接低价折扣电影票渠道需要经过一系列步骤&#xff0c;以确保能够为用户提供优惠且可靠的购票体验。以下是一个基本的对接流程&#xff1a; 1.市场调研&#xff1a; 调研市场上的电影票销售渠道&#xff0c;了解主要的电影票批发商和分销商。分析竞争对手的折扣电影票服务&a…

【上云拼团Go】如何在腾讯云双十一活动中省钱

1. 前言 双十一已经成为了全球最大的购物狂欢节&#xff0c;除了电商平台的优惠&#xff0c;云计算服务商也纷纷在这个期间推出了诱人的促销活动。腾讯云作为中国云计算的领军企业之一&#xff0c;每年双十一的活动都吸引了大量开发者、企业和个人用户参与。那么&#xff0c;在…

新能源企业在精益变革过程中可能会遇到哪些困难?

在绿色转型的浪潮中&#xff0c;新能源企业作为推动社会可持续发展的先锋力量&#xff0c;正加速迈向精益化管理的新阶段。然而&#xff0c;这条变革之路并非坦途&#xff0c;而是布满了未知与挑战。本文&#xff0c;天行健王春城老师将深入探讨新能源企业在精益变革过程中可能…

Maven的安装配置

文章目录 一、MVN 的下载二、配置maven2.1、更改maven/conf/settings.xml配置2.2、配置环境变量一、MVN 的下载 还是那句话,要去就去官网或者github,别的地方不要去下载。我们下载binaries/ 目录下的 cd /opt/server wget https://downloads.apache.org/maven/maven-3/3.9.6/…

OpenCV视觉分析之目标跟踪(10)估计两个点集之间的刚性变换函数estimateRigidTransform的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 计算两个2D点集之间的最优仿射变换 estimateRigidTransform 是 OpenCV 中的一个函数&#xff0c;用于估计两个点集之间的刚性变换&#xff08;即…

块存储、文件存储和对象存储详细介绍

块存储、文件存储和对象存储介绍 块存储&#xff1a;像跑车&#xff0c;因为它们都能提供快速的响应和高性能&#xff0c;适合需要即时数据访问的场景&#xff0c;比如数据库和虚拟化技术。 文件存储&#xff1a;像货车&#xff0c;因为它们都能承载大量货物&#xff08;文件&…

A019基于SpringBoot的校园闲置物品交易系统

&#x1f64a;作者简介&#xff1a;在校研究生&#xff0c;拥有计算机专业的研究生开发团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339; 赠送计算机毕业设计600…

基于YOLO11/v10/v8/v5深度学习的煤矿传送带异物检测系统设计与实现【python源码+Pyqt5界面+数据集+训练代码】

《------往期经典推荐------》 一、AI应用软件开发实战专栏【链接】 项目名称项目名称1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】3.【手势识别系统开发】4.【人脸面部活体检测系统开发】5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】7.【…

explain执行计划分析 ref_

这里写目录标题 什么是ExplainExplain命令扩展explain extendedexplain partitions 两点重要提示本文示例使用的数据库表Explain命令(关键字)explain简单示例explain结果列说明【id列】【select_type列】【table列】【type列】 【possible_keys列】【key列】【key_len列】【ref…

关于elementui el-radio 赋值问题

今天遇到这样的问题&#xff1a; 点击的时候&#xff0c;同时选中 照抄官网&#xff01; 后来发现了问题&#xff1a; 也就是说如果你的版本太低&#xff0c;就不能用value&#xff0c;而得用label&#xff0c;于是修改 <el-radio-group v-model"searchTime"&g…

微服务系列六:分布式事务与seata

目录 实验环境说明 前言 一、分布式事务问题与策略 1.1 分布式事务介绍 1.2 分布式事务解决策略分析 二、分布式事务解决方案 Seata 2.1 认识Seata 2.2 Seata的工作原理 2.3 部署Seata微服务 2.3.1 准备数据库表 2.3.2 准备配置文件 2.3.3 docker部署 2.4 微服务集…

OceanBase 安装使用详细说明

OceanBase 安装使用详细说明 一、系统环境要求二、安装OceanBase环境方案一:在线下载并安装all-in-one安装包方案二:离线安装all-in-one安装包安装前的准备工作三、配置OceanBase集群编辑配置文件部署和启动集群连接到集群集群状态和管理四、创建业务租户和数据库创建用户并赋…

如何使用 SSH 连接并管理你的 WordPress 网站

在当今数字化的世界里&#xff0c;网站的管理与维护至关重要。对于使用 WordPress 搭建网站的用户而言&#xff0c;掌握基本的 SSH&#xff08;安全壳&#xff09;命令能够极大地简化网站管理工作。本指南将向你介绍 SSH 的基本知识&#xff0c;并教你如何通过 SSH 连接和管理你…