NGINX - указание поддомена в другом каталоге, который не является подкаталогом каталога домена - PullRequest
0 голосов
/ 28 ноября 2018

Я использую Nginx в качестве обратного прокси с Apache.У меня есть домен, скажем, example.com, который указывает на каталог /var/www/html/example.

Я хочу указать поддомен phpmyadmin.example.com на каталог /var/www/html/phpmyadmin, который явно не является субдоменом.каталог каталога домена.

Мой полный файл конфигурации /etc/nginx/sites-enabled/example показан ниже.Я добавил части между ##### BEGIN .. и ###### END .. в свой файл конфигурации, чтобы попытаться сделать эту работу.

Затем я сделал sudo service nginx restart, чтобы успешно перезапустить NGINX, но я все еще не могу получить доступ к phpmyadmin.example.com.

Вот моя конфигурация:

server {
    root /var/www/html/example;

    # Add index.php to the list if you are using PHP
    index index.php index.html index.htm index.nginx-debian.html;

    server_name example.com;

        access_log /var/www/html/example/access.log;
        error_log /var/www/html/example/error.log;

    location / {
        # First attempt to serve request as file, then
        # as directory, then fall back to displaying a 404.
        try_files $uri $uri/ /index.php?$args;
    }

    # pass PHP scripts to FastCGI server
    #
    location ~ \.php$ {
        include snippets/fastcgi-php.conf;
    #
    #   # With php-fpm (or other unix sockets):
        fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
    #   # With php-cgi (or other tcp sockets):
    #   fastcgi_pass 127.0.0.1:9000;
    }

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    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
}

##### BEGIN PHPMYADMIN CONFIG    #####
server {
    root /var/www/html/phpmyadmin;

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

    server_name phpmyadmin.example.com;

    location / {
        # First attempt to serve request as file, then
        # as directory, then fall back to displaying a 404.
        try_files $uri $uri/ /index.php?$args;
    }

    # pass PHP scripts to FastCGI server
    #
    location ~ \.php$ {
        include snippets/fastcgi-php.conf;
    #
    #   # With php-fpm (or other unix sockets):
        fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
    #   # With php-cgi (or other tcp sockets):
    #   fastcgi_pass 127.0.0.1:9000;
    }
}
###### END OF PHPMYADMIN CONFIG #####

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


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

    listen 80 ;
    listen [::]:80 ;

    server_name example.com www.example.com
    return 404; # managed by Certbot
}

1 Ответ

0 голосов
/ 29 ноября 2018

Я решил свою проблему, и я собираюсь перечислить шаги, которые я предпринял, чтобы решить эту проблему, как будущую ссылку для других:

Конфигурация NGINX

Конфигурация nginx, которую я попробовал изначально, была правильной(как написано в вопросе).

Добавление записи CNAME в записи DNS

Это был основной недостающий элемент.Я добавил запись CNAME в свою панель управления DNS следующим образом:

Тип: CNAME Имя: phpmyadmin Значение: example.com TTL: 3600 (также можно установить как автоматический)

Расширение SSL-сертификата

Я использую certbot для SSL-сертификата, и мне пришлось регенерировать его, чтобы включить домен в сертификат.

sudo certbot --nginx -d example.com -d www.example.com -d phpmyadmin.example.com

На этом этапе certbot может позаботиться о конфигурации nginx, чтобы перенаправить HTTP-трафик на HTTPS.

Перезагрузить службу NGINX

Перезагрузить новую конфигурацию: sudo service nginx reload

Ипроверил статус услуги: sudo service nginx status

Теперь все работает хорошо.

...