Как настроить безопасный Websocket (wss) на сервере Nginx узла? - PullRequest
0 голосов
/ 01 мая 2020

Я пытался настроить прокси Websocket на моем Nginx сервере, но, к сожалению, у меня не получается. Я читал различные формы, но не могу выбраться из этого. Я думаю, что это связано с подключением клиента к серверу. Локальный ом мой p c все работает нормально

код клиента:

 var port = new osc.WebSocketPort({
          url: "wss://circusfamilyprojects.nl/"
        }); 

код сервера:

var wss = new WebSocket.Server({
    port: 8083
});

Это моя конфигурация в Nginx

 # custom code for hop by hop headers
    map $http_upgrade $connection_upgrade {
        default upgrade;
        ''      close;
    }


    #custom code for connection with websocket this is the port on the server
     upstream websocket  {
        server 178.62.209.37:8083;
    }

server {

      listen [::]:443 ssl ipv6only=on; # managed by Certbot
      listen 443 ssl; # managed by Certbot
      ssl_certificate /etc/letsencrypt/live/circusfamilyprojects.nl/fullchain.pem; # managed by Cert$
      ssl_certificate_key /etc/letsencrypt/live/circusfamilyprojects.nl/privkey.pem; # managed by Ce$
      include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
      ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot

       root /var/www/html/vue/cfdomotica/server/public;

        # Add index.php to the list if you are using PHP
        index index.html index.htm index.nginx-debian.html;

       server_name  circusfamilyprojects.nl www.circusfmailyprojects.nl; # managed by Certbot

      location / {
            proxy_pass http://websocket;
            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_request_headers on;
            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection $connection_upgrade;

        }
}

server {
    if ($host = www.circusfamilyprojects.nl) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


    if ($host = circusfamilyprojects.nl) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


        listen 8080 ;
        listen [::]:8080 ;
    server_name  circusfamilyprojects.nl;
    return 404; # managed by Certbot
}

В браузере появляется сообщение «Код состояния: требуется обновление 426». Надеюсь, кто-то может мне помочь, заранее спасибо!

1 Ответ

0 голосов
/ 05 мая 2020

Я решил сам, разделив блок сервера для порта 443 и блок сервера для клиента WebSocket. Я сделал блок сервера для клиента на порту 8086.

...