NGINX - 子域名的重写规则

NGINX - 子域名的重写规则

我有一个 SaaS 网站构建器。每个租户都有一个子域。

出于业务需求,我需要为每个租户提供自己的站点地图。生成部分不是问题,而是如何呈现它。

目前我已经为每个租户生成了一个索引站点地图和一个站点地图。

$ ls public/sitemaps
sitemap.tenant1.xml
sitemap.tenant2.xml

我感兴趣的是制定一条重写规则,该规则将发出请求来提供当前也可以访问的tenant1.example.com/sitemap.xml文件。public/sitemaps/sitemap.tenant1.xmltenant1.example.com/sitemaps/sitemap.tenant1.xml

这可以通过重写规则来实现吗?

更多

cat /etc/nginx/sites-enabled/example.com

server {
    listen 80;
    server_name example.com www.example.com;
    return 301 https://$host$request_uri;
}

server {
  listen 80;
  server_name example.com;
  return 301 $scheme://www.example.com$request_uri;
}

upstream app {
    server localhost:3000 max_fails=3 fail_timeout=300;
}


server {
    listen 443 ssl;
    server_name *.example.com;

    root /var/www/app/public;

    ssl_certificate /etc/ssl/app.crt;
    ssl_certificate_key /etc/ssl/app.key;

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_prefer_server_ciphers on;
    ssl_dhparam ...;
    ssl_ciphers ...;
    ssl_session_timeout 1d;
    ssl_session_cache shared:SSL:50m;
    ssl_stapling on;
    ssl_stapling_verify on;
    add_header Strict-Transport-Security max-age=15768000;
    server_tokens off;

    try_files $uri/index.html $uri @app;

    location @app {
        proxy_pass http://app;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_redirect off;
    }

    error_page 500 502 503 504 /500.html;
    client_max_body_size 4G;
    keepalive_timeout 10;
}

答案1

您使用一个 catch-allserver块来处理所有子域名。因此,如果您使用文件名中的实际子域名来命名 XML 站点地图文件,那么这将变得非常容易。

例如,您可以创建一个文件。然后您可以使用带有以下内容的sitemap.tenant1.example.com.xml单个文件加载该文件:locationalias

location = /sitemap.xml {
    alias /unix/path/to/sitemap.$host.xml;
}

相关内容