Was ich brauche ist
Client <--wss---> nginx <--wss--> server
Ich arbeite an einem WSS-Proxy, der auf Apache bereits funktioniert, aber ich möchte jetzt zu Nginx wechseln. Hier ist die Apache-Konfiguration:
<LocationMatch "/statistics">
ProxyPass wss://127.0.0.1:23456
ProxyAddHeaders Off
ProxyPreserveHost On
RequestHeader set Host %{HTTP_HOST}s
RequestHeader set X-Forwarded-For %{REMOTE_ADDR}s
</LocationMatch>
Unter nginx verwende ich diese Konfiguration/etc/nginx/nginx.conf
server {
listen 444 ssl;
listen [::]:444 ssl;
server_name domain.com www.domain.com;
root /usr/share/nginx/html;
ssl_certificate "/etc/letsencrypt/live/domain/fullchain.pem";
ssl_certificate_key "/etc/letsencrypt/live/domain/privkey.pem";
ssl_session_cache shared:SSL:1m;
ssl_session_timeout 10m;
ssl_ciphers PROFILE=SYSTEM;
ssl_prefer_server_ciphers on;
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
proxy_ssl_server_name on;
ssl_protocols TLSv1.2 TLSv1.3;
location /statistics {
proxy_pass https://127.0.0.1:23456;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header Host $host;
proxy_ssl_name $host;
proxy_ssl_session_reuse off;
proxy_ssl_certificate "/etc/letsencrypt/live/domain/fullchain.pem";
proxy_ssl_certificate_key "/etc/letsencrypt/live/domain/privkey.pem";
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
Meine Website wird auf Nginx problemlos und ohne SSL-Fehler geladen. Was nicht funktioniert, ist der WebSocket mit WSS. Der WebSocket mit WS funktioniert auch!
Ich verwende wscat
zum Testen der Verbindung folgendes:
wscat -c wss://kaveneger.ir:23456
Connected (press CTRL+C to quit)
>
Bedeutet, dass mein Endpunkt in Ordnung ist (ich brauchte diesen Test nicht wirklich, da er in Apache funktioniert, aber egal …)
Hier ist, wenn ich es mit nginx mache
wscat -c wss://domain.com:444/statistics
error: Unexpected server response: 404
> %
Nginx-Protokolle
/var/log/nginx/access.log
123.123.123.123 - - [27/Feb/2023:21:53:15 +0000] "GET /statistics HTTP/1.1" 404 0 "-" "-" "-"
/var/log/nginx/error.log
2023/02/27 21:53:49 [crit] 70632#70632: *14 SSL_read() failed (SSL: error:0A000126:SSL routines::unexpected eof while reading) while keepalive, client: 123.123.123.123, server: 0.0.0.0:444
Mein Betriebssystem ist Rocky Linux 9 und die Nginx-Version: nginx/1.20.1
Ich habe bereits viel gesucht und alle gefundenen Lösungen ausprobiert, aber nichts hat funktioniert!
Aktualisieren
es funktioniert, wenn ich location /
anstelle von verwende location /statistics
!