こんにちは私はror 5.0.0ベータ(プーマ付き) を使って簡単なチャットを提供しようとしています(ローカルホストでは問題ありません) 。RoR 5.0.0 ActionCable wss WebSocketハンドシェイク:予期しない応答コード:301
これは私のnginxの構成です: URL:Redisの:// localhostを:1分の6379
upstream websocket {
server 127.0.0.1:28080;
}
server {
listen 443;
server_name mydomain;
ssl_certificate ***/server.crt;
ssl_certificate_key ***/server.key;
ssl on;
ssl_session_cache builtin:1000 shared:SSL:10m;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers
HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
ssl_prefer_server_ciphers on;
access_log /var/log/nginx/jenkins.access.log;
location/{
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_pass http://localhost:3000;
proxy_read_timeout 90;
proxy_redirect http://localhost:3000 https://mydomain;
location /cable/{
proxy_pass http://websocket/;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $http_host;
break;
}
}
これはのconfig/Redisの/ cable.yml
生産です
開発: url:redis:// localhost:6379/2
テスト: URL:Redisの:// localhostを:3分の6379
と設定/環境/ production.rb
# Action Cable endpoint configuration
config.action_cable.url = 'wss://mydomain/cable'
# config.action_cable.allowed_request_origins = [ 'http://example.com', /http:\/\/example.*/ ]
# Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
config.force_ssl = false
そして、これは私が受けてるのエラーです:
アプリケーション - [...]。js:27 'wss:// mydomain/cable'へのWebSocket接続に失敗しました:WebSocketハンドシェイク中にエラーが発生しました:予期しない応答コード:301
ヒント? :)ありがとう
ため、誰もが場所/ケーブル/ {...} /ケーブル私を返すように変更
感謝「のWebSocket接続」にしますwss:// mydomain/cable 'failed:WebSocketハンドシェイク中にエラーが発生しました:予期しない応答コード:502 " –
サービスがポート28080で実行されていることを確認してください。 –
ファイアウォールがポートをブロックしていました。 "upstream websocket" {127.0.0.1:4443} - > WebSocketハンドシェイク中のエラー:予期しない応答コード:404少なくとも私のエラーコードがxdを変更しています –