У меня настроен рабочий сайт, и теперь я пытаюсь настроить сайт разработки / тестирования для запуска живых тестов.
У меня проблемы с указанием правильного корня для моего поддомена путь в моем приложении Laravel.
Мне нужно следующее:
root /var/www/dev/public;[12214 impressionexample.com и www.example.com чтобы указать на root / var / www / laravel / public;
/ var / www / laravel / public
Сервер:
У меня есть домен example.com
, и я создал поддомен под названием dev.example.com
каждая ссылка на домен находится в моем сертификате SSL через certbot / LetsEncrypt. www.example.com, example.com и dev.example.com
DNS для субдомена:
A (запись) | dev (Имя) | 140.xx.xx.xx (Данные)
У меня есть 2 папки, расположенные здесь:
laravel
/ public (Мой основной производственный сайт) 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;
Мы будем благодарны за любую помощь в выяснении этого вопроса.
Вам необходимо создать новый блок server
для обслуживания нового имени хоста с корнем
, который вам нужен. Вы можете либо скопировать остальную часть конфигурации из существующего блока, либо позже использовать include
, чтобы СУШИТЬ его.