7

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 

enter image description here

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 
+0

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

+0

nginx gibi bir ters proxy kullanıyor veya port 80 üzerinde çalışan bir ray uygulamasına doğrudan bağlanıyor musunuz? – tpbowden

+0

Bu ters proxy yapılandırmasıyla birlikte çalıştıysanız: https://gist.github.com/KeithP/f8534c04d20c2b4e4b1d – KeithP

cevap

4

AWS tek örneği Elastik Beanstalk dağıtım üzerinde WebSocket sohbet örneği çalıştırmak için, aşağıdaki Nginx proxy yapılandırması (Not eklemek gerekir: "env1 değiştirin. t3tiiauce6.us-west-2.elasticbeanstalk.com" senin sitename ile):

.ebextensions/nginx_proxy.config

files: 
    "/etc/nginx/conf.d/websockets.conf" : 
    content: | 
     upstream backend { 
      server unix:///var/run/puma/my_app.sock; 
     } 

    server { 
     listen 80; 

     access_log /var/log/nginx/access.log; 
     error_log /var/log/nginx/error.log; 

     server_name env1.t3tiiauce6.us-west-2.elasticbeanstalk.com 

     # prevents 502 bad gateway error 
     large_client_header_buffers 8 32k; 

     location/{ 
      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; 
      proxy_set_header X-NginX-Proxy true; 

      # prevents 502 bad gateway error 
      proxy_buffers 8 32k; 
      proxy_buffer_size 64k; 

      proxy_pass http://backend; 
      proxy_redirect off; 

      location /assets { 
      root /var/app/current/public; 
      } 

      # enables WS support 
      location /cable { 
      proxy_pass http://backend; 
      proxy_http_version 1.1; 
      proxy_set_header Upgrade $http_upgrade; 
      proxy_set_header Connection "upgrade"; 
      } 
     } 
    } 

container_commands: 
    01restart_nginx: 
    command: "nginx -t && service nginx reload" 

`

+2

AWS sunucu adları Ocak 2016'da daha uzun sürüyordu, bu da e-dağıtım hatası iletisine neden oluyor: "nginx: emerg server_names_hash dosyasını oluşturamadı, sunucu_names_hash_bucket_size değerini artırmanız gerekir: 64". Bir çözüm olarak - eğer çevre adınızı olabildiğince kısa yaparsanız, bunun tavuğunu düşürmezsiniz. Örneğin 'dev-env' yerine 'dev1' kullanın. Yanıtdaki yapılandırma dosyası bunu yansıtacak şekilde güncellendi. – KeithP

+0

dosya uzantısı nedir? Bir sonraki hata – jasmo2

+0

alıyorum Uygulama sürümü app-8b83-170330_144118 yapılandırma dosyası .ebextensions/nginx_proxy.config geçersiz YAML veya JSON içeriyor. YAML istisnası – jasmo2

İlgili konular