Nginx als Reverse-Proxy für Gitblit mit Client-Zertifikatauthentifizierung. Peer-Closed-Verbindung im SSL-Handshake während SSL-Handshake zum Upstream

Nginx als Reverse-Proxy für Gitblit mit Client-Zertifikatauthentifizierung. Peer-Closed-Verbindung im SSL-Handshake während SSL-Handshake zum Upstream

Wir haben Nginx als Reverse-Proxy für Gitblit mit Client-Zertifikatauthentifizierung verwendet.

Gegeben ist die Nginx-Konfiguration wie unten.

server {
listen       443 ssl http2 default_server;
server_name  _;

charset utf-8;

ssl_certificate      D:\cert.pem;
ssl_certificate_key  D:\key.pem;

ssl_session_cache    off;
ssl_session_timeout  1h;
ssl_buffer_size 8192;

ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3;
ssl_ciphers  HIGH:!aNULL:!MD5;

ssl_client_certificate D:\Program\GitBlit\gitblit-1.8.0\data\certs\ca.pem;
ssl_verify_client optional;

ssl_prefer_server_ciphers  on;
proxy_intercept_errors on;          

location /git {
    proxy_pass https://127.0.0.1:1111;
    proxy_set_header Host $http_host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Proto $scheme;
    
    proxy_ssl_verify off;
    proxy_ssl_name $host;
    proxy_ssl_server_name on;
    proxy_ssl_session_reuse off;
}
}

Um ssl_verify_client optional;den Webclient zu erstellen, ist das Client-Zertifikat erforderlich, wenn zu https://my_server/git navigiert wird. Aber ich habe den Fehler 502 Bad Gateway erhalten. Das Nginx-Fehlerprotokoll ist wie unten dargestellt und von Gitblit ist kein Fehlerprotokoll zu sehen.

2023/10/25 14:48:14 [error] 29404#2072: *43 peer closed connection in SSL handshake while SSL handshaking to upstream, client: 127.0.0.1, server: _, request: "GET /git/ HTTP/2.0", upstream: "https://127.0.0.1:1111/git/", host: "127.0.0.1"

Ich habe sichergestellt, dass, wenn ich zu denhttps://127.0.0.1:1111/gitund dasselbe Client-Zertifikat bereitstellen, funktioniert die Authentifizierung gut. Das Gitblit-SSL-Zertifikat ist von einer selbstsignierten Zertifizierungsstelle an my_server signiert (D:\Program\GitBlit\gitblit-1.8.0\data\certs\ca.pem für das SSL-Client-Zertifikat).

Liegt dies daran, dass Nginx das SSL-Zertifikat von Gitblit nicht erkannt hat oder das Client-Zertifikat für die Authentifizierung nicht übergeben wurde?

verwandte Informationen