Назад | Перейти на главную страницу

Как мне указать мой субдомен на правильную корневую папку

У меня настроен производственный сайт, и теперь я пытаюсь настроить сайт разработки / тестирования для запуска живых тестов.

У меня возникают проблемы с указанием правильного корневого пути моего поддомена в моем приложении Laravel.

Мне нужно следующее:

Сервер:

У меня есть домен example.com и я создал поддомен под названием dev.example.com каждая ссылка на домен находится в моем сертификате SSL через certbot / LetsEncrypt. www.example.com, example.com и dev.example.com

DNS для поддомена:

A (Record) | dev (Name) | 140.xx.xx.xx (Data)

У меня здесь 2 папки:

На сайтах-доступных /etc/nginx/sites-available у меня есть default файл со следующими конфигурациями.

(Я пробовал несколько вариантов этого, но на этом я остановился)

 server {

    root /var/www/laravel/public;

    index index.php index.html index.htm index.nginx-debian.html;

    server_name example.com www.example.com dev.example.com;

    location / {
        try_files $uri $uri/ /index.php?$query_string;
        client_max_body_size 200M;
    }

    location ~ \.php$ {
        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
    }

    location ~ /\.ht {
        deny all;
    }

    listen [::]:443 ssl ipv6only=on; # managed by Certbot
    listen 443 ssl; # managed by Certbot
    ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem; # managed by Certbot
    include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
    ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot

}

# Virtual Host configuration for example.com

server {

    if ($host = dev.example.com) {
        return 301 https://$host$request_uri;
    } # managed by Certbot

    listen 80;
    listen [::]:80;
    server_name dev.example.com;
    root /var/www/dev/public;
    return 404; # managed by Certbot

}

server {

    if ($host = www.example.com) {
        return 301 https://$host$request_uri;
    } # managed by Certbot

    listen 80;
    listen [::]:80;
    server_name www.example.com;
    return 404; # managed by Certbot

}

server {

    if ($host = example.com) {
        return 301 https://$host$request_uri;
    } # managed by Certbot

    listen 80 default_server;
    listen [::]:80;
    server_name example.com;
    return 404; # managed by Certbot

}

Очередной раз...

Любая помощь в выяснении этого будет оценена.

Вам нужно создать новый server блок для обслуживания нового имени хоста с root что вы желаете. Вы можете либо скопировать остальную конфигурацию из существующего блока, либо позже использовать includes, чтобы высушить его.