Yoo*_*Yoo 9 web-services ruby-on-rails amazon-elastic-beanstalk actioncable
WebSocket connection to 'ws://{hostname}/cable' failed: WebSocket is closed before the connection is established.
当我连接到我的Rails 5 + ActionCable应用程序时,我进入了我的Chrome浏览器.在我的本地开发环境中,它不会发生.它只发生在我的临时和生产环境中.
我使用Amazon ElasticBeanstalk来部署我的应用程序.在使用chrome开发人员工具监控请求之后,我发现与开发环境不同,WebSocket请求在登台,生产环境中没有得到响应(待定),因此ActionCable不断尝试连接到WebSocket端点(ws:// {hostname} /电缆).
问题是,在我的puma.log中,它说的是这样的:
I, [2016-07-26T13:45:53.921154 #32369] INFO -- : Registered connection (Z2lkOi8vYXNrLWNvLWRlL1VzZXIvMg)
I, [2016-07-26T13:46:05.775788 #32369] INFO -- : Finished "/cable/" [WebSocket] for 121.166.105.106 at 2016-07-26 13:46:05 +0000
I, [2016-07-26T13:46:18.074895 #32369] INFO -- : [917fd706-4f1a-4178-bd95-7a33c0c7b621] Started GET "/cable" for 121.166.105.106 at 2016-07-26 13:46:18 +0000
I, [2016-07-26T13:46:18.075764 #32369] INFO -- : [917fd706-4f1a-4178-bd95-7a33c0c7b621] Started GET "/cable/" [WebSocket] for 121.166.105.106 at 2016-07-26 13:46:18 +0000
I, [2016-07-26T13:46:18.075817 #32369] INFO -- : [917fd706-4f1a-4178-bd95-7a33c0c7b621] Successfully upgraded to WebSocket (REQUEST_METHOD: GET, HTTP_CONNECTION: Upgrade, HTTP_UPGRADE: websocket)
Run Code Online (Sandbox Code Playgroud)
也就是说,升级到WebSocket是成功的,但其余的是未知的.你有解决这个问题的线索吗?
正如问题的作者已经评论的那样,websocket 连接失败的可能原因是由于错误配置的负载均衡器后面的请求重写造成的。
例如,我遇到了配置错误的 Apache 服务器,其中重写规则用于将 Rails 应用程序使用的协议从 http 重写为 ws。
如果它对其他人有帮助,这里是在这种情况下启用 websockets 的工作 Apache VHost 配置。
<VirtualHost domain.of.the.rails-app:80>
ServerName domain.of.the.rails-app
DocumentRoot /var/www/apps/rails-app/public
ProxyPreserveHost On
ProxyPass /error-documents !
ErrorDocument 503 /error-documents/503.html
Alias /error-documents /var/www/apps/rails-app/public
ProxyPass / http://0.0.0.0:3000/
ProxyPassReverse / http://0.0.0.0:3000/
RewriteEngine on
RewriteCond %{HTTP:UPGRADE} websocket [NC]
RewriteRule /(.*) ws://localhost:3000/$1 [P]
</VirtualHost>
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
1757 次 |
最近记录: |