7

Staramy się wdrażać proste Szyny DHH za 5 czat przykład do jednego, samowystarczalne instancji EC2 na AWS. Kod jest dostępny tutaj: https://github.com/HectorPerez/chat-in-rails5ActionCable na AWS: Błąd podczas websocket uzgadniania: Nieoczekiwany kod odpowiedzi: 404

Użyliśmy Elastic Beanstalk rozpędzają pojedynczą instancję tak:

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 

Jest to minimalna instalacja, więc nie ma Elasticache i nie równoważenia obciążenia. Aby zainstalować redis na instancji EC2, dodaliśmy plik konfiguracyjny .ebextensions w następujący sposób: https://gist.github.com/KeithP/08b38189372b7fd241e5#file-ebextensions-redis-config; Git zatwierdzić i wdrożyć.

Ale praca websocket robi: Kontrola konsolę przeglądarki, widzimy ten błąd powtarzając w kółko:

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

production.log serwer znajdują się 2 "Rozpoczęcie GET/kabel" dla każde wywołanie "zakończone/kabel". Brak komunikaty ze 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

Sprawdziliśmy, czy czerwone jest zainstalowane i uruchomione poprawnie; i starał „ActionCable.server.config.disable_request_forgery_protection = true” w production.rb – KeithP

+0

Używasz odwrotnego proxy jak nginx lub podłączenie bezpośrednio do aplikacji szyn uruchomiony na porcie 80? – tpbowden

+0

Próbowałem zi bez tej odwrotnej konfiguracji proxy: https://gist.github.com/KeithP/f8534c04d20c2b4e4b1d – KeithP

Odpowiedz

4

Aby uruchomić przykład websocket czat na pojedynczym egzemplarzu Elastic Beanstalk rozmieszczenia w AWS, trzeba będzie dodać następujące Nginx proxy konfiguracja (Uwaga: zastąpić „env1. t3tiiauce6.us-west-2.elasticbeanstalk.com”z 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

nazwy serwerów AWS dostał już w styczniu 2016 roku, w wyniku eb wdrożyć wiadomość awaria „nginx: Emerg nie mógł zbudować server_names_hash, należy zwiększyć server_names_hash_bucket_size: 64”. Jako obejście - jeśli sprawisz, że nazwa twojego środowiska będzie tak krótka, jak to możliwe, nie spadnie z tego ptactwo. Np. Użyj "dev1" zamiast "dev-env". Plik konfiguracyjny w odpowiedzi został zaktualizowany, aby to odzwierciedlić. – KeithP

+0

jakie jest rozszerzenie pliku? Ja dostaję kolejny błąd – jasmo2

+0

.ebextensions plik konfiguracyjny/nginx_proxy.config w wersji aplikacja app-8b83-170330_144118 zawiera nieprawidłową YAML lub JSON. Wyjątek YAML – jasmo2

Powiązane problemy