Nginx为某些子域返回404,但不为其他子域返回404

Nginx为某些子域返回404,但不为其他子域返回404,nginx,http-status-code-404,Nginx,Http Status Code 404,因此,我试图建立5个网站,都在同一个领域,只是不同的子域,等等www.和cdn。 但万维网本应运行良好 tho cdn。没有,它得到了与我刚才复制的相同的文件,所有文件夹的权限都是相同的。 我在自己的文件中有每个子域,如wwwmydomaincom和cdnmydomaincom,配置相同,只是服务器名称不同。有效的文件是www.mydomain.com,其余的文件是somesubdomain.mydomain.com,他们抛出404 我在ubuntu服务器16.04.1上使用Nginx 增加 子

因此,我试图建立5个网站,都在同一个领域,只是不同的子域,等等www.和cdn。 但万维网本应运行良好 tho cdn。没有,它得到了与我刚才复制的相同的文件,所有文件夹的权限都是相同的。 我在自己的文件中有每个子域,如wwwmydomaincom和cdnmydomaincom,配置相同,只是服务器名称不同。有效的文件是www.mydomain.com,其余的文件是somesubdomain.mydomain.com,他们抛出404

我在ubuntu服务器16.04.1上使用Nginx

增加

子域可以很好地显示html页面(现在它们的配置与工作的配置不同) 但是每一个资产,css,js,图像或其他东西得到404,所以它是一个纯html页面

下面的配置与www.mydomain.com的配置完全相同,但已更改为适合cdn.mydomain.com

server {
  listen 80;
  server_name cdn.domain.com;
  location /.well-known/acme-challenge {
     default_type "text/plain";
     root /storage/webserver/certbot;
  }

  #Forces all other requests to HTTPS
  location / {
     return 301 https://$host$request_uri;
  }
}
server {
  listen 443 ssl http2;
  server_name cdn.domain.com;
  ssl_certificate /etc/letsencrypt/live/cdn.domain.com/fullchain.pem;
  ssl_certificate_key /etc/letsencrypt/live/cdn.domain.com/privkey.pem;
  ssl_dhparam /etc/ssl/certs/dhparam.pem;
  ssl_protocols TLSv1.2 TLSv1.1 TLSv1;
  ssl_prefer_server_ciphers on;
  ssl_ciphers EECDH+ECDSA+AESGCM:EECDH+aRSA+AESGCM:EECDH+ECDSA+SHA512:EECDH+ECDSA+SHA384:EECDH+ECDSA+SHA256:ECDH+AESGCM:ECDH+AES256:DH+AESGCM:DH+AES256:RSA+AESGCM:!aNULL:!eNULL:!LOW:!RC4:!3DES:!MD5:!EXP:!PSK:!SRP:!DSS;
  ssl_session_cache shared:TLS:2m;
  # OCSP stapling
  ssl_stapling on;
  ssl_stapling_verify on;
  resolver 8.8.8.8;
  # Set HSTS to 365 days
  add_header Strict-Transport-Security 'max-age=31536000; includeSubDomains';
  root /storage/webserver/cdn.domain.com;
  index index.html index.php;
  location @rewrite {
    rewrite ^ $uri.php last;
    try_files $uri =404;
  }
  location ~ \.php$ {
    fastcgi_split_path_info ^(.+?\.php)(/.+)$;
    fastcgi_pass unix:/run/php/php7.0-fpm.sock;
    fastcgi_index index.php;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    include fastcgi_params;
    include fastcgi.conf;
    try_files $uri =404;
  }
  rewrite ^(/.*)\.html(\?.*)?$ $1$2 permanent;
  #rewrite ^/(.*)/$ /$1 permanent;
  error_page 404 /404.php;
  error_page 500 503 502 504 /error/40x.php;
  location =/error/40x.html {
    internal;
  }
}

啊哼,这就是我想学这种东西的原因

显然,您需要让它查找文件

因此,如果有人进入这个小情况,不要忘记让它看起来在根文件夹中

location / {
  try_files $uri $uri/ $uri.html @rewrite;
}
location / {
  try_files $uri $uri/ $uri.html @rewrite;
}