Уже неделю не могу найти причину. На 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/... тоже не помогло.
Даже не знаю, как продебажить это?
Пожалуйста, помогите)