WebSocket-соединение с 'wss://...' не удалось: (Django + Gunicorn + Nginx + Daphne)

Я получаю ошибку при подключении вебсокета. Я читал похожие вопросы и ответы на stackoverflow, но у меня ничего не получается. Я пробовал всевозможные способы в течение нескольких дней, но все еще не могу установить соединение. Это моя ошибка

Сервер, который я использую, это: Django + Gunicorn + Nginx + Daphne

Ошибка браузера

WebSocket connection to 'wss://mydomain/ws/some_url/' failed: 

Ниже приведен мой конфиг на сервере

Ngnix config:

server {
    server_name ****** mydomain www.mydomain;

    location = /favicon.ico { access_log off; log_not_found off; }
    location /static/ {
        alias /home/django/magi/src/staticfiles/;
    }
    
    location / {
        include proxy_params;
        proxy_pass http://unix:/run/gunicorn.sock;
    }
    

   location /ws/ {
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_redirect off;
        proxy_pass http://127.0.0.1:8001;
    }

    listen 443 ssl; # managed by Certbot
    ssl_certificate /etc/letsencrypt/live/mydomain/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/mydomain/privkey.pem; # managed by Certbot
    include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
    ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot


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


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


    server_name 103.221.223.183 mydomain www.mydomain;
    listen 80;
    return 404; # managed by Certbot




}

Если вам нужно проверить какие-либо файлы, пожалуйста, прокомментируйте ниже, чтобы я мог их добавить!

Большое спасибо

Эта проблема, вероятно, связана с тем, что вы не добавили блок upstream в конфигурацию Nginx, который позволит вашим WebSocket-запросам перенаправляться на порт 8001. Ваша конфигурация Nginx должна быть такой, как показано ниже:

upstream channels-backend {
 server localhost:8001;
}

server {
    server_name ****** mydomain www.mydomain;

    location = /favicon.ico { access_log off; log_not_found off; }
    location /static/ {
        alias /home/django/magi/src/staticfiles/;
    }
    
    location / {
        include proxy_params;
        proxy_pass http://unix:/run/gunicorn.sock;
    }
    

   location /ws/ {
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_redirect off;
        proxy_pass http://127.0.0.1:8001;
    }

    listen 443 ssl; # managed by Certbot
    ssl_certificate /etc/letsencrypt/live/mydomain/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/mydomain/privkey.pem; # managed by Certbot
    include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
    ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot


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


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


    server_name ****** mydomain www.mydomain;
    listen 80;
    return 404; # managed by Certbot

}

Кроме того, попробуйте сначала удалить конфигурацию SSL для HTTPS и WSS, которую вы сделали с помощью Certbot, и убедитесь, что все работает в HTTP и WS. Если он все еще не работает на WSS даже после добавления блока восходящего потока, проверьте конфигурацию перенаправления, добавленную Certbot, попробуйте удалить их и протестируйте.

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


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


    server_name ****** mydomain www.mydomain;
    listen 80;
    return 404; # managed by Certbot

}
Вернуться на верх