ao usar em produção, meu servidor de reverberação não recebe nenhum evento do meu trabalhador de fila, a conexão do cliente é bem-sucedida e o ping pong está funcionando, mas quando disparo um evento, o servidor de reverberação não o reconhece.
Minha configuração nginx:
map $http_upgrade $type {
default "web";
}
server {
listen 80;
listen [::]:80;
server_name mypage.de;
location /.well-known/acme-challenge/ {
root /var/www/letsencrypt;
}
return 301 $host$request_uri;
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name mypage.de;
ssl_certificate /etc/letsencrypt/live/mypage.de/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/mypage.de/privkey.pem;
ssl_trusted_certificate /etc/letsencrypt/live/mypage.de/chain.pem;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers "ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305";
ssl_prefer_server_ciphers on;
ssl_session_cache shared:SSL:10m;
ssl_session_timeout 1h;
root /var/www/mypage/public;
add_header X-Frame-Options "SAMEORIGIN";
add_header X-Content-Type-Options "nosniff";
index index.php;
charset utf-8;
location / {
try_files /nonexistent @$type;
}
location @web {
try_files $uri $uri/ /index.php?$query_string;
}
location /app {
proxy_http_version 1.1;
proxy_set_header Host $http_host;
proxy_set_header Scheme $scheme;
proxy_set_header SERVER_PORT $server_port;
proxy_set_header REMOTE_ADDR $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_read_timeout 180;
proxy_send_timeout 180;
proxy_pass 127.0.0.1:6001;
}
location /apps {
proxy_http_version 1.1;
proxy_set_header Host $http_host;
proxy_set_header Scheme $scheme;
proxy_set_header SERVER_PORT $server_port;
proxy_set_header REMOTE_ADDR $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_pass 127.0.0.1:6001;
}
location = /favicon.ico {
access_log off; log_not_found off;
}
location = /robots.txt {
access_log off; log_not_found off;
}
error_page 404 /index.php;
location ~ ^/index\.php(/|$) {
try_files $uri /index.php =404;
fastcgi_pass unix:/var/run/php/php8.4-fpm.sock;
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
include fastcgi_params;
fastcgi_hide_header X-Powered-By;
}
location ~ /\.(?!well-known).* {
deny all;
}
}
meu .env:
REVERB_APP_ID=xxxx
REVERB_APP_KEY=xxxx
REVERB_APP_SECRET=xxxx
REVERB_HOST="mypage.de"
REVERB_PORT=443
REVERB_SCHEME=https
REVERB_SERVER_HOST=127.0.0.1
REVERB_SERVER_PORT=6001
VITE_REVERB_APP_KEY="${REVERB_APP_KEY}"
VITE_REVERB_HOST="${REVERB_HOST}"
VITE_REVERB_PORT="${REVERB_PORT}"
VITE_REVERB_SCHEME="${REVERB_SCHEME}"
No ambiente de desenvolvimento local, tudo funciona bem, os eventos são enviados ao cliente e o js do cliente é executado. Na produção, o worker registra que o evento foi disparado, mas no log de reverberação nada aparece.
EDITAR:
ambiente local:
BROADCAST_CONNECTION=reverb
QUEUE_CONNECTION=redis
ambiente de produção:
BROADCAST_DRIVER=reverb
QUEUE_CONNECTION=redis
EDITAR NOVAMENTE: Ao postar as variáveis do ambiente de transmissão, eu obviamente encontrei meu erro, olhei milhares de vezes em cada variável, mas não descobri que no meu ambiente de produção o BROADCAST_DRIVER desatualizado estava definido em vez da variável correta atual BROADCAST_CONNECTION...
Agora me sinto idiota...