【发布时间】:2018-11-07 11:26:17
【问题描述】:
ElasticBeanstalk 是一种应用程序负载均衡器配置。它是一个 Ruby on Rails,具有 Passenger、Puma 和 NGINX(默认 Ruby AWS 堆栈)。
我正在强制使用 ssl,并且我的一切都运行良好,除了 websockets,这似乎是(阻塞|丢弃|损坏)。
控制台显示第一个错误:(URL is my domain)
WebSocket connection to 'wss://<URL>/cable' failed: WebSocket is closed before the connection is established.
此请求失败,前端出现(OPCODE -1)。
通过检查服务器日志,我有 access.log 显示:
/cable"499 这不是一个描述性很强的错误。
轨道production.log 显示:
Started GET "/cable/" [WebSocket] for 152.170.14.251 at 2018-05-28 21:01:27 +0000
Successfully upgraded to WebSocket (REQUEST_METHOD: GET, HTTP_CONNECTION: upgrade, HTTP_UPGRADE: websocket)
Registered connection (Z2lkOi8vYXNlc29yLWFwcC9JZGVudGl0eS81:Z2lkOi8vYXNlc29yLWFwcC9Vc2VyLzI)
WebSocket error occurred: wrong number of arguments (given 2, expected 1)
有时我会看到另一个错误:
NoMethodError: undefined method `+' for nil:NilClass
File "/opt/rubies/ruby-2.5.1/lib/ruby/gems/2.5.0/gems/websocket-driver-0.7.0/lib/websocket/driver/hybi.rb" line 11 in generate_accept
File "/opt/rubies/ruby-2.5.1/lib/ruby/gems/2.5.0/gems/websocket-driver-0.7.0/lib/websocket/driver/hybi.rb" line 76 in initialize
File "/opt/rubies/ruby-2.5.1/lib/ruby/gems/2.5.0/gems/websocket-driver-0.7.0/lib/websocket/driver.rb" line 160 in new
File "/opt/rubies/ruby-2.5.1/lib/ruby/gems/2.5.0/gems/websocket-driver-0.7.0/lib/websocket/driver.rb" line 160 in rack
File "/opt/rubies/ruby-2.5.1/lib/ruby/gems/2.5.0/gems/actioncable-5.2.0/lib/action_cable/connection/client_socket.rb" line 47 in initialize
该文件显示缺少密钥。
通过跟踪该错误,我发现了这个问题:
这让我看到了这个最终文件:
File variable that seems to be missing
这最终使我找到了可能缺少的配置:
经过大量调查,我最终找到了 gem 源代码,看起来某些字符的编码失败并创建了一个 ActionCable 无法解析的奇怪字符串:
【问题讨论】:
-
您可以在这里阅读更多关于 499 错误代码的信息:httpstatuses.com/499
标签: ruby websocket ruby-on-rails-5 amazon-elastic-beanstalk passenger