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

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

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

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

  • dev.example.com, чтобы указать на root /var/www/dev/public;[12214 impressionexample.com и www.example.com чтобы указать на root / var / www / laravel / public;
  • в настоящее время все идет на / var / www / laravel / public

Сервер:

  • Ubuntu 18.10 x64
  • Nginx

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

DNS для субдомена:

A (запись) | dev (Имя) | 140.xx.xx.xx (Данные)

У меня есть 2 папки, расположенные здесь:

  • / var / www / laravel / public (Мой основной производственный сайт)
  • / var / www / dev / public (Мой сайт разработки)

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

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

 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

}

Опять же ...

  • Мне нужно dev.example.com , чтобы указать на root / var / www / dev / public;

  • Мне нужно, чтобы example.com и www.example.com указывали на root / var / www / laravel / public;

Мы будем благодарны за любую помощь в выяснении этого вопроса.

1
задан 28 March 2019 в 05:33
1 ответ

Вам необходимо создать новый блок server для обслуживания нового имени хоста с корнем , который вам нужен. Вы можете либо скопировать остальную часть конфигурации из существующего блока, либо позже использовать include , чтобы СУШИТЬ его.

2
ответ дан 3 December 2019 в 20:08

Теги

Похожие вопросы