【问题标题】:Nginx Server Configuration: Hostname not resolving on SubdomainNginx 服务器配置:主机名未在子域上解析
【发布时间】:2021-04-09 18:52:57
【问题描述】:

提前感谢您的支持。

我使用 Nginx 作为 Digitalocean Droplet 设置了一个 Ubuntu 服务器,并且正在使用服务器配置工具 Laravel Forge,它工作正常。我成功安装了 PHP 框架 Laravel 并在服务器上部署了代码。我 ssh 进入服务器并检查了假定目录中的文件。代码部署成功。

接下来我拥有一个域,并为以下子域创建了一条 A 记录:app.mywebsite.de,它指向该服务器。我跟着digitalocean instructions 等待了所需的时间。使用 DNS 查找工具,我确认子域实际上指向服务器。

Screenshot of DNS Lookup

然而,当我在浏览器中使用子域时,浏览器并没有连接到服务器。我在浏览器中收到以下错误消息:

Screenshot of Browser when connecting to server

似乎子域已正确指向服务器,但服务器配置不正确。我尝试检查 nginx 配置,在 sites-avaialble 下我有以下子域配置:

    # FORGE CONFIG (DO NOT REMOVE!)
include forge-conf/app.mywebsite.de/before/*;

server {
    listen 80;
    listen [::]:80;
    server_name app.mywebsite.de;
    server_tokens off;
    root /home/forge/app.mywebsite.de/public;

    # FORGE SSL (DO NOT REMOVE!)
    # ssl_certificate;
    # ssl_certificate_key;

    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers TLS13-AES-256-GCM-SHA384:TLS13-CHACHA20-POLY1305-SHA256:TLS_AES_256_GCM_SHA384:TLS-AES-256-GCM-SHA384:TLS_CHACHA20_POLY1305_SHA256:TLS-CHACHA20-POLY1305-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA:ECDHE-RSA-AES256-SHA;
    ssl_prefer_server_ciphers on;
    ssl_dhparam /etc/nginx/dhparams.pem;

    add_header X-Frame-Options "SAMEORIGIN";
    add_header X-XSS-Protection "1; mode=block";
    add_header X-Content-Type-Options "nosniff";

    index index.html index.htm index.php;

    charset utf-8;

    # FORGE CONFIG (DO NOT REMOVE!)
    include forge-conf/app.mywebsite.de/server/*;

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

    location = /favicon.ico { access_log off; log_not_found off; }
    location = /robots.txt  { access_log off; log_not_found off; }

    access_log off;
    error_log  /var/log/nginx/app.mywebsite.de-error.log error;

    error_page 404 /index.php;

    location ~ \.php$ {
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/var/run/php/php8.0-fpm.sock;
        fastcgi_index index.php;
        include fastcgi_params;
    }

    location ~ /\.(?!well-known).* {
        deny all;
    }
}

# FORGE CONFIG (DO NOT REMOVE!)
include forge-conf/app.mywebsite.de/after/*;

forge-conf/app.website.de/before/*;中只有一个redirect.conf文件,代码如下:

server {
    listen 80;
    listen [::]:80;

    server_name www.app.website.de;

    if ($http_x_forwarded_proto = 'https') {
        return 301 https://app.website.de$request_uri;
    }

    return 301 $scheme://app.website.de$request_uri;
}

服务器上没有其他站点。所以nginx配置文件夹的sites available目录下只有000-catch-all文件。

不幸的是,我在这里达到了我的理解极限,如果有人能指出我正确的方向来找出 nginx 的哪个部分没有正确配置,我会很高兴。

附: 一些附加信息: 是的,我多次重启了 Nginx 和整个服务器。

【问题讨论】:

    标签: laravel ubuntu nginx digital-ocean laravel-forge


    【解决方案1】:

    事实证明,一切都已正确配置。我没有做任何改变,只是在 nginx 服务器上添加了一些额外的站点。 Forge 可能更新了服务器块,从而解决了问题。

    【讨论】:

      猜你喜欢
      • 2012-12-24
      • 2019-09-19
      • 2012-03-03
      • 1970-01-01
      • 2014-06-02
      • 1970-01-01
      • 1970-01-01
      • 2020-10-27
      • 2013-08-10
      相关资源
      最近更新 更多