7

Stiamo tentando di distribuire il semplice esempio di chat di Rails 5 di DHH a una singola istanza EC2 autonoma su AWS. Codice è disponibile qui: https://github.com/HectorPerez/chat-in-rails5ActionCable su AWS: errore durante l'handshake WebSocket: codice di risposta imprevisto: 404

Abbiamo usato Elastic Beanstalk a girare su una singola istanza in tal modo:

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 

Questa è un'installazione minima, quindi non c'è Elasticache, e nessuna di bilanciamento del carico. Per installare redis sull'istanza EC2 abbiamo aggiunto un file di configurazione .ebextensions come questo: https://gist.github.com/KeithP/08b38189372b7fd241e5#file-ebextensions-redis-config; Git commettere e distribuire.

Ma il lavoro websocket pretende molto: Controllo della console del browser, vediamo questo errore ripetere più e più volte:

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

Il production.log server mostra 2 "Avviato GET/cavo" per ogni chiamata "Finito/via cavo". Non ci sono messaggi di debug da ActiveCable:

/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

Abbiamo verificato che le immagini rosse siano installate e avviate correttamente; e ho provato 'ActionCable.server.config.disable_request_forgery_protection = true' in production.rb – KeithP

+0

Stai usando un proxy inverso come nginx o ci si collega direttamente a un'app per rails in esecuzione sulla porta 80? – tpbowden

+0

Ho provato con e senza questa configurazione del proxy inverso: https://gist.github.com/KeithP/f8534c04d20c2b4e4b1d – KeithP

risposta

4

per eseguire l'esempio websocket chat a una singola istanza distribuzione Elastic Beanstalk in AWS, sarà necessario aggiungere la seguente Nginx delega configurazione (Nota: sostituire "ENV1. t3tiiauce6.us-west-2.elasticbeanstalk.com" con il sitename):

.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

I nomi dei server AWS sono diventati più lunghi a gennaio 2016, con conseguente messaggio di errore di distribuzione eb "nginx: emerge impossibile creare il nome_server_shp, è necessario aumentare server_names_hash_bucket_size: 64". Come soluzione alternativa: se il nome dell'ambiente è il più breve possibile, non si accorgerebbe di questo. Ad esempio, usa "dev1" invece di "dev-env". Il file di configurazione nella risposta è stato aggiornato per riflettere questo. – KeithP

+0

qual è l'estensione del file? Viene visualizzato l'errore successivo – jasmo2

+0

Il file di configurazione .ebextensions/nginx_proxy.config nella versione dell'app dell'app-8b83-170330_144118 contiene YAML o JSON non validi. L'eccezione YAML – jasmo2

Problemi correlati