@MrPofix

Как победить 502 ошибку при работе с Laravel-echo-server?

Уже неделю не могу найти причину. На dev сервере работает отлично, а на продакшне - нет.
Использую CloudFlare. Настроил прокси, laravel echo работает, события принимает. Но при попытке подключиться к сокету пишет ошибку: WebSocketError: Unexpected status code received (502 Bad Gateway)

Окружение:
Ubuntu 16.04.7 LTS
Laravel Echo Server: 1.6.1
NodeJs: v12.19.0

laravel-echo-server.json:
{
    "authHost": "http://localhost",
    "authEndpoint": "/broadcasting/auth",
    "clients": [
        {
            "appId": "...",
            "key": "..."
        }
    ],
    "database": "redis",
    "databaseConfig": {
        "redis": {
            "password": "...",
            "port": "...",
            "db": 0
        },
        "sqlite": {}
    },
    "devMode": true,
    "host": "",
    "port": "6001",
    "protocol": "http",
    "socketio": {
        "transports": ["websocket", "polling"]
    },
    "secureOptions": 67108864,
    "sslCertPath": "",
    "sslKeyPath": "",
    "sslCertChainPath": "",
    "sslPassphrase": "",
    "subscribers": {
        "http": true,
        "redis": true
    },
    "apiOriginAllow": {
        "allowCors": true,
        "allowOrigin": "*",
        "allowMethods": "GET, POST",
        "allowHeaders": "Origin, Content-Type, X-Auth-Token, X-Requested-With, Accept, Authorization, X-CSRF-TOKEN, X-Socket-Id"
    }
}


Конфигурация хоста Nginx:
server {
        listen 8443 ssl;
        server_name domain.tld;       
        ssl_certificate /etc/nginx/ssl/my.crt;
        ssl_certificate_key  /etc/nginx/ssl/my.key;
        error_log /var/log/nginx/domain.tld/ws.log info;

        location /ws {
                proxy_pass http://127.0.0.1:6001;
                proxy_http_version 1.1;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection "Upgrade";
        }
}


Запускаю Laravel Echo, вижу, что все ок:
L A R A V E L  E C H O  S E R V E R

version 1.6.1

⚠ Starting server in DEV mode...

✔  Running at localhost on port 6001
✔  Channels are ready.
✔  Listening for http events...
✔  Listening for redis events...

Server ready!


Пробую через curl, работает:
$ curl 127.0.0.1:6001
> OK


Пробую подключиться через домен:
websocat wss://domain.tld:8443/ws

И вижу ошибку:
websocat: WebSocketError: Received unexpected status code (502 Bad Gateway)


В настройках laravel-echo-server.json перепробовал разные хосты (127.0.0.1, localhost, null, 0.0.0.0) - не помогает.
Читал этот пост https://github.com/tlaverdure/laravel-echo-server/... тоже не помогло.
Даже не знаю, как продебажить это?

Пожалуйста, помогите)
  • Вопрос задан
  • 510 просмотров
Решения вопроса 1
@MrPofix Автор вопроса
Не знаю, в чем проблема, но я нашел решение.
Я обновил Nginx до 1.19.1, возможно, установил дополнительные модули, когда пытался собрать Nginx из исходников.
Установил npm не глобально, а локально - может это тоже как-то повлияло.

Внимание: это работает, только если вы напишете location /socket.io.
Ни один другой location не работает, именно такой!
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы