Estou usando o NGINX. Descobri que o NGINX gera um erro quando defino vários domínios para uma porta HTTP/3.
server {
listen 443 http3 reuseport;
listen 443 ssl http2;
server_name FIRST_DOMAIN;
ssl_certificate /etc/letsencrypt-ecdsa/live/FIRST_DOMAIN/fullchain.pem;
ssl_certificate_key /etc/letsencrypt-ecdsa/live/FIRST_DOMAIN/privkey.pem;
ssl_protocols TLSv1.3;
return 301 https://SECOND_DOMAIN$request_uri;
}
server {
listen 443 http3 reuseport;
listen 443 ssl http2;
server_name SECOND_DOMAIN default;
ssl_certificate /etc/letsencrypt-ecdsa/live/SECOND_DOMAIN/fullchain.pem;
ssl_certificate_key /etc/letsencrypt-ecdsa/live/SECOND_DOMAIN/privkey.pem;
ssl_protocols TLSv1.3;
add_header Alt-Svc 'h3=":443"; ma=86400';
location / {
proxy_pass http://host.docker.internal:10002/;
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;
}
}
nginx: [emerg] duplicate listen options for 0.0.0.0:443 in /etc/nginx/nginx.conf:35
Posso ouvir vários domínios em um IP em HTTP/3?
Responder1
const express = require('express');
const app = express();
app.get('/', (req, res) => {
res.send(req.hostname);
});
app.listen(40000);
Eu experimentei isso com o Node.js express. Quando uso HTTP/2, o nome do host é impresso. Mas quando uso HTTP/3, undefined
impresso. Isso mostra que o HTTP/3 não se importa com o nome do host. Portanto, é impossível ouvir vários domínios em uma porta HTTP/3. Mas você pode abrir várias portas para cada domínio HTTP/3 e adicionar Alt-Svc
cabeçalho para anunciá-los no navegador.
Mas de acordo com minha experiência, Alt-Svc
não funciona de forma estável dependendo do navegador. Portanto, você não pode ouvir vários domínios em um IP em HTTP/3 de forma estável.