Home
Document
Q&A
Video
Donate
Source Code
Code-Galaxy 云原生平台
Business
Swoole Tracker
Swoole Compiler
Login
Register
全部
提问
分享
讨论
建议
公告
开发框架
发表新帖
websocket 服务器通过nginx转发请求后无法正常建立连接
### 问题描述 直接通过开放端口访问可以建立连接 通过nginx转发后无法建立连接 同电脑,安装谷歌以外的浏览器无法建立连接 nginx配置如下 # 至少需要一个 Hyperf 节点,多个配置多行 upstream hyperf_websocket { # 设置负载均衡模式为 IP Hash 算法模式,这样不同的客户端每次请求都会与同一节点进行交互 ip_hash; # Hyperf WebSocket Server 的 IP 及 端口 server 127.0.0.1:9502; } server { listen 80; server_name websocket.shopapi.chenm.xyz; more_clear_headers "Date:"; access_log /usr/local/nginx/logs/websocket.access_log logstash; error_log /usr/local/nginx/logs/websocket.error_log; location / { # WebSocket Header proxy_http_version 1.1; proxy_set_header Upgrade "websocket"; proxy_set_header Connection "Upgrade"; # 将客户端的 Host 和 IP 信息一并转发到对应节点 proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; # 客户端与服务端无交互 60s 后自动断开连接,请根据实际业务场景设置 #proxy_read_timeout 60s ; # 执行代理访问真实服务器 proxy_pass http://hyperf_websocket; } } 原来是在项目里写的websocket控制器,现在单独拉出swoole示例的代码监听9502,还是出现这种情况, #具体链接建立不了表现为 使用http://websocket-test.com 进行测试的时候, 点击连接,服务器打印信息同时显示connection open: 1 但是网页这边显示一直都是等待服务器的握手包 一直等到60秒 nginx断开请求,swoole打印connection close: 1 然后网页里同时收到握手包,建立连接,服务器断开连接3个信息 nginx的错误日志如下 2020/06/26 16:22:36 [error] 13849#0: *7 upstream timed out (110: Connection timed out) while reading upstream, client: 183.209.155.244, server: websocket.shopapi.chenm.xyz, request: "GET / HTTP/1.0", upstream: "http://127.0.0.1:9502/", host: "websocket.shopapi.chenm.xyz 最奇怪的事 换了一台电脑就没有这个问题了。。。
发布于2年前 · 6 次浏览 · 来自
提问
chen0520
### 问题描述 直接通过开放端口访问可以建立连接 通过nginx转发后无法建立连接 同电脑,安装谷歌以外的浏览器无法建立连接 nginx配置如下 # 至少需要一个 Hyperf 节点,多个配置多行 upstream hyperf_websocket { # 设置负载均衡模式为 IP Hash 算法模式,这样不同的客户端每次请求都会与同一节点进行交互 ip_hash; # Hyperf WebSocket Server 的 IP 及 端口 server 127.0.0.1:9502; } server { listen 80; server_name websocket.shopapi.chenm.xyz; more_clear_headers "Date:"; access_log /usr/local/nginx/logs/websocket.access_log logstash; error_log /usr/local/nginx/logs/websocket.error_log; location / { # WebSocket Header proxy_http_version 1.1; proxy_set_header Upgrade "websocket"; proxy_set_header Connection "Upgrade"; # 将客户端的 Host 和 IP 信息一并转发到对应节点 proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; # 客户端与服务端无交互 60s 后自动断开连接,请根据实际业务场景设置 #proxy_read_timeout 60s ; # 执行代理访问真实服务器 proxy_pass http://hyperf_websocket; } } 原来是在项目里写的websocket控制器,现在单独拉出swoole示例的代码监听9502,还是出现这种情况, #具体链接建立不了表现为 使用http://websocket-test.com 进行测试的时候, 点击连接,服务器打印信息同时显示connection open: 1 但是网页这边显示一直都是等待服务器的握手包 一直等到60秒 nginx断开请求,swoole打印connection close: 1 然后网页里同时收到握手包,建立连接,服务器断开连接3个信息 nginx的错误日志如下 2020/06/26 16:22:36 [error] 13849#0: *7 upstream timed out (110: Connection timed out) while reading upstream, client: 183.209.155.244, server: websocket.shopapi.chenm.xyz, request: "GET / HTTP/1.0", upstream: "http://127.0.0.1:9502/", host: "websocket.shopapi.chenm.xyz 最奇怪的事 换了一台电脑就没有这个问题了。。。
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
评论
2020-06-28
鲁飞
swoole版本是否一致?
赞
0
回复
微信公众号
热门内容
- swoole针对400的请求--TRACE Port_onRead_http() (ERRNO 7102): Bad Request: unknown protocol from session#193 on 0.0.0.0:9505
- 基于Swoole+PHP的超高性能短信网关(CMPP、SMPP)模拟器
- http服务中,使用write分段输出文件。设置header总文件长度无用
- Call to undefined function Swoole\Coroutine\run() 是怎么回事啊?
- Swoole Loader扩展 如何下载,https://business.swoole.com/trial/download/ 404
- 请教当使用request主动推送的时候,产生新的连接,及会马上关闭连接问题
- 为什么连接池只创建一个连接
- timer定时器,启动一下,突然执行了1万多次,这是怎么回事呢?
- 在swoole 中, 使用地址引用自身,造成内存增加
- windows 配置wss链接,链接不成功
作者其它话题
- 异步风格的写法,如何同时开启http和websocket?
- 如何设计让子协程全部结束后再执行主协程的代码呢?
- 定时器tick内执行的外部命令,只能保持在当前的定时器空间内,一旦退出或者下一次tick就会被杀死进程
- 关于swoole在win服务器下的运行
暂无回复的问答
- 关于openssl CURL WARNING swSSL_connect: SSL_connect(fd=69) failed. Error: error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small[1|394]
- 请问那个一键协程化的代码是放外面还是set里面
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。