DHH'nin basit Rails 5 sohbet örneğini AWS'de tek bir bağımsız EC2 örneğine dağıtmaya çalışıyoruz.AWS üzerinde ActionCable: WebSocket el sıkışma sırasında hata: Beklenmeyen yanıt kodu: 404
eb create dev-env -p “64bit Amazon Linux 2015.09 v2.0.4 running Ruby
2.2 (Puma)” –single -i t2.micro --envvars
SECRET_KEY_BASE=g5dh9cg614a37d4bdece9126b42d50d0ab8b2fc785daa1e0dac0383d6387f36b
Bu minimal yükleme olduğundan, herhangi Elasticache ve hiçbir yük dengeleyici vardır:
https://github.com/HectorPerez/chat-in-rails5 Biz böylece tek bir örneğini yukarı dönmeye Elastik Sihirli Fasulye kullandı: Kod burada mevcuttur. EC2 örneğine redis yüklemek için şu şekilde bir .ebextensions yapılandırma dosyası ekledik: https://gist.github.com/KeithP/08b38189372b7fd241e5#file-ebextensions-redis-config; Git işlemek ve dağıtmak.
Ama WebSocket çalışmıyor:
application-a57354de3399cd895ca366df9bd7316ab69e81d266b63be7d7be563ebc78ab9d.js:27
WebSocket connection to ‘ws://dev-env-y2e5dcrxqk.elasticbeanstalk.com/cable’ failed:
Error during WebSocket handshake: Unexpected response code: 404
sunucu production.log 2 için "/ kablo GET Started" gösterir: tarayıcı konsolu incelenmesi, biz tekrar yinelenen ve boyunca bu hatayı görmeye her "bitmiş/kablo" çağrısı. ActiveCable hiçbir DEBUG mesajı vardır:
/var/app/containerfiles/logs/production.log
-------------------------------------
INFO -- : Processing by RoomsController#show as HTML
DEBUG -- : [1m[36mMessage Load (0.1ms)[0m [1m[34mSELECT "messages".* FROM "messages"[0m INFO -- : Rendered collection (0.0ms)
INFO -- : Rendered rooms/show.html.erb within layouts/application (0.5ms)
INFO -- : Completed 200 OK in 2ms (Views: 1.2ms | ActiveRecord: 0.1ms)
INFO -- : Started GET "/cable" for <ip_address> at 2016-01-01 17:28:26 +0000
INFO -- : Started GET "/cable/" for <ip_address> at 2016-01-01 17:28:26 +0000
INFO -- : Finished "/cable/" for <ip_address> at 2016-01-01 17:28:26 +0000
Redis'in kurulu olduğunu ve başladığını kontrol ettik; ve production.rb içinde 'ActionCable.server.config.disable_request_forgery_protection = true' denediniz – KeithP
nginx gibi bir ters proxy kullanıyor veya port 80 üzerinde çalışan bir ray uygulamasına doğrudan bağlanıyor musunuz? – tpbowden
Bu ters proxy yapılandırmasıyla birlikte çalıştıysanız: https://gist.github.com/KeithP/f8534c04d20c2b4e4b1d – KeithP