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
}