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.com
exigiria CNAME
entradas específicas no servidor de nomes para funcionar corretamente.