我从看似有效的 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。>
有什么想法吗?
答案 0 :(得分:1)
在错误信息中:
<块引用>nginx: [emerg] /etc/nginx/conf.d/default.conf:49 中的未知指令“location /”
Nginx 将引用的文本作为单个指令读取,因此它无法识别 location
和 /
部分之间的间隙。
间隙应该是一个空白字符(例如 ASCII 空格 20h)。很可能您缺少空格分隔符,或者您的编辑器插入了一个不可见的格式化字符,而该字符不是正常的 ASCII 空格。