nginx, dns - domain.com resolve, mas subdomain.domain.com não

nginx, dns - domain.com resolve, mas subdomain.domain.com não

Vou arrancar meu cabelo!

Eu tenho um site domain.com com a seguinte configuração de host virtual/etc/nginx/sites-disponíveis/domínio:

server {
        listen 80;
        server_name www.domain.com;
        return 301 $scheme://domain.com$request_uri;
}
server {
        listen 80;
        server_name domain.com;
        root /var/www/wordpress;
        index index.php index.html;

        location / {
                try_files $uri $uri/ /index.php?$args;
        }

        location = /favicon.ico {
                log_not_found off;
                access_log off;
        }
        location = /robots.txt {
                allow all;
                log_not_found off;
                access_log off;
        }
        location ~ /\. {
            deny all;
            access_log off;
            log_not_found off;
        }
        location ~ \.php$ {
                #NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini
                include fastcgi-gen.conf;
        }
        location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {
                expires max;
        }
}
server {
        listen 443 ssl;
        ssl_certificate /etc/ssl/localcerts/certificate.crt;
        ssl_certificate_key /etc/ssl/localcerts/privateKey.key;

        server_name domain.com;
        root /var/www/wordpress;

        index index.php index.html;

        location / {
                try_files $uri $uri/ /index.php?$args;
        }

        location = /favicon.ico {
                log_not_found off;
                access_log off;
        }
        location = /robots.txt {
                allow all;
                log_not_found off;
                access_log off;
        }
        location ~ /\. {
            deny all;
            access_log off;
            log_not_found off;
        }
        location ~ \.php$ {
                #NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini
                include fastcgi-gen.conf;
        }
        location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {
                expires max;
                log_not_found off;
        }
}

funciona muito bem. Tanto domínio.com quanto o redirecionamento de www para não www. Eu também tenho essa configuração de host virtual/etc/nginx/sites-available/owncloudpara meu subdomínio cloud.domain.com:

server {
        listen 80;
        server_name cloud.domain.com;
        return 301 https://$server_name$request_uri; # enforce https
}
server {
        listen 443 ssl;
        ssl_certificate /etc/ssl/localcerts/certificate.crt;
        ssl_certificate_key /etc/ssl/localcerts/privateKey.key;
        server_name cloud.domain.com;

        root /var/www/owncloud;

        client_max_body_size 10G; # set max upload size

        fastcgi_buffers 64 4K;
        rewrite ^/caldav(.*)$ /remote.php/caldav$1 redirect;
        rewrite ^/carddav(.*)$ /remote.php/carddav$1 redirect;
        rewrite ^/webdav(.*)$ /remote.php/webdav$1 redirect;

        index index.php index.html;

        error_page 403 = /core/templates/403.php;
        error_page 404 = /core/templates/404.php;

        location = /robots.txt {
            allow all;
            log_not_found off;
            access_log off;
        }
        location ~ ^/(data|config|\.ht|db_structure\.xml|README) {
                deny all;
        }
        location / {
                # The following 2 rules are only needed with webfinger
                rewrite ^/.well-known/host-meta /public.php?service=host-meta last;
                rewrite ^/.well-known/host-meta.json /public.php?service=host-meta-json last;
                rewrite ^/.well-known/carddav /remote.php/carddav/ redirect;
                rewrite ^/.well-known/caldav /remote.php/caldav/ redirect;
                rewrite ^(/core/doc/[^\/]+/)$ $1/index.html;
                try_files $uri $uri/ index.php;
        }

        location ~ ^(.+?\.php)(/.*)?$ {
                try_files $1 = 404;

                include fastcgi_params;
                fastcgi_param SCRIPT_FILENAME $document_root$1;
                fastcgi_param PATH_INFO $2;
                fastcgi_param HTTPS on;
                fastcgi_pass unix:/var/run/php5-fpm.sock;
        }

        # Optional: set long EXPIRES header on static assets
        location ~* ^.+\.(jpg|jpeg|gif|bmp|ico|png|css|js|swf)$ {
                expires 30d;
                # Optional: Don't log access to assets
                access_log off;
        }
}

Mas cloud.domain.com não funciona! Tentei fazer ping e não resolve para o meu ip.

Além disso, o estranho é que tenho outro vps com as configurações exatas usando um domínio diferente, digamos domain2.com. Nos meus outros vps tudo funciona bem. Tanto domain2.com quanto cloud.domain2.com resolvem para meu ip vps.

Eu também tenho uma estrutura de diretórios idêntica.

  • site: /var/www/wordpress
  • owncloud: /var/www/owncloud

Estou usando os servidores de nomes do meu provedor de nomes de domínio (em ambos os casos).

não tenho ideia do que estou fazendo de errado.

Responder1

Crie um CNAME para cloud.domain.com que aponte para domain.com. Deve ser algo assim:

cloud.domain.com   300   IN   CNAME   domain.com

Alternativamente, você poderia fazer uma entrada de domínio curinga:

*.domain.com   300   IN   CNAME   domain.com

Observe que um curinga direcionaráqualquersolicitações que não possuem entradas DNS explícitas. Portanto, "anyrandombogusname.domain.com" resolveria o endereço IP de domain.com.

Responder2

Sua pergunta não lista sua configuração de DNS, mas subdomain.domain.comexigiria CNAMEentradas específicas no servidor de nomes para funcionar corretamente.

informação relacionada