janw Asked: 2017-10-31 13:11:28 +0800 CST2017-10-31 13:11:28 +0800 CST 2017-10-31 13:11:28 +0800 CST Nginx 错误日志不会读取变量 772 在我的虚拟主机中,我有: root /var/www/$server_name/public_html; index index.php; access_log /var/log/nginx/$server_name.access.log; error_log /var/log/nginx/$server_name.error.log debug; 对于根和访问日志的$server_name工作。它不适用于错误日志。 我看到它是由 root 而不是 pi 设置的(我使用pi而不是data-www)我该如何解决这个问题? nginx/1.13.5 nginx 1 个回答 Voted Best Answer Marco Gomez 2017-10-31T13:54:49+08:002017-10-31T13:54:49+08:00 error_log据我所知,即使您可以使用变量,仍然不允许使用它们access_log(因为您的屏幕截图显示在您的场景中正常工作)。 除此之外,您几乎应该始终使用$host它,因为它是唯一保证的变量,无论用户代理的行为如何,都可以说一些明智的事情。 您可以在nginx 文档中检查 $host 和 $server_name 之间的区别: $host:按照优先顺序:请求行中的主机名,或“Host”请求标头字段中的主机名,或与请求匹配的服务器名。 $server_name:接受请求的服务器的名称。它包含server_name处理请求的虚拟主机,正如它在 nginx 配置中定义的那样。如果服务器包含多个 server_name,则此变量中仅存在第一个。 由于您必须考虑到用户代理在形成 HTTP 请求时可能会做的所有事情(古老的 HTTP/1.0 请求和现代编写不佳的软件可能一直发生),因此您应该考虑仅使用$host变量作为您的预期目的。 值得一提的access_log 是,它是由 处理的ngx_http_log_module,而 error_log的处理方式与ngx_core_module.
error_log
据我所知,即使您可以使用变量,仍然不允许使用它们access_log
(因为您的屏幕截图显示在您的场景中正常工作)。除此之外,您几乎应该始终使用
$host
它,因为它是唯一保证的变量,无论用户代理的行为如何,都可以说一些明智的事情。您可以在nginx 文档中检查 $host 和 $server_name 之间的区别:
$host
:按照优先顺序:请求行中的主机名,或“Host”请求标头字段中的主机名,或与请求匹配的服务器名。$server_name
:接受请求的服务器的名称。它包含server_name
处理请求的虚拟主机,正如它在 nginx 配置中定义的那样。如果服务器包含多个 server_name,则此变量中仅存在第一个。由于您必须考虑到用户代理在形成 HTTP 请求时可能会做的所有事情(古老的 HTTP/1.0 请求和现代编写不佳的软件可能一直发生),因此您应该考虑仅使用
$host
变量作为您的预期目的。值得一提的
access_log
是,它是由 处理的ngx_http_log_module
,而 error_log的处理方式与ngx_core_module
.