未知指令“位置/”(在服务器块内)

时间:2021-02-03 13:38:45

标签: nginx nginx-config

我从看似有效的 nginx 配置中收到以下错误:

nginx: [emerg] unknown directive "location /" in /etc/nginx/conf.d/default.conf:49

这是我的 default.conf 的相关部分:

upstream channels-backend {
    server api:5000;
}

server {
    listen 80;
    listen [::]:80;
    server_name _;
    server_tokens off;

    location = /.well-known/acme-challenge/ {
        root /var/www/certbot;
    }

    location / {
        return 301 https://$host$request_uri;
    }
}

server {
    listen 443 ssl default_server;
    server_name _;
    server_tokens off;

    ssl_certificate /etc/letsencrypt/live/mydomain.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/mydomain.com/privkey.pem;
    # include /etc/letsencrypt/options-ssl-nginx.conf;
    # ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
    # ssl_password_file /etc/letsencrypt/live/mydomain.com/global.pass;
    ssl_session_cache shared:SSL:10m;
    ssl_session_timeout 10m;
    ssl_protocols TLSv1.2 TLSv1.1;

    access_log /var/log/nginx/access.log;
    underscores_in_headers on;

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

    location /static {
        alias /home/docker/code/static;
    }

    location / {  # this is line 49
        try_files $uri @proxy_to_app;
    }

    location @proxy_to_app {
        proxy_read_timeout 30;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $http_x_forwarded_proto;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-Host $server_name;
        proxy_redirect off;
        proxy_pass http://channels-backend;
    }
}

我的问题与 nginx : unknown directive "location" 不同,因为指令位于 server 块内。

请注意,“mydomain.com”已被替换为我的实际域,并且几乎相同的配置之前已经运行过多次。这个配置和之前配置的主要区别是ssl_certificate*设置指向了不同的位置,没有/.well-known/acme-challenge/,因为我之前没有在nginx/docker中使用certbot/let's encrypt。

有什么想法吗?

1 个答案:

答案 0 :(得分:1)

在错误信息中:

<块引用>

nginx: [emerg] /etc/nginx/conf.d/default.conf:49 中的未知指令“location /”

Nginx 将引用的文本作为单个指令读取,因此它无法识别 location/ 部分之间的间隙。

间隙应该是一个空白字符(例如 ASCII 空格 20h)。很可能您缺少空格分隔符,或者您的编辑器插入了一个不可见的格式化字符,而该字符不是正常的 ASCII 空格。

相关问题